1/* 2 * arch/arm/mach-pxa/include/mach/viper.h 3 * 4 * Author: Ian Campbell 5 * Created: Feb 03, 2003 6 * Copyright: Arcom Control Systems. 7 * 8 * Maintained by Marc Zyngier <maz@misterjones.org> 9 * <marc.zyngier@altran.com> 10 * 11 * Created based on lubbock.h: 12 * Author: Nicolas Pitre 13 * Created: Jun 15, 2001 14 * Copyright: MontaVista Software Inc. 15 * 16 * This program is free software; you can redistribute it and/or modify 17 * it under the terms of the GNU General Public License version 2 as 18 * published by the Free Software Foundation. 19 */ 20 21#ifndef ARCH_VIPER_H 22#define ARCH_VIPER_H 23 24#define VIPER_BOOT_PHYS PXA_CS0_PHYS 25#define VIPER_FLASH_PHYS PXA_CS1_PHYS 26#define VIPER_ETH_PHYS PXA_CS2_PHYS 27#define VIPER_USB_PHYS PXA_CS3_PHYS 28#define VIPER_ETH_DATA_PHYS PXA_CS4_PHYS 29#define VIPER_CPLD_PHYS PXA_CS5_PHYS 30 31#define VIPER_CPLD_BASE (0xf0000000) 32#define VIPER_PC104IO_BASE (0xf1000000) 33#define VIPER_USB_BASE (0xf1800000) 34 35#define VIPER_ETH_GPIO (0) 36#define VIPER_CPLD_GPIO (1) 37#define VIPER_USB_GPIO (2) 38#define VIPER_UARTA_GPIO (4) 39#define VIPER_UARTB_GPIO (3) 40#define VIPER_CF_CD_GPIO (32) 41#define VIPER_CF_RDY_GPIO (8) 42#define VIPER_BCKLIGHT_EN_GPIO (9) 43#define VIPER_LCD_EN_GPIO (10) 44#define VIPER_PSU_DATA_GPIO (6) 45#define VIPER_PSU_CLK_GPIO (11) 46#define VIPER_UART_SHDN_GPIO (12) 47#define VIPER_BRIGHTNESS_GPIO (16) 48#define VIPER_PSU_nCS_LD_GPIO (19) 49#define VIPER_UPS_GPIO (20) 50#define VIPER_CF_POWER_GPIO (82) 51#define VIPER_TPM_I2C_SDA_GPIO (26) 52#define VIPER_TPM_I2C_SCL_GPIO (27) 53#define VIPER_RTC_I2C_SDA_GPIO (83) 54#define VIPER_RTC_I2C_SCL_GPIO (84) 55 56#define VIPER_CPLD_P2V(x) ((x) - VIPER_CPLD_PHYS + VIPER_CPLD_BASE) 57#define VIPER_CPLD_V2P(x) ((x) - VIPER_CPLD_BASE + VIPER_CPLD_PHYS) 58 59#ifndef __ASSEMBLY__ 60# define __VIPER_CPLD_REG(x) (*((volatile u16 *)VIPER_CPLD_P2V(x))) 61#endif 62 63/* board level registers in the CPLD: (offsets from CPLD_BASE) ... */ 64 65/* ... Physical addresses */ 66#define _VIPER_LO_IRQ_STATUS (VIPER_CPLD_PHYS + 0x100000) 67#define _VIPER_ICR_PHYS (VIPER_CPLD_PHYS + 0x100002) 68#define _VIPER_HI_IRQ_STATUS (VIPER_CPLD_PHYS + 0x100004) 69#define _VIPER_VERSION_PHYS (VIPER_CPLD_PHYS + 0x100006) 70#define VIPER_UARTA_PHYS (VIPER_CPLD_PHYS + 0x300010) 71#define VIPER_UARTB_PHYS (VIPER_CPLD_PHYS + 0x300000) 72#define _VIPER_SRAM_BASE (VIPER_CPLD_PHYS + 0x800000) 73 74/* ... Virtual addresses */ 75#define VIPER_LO_IRQ_STATUS __VIPER_CPLD_REG(_VIPER_LO_IRQ_STATUS) 76#define VIPER_HI_IRQ_STATUS __VIPER_CPLD_REG(_VIPER_HI_IRQ_STATUS) 77#define VIPER_VERSION __VIPER_CPLD_REG(_VIPER_VERSION_PHYS) 78#define VIPER_ICR __VIPER_CPLD_REG(_VIPER_ICR_PHYS) 79 80/* Decode VIPER_VERSION register */ 81#define VIPER_CPLD_REVISION(x) (((x) >> 5) & 0x7) 82#define VIPER_BOARD_VERSION(x) (((x) >> 3) & 0x3) 83#define VIPER_BOARD_ISSUE(x) (((x) >> 0) & 0x7) 84 85/* Interrupt and Configuration Register (VIPER_ICR) */ 86/* This is a write only register. Only CF_RST is used under Linux */ 87 88#define VIPER_ICR_RETRIG (1 << 0) 89#define VIPER_ICR_AUTO_CLR (1 << 1) 90#define VIPER_ICR_R_DIS (1 << 2) 91#define VIPER_ICR_CF_RST (1 << 3) 92 93#endif 94 95