2006-09-18 23:24:52 +01:00
/*
* arch / arm / mach - iop33x / iq80332 . c
*
* Board support code for the Intel IQ80332 platform .
*
* Author : Dave Jiang < dave . jiang @ intel . com >
* Copyright ( C ) 2004 Intel Corp .
*
* 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 .
*/
# include <linux/mm.h>
# include <linux/init.h>
# include <linux/kernel.h>
# include <linux/pci.h>
# include <linux/string.h>
# include <linux/serial_core.h>
# include <linux/serial_8250.h>
# include <linux/mtd/physmap.h>
# include <linux/platform_device.h>
2008-09-06 12:10:45 +01:00
# include <linux/io.h>
2008-08-05 16:14:15 +01:00
# include <mach/hardware.h>
2006-09-18 23:24:52 +01:00
# include <asm/irq.h>
# include <asm/mach/arch.h>
# include <asm/mach/map.h>
# include <asm/mach/pci.h>
# include <asm/mach/time.h>
# include <asm/mach-types.h>
# include <asm/page.h>
# include <asm/pgtable.h>
2008-08-05 16:14:15 +01:00
# include <mach/time.h>
2006-09-18 23:24:52 +01:00
/*
* IQ80332 timer tick configuration .
*/
static void __init iq80332_timer_init ( void )
{
/* D-Step parts and the iop333 run at a higher internal bus frequency */
if ( * IOP3XX_ATURID > = 0xa | | * IOP3XX_ATUDID = = 0x374 )
2007-02-13 17:13:34 +01:00
iop_init_time ( 333000000 ) ;
2006-09-18 23:24:52 +01:00
else
2007-02-13 17:13:34 +01:00
iop_init_time ( 266000000 ) ;
2006-09-18 23:24:52 +01:00
}
/*
* IQ80332 PCI .
*/
2007-05-15 01:03:36 +01:00
static int __init
2011-06-10 15:30:21 +01:00
iq80332_pci_map_irq ( const struct pci_dev * dev , u8 slot , u8 pin )
2006-09-18 23:24:52 +01:00
{
int irq ;
if ( slot = = 4 & & pin = = 1 ) {
/* PCI-X Slot INTA */
2006-09-18 23:26:25 +01:00
irq = IRQ_IOP33X_XINT0 ;
2006-09-18 23:24:52 +01:00
} else if ( slot = = 4 & & pin = = 2 ) {
/* PCI-X Slot INTB */
2006-09-18 23:26:25 +01:00
irq = IRQ_IOP33X_XINT1 ;
2006-09-18 23:24:52 +01:00
} else if ( slot = = 4 & & pin = = 3 ) {
/* PCI-X Slot INTC */
2006-09-18 23:26:25 +01:00
irq = IRQ_IOP33X_XINT2 ;
2006-09-18 23:24:52 +01:00
} else if ( slot = = 4 & & pin = = 4 ) {
/* PCI-X Slot INTD */
2006-09-18 23:26:25 +01:00
irq = IRQ_IOP33X_XINT3 ;
2006-09-18 23:24:52 +01:00
} else if ( slot = = 6 ) {
/* GigE */
2006-09-18 23:26:25 +01:00
irq = IRQ_IOP33X_XINT2 ;
2006-09-18 23:24:52 +01:00
} else {
printk ( KERN_ERR " iq80332_pci_map_irq() called for unknown "
" device PCI:%d:%d:%d \n " , dev - > bus - > number ,
PCI_SLOT ( dev - > devfn ) , PCI_FUNC ( dev - > devfn ) ) ;
irq = - 1 ;
}
return irq ;
}
static struct hw_pci iq80332_pci __initdata = {
. nr_controllers = 1 ,
2012-03-10 12:49:16 +00:00
. ops = & iop3xx_ops ,
2006-09-18 23:24:52 +01:00
. setup = iop3xx_pci_setup ,
2008-03-26 19:12:38 -07:00
. preinit = iop3xx_pci_preinit_cond ,
2006-09-18 23:24:52 +01:00
. map_irq = iq80332_pci_map_irq ,
} ;
static int __init iq80332_pci_init ( void )
{
2007-05-02 17:59:44 +01:00
if ( ( iop3xx_get_init_atu ( ) = = IOP3XX_INIT_ATU_ENABLE ) & &
machine_is_iq80332 ( ) )
2006-09-18 23:24:52 +01:00
pci_common_init ( & iq80332_pci ) ;
return 0 ;
}
subsys_initcall ( iq80332_pci_init ) ;
/*
* IQ80332 machine initialisation .
*/
static struct physmap_flash_data iq80332_flash_data = {
. width = 1 ,
} ;
static struct resource iq80332_flash_resource = {
. start = 0xc0000000 ,
. end = 0xc07fffff ,
. flags = IORESOURCE_MEM ,
} ;
static struct platform_device iq80332_flash_device = {
. name = " physmap-flash " ,
. id = 0 ,
. dev = {
. platform_data = & iq80332_flash_data ,
} ,
. num_resources = 1 ,
. resource = & iq80332_flash_resource ,
} ;
static void __init iq80332_init_machine ( void )
{
platform_device_register ( & iop3xx_i2c0_device ) ;
platform_device_register ( & iop3xx_i2c1_device ) ;
platform_device_register ( & iop33x_uart0_device ) ;
platform_device_register ( & iop33x_uart1_device ) ;
platform_device_register ( & iq80332_flash_device ) ;
2007-01-02 13:52:31 -07:00
platform_device_register ( & iop3xx_dma_0_channel ) ;
platform_device_register ( & iop3xx_dma_1_channel ) ;
platform_device_register ( & iop3xx_aau_channel ) ;
2006-09-18 23:24:52 +01:00
}
MACHINE_START ( IQ80332 , " Intel IQ80332 " )
/* Maintainer: Intel Corp. */
2011-07-05 22:38:13 -04:00
. atag_offset = 0x100 ,
2006-09-18 23:24:52 +01:00
. map_io = iop3xx_map_io ,
2006-09-18 23:26:25 +01:00
. init_irq = iop33x_init_irq ,
2012-11-08 12:40:59 -07:00
. init_time = iq80332_timer_init ,
2006-09-18 23:24:52 +01:00
. init_machine = iq80332_init_machine ,
2011-11-05 11:26:32 +00:00
. restart = iop3xx_restart ,
2006-09-18 23:24:52 +01:00
MACHINE_END