static int irq_affinity_hint_proc_show(struct seq_file *m, void *v)
 {
        struct irq_desc *desc = irq_to_desc((long)m->private);
-       unsigned long flags;
        cpumask_var_t mask;
 
        if (!zalloc_cpumask_var(&mask, GFP_KERNEL))
                return -ENOMEM;
 
-       raw_spin_lock_irqsave(&desc->lock, flags);
-       if (desc->affinity_hint)
-               cpumask_copy(mask, desc->affinity_hint);
-       raw_spin_unlock_irqrestore(&desc->lock, flags);
+       scoped_guard(raw_spinlock_irq, &desc->lock) {
+               if (desc->affinity_hint)
+                       cpumask_copy(mask, desc->affinity_hint);
+       }
 
        seq_printf(m, "%*pb\n", cpumask_pr_args(mask));
        free_cpumask_var(mask);
-
        return 0;
 }
 
 
 #define MAX_NAMELEN 128
 
-static int name_unique(unsigned int irq, struct irqaction *new_action)
+static bool name_unique(unsigned int irq, struct irqaction *new_action)
 {
        struct irq_desc *desc = irq_to_desc(irq);
        struct irqaction *action;
-       unsigned long flags;
-       int ret = 1;
 
-       raw_spin_lock_irqsave(&desc->lock, flags);
+       guard(raw_spinlock_irq)(&desc->lock);
        for_each_action_of_desc(desc, action) {
                if ((action != new_action) && action->name &&
-                               !strcmp(new_action->name, action->name)) {
-                       ret = 0;
-                       break;
-               }
+                   !strcmp(new_action->name, action->name))
+                       return false;
        }
-       raw_spin_unlock_irqrestore(&desc->lock, flags);
-       return ret;
+       return true;
 }
 
 void register_handler_proc(unsigned int irq, struct irqaction *action)
        char name [MAX_NAMELEN];
        struct irq_desc *desc = irq_to_desc(irq);
 
-       if (!desc->dir || action->dir || !action->name ||
-                                       !name_unique(irq, action))
+       if (!desc->dir || action->dir || !action->name || !name_unique(irq, action))
                return;
 
        snprintf(name, MAX_NAMELEN, "%s", action->name);
         * added, not when the descriptor is created, so multiple
         * tasks might try to register at the same time.
         */
-       mutex_lock(®ister_lock);
+       guard(mutex)(®ister_lock);
 
        if (desc->dir)
-               goto out_unlock;
-
-       sprintf(name, "%d", irq);
+               return;
 
        /* create /proc/irq/1234 */
+       sprintf(name, "%d", irq);
        desc->dir = proc_mkdir(name, root_irq_dir);
        if (!desc->dir)
-               goto out_unlock;
+               return;
 
 #ifdef CONFIG_SMP
        umode_t umode = S_IRUGO;
                umode |= S_IWUSR;
 
        /* create /proc/irq/<irq>/smp_affinity */
-       proc_create_data("smp_affinity", umode, desc->dir,
-                        &irq_affinity_proc_ops, irqp);
+       proc_create_data("smp_affinity", umode, desc->dir, &irq_affinity_proc_ops, irqp);
 
        /* create /proc/irq/<irq>/affinity_hint */
        proc_create_single_data("affinity_hint", 0444, desc->dir,
-                       irq_affinity_hint_proc_show, irqp);
+                               irq_affinity_hint_proc_show, irqp);
 
        /* create /proc/irq/<irq>/smp_affinity_list */
        proc_create_data("smp_affinity_list", umode, desc->dir,
                         &irq_affinity_list_proc_ops, irqp);
 
-       proc_create_single_data("node", 0444, desc->dir, irq_node_proc_show,
-                       irqp);
+       proc_create_single_data("node", 0444, desc->dir, irq_node_proc_show, irqp);
 # ifdef CONFIG_GENERIC_IRQ_EFFECTIVE_AFF_MASK
        proc_create_single_data("effective_affinity", 0444, desc->dir,
-                       irq_effective_aff_proc_show, irqp);
+                               irq_effective_aff_proc_show, irqp);
        proc_create_single_data("effective_affinity_list", 0444, desc->dir,
-                       irq_effective_aff_list_proc_show, irqp);
+                               irq_effective_aff_list_proc_show, irqp);
 # endif
 #endif
        proc_create_single_data("spurious", 0444, desc->dir,
-                       irq_spurious_proc_show, (void *)(long)irq);
+                               irq_spurious_proc_show, (void *)(long)irq);
 
-out_unlock:
-       mutex_unlock(®ister_lock);
 }
 
 void unregister_irq_proc(unsigned int irq, struct irq_desc *desc)
        int i = *(loff_t *) v, j;
        struct irqaction *action;
        struct irq_desc *desc;
-       unsigned long flags;
 
        if (i > ACTUAL_NR_IRQS)
                return 0;
                seq_putc(p, '\n');
        }
 
-       rcu_read_lock();
+       guard(rcu)();
        desc = irq_to_desc(i);
        if (!desc || irq_settings_is_hidden(desc))
-               goto outsparse;
+               return 0;
 
        if (!desc->action || irq_desc_is_chained(desc) || !desc->kstat_irqs)
-               goto outsparse;
+               return 0;
 
        seq_printf(p, "%*d:", prec, i);
        for_each_online_cpu(j) {
        }
        seq_putc(p, ' ');
 
-       raw_spin_lock_irqsave(&desc->lock, flags);
+       guard(raw_spinlock_irq)(&desc->lock);
        if (desc->irq_data.chip) {
                if (desc->irq_data.chip->irq_print_chip)
                        desc->irq_data.chip->irq_print_chip(&desc->irq_data, p);
        }
 
        seq_putc(p, '\n');
-       raw_spin_unlock_irqrestore(&desc->lock, flags);
-outsparse:
-       rcu_read_unlock();
        return 0;
 }
 #endif