Changeset cffa14e6 in mainline for uspace/drv/bus/usb/ohci/ohci.c


Ignore:
Timestamp:
2013-07-24T17:27:56Z (12 years ago)
Author:
Jan Vesely <jano.vesely@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
db71e2a
Parents:
c442f63
Message:

revert usb hc macro changes

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/drv/bus/usb/ohci/ohci.c

    rc442f63 rcffa14e6  
    143143int device_setup_ohci(ddf_dev_t *device)
    144144{
    145         bool ih_registered = false;
    146         bool hc_inited = false;
    147         int rc;
    148 
    149145        if (device == NULL)
    150146                return EBADMEM;
     
    156152        }
    157153
     154#define CHECK_RET_DEST_FREE_RETURN(ret, message...) \
     155if (ret != EOK) { \
     156        if (instance->hc_fun) { \
     157                ddf_fun_destroy(instance->hc_fun); \
     158        } \
     159        if (instance->rh_fun) { \
     160                ddf_fun_destroy(instance->rh_fun); \
     161        } \
     162        usb_log_error(message); \
     163        return ret; \
     164} else (void)0
     165
    158166        instance->hc_fun = ddf_fun_create(device, fun_exposed, "ohci_hc");
    159         if (instance->hc_fun == NULL) {
    160                 usb_log_error("Failed to create OHCI HC function: %s.\n",
    161                     str_error(ENOMEM));
    162                 rc = ENOMEM;
    163                 goto error;
    164         }
    165 
     167        int ret = instance->hc_fun ? EOK : ENOMEM;
     168        CHECK_RET_DEST_FREE_RETURN(ret,
     169            "Failed to create OHCI HC function: %s.\n", str_error(ret));
    166170        ddf_fun_set_ops(instance->hc_fun, &hc_ops);
    167171        ddf_fun_data_implant(instance->hc_fun, &instance->hc);
    168172
    169173        instance->rh_fun = ddf_fun_create(device, fun_inner, "ohci_rh");
    170         if (instance->rh_fun == NULL) {
    171                 usb_log_error("Failed to create OHCI RH function: %s.\n",
    172                     str_error(ENOMEM));
    173                 rc = ENOMEM;
    174                 goto error;
    175         }
    176 
     174        ret = instance->rh_fun ? EOK : ENOMEM;
     175        CHECK_RET_DEST_FREE_RETURN(ret,
     176            "Failed to create OHCI RH function: %s.\n", str_error(ret));
    177177        ddf_fun_set_ops(instance->rh_fun, &rh_ops);
    178178
     
    181181        int irq = 0;
    182182
    183         rc = get_my_registers(device, &reg_base, &reg_size, &irq);
    184         if (rc != EOK) {
    185                 usb_log_error("Failed to get register memory addresses "
    186                     "for %" PRIun ": %s.\n", ddf_dev_get_handle(device),
    187                     str_error(rc));
    188                 goto error;
    189         }
    190 
     183        ret = get_my_registers(device, &reg_base, &reg_size, &irq);
     184        CHECK_RET_DEST_FREE_RETURN(ret,
     185            "Failed to get register memory addresses for %" PRIun ": %s.\n",
     186            ddf_dev_get_handle(device), str_error(ret));
    191187        usb_log_debug("Memory mapped regs at %p (size %zu), IRQ %d.\n",
    192188            (void *) reg_base, reg_size, irq);
    193189
    194         rc = hc_register_irq_handler(device, reg_base, reg_size, irq, irq_handler);
    195         if (rc != EOK) {
    196                 usb_log_error("Failed to register interrupt handler: %s.\n",
    197                     str_error(rc));
    198                 goto error;
    199         }
    200 
    201         ih_registered = true;
     190        const size_t ranges_count = hc_irq_pio_range_count();
     191        const size_t cmds_count = hc_irq_cmd_count();
     192        irq_pio_range_t irq_ranges[ranges_count];
     193        irq_cmd_t irq_cmds[cmds_count];
     194        irq_code_t irq_code = {
     195                .rangecount = ranges_count,
     196                .ranges = irq_ranges,
     197                .cmdcount = cmds_count,
     198                .cmds = irq_cmds
     199        };
     200
     201        ret = hc_get_irq_code(irq_ranges, sizeof(irq_ranges), irq_cmds,
     202            sizeof(irq_cmds), reg_base, reg_size);
     203        CHECK_RET_DEST_FREE_RETURN(ret,
     204            "Failed to generate IRQ code: %s.\n", str_error(ret));
     205
     206
     207        /* Register handler to avoid interrupt lockup */
     208        ret = register_interrupt_handler(device, irq, irq_handler, &irq_code);
     209        CHECK_RET_DEST_FREE_RETURN(ret,
     210            "Failed to register interrupt handler: %s.\n", str_error(ret));
    202211
    203212        /* Try to enable interrupts */
    204213        bool interrupts = false;
    205         rc = enable_interrupts(device);
    206         if (rc != EOK) {
     214        ret = enable_interrupts(device);
     215        if (ret != EOK) {
    207216                usb_log_warning("Failed to enable interrupts: %s."
    208                     " Falling back to polling\n", str_error(rc));
     217                    " Falling back to polling\n", str_error(ret));
    209218                /* We don't need that handler */
    210219                unregister_interrupt_handler(device, irq);
    211                 ih_registered = false;
    212220        } else {
    213221                usb_log_debug("Hw interrupts enabled.\n");
     
    215223        }
    216224
    217         rc = hc_init(&instance->hc, reg_base, reg_size, interrupts);
    218         if (rc != EOK) {
    219                 usb_log_error("Failed to init ohci_hcd: %s.\n", str_error(rc));
    220                 goto error;
    221         }
    222 
    223         hc_inited = true;
    224 
    225         rc = ddf_fun_bind(instance->hc_fun);
    226         if (rc != EOK) {
    227                 usb_log_error("Failed to bind OHCI device function: %s.\n",
    228                     str_error(rc));
    229                 goto error;
    230         }
    231 
    232         rc = ddf_fun_add_to_category(instance->hc_fun, USB_HC_CATEGORY);
    233         if (rc != EOK) {
    234                 usb_log_error("Failed to add OHCI to HC category: %s.\n",
    235                     str_error(rc));
    236                 goto error;
    237         }
    238 
    239         rc = hc_register_hub(&instance->hc, instance->rh_fun);
    240         if (rc != EOK) {
    241                 usb_log_error("Failed to register OHCI root hub: %s.\n",
    242                     str_error(rc));
    243                 goto error;
    244         }
    245 
    246         return EOK;
    247 
    248 error:
    249         if (hc_inited)
    250                 hc_fini(&instance->hc);
    251         if (ih_registered)
    252                 unregister_interrupt_handler(device, irq);
    253         if (instance->hc_fun != NULL)
    254                 ddf_fun_destroy(instance->hc_fun);
    255         if (instance->rh_fun != NULL)
    256                 ddf_fun_destroy(instance->rh_fun);
    257         return rc;
     225        ret = hc_init(&instance->hc, reg_base, reg_size, interrupts);
     226        CHECK_RET_DEST_FREE_RETURN(ret,
     227            "Failed to init ohci_hcd: %s.\n", str_error(ret));
     228
     229#define CHECK_RET_FINI_RETURN(ret, message...) \
     230if (ret != EOK) { \
     231        hc_fini(&instance->hc); \
     232        unregister_interrupt_handler(device, irq); \
     233        CHECK_RET_DEST_FREE_RETURN(ret, message); \
     234} else (void)0
     235
     236
     237        ret = ddf_fun_bind(instance->hc_fun);
     238        CHECK_RET_FINI_RETURN(ret,
     239            "Failed to bind OHCI device function: %s.\n", str_error(ret));
     240
     241        ret = ddf_fun_add_to_category(instance->hc_fun, USB_HC_CATEGORY);
     242        CHECK_RET_FINI_RETURN(ret,
     243            "Failed to add OHCI to HC class: %s.\n", str_error(ret));
     244
     245        ret = hc_register_hub(&instance->hc, instance->rh_fun);
     246        CHECK_RET_FINI_RETURN(ret,
     247            "Failed to register OHCI root hub: %s.\n", str_error(ret));
     248        return ret;
     249
     250#undef CHECK_RET_FINI_RETURN
    258251}
    259252/**
Note: See TracChangeset for help on using the changeset viewer.