2008-03-20 23:54:13 -07:00
|
|
|
/*
|
|
|
|
* linux/arch/sh/boards/se/7721/irq.c
|
|
|
|
*
|
|
|
|
* Copyright (C) 2008 Renesas Solutions Corp.
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
|
|
* for more details.
|
|
|
|
*/
|
|
|
|
#include <linux/init.h>
|
|
|
|
#include <linux/irq.h>
|
|
|
|
#include <linux/interrupt.h>
|
|
|
|
#include <linux/io.h>
|
2008-07-29 05:41:37 -07:00
|
|
|
#include <mach-se/mach/se7721.h>
|
2008-03-20 23:54:13 -07:00
|
|
|
|
|
|
|
enum {
|
|
|
|
UNUSED = 0,
|
|
|
|
|
|
|
|
/* board specific interrupt sources */
|
|
|
|
MRSHPC,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct intc_vect vectors[] __initdata = {
|
|
|
|
INTC_IRQ(MRSHPC, MRSHPC_IRQ0),
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct intc_prio_reg prio_registers[] __initdata = {
|
|
|
|
{ FPGA_ILSR6, 0, 8, 4, /* IRLMSK */
|
|
|
|
{ 0, MRSHPC } },
|
|
|
|
};
|
|
|
|
|
|
|
|
static DECLARE_INTC_DESC(intc_desc, "SE7721", vectors,
|
|
|
|
NULL, NULL, prio_registers, NULL);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Initialize IRQ setting
|
|
|
|
*/
|
|
|
|
void __init init_se7721_IRQ(void)
|
|
|
|
{
|
|
|
|
/* PPCR */
|
2010-01-25 20:58:40 -07:00
|
|
|
__raw_writew(__raw_readw(0xa4050118) & ~0x00ff, 0xa4050118);
|
2008-03-20 23:54:13 -07:00
|
|
|
|
|
|
|
register_intc_controller(&intc_desc);
|
|
|
|
intc_set_priority(MRSHPC_IRQ0, 0xf - MRSHPC_IRQ0);
|
|
|
|
}
|