162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * linux/arch/sh/boards/renesas/sdk7780/irq.c 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Renesas Technology Europe SDK7780 Support. 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Copyright (C) 2008 Nicholas Beck <nbeck@mpc-data.co.uk> 862306a36Sopenharmony_ci */ 962306a36Sopenharmony_ci#include <linux/init.h> 1062306a36Sopenharmony_ci#include <linux/irq.h> 1162306a36Sopenharmony_ci#include <linux/io.h> 1262306a36Sopenharmony_ci#include <mach/sdk7780.h> 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_cienum { 1562306a36Sopenharmony_ci UNUSED = 0, 1662306a36Sopenharmony_ci /* board specific interrupt sources */ 1762306a36Sopenharmony_ci SMC91C111, /* Ethernet controller */ 1862306a36Sopenharmony_ci}; 1962306a36Sopenharmony_ci 2062306a36Sopenharmony_cistatic struct intc_vect fpga_vectors[] __initdata = { 2162306a36Sopenharmony_ci INTC_IRQ(SMC91C111, IRQ_ETHERNET), 2262306a36Sopenharmony_ci}; 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_cistatic struct intc_mask_reg fpga_mask_registers[] __initdata = { 2562306a36Sopenharmony_ci { 0, FPGA_IRQ0MR, 16, 2662306a36Sopenharmony_ci { 0, 0, 0, 0, 0, 0, 0, 0, 2762306a36Sopenharmony_ci 0, 0, 0, SMC91C111, 0, 0, 0, 0 } }, 2862306a36Sopenharmony_ci}; 2962306a36Sopenharmony_ci 3062306a36Sopenharmony_cistatic DECLARE_INTC_DESC(fpga_intc_desc, "sdk7780-irq", fpga_vectors, 3162306a36Sopenharmony_ci NULL, fpga_mask_registers, NULL, NULL); 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_civoid __init init_sdk7780_IRQ(void) 3462306a36Sopenharmony_ci{ 3562306a36Sopenharmony_ci printk(KERN_INFO "Using SDK7780 interrupt controller.\n"); 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci __raw_writew(0xFFFF, FPGA_IRQ0MR); 3862306a36Sopenharmony_ci /* Setup IRL 0-3 */ 3962306a36Sopenharmony_ci __raw_writew(0x0003, FPGA_IMSR); 4062306a36Sopenharmony_ci plat_irq_setup_pins(IRQ_MODE_IRL3210); 4162306a36Sopenharmony_ci 4262306a36Sopenharmony_ci register_intc_controller(&fpga_intc_desc); 4362306a36Sopenharmony_ci} 44