blob: c0a015ae6ecf718df7a2bfba9ea4fc4edd35bd82 [file] [log] [blame]
Nicholas Beck4862ec02008-01-23 12:50:51 +09001/*
2 * arch/sh/drivers/pci/fixups-sdk7780.c
3 *
4 * PCI fixups for the SDK7780SE03
5 *
6 * Copyright (C) 2003 Lineo uSolutions, Inc.
7 * Copyright (C) 2004 - 2006 Paul Mundt
Paul Mundta6d377b2009-04-17 20:11:44 +09008 * Copyright (C) 2006 Nobuhiro Iwamatsu
Nicholas Beck4862ec02008-01-23 12:50:51 +09009 *
10 * This file is subject to the terms and conditions of the GNU General Public
11 * License. See the file "COPYING" in the main directory of this archive
12 * for more details.
13 */
14#include <linux/pci.h>
Paul Mundta6d377b2009-04-17 20:11:44 +090015#include <linux/io.h>
Paul Mundt58796ce2012-05-18 17:42:29 +090016#include <linux/sh_intc.h>
Nicholas Beck4862ec02008-01-23 12:50:51 +090017#include "pci-sh4.h"
Nicholas Beck4862ec02008-01-23 12:50:51 +090018
Paul Mundt58796ce2012-05-18 17:42:29 +090019#define IRQ_INTA evt2irq(0xa20)
20#define IRQ_INTB evt2irq(0xa40)
21#define IRQ_INTC evt2irq(0xa60)
22#define IRQ_INTD evt2irq(0xa80)
23
Paul Mundta6d377b2009-04-17 20:11:44 +090024/* IDSEL [16][17][18][19][20][21][22][23][24][25][26][27][28][29][30][31] */
25static char sdk7780_irq_tab[4][16] __initdata = {
26 /* INTA */
Paul Mundt58796ce2012-05-18 17:42:29 +090027 { IRQ_INTA, IRQ_INTD, IRQ_INTC, IRQ_INTD, -1, -1, -1, -1, -1, -1,
28 -1, -1, -1, -1, -1, -1 },
Paul Mundta6d377b2009-04-17 20:11:44 +090029 /* INTB */
Paul Mundt58796ce2012-05-18 17:42:29 +090030 { IRQ_INTB, IRQ_INTA, -1, IRQ_INTA, -1, -1, -1, -1, -1, -1, -1, -1,
31 -1, -1, -1, -1 },
Paul Mundta6d377b2009-04-17 20:11:44 +090032 /* INTC */
Paul Mundt58796ce2012-05-18 17:42:29 +090033 { IRQ_INTC, IRQ_INTB, -1, IRQ_INTB, -1, -1, -1, -1, -1, -1, -1, -1,
34 -1, -1, -1, -1 },
Paul Mundta6d377b2009-04-17 20:11:44 +090035 /* INTD */
Paul Mundt58796ce2012-05-18 17:42:29 +090036 { IRQ_INTD, IRQ_INTC, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
37 -1, -1, -1 },
Paul Mundta6d377b2009-04-17 20:11:44 +090038};
39
Ralf Baechled5341942011-06-10 15:30:21 +010040int __init pcibios_map_platform_irq(const struct pci_dev *pdev, u8 slot, u8 pin)
Paul Mundta6d377b2009-04-17 20:11:44 +090041{
42 return sdk7780_irq_tab[pin-1][slot];
43}