Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/drv/nic/ne2k/ne2k.c

    re86b8f0 r9571230  
    6464#define NE2K(device) ((ne2k_t *) nic_get_specific(DRIVER_DATA(device)))
    6565
     66static irq_pio_range_t ne2k_ranges_prototype[] = {
     67        {
     68                .base = 0,
     69                .size = NE2K_IO_SIZE,
     70        }
     71};
     72
    6673/** NE2000 kernel interrupt command sequence.
    6774 *
     
    122129
    123130        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);
    126144                        return ENOMEM;
    127145                }
    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;
    131150                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);
    135159                ne2k->code.cmds = ne2k_cmds;
    136160        }
     
    148172                ne2k_t *ne2k = NE2K(dev);
    149173                if (ne2k) {
     174                        free(ne2k->code.ranges);
    150175                        free(ne2k->code.cmds);
    151176                }
     
    261286        /* Note: some frame with previous physical address may slip to NIL here
    262287         * (for a moment the filtering is not exact), but ethernet should be OK with
    263          * that. Some frames may also be lost, but this is not a problem.
     288         * that. Some packet may also be lost, but this is not a problem.
    264289         */
    265290        ne2k_set_physical_address((ne2k_t *) nic_get_specific(nic_data), address);
     
    338363static int ne2k_dev_add(ddf_dev_t *dev)
    339364{
    340         ddf_fun_t *fun;
    341        
    342365        /* Allocate driver data for the device. */
    343366        nic_t *nic_data = nic_create_and_bind(dev);
     
    373396        }
    374397       
     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       
    375404        rc = nic_connect_to_services(nic_data);
    376405        if (rc != EOK) {
     
    379408        }
    380409       
    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        
    404410        return EOK;
    405411}
Note: See TracChangeset for help on using the changeset viewer.