Changeset e9d15d9 in mainline for uspace/lib


Ignore:
Timestamp:
2017-08-18T21:15:26Z (8 years ago)
Author:
Jakub Jermar <jakub@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
24abb85d
Parents:
1c85bae
Message:

Turn IRQ structures into kernel objects

ipc_irq_subscribe() now returns a capability for the underlying IRQ kernel
object. ipc_irq_unsubscribe() can now be done only with a valid IRQ capability.

Location:
uspace/lib
Files:
6 edited

Legend:

Unmodified
Added
Removed
  • uspace/lib/c/generic/async.c

    r1c85bae re9d15d9  
    10271027 * @param ucode   Top-half pseudocode handler.
    10281028 *
    1029  * @return Zero on success or a negative error code.
     1029 * @return IRQ capability on success.
     1030 * @return Negative error code.
    10301031 *
    10311032 */
     
    10561057/** Unsubscribe from IRQ notification.
    10571058 *
    1058  * @param inr     IRQ number.
    1059  * @param devno   Device number of the device generating inr.
     1059 * @param cap     IRQ capability.
    10601060 *
    10611061 * @return Zero on success or a negative error code.
    10621062 *
    10631063 */
    1064 int async_irq_unsubscribe(int inr, int devno)
     1064int async_irq_unsubscribe(int cap)
    10651065{
    10661066        // TODO: Remove entry from hash table
    10671067        //       to avoid memory leak
    10681068       
    1069         return ipc_irq_unsubscribe(inr, devno);
     1069        return ipc_irq_unsubscribe(cap);
    10701070}
    10711071
  • uspace/lib/c/generic/irq.c

    r1c85bae re9d15d9  
    5959 * @param ucode  Top-half pseudocode handler.
    6060 *
    61  * @return Value returned by the kernel.
     61 * @return IRQ capability returned by the kernel.
     62 * @return Error code returned by the kernel.
    6263 *
    6364 */
     
    7475/** Unsubscribe from IRQ notification.
    7576 *
    76  * @param inr   IRQ number.
    77  * @param devno Device number of the device generating inr.
     77 * @param cap   IRQ capability.
    7878 *
    7979 * @return Value returned by the kernel.
    8080 *
    8181 */
    82 int ipc_irq_unsubscribe(int inr, int devno)
     82int ipc_irq_unsubscribe(int cap)
    8383{
    84         return __SYSCALL2(SYS_IPC_IRQ_UNSUBSCRIBE, inr, devno);
     84        return __SYSCALL1(SYS_IPC_IRQ_UNSUBSCRIBE, cap);
    8585}
    8686
  • uspace/lib/c/include/async.h

    r1c85bae re9d15d9  
    168168extern int async_irq_subscribe(int, int, async_notification_handler_t, void *,
    169169    const irq_code_t *);
    170 extern int async_irq_unsubscribe(int, int);
     170extern int async_irq_unsubscribe(int);
    171171
    172172extern int async_event_subscribe(event_type_t, async_notification_handler_t,
  • uspace/lib/c/include/ipc/irq.h

    r1c85bae re9d15d9  
    4040
    4141extern int ipc_irq_subscribe(int, int, sysarg_t, const irq_code_t *);
    42 extern int ipc_irq_unsubscribe(int, int);
     42extern int ipc_irq_unsubscribe(int);
    4343
    4444#endif
  • uspace/lib/drv/generic/interrupt.c

    r1c85bae re9d15d9  
    4444
    4545int register_interrupt_handler(ddf_dev_t *dev, int irq,
    46     interrupt_handler_t *handler, const irq_code_t *pseudocode)
     46    interrupt_handler_t *handler, const irq_code_t *irq_code)
    4747{
    4848        return async_irq_subscribe(irq, dev->handle,
    49             (async_notification_handler_t) handler, dev, pseudocode);
     49            (async_notification_handler_t) handler, dev, irq_code);
    5050}
    5151
    52 int unregister_interrupt_handler(ddf_dev_t *dev, int irq)
     52int unregister_interrupt_handler(ddf_dev_t *dev, int cap)
    5353{
    54         return async_irq_unsubscribe(irq, dev->handle);
     54        return async_irq_unsubscribe(cap);
    5555}
    5656
  • uspace/lib/usbhost/src/ddf_helpers.c

    r1c85bae re9d15d9  
    748748 * @param[in] gen_irq_code IRQ code generator.
    749749 *
    750  * @return EOK on success or negative error code
     750 * @return IRQ kernel object capability on success.
     751 * @return Negative error code.
    751752 */
    752753int hcd_ddf_setup_interrupts(ddf_dev_t *device,
     
    770771
    771772        /* Register handler to avoid interrupt lockup */
    772         int ret = register_interrupt_handler(device, irq, handler, &irq_code);
     773        const int irq_cap = register_interrupt_handler(device, irq, handler,
     774            &irq_code);
    773775        irq_code_clean(&irq_code);
     776        if (irq_cap < 0) {
     777                usb_log_error("Failed to register interrupt handler: %s.\n",
     778                    str_error(irq_cap));
     779                return irq_cap;
     780        }
     781
     782        /* Enable interrupts */
     783        int ret = hcd_ddf_enable_interrupts(device);
    774784        if (ret != EOK) {
    775785                usb_log_error("Failed to register interrupt handler: %s.\n",
    776786                    str_error(ret));
    777                 return ret;
    778         }
    779 
    780         /* Enable interrupts */
    781         ret = hcd_ddf_enable_interrupts(device);
    782         if (ret != EOK) {
    783                 usb_log_error("Failed to register interrupt handler: %s.\n",
    784                     str_error(ret));
    785                 unregister_interrupt_handler(device, irq);
    786                 return ret;
    787         }
    788         assert(irq > 0);
    789         return irq;
     787                unregister_interrupt_handler(device, irq_cap);
     788                return ret;
     789        }
     790        return irq_cap;
    790791}
    791792
     
    882883        interrupt_handler_t *irq_handler =
    883884            driver->irq_handler ? driver->irq_handler : ddf_hcd_gen_irq_handler;
    884         const int irq = hcd_ddf_setup_interrupts(device, &hw_res, irq_handler,
    885             driver->irq_code_gen);
    886         if (!(irq < 0)) {
     885        const int irq_cap = hcd_ddf_setup_interrupts(device, &hw_res,
     886            irq_handler, driver->irq_code_gen);
     887        bool irqs_enabled = !(irq_cap < 0);
     888        if (irqs_enabled) {
    887889                usb_log_debug("Hw interrupts enabled.\n");
    888890        }
     
    899901        /* Init hw driver */
    900902        hcd_t *hcd = dev_to_hcd(device);
    901         ret = driver->init(hcd, &hw_res, !(irq < 0));
     903        ret = driver->init(hcd, &hw_res, irqs_enabled);
    902904        hw_res_list_parsed_clean(&hw_res);
    903905        if (ret != EOK) {
     
    907909
    908910        /* Need working irq replacement to setup root hub */
    909         if ((irq < 0) && hcd->ops.status_hook) {
     911        if (!irqs_enabled && hcd->ops.status_hook) {
    910912                hcd->polling_fibril = fibril_create(interrupt_polling, hcd);
    911913                if (hcd->polling_fibril == 0) {
     
    916918                fibril_add_ready(hcd->polling_fibril);
    917919                usb_log_warning("Failed to enable interrupts: %s."
    918                     " Falling back to polling.\n", str_error(irq));
     920                    " Falling back to polling.\n", str_error(irq_cap));
    919921        }
    920922
     
    930932irq_unregister:
    931933                /* Unregistering non-existent should be ok */
    932                 unregister_interrupt_handler(device, irq);
     934                unregister_interrupt_handler(device, irq_cap);
    933935                hcd_ddf_clean_hc(device);
    934936                return ret;
Note: See TracChangeset for help on using the changeset viewer.