Path: blob/master/arch/arm/mach-ixp23xx/include/mach/ixp23xx.h
15157 views
/*1* arch/arm/mach-ixp23xx/include/mach/ixp23xx.h2*3* Register definitions for IXP23XX4*5* Copyright (C) 2003-2005 Intel Corporation.6* Copyright (C) 2005 MontaVista Software, Inc.7*8* Maintainer: Deepak Saxena <[email protected]>9*10* This program is free software; you can redistribute it and/or modify11* it under the terms of the GNU General Public License version 2 as12* published by the Free Software Foundation.13*/1415#ifndef __ASM_ARCH_IXP23XX_H16#define __ASM_ARCH_IXP23XX_H1718/*19* IXP2300 linux memory map:20*21* virt phys size22* fffd0000 a0000000 64K XSI2CPP_CSR23* fffc0000 c4000000 4K EXP_CFG24* fff00000 c8000000 64K PERIPHERAL25* fe000000 1c0000000 16M CAP_CSR26* fd000000 1c8000000 16M MSF_CSR27* fb000000 16M ---28* fa000000 1d8000000 32M PCI_IO29* f8000000 1da000000 32M PCI_CFG30* f6000000 1de000000 32M PCI_CREG31* f4000000 32M ---32* f0000000 1e0000000 64M PCI_MEM33* e[c-f]000000 per-platform mappings34*/353637/****************************************************************************38* Static mappings.39****************************************************************************/40#define IXP23XX_XSI2CPP_CSR_PHYS 0xa000000041#define IXP23XX_XSI2CPP_CSR_VIRT 0xfffd000042#define IXP23XX_XSI2CPP_CSR_SIZE 0x000100004344#define IXP23XX_EXP_CFG_PHYS 0xc400000045#define IXP23XX_EXP_CFG_VIRT 0xfffc000046#define IXP23XX_EXP_CFG_SIZE 0x000010004748#define IXP23XX_PERIPHERAL_PHYS 0xc800000049#define IXP23XX_PERIPHERAL_VIRT 0xfff0000050#define IXP23XX_PERIPHERAL_SIZE 0x000100005152#define IXP23XX_CAP_CSR_PHYS 0x1c0000000ULL53#define IXP23XX_CAP_CSR_VIRT 0xfe00000054#define IXP23XX_CAP_CSR_SIZE 0x010000005556#define IXP23XX_MSF_CSR_PHYS 0x1c8000000ULL57#define IXP23XX_MSF_CSR_VIRT 0xfd00000058#define IXP23XX_MSF_CSR_SIZE 0x010000005960#define IXP23XX_PCI_IO_PHYS 0x1d8000000ULL61#define IXP23XX_PCI_IO_VIRT 0xfa00000062#define IXP23XX_PCI_IO_SIZE 0x020000006364#define IXP23XX_PCI_CFG_PHYS 0x1da000000ULL65#define IXP23XX_PCI_CFG_VIRT 0xf800000066#define IXP23XX_PCI_CFG_SIZE 0x0200000067#define IXP23XX_PCI_CFG0_VIRT IXP23XX_PCI_CFG_VIRT68#define IXP23XX_PCI_CFG1_VIRT (IXP23XX_PCI_CFG_VIRT + 0x01000000)6970#define IXP23XX_PCI_CREG_PHYS 0x1de000000ULL71#define IXP23XX_PCI_CREG_VIRT 0xf600000072#define IXP23XX_PCI_CREG_SIZE 0x0200000073#define IXP23XX_PCI_CSR_VIRT (IXP23XX_PCI_CREG_VIRT + 0x01000000)7475#define IXP23XX_PCI_MEM_START 0xe000000076#define IXP23XX_PCI_MEM_PHYS 0x1e0000000ULL77#define IXP23XX_PCI_MEM_VIRT 0xf000000078#define IXP23XX_PCI_MEM_SIZE 0x04000000798081/****************************************************************************82* XSI2CPP CSRs.83****************************************************************************/84#define IXP23XX_XSI2CPP_REG(x) ((volatile unsigned long *)(IXP23XX_XSI2CPP_CSR_VIRT + (x)))85#define IXP23XX_CPP2XSI_CURR_XFER_REG3 IXP23XX_XSI2CPP_REG(0xf8)86#define IXP23XX_CPP2XSI_ADDR_31 (1 << 19)87#define IXP23XX_CPP2XSI_PSH_OFF (1 << 20)88#define IXP23XX_CPP2XSI_COH_OFF (1 << 21)899091/****************************************************************************92* Expansion Bus Config.93****************************************************************************/94#define IXP23XX_EXP_CFG_REG(x) ((volatile unsigned long *)(IXP23XX_EXP_CFG_VIRT + (x)))95#define IXP23XX_EXP_CS0 IXP23XX_EXP_CFG_REG(0x00)96#define IXP23XX_EXP_CS1 IXP23XX_EXP_CFG_REG(0x04)97#define IXP23XX_EXP_CS2 IXP23XX_EXP_CFG_REG(0x08)98#define IXP23XX_EXP_CS3 IXP23XX_EXP_CFG_REG(0x0c)99#define IXP23XX_EXP_CS4 IXP23XX_EXP_CFG_REG(0x10)100#define IXP23XX_EXP_CS5 IXP23XX_EXP_CFG_REG(0x14)101#define IXP23XX_EXP_CS6 IXP23XX_EXP_CFG_REG(0x18)102#define IXP23XX_EXP_CS7 IXP23XX_EXP_CFG_REG(0x1c)103#define IXP23XX_FLASH_WRITABLE (0x2)104#define IXP23XX_FLASH_BUS8 (0x1)105106#define IXP23XX_EXP_CFG0 IXP23XX_EXP_CFG_REG(0x20)107#define IXP23XX_EXP_CFG1 IXP23XX_EXP_CFG_REG(0x24)108#define IXP23XX_EXP_CFG0_MEM_MAP (1 << 31)109#define IXP23XX_EXP_CFG0_XSCALE_SPEED_SEL (3 << 22)110#define IXP23XX_EXP_CFG0_XSCALE_SPEED_EN (1 << 21)111#define IXP23XX_EXP_CFG0_CPP_SPEED_SEL (3 << 19)112#define IXP23XX_EXP_CFG0_CPP_SPEED_EN (1 << 18)113#define IXP23XX_EXP_CFG0_PCI_SWIN (3 << 16)114#define IXP23XX_EXP_CFG0_PCI_DWIN (3 << 14)115#define IXP23XX_EXP_CFG0_PCI33_MODE (1 << 13)116#define IXP23XX_EXP_CFG0_QDR_SPEED_SEL (1 << 12)117#define IXP23XX_EXP_CFG0_CPP_DIV_SEL (1 << 5)118#define IXP23XX_EXP_CFG0_XSI_NOT_PRES (1 << 4)119#define IXP23XX_EXP_CFG0_PROM_BOOT (1 << 3)120#define IXP23XX_EXP_CFG0_PCI_ARB (1 << 2)121#define IXP23XX_EXP_CFG0_PCI_HOST (1 << 1)122#define IXP23XX_EXP_CFG0_FLASH_WIDTH (1 << 0)123124#define IXP23XX_EXP_UNIT_FUSE IXP23XX_EXP_CFG_REG(0x28)125#define IXP23XX_EXP_MSF_MUX IXP23XX_EXP_CFG_REG(0x30)126#define IXP23XX_EXP_CFG_FUSE IXP23XX_EXP_CFG_REG(0x34)127128#define IXP23XX_EXP_BUS_PHYS 0x90000000129#define IXP23XX_EXP_BUS_WINDOW_SIZE 0x01000000130131#define IXP23XX_EXP_BUS_CS0_BASE (IXP23XX_EXP_BUS_PHYS + 0x00000000)132#define IXP23XX_EXP_BUS_CS1_BASE (IXP23XX_EXP_BUS_PHYS + 0x01000000)133#define IXP23XX_EXP_BUS_CS2_BASE (IXP23XX_EXP_BUS_PHYS + 0x02000000)134#define IXP23XX_EXP_BUS_CS3_BASE (IXP23XX_EXP_BUS_PHYS + 0x03000000)135#define IXP23XX_EXP_BUS_CS4_BASE (IXP23XX_EXP_BUS_PHYS + 0x04000000)136#define IXP23XX_EXP_BUS_CS5_BASE (IXP23XX_EXP_BUS_PHYS + 0x05000000)137#define IXP23XX_EXP_BUS_CS6_BASE (IXP23XX_EXP_BUS_PHYS + 0x06000000)138#define IXP23XX_EXP_BUS_CS7_BASE (IXP23XX_EXP_BUS_PHYS + 0x07000000)139140141/****************************************************************************142* Peripherals.143****************************************************************************/144#define IXP23XX_UART1_VIRT (IXP23XX_PERIPHERAL_VIRT + 0x0000)145#define IXP23XX_UART2_VIRT (IXP23XX_PERIPHERAL_VIRT + 0x1000)146#define IXP23XX_PMU_VIRT (IXP23XX_PERIPHERAL_VIRT + 0x2000)147#define IXP23XX_INTC_VIRT (IXP23XX_PERIPHERAL_VIRT + 0x3000)148#define IXP23XX_GPIO_VIRT (IXP23XX_PERIPHERAL_VIRT + 0x4000)149#define IXP23XX_TIMER_VIRT (IXP23XX_PERIPHERAL_VIRT + 0x5000)150#define IXP23XX_NPE0_VIRT (IXP23XX_PERIPHERAL_VIRT + 0x6000)151#define IXP23XX_DSR_VIRT (IXP23XX_PERIPHERAL_VIRT + 0x7000)152#define IXP23XX_NPE1_VIRT (IXP23XX_PERIPHERAL_VIRT + 0x8000)153#define IXP23XX_ETH0_VIRT (IXP23XX_PERIPHERAL_VIRT + 0x9000)154#define IXP23XX_ETH1_VIRT (IXP23XX_PERIPHERAL_VIRT + 0xA000)155#define IXP23XX_GIG0_VIRT (IXP23XX_PERIPHERAL_VIRT + 0xB000)156#define IXP23XX_GIG1_VIRT (IXP23XX_PERIPHERAL_VIRT + 0xC000)157#define IXP23XX_DDRS_VIRT (IXP23XX_PERIPHERAL_VIRT + 0xD000)158159#define IXP23XX_UART1_PHYS (IXP23XX_PERIPHERAL_PHYS + 0x0000)160#define IXP23XX_UART2_PHYS (IXP23XX_PERIPHERAL_PHYS + 0x1000)161#define IXP23XX_PMU_PHYS (IXP23XX_PERIPHERAL_PHYS + 0x2000)162#define IXP23XX_INTC_PHYS (IXP23XX_PERIPHERAL_PHYS + 0x3000)163#define IXP23XX_GPIO_PHYS (IXP23XX_PERIPHERAL_PHYS + 0x4000)164#define IXP23XX_TIMER_PHYS (IXP23XX_PERIPHERAL_PHYS + 0x5000)165#define IXP23XX_NPE0_PHYS (IXP23XX_PERIPHERAL_PHYS + 0x6000)166#define IXP23XX_DSR_PHYS (IXP23XX_PERIPHERAL_PHYS + 0x7000)167#define IXP23XX_NPE1_PHYS (IXP23XX_PERIPHERAL_PHYS + 0x8000)168#define IXP23XX_ETH0_PHYS (IXP23XX_PERIPHERAL_PHYS + 0x9000)169#define IXP23XX_ETH1_PHYS (IXP23XX_PERIPHERAL_PHYS + 0xA000)170#define IXP23XX_GIG0_PHYS (IXP23XX_PERIPHERAL_PHYS + 0xB000)171#define IXP23XX_GIG1_PHYS (IXP23XX_PERIPHERAL_PHYS + 0xC000)172#define IXP23XX_DDRS_PHYS (IXP23XX_PERIPHERAL_PHYS + 0xD000)173174175/****************************************************************************176* Interrupt controller.177****************************************************************************/178#define IXP23XX_INTC_REG(x) ((volatile unsigned long *)(IXP23XX_INTC_VIRT + (x)))179#define IXP23XX_INTR_ST1 IXP23XX_INTC_REG(0x00)180#define IXP23XX_INTR_ST2 IXP23XX_INTC_REG(0x04)181#define IXP23XX_INTR_ST3 IXP23XX_INTC_REG(0x08)182#define IXP23XX_INTR_ST4 IXP23XX_INTC_REG(0x0c)183#define IXP23XX_INTR_EN1 IXP23XX_INTC_REG(0x10)184#define IXP23XX_INTR_EN2 IXP23XX_INTC_REG(0x14)185#define IXP23XX_INTR_EN3 IXP23XX_INTC_REG(0x18)186#define IXP23XX_INTR_EN4 IXP23XX_INTC_REG(0x1c)187#define IXP23XX_INTR_SEL1 IXP23XX_INTC_REG(0x20)188#define IXP23XX_INTR_SEL2 IXP23XX_INTC_REG(0x24)189#define IXP23XX_INTR_SEL3 IXP23XX_INTC_REG(0x28)190#define IXP23XX_INTR_SEL4 IXP23XX_INTC_REG(0x2c)191#define IXP23XX_INTR_IRQ_ST1 IXP23XX_INTC_REG(0x30)192#define IXP23XX_INTR_IRQ_ST2 IXP23XX_INTC_REG(0x34)193#define IXP23XX_INTR_IRQ_ST3 IXP23XX_INTC_REG(0x38)194#define IXP23XX_INTR_IRQ_ST4 IXP23XX_INTC_REG(0x3c)195#define IXP23XX_INTR_IRQ_ENC_ST_OFFSET 0x54196197198/****************************************************************************199* GPIO.200****************************************************************************/201#define IXP23XX_GPIO_REG(x) ((volatile unsigned long *)(IXP23XX_GPIO_VIRT + (x)))202#define IXP23XX_GPIO_GPOUTR IXP23XX_GPIO_REG(0x00)203#define IXP23XX_GPIO_GPOER IXP23XX_GPIO_REG(0x04)204#define IXP23XX_GPIO_GPINR IXP23XX_GPIO_REG(0x08)205#define IXP23XX_GPIO_GPISR IXP23XX_GPIO_REG(0x0c)206#define IXP23XX_GPIO_GPIT1R IXP23XX_GPIO_REG(0x10)207#define IXP23XX_GPIO_GPIT2R IXP23XX_GPIO_REG(0x14)208#define IXP23XX_GPIO_GPCLKR IXP23XX_GPIO_REG(0x18)209#define IXP23XX_GPIO_GPDBSELR IXP23XX_GPIO_REG(0x1c)210211#define IXP23XX_GPIO_STYLE_MASK 0x7212#define IXP23XX_GPIO_STYLE_ACTIVE_HIGH 0x0213#define IXP23XX_GPIO_STYLE_ACTIVE_LOW 0x1214#define IXP23XX_GPIO_STYLE_RISING_EDGE 0x2215#define IXP23XX_GPIO_STYLE_FALLING_EDGE 0x3216#define IXP23XX_GPIO_STYLE_TRANSITIONAL 0x4217218#define IXP23XX_GPIO_STYLE_SIZE 3219220221/****************************************************************************222* Timer.223****************************************************************************/224#define IXP23XX_TIMER_REG(x) ((volatile unsigned long *)(IXP23XX_TIMER_VIRT + (x)))225#define IXP23XX_TIMER_CONT IXP23XX_TIMER_REG(0x00)226#define IXP23XX_TIMER1_TIMESTAMP IXP23XX_TIMER_REG(0x04)227#define IXP23XX_TIMER1_RELOAD IXP23XX_TIMER_REG(0x08)228#define IXP23XX_TIMER2_TIMESTAMP IXP23XX_TIMER_REG(0x0c)229#define IXP23XX_TIMER2_RELOAD IXP23XX_TIMER_REG(0x10)230#define IXP23XX_TIMER_WDOG IXP23XX_TIMER_REG(0x14)231#define IXP23XX_TIMER_WDOG_EN IXP23XX_TIMER_REG(0x18)232#define IXP23XX_TIMER_WDOG_KEY IXP23XX_TIMER_REG(0x1c)233#define IXP23XX_TIMER_WDOG_KEY_MAGIC 0x482e234#define IXP23XX_TIMER_STATUS IXP23XX_TIMER_REG(0x20)235#define IXP23XX_TIMER_SOFT_RESET IXP23XX_TIMER_REG(0x24)236#define IXP23XX_TIMER_SOFT_RESET_EN IXP23XX_TIMER_REG(0x28)237238#define IXP23XX_TIMER_ENABLE (1 << 0)239#define IXP23XX_TIMER_ONE_SHOT (1 << 1)240/* Low order bits of reload value ignored */241#define IXP23XX_TIMER_RELOAD_MASK (0x3)242#define IXP23XX_TIMER_DISABLED (0x0)243#define IXP23XX_TIMER1_INT_PEND (1 << 0)244#define IXP23XX_TIMER2_INT_PEND (1 << 1)245#define IXP23XX_TIMER_STATUS_TS_PEND (1 << 2)246#define IXP23XX_TIMER_STATUS_WDOG_PEND (1 << 3)247#define IXP23XX_TIMER_STATUS_WARM_RESET (1 << 4)248249250/****************************************************************************251* CAP CSRs.252****************************************************************************/253#define IXP23XX_GLOBAL_REG(x) ((volatile unsigned long *)(IXP23XX_CAP_CSR_VIRT + 0x4a00 + (x)))254#define IXP23XX_PRODUCT_ID IXP23XX_GLOBAL_REG(0x00)255#define IXP23XX_MISC_CONTROL IXP23XX_GLOBAL_REG(0x04)256#define IXP23XX_MSF_CLK_CNTRL IXP23XX_GLOBAL_REG(0x08)257#define IXP23XX_RESET0 IXP23XX_GLOBAL_REG(0x0c)258#define IXP23XX_RESET1 IXP23XX_GLOBAL_REG(0x10)259#define IXP23XX_STRAP_OPTIONS IXP23XX_GLOBAL_REG(0x18)260261#define IXP23XX_ENABLE_WATCHDOG (1 << 24)262#define IXP23XX_SHPC_INIT_COMP (1 << 21)263#define IXP23XX_RST_ALL (1 << 16)264#define IXP23XX_RESET_PCI (1 << 2)265#define IXP23XX_PCI_UNIT_RESET (1 << 1)266#define IXP23XX_XSCALE_RESET (1 << 0)267268#define IXP23XX_UENGINE_CSR_VIRT_BASE (IXP23XX_CAP_CSR_VIRT + 0x18000)269270271/****************************************************************************272* PCI CSRs.273****************************************************************************/274#define IXP23XX_PCI_CREG(x) ((volatile unsigned long *)(IXP23XX_PCI_CREG_VIRT + (x)))275#define IXP23XX_PCI_CMDSTAT IXP23XX_PCI_CREG(0x04)276#define IXP23XX_PCI_SRAM_BAR IXP23XX_PCI_CREG(0x14)277#define IXP23XX_PCI_SDRAM_BAR IXP23XX_PCI_CREG(0x18)278279280#define IXP23XX_PCI_CSR(x) ((volatile unsigned long *)(IXP23XX_PCI_CREG_VIRT + 0x01000000 + (x)))281#define IXP23XX_PCI_OUT_INT_STATUS IXP23XX_PCI_CSR(0x0030)282#define IXP23XX_PCI_OUT_INT_MASK IXP23XX_PCI_CSR(0x0034)283#define IXP23XX_PCI_SRAM_BASE_ADDR_MASK IXP23XX_PCI_CSR(0x00fc)284#define IXP23XX_PCI_DRAM_BASE_ADDR_MASK IXP23XX_PCI_CSR(0x0100)285#define IXP23XX_PCI_CONTROL IXP23XX_PCI_CSR(0x013c)286#define IXP23XX_PCI_ADDR_EXT IXP23XX_PCI_CSR(0x0140)287#define IXP23XX_PCI_ME_PUSH_STATUS IXP23XX_PCI_CSR(0x0148)288#define IXP23XX_PCI_ME_PUSH_EN IXP23XX_PCI_CSR(0x014c)289#define IXP23XX_PCI_ERR_STATUS IXP23XX_PCI_CSR(0x0150)290#define IXP23XX_PCI_ERROR_STATUS IXP23XX_PCI_CSR(0x0150)291#define IXP23XX_PCI_ERR_ENABLE IXP23XX_PCI_CSR(0x0154)292#define IXP23XX_PCI_XSCALE_INT_STATUS IXP23XX_PCI_CSR(0x0158)293#define IXP23XX_PCI_XSCALE_INT_ENABLE IXP23XX_PCI_CSR(0x015c)294#define IXP23XX_PCI_CPP_ADDR_BITS IXP23XX_PCI_CSR(0x0160)295296297#endif298299300