/kernel/irq/ |
D | chip.c | 45 struct irq_desc *desc = irq_get_desc_lock(irq, &flags, 0); in irq_set_chip() local 47 if (!desc) in irq_set_chip() 50 desc->irq_data.chip = (struct irq_chip *)(chip ?: &no_irq_chip); in irq_set_chip() 51 irq_put_desc_unlock(desc, flags); in irq_set_chip() 69 struct irq_desc *desc = irq_get_desc_buslock(irq, &flags, IRQ_GET_DESC_CHECK_GLOBAL); in irq_set_irq_type() local 72 if (!desc) in irq_set_irq_type() 75 ret = __irq_set_trigger(desc, type); in irq_set_irq_type() 76 irq_put_desc_busunlock(desc, flags); in irq_set_irq_type() 91 struct irq_desc *desc = irq_get_desc_lock(irq, &flags, 0); in irq_set_handler_data() local 93 if (!desc) in irq_set_handler_data() [all …]
|
D | manage.c | 38 static void __synchronize_hardirq(struct irq_desc *desc, bool sync_chip) in __synchronize_hardirq() argument 40 struct irq_data *irqd = irq_desc_get_irq_data(desc); in __synchronize_hardirq() 50 while (irqd_irq_inprogress(&desc->irq_data)) in __synchronize_hardirq() 54 raw_spin_lock_irqsave(&desc->lock, flags); in __synchronize_hardirq() 55 inprogress = irqd_irq_inprogress(&desc->irq_data); in __synchronize_hardirq() 70 raw_spin_unlock_irqrestore(&desc->lock, flags); in __synchronize_hardirq() 100 struct irq_desc *desc = irq_to_desc(irq); in synchronize_hardirq() local 102 if (desc) { in synchronize_hardirq() 103 __synchronize_hardirq(desc, false); in synchronize_hardirq() 104 return !atomic_read(&desc->threads_active); in synchronize_hardirq() [all …]
|
D | pm.c | 16 bool irq_pm_check_wakeup(struct irq_desc *desc) in irq_pm_check_wakeup() argument 18 if (irqd_is_wakeup_armed(&desc->irq_data)) { in irq_pm_check_wakeup() 19 irqd_clear(&desc->irq_data, IRQD_WAKEUP_ARMED); in irq_pm_check_wakeup() 20 desc->istate |= IRQS_SUSPENDED | IRQS_PENDING; in irq_pm_check_wakeup() 21 desc->depth++; in irq_pm_check_wakeup() 22 irq_disable(desc); in irq_pm_check_wakeup() 23 pm_system_irq_wakeup(irq_desc_get_irq(desc)); in irq_pm_check_wakeup() 33 void irq_pm_install_action(struct irq_desc *desc, struct irqaction *action) in irq_pm_install_action() argument 35 desc->nr_actions++; in irq_pm_install_action() 38 desc->force_resume_depth++; in irq_pm_install_action() [all …]
|
D | irqdesc.c | 55 static int alloc_masks(struct irq_desc *desc, int node) in alloc_masks() argument 57 if (!zalloc_cpumask_var_node(&desc->irq_common_data.affinity, in alloc_masks() 62 if (!zalloc_cpumask_var_node(&desc->irq_common_data.effective_affinity, in alloc_masks() 64 free_cpumask_var(desc->irq_common_data.affinity); in alloc_masks() 70 if (!zalloc_cpumask_var_node(&desc->pending_mask, GFP_KERNEL, node)) { in alloc_masks() 72 free_cpumask_var(desc->irq_common_data.effective_affinity); in alloc_masks() 74 free_cpumask_var(desc->irq_common_data.affinity); in alloc_masks() 81 static void desc_smp_init(struct irq_desc *desc, int node, in desc_smp_init() argument 86 cpumask_copy(desc->irq_common_data.affinity, affinity); in desc_smp_init() 89 cpumask_clear(desc->pending_mask); in desc_smp_init() [all …]
|
D | settings.h | 42 irq_settings_clr_and_set(struct irq_desc *desc, u32 clr, u32 set) in irq_settings_clr_and_set() argument 44 desc->status_use_accessors &= ~(clr & _IRQF_MODIFY_MASK); in irq_settings_clr_and_set() 45 desc->status_use_accessors |= (set & _IRQF_MODIFY_MASK); in irq_settings_clr_and_set() 48 static inline bool irq_settings_is_per_cpu(struct irq_desc *desc) in irq_settings_is_per_cpu() argument 50 return desc->status_use_accessors & _IRQ_PER_CPU; in irq_settings_is_per_cpu() 53 static inline bool irq_settings_is_per_cpu_devid(struct irq_desc *desc) in irq_settings_is_per_cpu_devid() argument 55 return desc->status_use_accessors & _IRQ_PER_CPU_DEVID; in irq_settings_is_per_cpu_devid() 58 static inline void irq_settings_set_per_cpu(struct irq_desc *desc) in irq_settings_set_per_cpu() argument 60 desc->status_use_accessors |= _IRQ_PER_CPU; in irq_settings_set_per_cpu() 63 static inline void irq_settings_set_no_balancing(struct irq_desc *desc) in irq_settings_set_no_balancing() argument [all …]
|
D | internals.h | 74 extern int __irq_set_trigger(struct irq_desc *desc, unsigned long flags); 75 extern void __disable_irq(struct irq_desc *desc); 76 extern void __enable_irq(struct irq_desc *desc); 84 extern int irq_activate(struct irq_desc *desc); 85 extern int irq_activate_and_startup(struct irq_desc *desc, bool resend); 86 extern int irq_startup(struct irq_desc *desc, bool resend, bool force); 88 extern void irq_shutdown(struct irq_desc *desc); 89 extern void irq_shutdown_and_deactivate(struct irq_desc *desc); 90 extern void irq_enable(struct irq_desc *desc); 91 extern void irq_disable(struct irq_desc *desc); [all …]
|
D | spurious.c | 36 bool irq_wait_for_poll(struct irq_desc *desc) in irq_wait_for_poll() argument 37 __must_hold(&desc->lock) in irq_wait_for_poll() 41 smp_processor_id(), desc->irq_data.irq)) in irq_wait_for_poll() 46 raw_spin_unlock(&desc->lock); in irq_wait_for_poll() 47 while (irqd_irq_inprogress(&desc->irq_data)) in irq_wait_for_poll() 49 raw_spin_lock(&desc->lock); in irq_wait_for_poll() 50 } while (irqd_irq_inprogress(&desc->irq_data)); in irq_wait_for_poll() 52 return !irqd_irq_disabled(&desc->irq_data) && desc->action; in irq_wait_for_poll() 62 static int try_one_irq(struct irq_desc *desc, bool force) in try_one_irq() argument 67 raw_spin_lock(&desc->lock); in try_one_irq() [all …]
|
D | autoprobe.c | 32 struct irq_desc *desc; in probe_irq_on() local 45 for_each_irq_desc_reverse(i, desc) { in probe_irq_on() 46 raw_spin_lock_irq(&desc->lock); in probe_irq_on() 47 if (!desc->action && irq_settings_can_probe(desc)) { in probe_irq_on() 52 if (desc->irq_data.chip->irq_set_type) in probe_irq_on() 53 desc->irq_data.chip->irq_set_type(&desc->irq_data, in probe_irq_on() 55 irq_activate_and_startup(desc, IRQ_NORESEND); in probe_irq_on() 57 raw_spin_unlock_irq(&desc->lock); in probe_irq_on() 68 for_each_irq_desc_reverse(i, desc) { in probe_irq_on() 69 raw_spin_lock_irq(&desc->lock); in probe_irq_on() [all …]
|
D | resend.c | 32 struct irq_desc *desc; in resend_irqs() local 38 desc = irq_to_desc(irq); in resend_irqs() 39 if (!desc) in resend_irqs() 42 desc->handle_irq(desc); in resend_irqs() 50 static int irq_sw_resend(struct irq_desc *desc) in irq_sw_resend() argument 52 unsigned int irq = irq_desc_get_irq(desc); in irq_sw_resend() 58 if (handle_enforce_irqctx(&desc->irq_data)) in irq_sw_resend() 66 if (irq_settings_is_nested_thread(desc)) { in irq_sw_resend() 71 if (!desc->parent_irq) in irq_sw_resend() 73 irq = desc->parent_irq; in irq_sw_resend() [all …]
|
D | proc.c | 48 struct irq_desc *desc = irq_to_desc((long)m->private); in show_irq_affinity() local 54 mask = desc->irq_common_data.affinity; in show_irq_affinity() 56 if (irqd_is_setaffinity_pending(&desc->irq_data)) in show_irq_affinity() 57 mask = desc->pending_mask; in show_irq_affinity() 63 mask = irq_data_get_effective_affinity_mask(&desc->irq_data); in show_irq_affinity() 85 struct irq_desc *desc = irq_to_desc((long)m->private); in irq_affinity_hint_proc_show() local 92 raw_spin_lock_irqsave(&desc->lock, flags); in irq_affinity_hint_proc_show() 93 if (desc->affinity_hint) in irq_affinity_hint_proc_show() 94 cpumask_copy(mask, desc->affinity_hint); in irq_affinity_hint_proc_show() 95 raw_spin_unlock_irqrestore(&desc->lock, flags); in irq_affinity_hint_proc_show() [all …]
|
D | msi.c | 38 struct msi_desc *desc = kzalloc(sizeof(*desc), GFP_KERNEL); in msi_alloc_desc() local 40 if (!desc) in msi_alloc_desc() 43 desc->dev = dev; in msi_alloc_desc() 44 desc->nvec_used = nvec; in msi_alloc_desc() 46 desc->affinity = kmemdup(affinity, nvec * sizeof(*desc->affinity), GFP_KERNEL); in msi_alloc_desc() 47 if (!desc->affinity) { in msi_alloc_desc() 48 kfree(desc); in msi_alloc_desc() 52 return desc; in msi_alloc_desc() 55 static void msi_free_desc(struct msi_desc *desc) in msi_free_desc() argument 57 kfree(desc->affinity); in msi_free_desc() [all …]
|
D | handle.c | 33 void handle_bad_irq(struct irq_desc *desc) in handle_bad_irq() argument 35 unsigned int irq = irq_desc_get_irq(desc); in handle_bad_irq() 37 print_irq_desc(irq, desc); in handle_bad_irq() 38 kstat_incr_irqs_this_cpu(desc); in handle_bad_irq() 61 void __irq_wake_thread(struct irq_desc *desc, struct irqaction *action) in __irq_wake_thread() argument 123 desc->threads_oneshot |= action->thread_mask; in __irq_wake_thread() 134 atomic_inc(&desc->threads_active); in __irq_wake_thread() 139 irqreturn_t __handle_irq_event_percpu(struct irq_desc *desc) in __handle_irq_event_percpu() argument 142 unsigned int irq = desc->irq_data.irq; in __handle_irq_event_percpu() 145 record_irq_time(desc); in __handle_irq_event_percpu() [all …]
|
D | cpuhotplug.c | 53 static bool migrate_one_irq(struct irq_desc *desc) in migrate_one_irq() argument 55 struct irq_data *d = irq_desc_get_irq_data(desc); in migrate_one_irq() 86 irq_fixup_move_pending(desc, false); in migrate_one_irq() 96 irq_force_complete_move(desc); in migrate_one_irq() 104 if (irq_fixup_move_pending(desc, true)) in migrate_one_irq() 105 affinity = irq_desc_get_pending_mask(desc); in migrate_one_irq() 120 irq_shutdown_and_deactivate(desc); in migrate_one_irq() 157 struct irq_desc *desc; in irq_migrate_all_off_this_cpu() local 163 desc = irq_to_desc(irq); in irq_migrate_all_off_this_cpu() 164 raw_spin_lock(&desc->lock); in irq_migrate_all_off_this_cpu() [all …]
|
D | debug.h | 6 #define ___P(f) if (desc->status_use_accessors & f) printk("%14s set\n", #f) 7 #define ___PS(f) if (desc->istate & f) printk("%14s set\n", #f) 11 static inline void print_irq_desc(unsigned int irq, struct irq_desc *desc) in print_irq_desc() argument 19 irq, desc, desc->depth, desc->irq_count, desc->irqs_unhandled); in print_irq_desc() 21 desc->handle_irq, desc->handle_irq); in print_irq_desc() 23 desc->irq_data.chip, desc->irq_data.chip); in print_irq_desc() 24 printk("->action(): %p\n", desc->action); in print_irq_desc() 25 if (desc->action) { in print_irq_desc() 27 desc->action->handler, desc->action->handler); in print_irq_desc()
|
D | debugfs.c | 30 static void irq_debug_show_masks(struct seq_file *m, struct irq_desc *desc) in irq_debug_show_masks() argument 32 struct irq_data *data = irq_desc_get_irq_data(desc); in irq_debug_show_masks() 42 msk = desc->pending_mask; in irq_debug_show_masks() 47 static void irq_debug_show_masks(struct seq_file *m, struct irq_desc *desc) { } in irq_debug_show_masks() argument 164 struct irq_desc *desc = m->private; in irq_debug_show() local 167 raw_spin_lock_irq(&desc->lock); in irq_debug_show() 168 data = irq_desc_get_irq_data(desc); in irq_debug_show() 169 seq_printf(m, "handler: %ps\n", desc->handle_irq); in irq_debug_show() 170 seq_printf(m, "device: %s\n", desc->dev_name); in irq_debug_show() 171 seq_printf(m, "status: 0x%08x\n", desc->status_use_accessors); in irq_debug_show() [all …]
|
D | migration.c | 18 bool irq_fixup_move_pending(struct irq_desc *desc, bool force_clear) in irq_fixup_move_pending() argument 20 struct irq_data *data = irq_desc_get_irq_data(desc); in irq_fixup_move_pending() 29 if (cpumask_any_and(desc->pending_mask, cpu_online_mask) >= nr_cpu_ids) { in irq_fixup_move_pending() 40 struct irq_desc *desc = irq_data_to_desc(idata); in irq_move_masked_irq() local 41 struct irq_data *data = &desc->irq_data; in irq_move_masked_irq() 57 if (unlikely(cpumask_empty(desc->pending_mask))) in irq_move_masked_irq() 63 assert_raw_spin_locked(&desc->lock); in irq_move_masked_irq() 77 if (cpumask_any_and(desc->pending_mask, cpu_online_mask) < nr_cpu_ids) { in irq_move_masked_irq() 80 ret = irq_do_set_affinity(data, desc->pending_mask, false); in irq_move_masked_irq() 91 cpumask_clear(desc->pending_mask); in irq_move_masked_irq()
|
D | ipi.c | 227 int __ipi_send_single(struct irq_desc *desc, unsigned int cpu) in __ipi_send_single() argument 229 struct irq_data *data = irq_desc_get_irq_data(desc); in __ipi_send_single() 269 int __ipi_send_mask(struct irq_desc *desc, const struct cpumask *dest) in __ipi_send_mask() argument 271 struct irq_data *data = irq_desc_get_irq_data(desc); in __ipi_send_mask() 315 struct irq_desc *desc = irq_to_desc(virq); in ipi_send_single() local 316 struct irq_data *data = desc ? irq_desc_get_irq_data(desc) : NULL; in ipi_send_single() 322 return __ipi_send_single(desc, cpu); in ipi_send_single() 336 struct irq_desc *desc = irq_to_desc(virq); in ipi_send_mask() local 337 struct irq_data *data = desc ? irq_desc_get_irq_data(desc) : NULL; in ipi_send_mask() 343 return __ipi_send_mask(desc, dest); in ipi_send_mask()
|
D | irqdomain.c | 956 struct irq_desc *desc = NULL; in __irq_resolve_mapping() local 963 return desc; in __irq_resolve_mapping() 969 desc = irq_data_to_desc(data); in __irq_resolve_mapping() 970 if (irq && desc) in __irq_resolve_mapping() 974 return desc; in __irq_resolve_mapping() 985 desc = irq_data_to_desc(data); in __irq_resolve_mapping() 991 return desc; in __irq_resolve_mapping() 1614 struct irq_desc *desc; in irq_domain_push_irq() local 1626 desc = irq_to_desc(virq); in irq_domain_push_irq() 1627 if (!desc) in irq_domain_push_irq() [all …]
|
D | dummychip.c | 20 struct irq_desc *desc = irq_data_to_desc(data); in ack_bad() local 22 print_irq_desc(data->irq, desc); in ack_bad()
|
/kernel/printk/ |
D | printk_ringbuffer.c | 437 struct prb_desc *desc = to_desc(desc_ring, id); in desc_read() local 438 atomic_long_t *state_var = &desc->state_var; in desc_read() 478 memcpy(&desc_out->text_blk_lpos, &desc->text_blk_lpos, in desc_read() 548 struct prb_desc *desc = to_desc(desc_ring, id); in desc_make_reusable() local 549 atomic_long_t *state_var = &desc->state_var; in desc_make_reusable() 574 struct prb_desc desc; in data_make_reusable() local 575 struct prb_data_blk_lpos *blk_lpos = &desc.text_blk_lpos; in data_make_reusable() 592 d_state = desc_read(desc_ring, id, &desc, in data_make_reusable() 772 struct prb_desc desc; in desc_push_tail() local 774 d_state = desc_read(desc_ring, tail_id, &desc, NULL, NULL); in desc_push_tail() [all …]
|
/kernel/ |
D | resource.c | 326 unsigned long flags, unsigned long desc, in find_next_iomem_res() argument 352 if ((desc != IORES_DESC_NONE) && (desc != p->desc)) in find_next_iomem_res() 365 .desc = p->desc, in find_next_iomem_res() 375 unsigned long flags, unsigned long desc, in __walk_iomem_res_desc() argument 383 !find_next_iomem_res(start, end, flags, desc, &res)) { in __walk_iomem_res_desc() 411 int walk_iomem_res_desc(unsigned long desc, unsigned long flags, u64 start, in walk_iomem_res_desc() argument 414 return __walk_iomem_res_desc(start, end, flags, desc, arg, func); in walk_iomem_res_desc() 494 unsigned long desc) in __region_intersects() argument 505 ((desc == IORES_DESC_NONE) || in __region_intersects() 506 (desc == p->desc))); in __region_intersects() [all …]
|
D | kexec_file.c | 588 return walk_iomem_res_desc(crashk_res.desc, in kexec_walk_resources() 677 struct shash_desc *desc; in kexec_calculate_store_digests() local 697 desc_size = crypto_shash_descsize(tfm) + sizeof(*desc); in kexec_calculate_store_digests() 698 desc = kzalloc(desc_size, GFP_KERNEL); in kexec_calculate_store_digests() 699 if (!desc) { in kexec_calculate_store_digests() 711 desc->tfm = tfm; in kexec_calculate_store_digests() 713 ret = crypto_shash_init(desc); in kexec_calculate_store_digests() 734 ret = crypto_shash_update(desc, ksegment->kbuf, in kexec_calculate_store_digests() 749 ret = crypto_shash_update(desc, zero_buf, bytes); in kexec_calculate_store_digests() 764 ret = crypto_shash_final(desc, digest); in kexec_calculate_store_digests() [all …]
|
/kernel/cgroup/ |
D | freezer.c | 17 int desc = 1; in cgroup_propagate_frozen() local 27 cgrp->freezer.nr_frozen_descendants += desc; in cgroup_propagate_frozen() 35 desc++; in cgroup_propagate_frozen() 38 cgrp->freezer.nr_frozen_descendants -= desc; in cgroup_propagate_frozen() 43 desc++; in cgroup_propagate_frozen()
|
/kernel/power/ |
D | wakeup_reason.c | 73 struct irq_desc *desc; in init_node() local 78 desc = irq_to_desc(irq); in init_node() 79 if (desc && desc->action && desc->action->name) in init_node() 80 p->irq_name = desc->action->name; in init_node()
|
/kernel/bpf/ |
D | cgroup.c | 512 struct cgroup *desc = container_of(css, struct cgroup, self); in update_effective_progs() local 514 if (percpu_ref_is_zero(&desc->bpf.refcnt)) in update_effective_progs() 517 err = compute_effective_progs(desc, atype, &desc->bpf.inactive); in update_effective_progs() 524 struct cgroup *desc = container_of(css, struct cgroup, self); in update_effective_progs() local 526 if (percpu_ref_is_zero(&desc->bpf.refcnt)) { in update_effective_progs() 527 if (unlikely(desc->bpf.inactive)) { in update_effective_progs() 528 bpf_prog_array_free(desc->bpf.inactive); in update_effective_progs() 529 desc->bpf.inactive = NULL; in update_effective_progs() 534 activate_effective_progs(desc, atype, desc->bpf.inactive); in update_effective_progs() 535 desc->bpf.inactive = NULL; in update_effective_progs() [all …]
|