Commit c4318baf authored by Thomas Gleixner's avatar Thomas Gleixner Committed by Paul Mundt
Browse files

sh: Sanitize sparse irq



Switch over to the new allocator functions.

Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Signed-off-by: default avatarPaul Mundt <lethal@linux-sh.org>
parent 2f98492c
Loading
Loading
Loading
Loading
+3 −3
Original line number Diff line number Diff line
@@ -62,13 +62,13 @@ void register_ipr_controller(struct ipr_desc *desc)

	for (i = 0; i < desc->nr_irqs; i++) {
		struct ipr_data *p = desc->ipr_data + i;
		struct irq_desc *irq_desc;
		int res;

		BUG_ON(p->ipr_idx >= desc->nr_offsets);
		BUG_ON(!desc->ipr_offsets[p->ipr_idx]);

		irq_desc = irq_to_desc_alloc_node(p->irq, numa_node_id());
		if (unlikely(!irq_desc)) {
		res = irq_alloc_desc_at(p->irq, numa_node_id());
		if (unlikely(res != p->irq && res != -EEXIST))
			printk(KERN_INFO "can not get irq_desc for %d\n",
			       p->irq);
			continue;
+5 −5
Original line number Diff line number Diff line
@@ -300,13 +300,13 @@ int __init register_intc_controller(struct intc_desc *desc)
	for (i = 0; i < hw->nr_vectors; i++) {
		struct intc_vect *vect = hw->vectors + i;
		unsigned int irq = evt2irq(vect->vect);
		struct irq_desc *irq_desc;
		int res;

		if (!vect->enum_id)
			continue;

		irq_desc = irq_to_desc_alloc_node(irq, numa_node_id());
		if (unlikely(!irq_desc)) {
		res = irq_alloc_desc_at(irq, numa_node_id());
		if (res != irq && res != -EEXIST) {
			pr_err("can't get irq_desc for %d\n", irq);
			continue;
		}
@@ -326,8 +326,8 @@ int __init register_intc_controller(struct intc_desc *desc)
			 * IRQ support, each vector still needs to have
			 * its own backing irq_desc.
			 */
			irq_desc = irq_to_desc_alloc_node(irq2, numa_node_id());
			if (unlikely(!irq_desc)) {
			res = irq_alloc_desc_at(irq2, numa_node_id());
			if (res != irq2 && res != -EEXIST) {
				pr_err("can't get irq_desc for %d\n", irq2);
				continue;
			}
+9 −14
Original line number Diff line number Diff line
@@ -37,7 +37,6 @@ unsigned int create_irq_nr(unsigned int irq_want, int node)
{
	unsigned int irq = 0, new;
	unsigned long flags;
	struct irq_desc *desc;

	raw_spin_lock_irqsave(&vector_lock, flags);

@@ -55,24 +54,20 @@ unsigned int create_irq_nr(unsigned int irq_want, int node)
		__set_bit(new, intc_irq_map);
	}

	desc = irq_to_desc_alloc_node(new, node);
	if (unlikely(!desc)) {
	raw_spin_unlock_irqrestore(&vector_lock, flags);

	irq = irq_alloc_desc_at(new, node);
	if (unlikely(irq != new)) {
		pr_err("can't get irq_desc for %d\n", new);
		goto out_unlock;
		return 0;
	}

	desc = move_irq_desc(desc, node);
	irq = new;
	activate_irq(irq);
	return 0;

out_unlock:
	raw_spin_unlock_irqrestore(&vector_lock, flags);

	if (irq > 0) {
		dynamic_irq_init(irq);
		activate_irq(irq);
	}

	return irq;
	return 0;
}

int create_irq(void)
@@ -91,7 +86,7 @@ void destroy_irq(unsigned int irq)
{
	unsigned long flags;

	dynamic_irq_cleanup(irq);
	irq_free_desc(irq);

	raw_spin_lock_irqsave(&vector_lock, flags);
	__clear_bit(irq, intc_irq_map);