2005-04-17 02:20:36 +04:00
/*
* arch / arm / mach - ixp4xx / gtwx5715 - pci . c
*
* Gemtek GTWX5715 ( Linksys WRV54G ) board setup
*
* Copyright ( C ) 2004 George T . Joseph
* Derived from Coyote
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation ; either version 2
* of the License , or ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 59 Temple Place - Suite 330 , Boston , MA 02111 - 1307 , USA .
*
*/
# include <linux/pci.h>
# include <linux/init.h>
# include <linux/delay.h>
2007-05-31 15:27:14 +04:00
# include <linux/irq.h>
2005-04-17 02:20:36 +04:00
# include <asm/mach-types.h>
2008-08-05 19:14:15 +04:00
# include <mach/hardware.h>
2005-04-17 02:20:36 +04:00
# include <asm/mach/pci.h>
2009-11-17 20:48:23 +03:00
# define SLOT0_DEVID 0
# define SLOT1_DEVID 1
2009-11-18 02:39:01 +03:00
# define INTA 10 /* slot 1 has INTA and INTB crossed */
# define INTB 11
2009-11-17 01:24:57 +03:00
2005-08-30 01:46:30 +04:00
/*
* Slot 0 isn ' t actually populated with a card connector but
* we initialize it anyway in case a future version has the
* slot populated or someone with good soldering skills has
* some free time .
*/
2005-04-17 02:20:36 +04:00
void __init gtwx5715_pci_preinit ( void )
{
2009-11-18 02:39:01 +03:00
set_irq_type ( IXP4XX_GPIO_IRQ ( INTA ) , IRQ_TYPE_LEVEL_LOW ) ;
set_irq_type ( IXP4XX_GPIO_IRQ ( INTB ) , IRQ_TYPE_LEVEL_LOW ) ;
2005-04-17 02:20:36 +04:00
ixp4xx_pci_preinit ( ) ;
}
static int __init gtwx5715_map_irq ( struct pci_dev * dev , u8 slot , u8 pin )
{
2009-11-18 02:39:01 +03:00
int rc = - 1 ;
2005-04-17 02:20:36 +04:00
2009-11-18 02:39:01 +03:00
if ( ( slot = = SLOT0_DEVID & & pin = = 1 ) | |
( slot = = SLOT1_DEVID & & pin = = 2 ) )
rc = IXP4XX_GPIO_IRQ ( INTA ) ;
else if ( ( slot = = SLOT0_DEVID & & pin = = 2 ) | |
( slot = = SLOT1_DEVID & & pin = = 1 ) )
rc = IXP4XX_GPIO_IRQ ( INTB ) ;
2005-04-17 02:20:36 +04:00
2009-11-17 20:48:23 +03:00
printk ( KERN_INFO " %s: Mapped slot %d pin %d to IRQ %d \n " ,
__func__ , slot , pin , rc ) ;
return rc ;
2005-04-17 02:20:36 +04:00
}
struct hw_pci gtwx5715_pci __initdata = {
. nr_controllers = 1 ,
. preinit = gtwx5715_pci_preinit ,
. swizzle = pci_std_swizzle ,
. setup = ixp4xx_setup ,
. scan = ixp4xx_scan_bus ,
. map_irq = gtwx5715_map_irq ,
} ;
int __init gtwx5715_pci_init ( void )
{
if ( machine_is_gtwx5715 ( ) )
pci_common_init ( & gtwx5715_pci ) ;
return 0 ;
}
subsys_initcall ( gtwx5715_pci_init ) ;