Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 1899a493 authored by Thomas Gleixner's avatar Thomas Gleixner
Browse files

m32r: Convert opsput lanpld irq chip



Convert the irq chips to the new functions and use proper flow
handlers. handle_level_irq is appropriate.

Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Cc: Hirokazu Takata <takata@linux-m32r.org>
Cc: Paul Mundt <lethal@linux-sh.org>
parent 22cbc938
Loading
Loading
Loading
Loading
+12 −20
Original line number Original line Diff line number Diff line
@@ -167,29 +167,23 @@ static void enable_opsput_lanpld_irq(unsigned int irq)
	outw(data, port);
	outw(data, port);
}
}


static void mask_and_ack_opsput_lanpld(unsigned int irq)
static void mask_opsput_lanpld(struct irq_data *data)
{
{
	disable_opsput_lanpld_irq(irq);
	disable_opsput_lanpld_irq(data->irq);
}
}


static void end_opsput_lanpld_irq(unsigned int irq)
static void unmask_opsput_lanpld(struct irq_data *data)
{
{
	enable_opsput_lanpld_irq(irq);
	enable_opsput_lanpld_irq(data->irq);
	enable_opsput_irq(M32R_IRQ_INT0);
	enable_opsput_irq(M32R_IRQ_INT0);
}
}


static unsigned int startup_opsput_lanpld_irq(unsigned int irq)
static void shutdown_opsput_lanpld(struct irq_data *data)
{
	enable_opsput_lanpld_irq(irq);
	return (0);
}

static void shutdown_opsput_lanpld_irq(unsigned int irq)
{
{
	unsigned long port;
	unsigned long port;
	unsigned int pldirq;
	unsigned int pldirq;


	pldirq = irq2lanpldirq(irq);
	pldirq = irq2lanpldirq(data->irq);
	port = lanpldirq2port(pldirq);
	port = lanpldirq2port(pldirq);
	outw(PLD_ICUCR_ILEVEL7, port);
	outw(PLD_ICUCR_ILEVEL7, port);
}
}
@@ -197,12 +191,9 @@ static void shutdown_opsput_lanpld_irq(unsigned int irq)
static struct irq_chip opsput_lanpld_irq_type =
static struct irq_chip opsput_lanpld_irq_type =
{
{
	.name		= "OPSPUT-PLD-LAN-IRQ",
	.name		= "OPSPUT-PLD-LAN-IRQ",
	.startup = startup_opsput_lanpld_irq,
	.irq_shutdown	= shutdown_opsput_lanpld,
	.shutdown = shutdown_opsput_lanpld_irq,
	.irq_mask	= mask_opsput_lanpld,
	.enable = enable_opsput_lanpld_irq,
	.irq_unmask	= unmask_opsput_lanpld,
	.disable = disable_opsput_lanpld_irq,
	.ack = mask_and_ack_opsput_lanpld,
	.end = end_opsput_lanpld_irq
};
};


/*
/*
@@ -278,7 +269,8 @@ void __init init_IRQ(void)
{
{
#if defined(CONFIG_SMC91X)
#if defined(CONFIG_SMC91X)
	/* INT#0: LAN controller on OPSPUT-LAN (SMC91C111)*/
	/* INT#0: LAN controller on OPSPUT-LAN (SMC91C111)*/
	set_irq_chip(OPSPUT_LAN_IRQ_LAN, &opsput_lanpld_irq_type);
	set_irq_chip_and_handler(OPSPUT_LAN_IRQ_LAN, &opsput_lanpld_irq_type,
				 handle_level_irq);
	lanpld_icu_data[irq2lanpldirq(OPSPUT_LAN_IRQ_LAN)].icucr = PLD_ICUCR_IEN|PLD_ICUCR_ISMOD02;	/* "H" edge sense */
	lanpld_icu_data[irq2lanpldirq(OPSPUT_LAN_IRQ_LAN)].icucr = PLD_ICUCR_IEN|PLD_ICUCR_ISMOD02;	/* "H" edge sense */
	disable_opsput_lanpld_irq(OPSPUT_LAN_IRQ_LAN);
	disable_opsput_lanpld_irq(OPSPUT_LAN_IRQ_LAN);
#endif  /* CONFIG_SMC91X */
#endif  /* CONFIG_SMC91X */