2006-12-16 23:04:05 +01:00
/*
* arch / arm / mach - ixp4xx / avila - pci . c
*
* Gateworks Avila board - level PCI initialization
*
* Author : Michael - Luke Jones < mlj28 @ cam . ac . uk >
*
* Based on ixdp - pci . c
* Copyright ( C ) 2002 Intel Corporation .
* Copyright ( C ) 2003 - 2004 MontaVista Software , Inc .
*
* Maintainer : Deepak Saxena < dsaxena @ plexity . net >
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation .
*
*/
# include <linux/kernel.h>
# include <linux/pci.h>
# include <linux/init.h>
# include <linux/irq.h>
# include <linux/delay.h>
# include <asm/mach/pci.h>
# include <asm/irq.h>
2008-08-05 16:14:15 +01:00
# include <mach/hardware.h>
2006-12-16 23:04:05 +01:00
# include <asm/mach-types.h>
2009-11-17 18:48:23 +01:00
# define AVILA_MAX_DEV 4
# define LOFT_MAX_DEV 6
# define IRQ_LINES 4
2009-11-16 15:39:11 +01:00
/* PCI controller GPIO to IRQ pin mappings */
2009-11-17 18:48:23 +01:00
# define INTA 11
# define INTB 10
# define INTC 9
# define INTD 8
2009-11-16 15:39:11 +01:00
2006-12-16 23:04:05 +01:00
void __init avila_pci_preinit ( void )
{
2011-03-24 13:25:22 +01:00
irq_set_irq_type ( IXP4XX_GPIO_IRQ ( INTA ) , IRQ_TYPE_LEVEL_LOW ) ;
irq_set_irq_type ( IXP4XX_GPIO_IRQ ( INTB ) , IRQ_TYPE_LEVEL_LOW ) ;
irq_set_irq_type ( IXP4XX_GPIO_IRQ ( INTC ) , IRQ_TYPE_LEVEL_LOW ) ;
irq_set_irq_type ( IXP4XX_GPIO_IRQ ( INTD ) , IRQ_TYPE_LEVEL_LOW ) ;
2006-12-16 23:04:05 +01:00
ixp4xx_pci_preinit ( ) ;
}
2011-06-10 15:30:21 +01:00
static int __init avila_map_irq ( const struct pci_dev * dev , u8 slot , u8 pin )
2006-12-16 23:04:05 +01:00
{
2009-11-17 18:48:23 +01:00
static int pci_irq_table [ IRQ_LINES ] = {
IXP4XX_GPIO_IRQ ( INTA ) ,
IXP4XX_GPIO_IRQ ( INTB ) ,
IXP4XX_GPIO_IRQ ( INTC ) ,
IXP4XX_GPIO_IRQ ( INTD )
2006-12-16 23:04:05 +01:00
} ;
if ( slot > = 1 & &
2009-11-17 18:48:23 +01:00
slot < = ( machine_is_loft ( ) ? LOFT_MAX_DEV : AVILA_MAX_DEV ) & &
pin > = 1 & & pin < = IRQ_LINES )
return pci_irq_table [ ( slot + pin - 2 ) % 4 ] ;
2006-12-16 23:04:05 +01:00
2009-11-17 18:48:23 +01:00
return - 1 ;
2006-12-16 23:04:05 +01:00
}
struct hw_pci avila_pci __initdata = {
. nr_controllers = 1 ,
2012-03-10 12:49:16 +00:00
. ops = & ixp4xx_ops ,
2006-12-16 23:04:05 +01:00
. preinit = avila_pci_preinit ,
. setup = ixp4xx_setup ,
. map_irq = avila_map_irq ,
} ;
int __init avila_pci_init ( void )
{
if ( machine_is_avila ( ) | | machine_is_loft ( ) )
pci_common_init ( & avila_pci ) ;
return 0 ;
}
subsys_initcall ( avila_pci_init ) ;