2019-05-27 08:55:01 +02:00
// SPDX-License-Identifier: GPL-2.0-or-later
2006-09-18 23:24:52 +01:00
/*
* arch / arm / mach - iop32x / iq80321 . c
*
* Board support code for the Intel IQ80321 platform .
*
* Author : Rory Bolt < rorybolt @ pacbell . net >
* Copyright ( C ) 2002 Rory Bolt
* Copyright ( C ) 2004 Intel Corp .
*/
# 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>
2019-06-01 00:37:56 +02:00
# include <linux/gpio/machine.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>
2019-08-09 18:33:21 +02:00
# include "hardware.h"
# include "irqs.h"
2013-09-09 16:39:51 +02:00
# include "gpio-iop32x.h"
2006-09-18 23:24:52 +01:00
/*
* IQ80321 timer tick configuration .
*/
static void __init iq80321_timer_init ( void )
{
/* 33.333 MHz crystal. */
2007-02-13 17:13:34 +01:00
iop_init_time ( 200000000 ) ;
2006-09-18 23:24:52 +01:00
}
/*
* IQ80321 I / O .
*/
static struct map_desc iq80321_io_desc [ ] __initdata = {
{ /* on-board devices */
. virtual = IQ80321_UART ,
. pfn = __phys_to_pfn ( IQ80321_UART ) ,
. length = 0x00100000 ,
. type = MT_DEVICE ,
} ,
} ;
void __init iq80321_map_io ( void )
{
iop3xx_map_io ( ) ;
iotable_init ( iq80321_io_desc , ARRAY_SIZE ( iq80321_io_desc ) ) ;
}
/*
* IQ80321 PCI .
*/
2007-05-15 01:03:36 +01:00
static int __init
2011-06-10 15:30:21 +01:00
iq80321_pci_map_irq ( const struct pci_dev * dev , u8 slot , u8 pin )
2006-09-18 23:24:52 +01:00
{
int irq ;
if ( ( slot = = 2 | | slot = = 6 ) & & pin = = 1 ) {
/* PCI-X Slot INTA */
2006-09-18 23:26:25 +01:00
irq = IRQ_IOP32X_XINT2 ;
2006-09-18 23:24:52 +01:00
} else if ( ( slot = = 2 | | slot = = 6 ) & & pin = = 2 ) {
/* PCI-X Slot INTA */
2006-09-18 23:26:25 +01:00
irq = IRQ_IOP32X_XINT3 ;
2006-09-18 23:24:52 +01:00
} else if ( ( slot = = 2 | | slot = = 6 ) & & pin = = 3 ) {
/* PCI-X Slot INTA */
2006-09-18 23:26:25 +01:00
irq = IRQ_IOP32X_XINT0 ;
2006-09-18 23:24:52 +01:00
} else if ( ( slot = = 2 | | slot = = 6 ) & & pin = = 4 ) {
/* PCI-X Slot INTA */
2006-09-18 23:26:25 +01:00
irq = IRQ_IOP32X_XINT1 ;
2006-09-18 23:24:52 +01:00
} else if ( slot = = 4 | | slot = = 8 ) {
/* Gig-E */
2006-09-18 23:26:25 +01:00
irq = IRQ_IOP32X_XINT0 ;
2006-09-18 23:24:52 +01:00
} else {
printk ( KERN_ERR " iq80321_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 iq80321_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 = iq80321_pci_map_irq ,
} ;
static int __init iq80321_pci_init ( void )
{
2007-05-02 17:59:44 +01:00
if ( ( iop3xx_get_init_atu ( ) = = IOP3XX_INIT_ATU_ENABLE ) & &
machine_is_iq80321 ( ) )
2006-09-18 23:24:52 +01:00
pci_common_init ( & iq80321_pci ) ;
return 0 ;
}
subsys_initcall ( iq80321_pci_init ) ;
/*
* IQ80321 machine initialisation .
*/
static struct physmap_flash_data iq80321_flash_data = {
. width = 1 ,
} ;
static struct resource iq80321_flash_resource = {
. start = 0xf0000000 ,
. end = 0xf07fffff ,
. flags = IORESOURCE_MEM ,
} ;
static struct platform_device iq80321_flash_device = {
. name = " physmap-flash " ,
. id = 0 ,
. dev = {
. platform_data = & iq80321_flash_data ,
} ,
. num_resources = 1 ,
. resource = & iq80321_flash_resource ,
} ;
static struct plat_serial8250_port iq80321_serial_port [ ] = {
{
. mapbase = IQ80321_UART ,
. membase = ( char * ) IQ80321_UART ,
2006-09-18 23:26:25 +01:00
. irq = IRQ_IOP32X_XINT1 ,
2006-09-18 23:24:52 +01:00
. flags = UPF_SKIP_TEST ,
. iotype = UPIO_MEM ,
. regshift = 0 ,
. uartclk = 1843200 ,
} ,
{ } ,
} ;
static struct resource iq80321_uart_resource = {
. start = IQ80321_UART ,
. end = IQ80321_UART + 7 ,
. flags = IORESOURCE_MEM ,
} ;
static struct platform_device iq80321_serial_device = {
. name = " serial8250 " ,
. id = PLAT8250_DEV_PLATFORM ,
. dev = {
. platform_data = iq80321_serial_port ,
} ,
. num_resources = 1 ,
. resource = & iq80321_uart_resource ,
} ;
static void __init iq80321_init_machine ( void )
{
2013-09-09 16:39:51 +02:00
register_iop32x_gpio ( ) ;
2019-06-01 00:37:56 +02:00
gpiod_add_lookup_table ( & iop3xx_i2c0_gpio_lookup ) ;
gpiod_add_lookup_table ( & iop3xx_i2c1_gpio_lookup ) ;
2006-09-18 23:24:52 +01:00
platform_device_register ( & iop3xx_i2c0_device ) ;
platform_device_register ( & iop3xx_i2c1_device ) ;
platform_device_register ( & iq80321_flash_device ) ;
platform_device_register ( & iq80321_serial_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 ( IQ80321 , " Intel IQ80321 " )
/* Maintainer: Intel Corp. */
2011-07-05 22:38:12 -04:00
. atag_offset = 0x100 ,
2006-09-18 23:24:52 +01:00
. map_io = iq80321_map_io ,
2006-09-18 23:26:25 +01:00
. init_irq = iop32x_init_irq ,
2012-11-08 12:40:59 -07:00
. init_time = iq80321_timer_init ,
2006-09-18 23:24:52 +01:00
. init_machine = iq80321_init_machine ,
2011-11-05 11:26:32 +00:00
. restart = iop3xx_restart ,
2006-09-18 23:24:52 +01:00
MACHINE_END