Changes in uspace/drv/nic/ne2k/ne2k.c [e86b8f0:9571230] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/drv/nic/ne2k/ne2k.c
re86b8f0 r9571230 64 64 #define NE2K(device) ((ne2k_t *) nic_get_specific(DRIVER_DATA(device))) 65 65 66 static irq_pio_range_t ne2k_ranges_prototype[] = { 67 { 68 .base = 0, 69 .size = NE2K_IO_SIZE, 70 } 71 }; 72 66 73 /** NE2000 kernel interrupt command sequence. 67 74 * … … 122 129 123 130 if (ne2k->code.cmdcount == 0) { 124 irq_cmd_t *ne2k_cmds = malloc(sizeof(ne2k_cmds_prototype)); 125 if (ne2k_cmds == NULL) { 131 irq_pio_range_t *ne2k_ranges; 132 irq_cmd_t *ne2k_cmds; 133 134 ne2k_ranges = malloc(sizeof(ne2k_ranges_prototype)); 135 if (!ne2k_ranges) 136 return ENOMEM; 137 memcpy(ne2k_ranges, ne2k_ranges_prototype, 138 sizeof(ne2k_ranges_prototype)); 139 ne2k_ranges[0].base = (uintptr_t) ne2k->base_port; 140 141 ne2k_cmds = malloc(sizeof(ne2k_cmds_prototype)); 142 if (!ne2k_cmds) { 143 free(ne2k_ranges); 126 144 return ENOMEM; 127 145 } 128 memcpy(ne2k_cmds, ne2k_cmds_prototype, sizeof (ne2k_cmds_prototype)); 129 ne2k_cmds[0].addr = ne2k->port + DP_ISR; 130 ne2k_cmds[3].addr = ne2k->port + DP_IMR; 146 memcpy(ne2k_cmds, ne2k_cmds_prototype, 147 sizeof(ne2k_cmds_prototype)); 148 ne2k_cmds[0].addr = ne2k->base_port + DP_ISR; 149 ne2k_cmds[3].addr = ne2k->base_port + DP_IMR; 131 150 ne2k_cmds[4].addr = ne2k_cmds[0].addr; 132 ne2k_cmds[5].addr = ne2k->port + DP_TSR; 133 134 ne2k->code.cmdcount = sizeof(ne2k_cmds_prototype) / sizeof(irq_cmd_t); 151 ne2k_cmds[5].addr = ne2k->base_port + DP_TSR; 152 153 ne2k->code.rangecount = sizeof(ne2k_ranges_prototype) / 154 sizeof(irq_pio_range_t); 155 ne2k->code.ranges = ne2k_ranges; 156 157 ne2k->code.cmdcount = sizeof(ne2k_cmds_prototype) / 158 sizeof(irq_cmd_t); 135 159 ne2k->code.cmds = ne2k_cmds; 136 160 } … … 148 172 ne2k_t *ne2k = NE2K(dev); 149 173 if (ne2k) { 174 free(ne2k->code.ranges); 150 175 free(ne2k->code.cmds); 151 176 } … … 261 286 /* Note: some frame with previous physical address may slip to NIL here 262 287 * (for a moment the filtering is not exact), but ethernet should be OK with 263 * that. Some framesmay also be lost, but this is not a problem.288 * that. Some packet may also be lost, but this is not a problem. 264 289 */ 265 290 ne2k_set_physical_address((ne2k_t *) nic_get_specific(nic_data), address); … … 338 363 static int ne2k_dev_add(ddf_dev_t *dev) 339 364 { 340 ddf_fun_t *fun;341 342 365 /* Allocate driver data for the device. */ 343 366 nic_t *nic_data = nic_create_and_bind(dev); … … 373 396 } 374 397 398 rc = nic_register_as_ddf_fun(nic_data, &ne2k_dev_ops); 399 if (rc != EOK) { 400 ne2k_dev_cleanup(dev); 401 return rc; 402 } 403 375 404 rc = nic_connect_to_services(nic_data); 376 405 if (rc != EOK) { … … 379 408 } 380 409 381 fun = ddf_fun_create(nic_get_ddf_dev(nic_data), fun_exposed, "port0");382 if (fun == NULL) {383 ne2k_dev_cleanup(dev);384 return ENOMEM;385 }386 nic_set_ddf_fun(nic_data, fun);387 fun->ops = &ne2k_dev_ops;388 fun->driver_data = nic_data;389 390 rc = ddf_fun_bind(fun);391 if (rc != EOK) {392 ddf_fun_destroy(fun);393 ne2k_dev_cleanup(dev);394 return rc;395 }396 397 rc = ddf_fun_add_to_category(fun, DEVICE_CATEGORY_NIC);398 if (rc != EOK) {399 ddf_fun_unbind(fun);400 ddf_fun_destroy(fun);401 return rc;402 }403 404 410 return EOK; 405 411 }
Note:
See TracChangeset
for help on using the changeset viewer.