Changeset ba4a03a5 in mainline for uspace/drv/bus/usb/ohci


Ignore:
Timestamp:
2013-12-31T23:11:00Z (12 years ago)
Author:
Jan Vesely <jano.vesely@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
d1df381
Parents:
e3a07bba
Message:

usb host: Use all hw resources when generating irq code.

Location:
uspace/drv/bus/usb/ohci
Files:
3 edited

Legend:

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

    re3a07bba rba4a03a5  
    100100 * @param[out] cmds Commands buffer.
    101101 * @param[in] cmds_size Size of the commands buffer (bytes).
    102  * @param[in] regs Device's register range.
     102 * @param[in] hw_res Device's resources.
    103103 *
    104104 * @return Error code.
    105105 */
    106 int hc_gen_irq_code(irq_code_t *code, addr_range_t *regs)
     106int hc_gen_irq_code(irq_code_t *code, const hw_res_list_parsed_t *hw_res)
    107107{
    108108        assert(code);
    109         if (RNGSZ(*regs) < sizeof(ohci_regs_t))
     109        assert(hw_res);
     110
     111        if (hw_res->irqs.count != 1 || hw_res->mem_ranges.count != 1)
     112                return EINVAL;
     113
     114        const addr_range_t regs = hw_res->mem_ranges.ranges[0];
     115
     116        if (RNGSZ(regs) < sizeof(ohci_regs_t))
    110117                return EOVERFLOW;
    111118
     
    124131
    125132        memcpy(code->ranges, ohci_pio_ranges, sizeof(ohci_pio_ranges));
    126         code->ranges[0].base = RNGABS(*regs);
     133        code->ranges[0].base = RNGABS(regs);
    127134
    128135        memcpy(code->cmds, ohci_irq_commands, sizeof(ohci_irq_commands));
    129         ohci_regs_t *registers = (ohci_regs_t *) RNGABSPTR(*regs);
     136        ohci_regs_t *registers = (ohci_regs_t *) RNGABSPTR(regs);
    130137        code->cmds[0].addr = (void *) &registers->interrupt_status;
    131138        code->cmds[3].addr = (void *) &registers->interrupt_status;
    132139        OHCI_WR(code->cmds[1].value, OHCI_USED_INTERRUPTS);
    133140
    134         return EOK;
     141        usb_log_debug("Memory mapped regs at %p (size %zu), IRQ %d.\n",
     142            RNGABSPTR(regs), RNGSZ(regs), hw_res->irqs.irqs[0]);
     143
     144        return hw_res->irqs.irqs[0];
    135145}
    136146
  • uspace/drv/bus/usb/ohci/hc.h

    re3a07bba rba4a03a5  
    7575} hc_t;
    7676
    77 int hc_gen_irq_code(irq_code_t *code, addr_range_t *regs);
     77int hc_gen_irq_code(irq_code_t *code, const hw_res_list_parsed_t *hw_res);
    7878int hc_register_hub(hc_t *instance, ddf_fun_t *hub_fun);
    7979int hc_init(hc_t *instance, addr_range_t *regs, bool interrupts);
  • uspace/drv/bus/usb/ohci/ohci.c

    re3a07bba rba4a03a5  
    9696        addr_range_t regs = hw_res.mem_ranges.ranges[0];
    9797        const int irq = hw_res.irqs.irqs[0];
    98         hw_res_list_parsed_clean(&hw_res);
    99 
    100         usb_log_debug("Memory mapped regs at %p (size %zu), IRQ %d.\n",
    101             RNGABSPTR(regs), RNGSZ(regs), irq);
    10298
    10399        /* Initialize generic HCD driver */
     
    105101            BANDWIDTH_AVAILABLE_USB11, bandwidth_count_usb11);
    106102        if (ret != EOK) {
     103                hw_res_list_parsed_clean(&hw_res);
    107104                usb_log_error("Failed to setup generic hcd structures: %s.",
    108105                    str_error(ret));
     
    113110        if (!hc) {
    114111                usb_log_error("Failed to allocate driver structure.\n");
     112                hw_res_list_parsed_clean(&hw_res);
    115113                ret = ENOMEM;
    116114                goto ddf_hc_clean;
     
    119117        /* Try to enable interrupts */
    120118        bool interrupts = false;
    121         ret = hcd_ddf_setup_interrupts(device, &regs, irq, irq_handler,
     119        ret = hcd_ddf_setup_interrupts(device, &hw_res, irq_handler,
    122120            hc_gen_irq_code);
    123121        if (ret != EOK) {
     
    131129        /* Initialize OHCI HC */
    132130        ret = hc_init(hc, &regs, interrupts);
     131        hw_res_list_parsed_clean(&hw_res);
    133132        if (ret != EOK) {
    134133                usb_log_error("Failed to init hc: %s.\n", str_error(ret));
Note: See TracChangeset for help on using the changeset viewer.