Function report |
Source Code:kernel\irq\manage.c |
Create Date:2022-07-28 10:09:29 |
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
| home page | Tree |
| Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:Oneshot interrupts keep the irq line masked until the threaded* handler finished. unmask if the interrupt has not been disabled and* is marked MASKED.
Proto:static void irq_finalize_oneshot(struct irq_desc *desc, struct irqaction *action)
Type:void
Parameter:
| Type | Parameter | Name |
|---|---|---|
| struct irq_desc * | desc | |
| struct irqaction * | action |
| 880 | If Not (istate & IRQS_ONESHOT) || handler == irq_forced_secondary_handler Then Return |
| 883 | again : |
| 885 | raw_spin_lock_irq( & lock) |
| 913 | If st_bit - Determine whether a bit is set*@nr: bit number to test*@addr: Address to start counting from Then Go to out_unlock |
| 916 | threads_oneshot &= ~thread_mask |
| 918 | If Not threads_oneshot && Not irqd_irq_disabled( & irq_data) && irqd_irq_masked( & irq_data) Then unmask_threaded_irq(desc) |
| 922 | out_unlock : |
| 923 | raw_spin_unlock_irq( & lock) |
| 924 | chip_bus_sync_unlock(desc) |
| Name | Describe |
|---|---|
| irq_forced_thread_fn | Interrupts which are not explicitly requested as threaded* interrupts rely on the implicit bh/preempt disable of the hard irq* context. So we need to disable bh here to avoid deadlocks and other* side effects. |
| irq_thread_fn | Interrupts explicitly requested as threaded interrupts want to be* preemtible - many of them need to sleep and wait for slow busses to* complete. |
| irq_thread_dtor |
| Source code conversion tool public plug-in interface | X |
|---|---|
| Support c/c++/esqlc/java Oracle/Informix/Mysql Plug-in can realize: logical Report Code generation and batch code conversion |