2019-06-04 10:11:33 +02:00
/* SPDX-License-Identifier: GPL-2.0-only */
2008-08-14 17:20:31 +02:00
/*
* arch / arm / mach - pxa / include / mach / viper . h
*
* Author : Ian Campbell
* Created : Feb 03 , 2003
* Copyright : Arcom Control Systems .
*
* Maintained by Marc Zyngier < maz @ misterjones . org >
* < marc . zyngier @ altran . com >
*
* Created based on lubbock . h :
* Author : Nicolas Pitre
* Created : Jun 15 , 2001
* Copyright : MontaVista Software Inc .
*/
# ifndef ARCH_VIPER_H
# define ARCH_VIPER_H
# define VIPER_BOOT_PHYS PXA_CS0_PHYS
# define VIPER_FLASH_PHYS PXA_CS1_PHYS
# define VIPER_ETH_PHYS PXA_CS2_PHYS
# define VIPER_USB_PHYS PXA_CS3_PHYS
# define VIPER_ETH_DATA_PHYS PXA_CS4_PHYS
# define VIPER_CPLD_PHYS PXA_CS5_PHYS
# define VIPER_CPLD_BASE (0xf0000000)
# define VIPER_PC104IO_BASE (0xf1000000)
# define VIPER_USB_BASE (0xf1800000)
# define VIPER_ETH_GPIO (0)
# define VIPER_CPLD_GPIO (1)
# define VIPER_USB_GPIO (2)
# define VIPER_UARTA_GPIO (4)
# define VIPER_UARTB_GPIO (3)
# define VIPER_CF_CD_GPIO (32)
# define VIPER_CF_RDY_GPIO (8)
# define VIPER_BCKLIGHT_EN_GPIO (9)
# define VIPER_LCD_EN_GPIO (10)
# define VIPER_PSU_DATA_GPIO (6)
# define VIPER_PSU_CLK_GPIO (11)
# define VIPER_UART_SHDN_GPIO (12)
# define VIPER_BRIGHTNESS_GPIO (16)
# define VIPER_PSU_nCS_LD_GPIO (19)
# define VIPER_UPS_GPIO (20)
# define VIPER_CF_POWER_GPIO (82)
# define VIPER_TPM_I2C_SDA_GPIO (26)
# define VIPER_TPM_I2C_SCL_GPIO (27)
# define VIPER_RTC_I2C_SDA_GPIO (83)
# define VIPER_RTC_I2C_SCL_GPIO (84)
# define VIPER_CPLD_P2V(x) ((x) - VIPER_CPLD_PHYS + VIPER_CPLD_BASE)
# define VIPER_CPLD_V2P(x) ((x) - VIPER_CPLD_BASE + VIPER_CPLD_PHYS)
# ifndef __ASSEMBLY__
# define __VIPER_CPLD_REG(x) (*((volatile u16 *)VIPER_CPLD_P2V(x)))
# endif
/* board level registers in the CPLD: (offsets from CPLD_BASE) ... */
/* ... Physical addresses */
# define _VIPER_LO_IRQ_STATUS (VIPER_CPLD_PHYS + 0x100000)
# define _VIPER_ICR_PHYS (VIPER_CPLD_PHYS + 0x100002)
# define _VIPER_HI_IRQ_STATUS (VIPER_CPLD_PHYS + 0x100004)
# define _VIPER_VERSION_PHYS (VIPER_CPLD_PHYS + 0x100006)
# define VIPER_UARTA_PHYS (VIPER_CPLD_PHYS + 0x300010)
# define VIPER_UARTB_PHYS (VIPER_CPLD_PHYS + 0x300000)
# define _VIPER_SRAM_BASE (VIPER_CPLD_PHYS + 0x800000)
/* ... Virtual addresses */
# define VIPER_LO_IRQ_STATUS __VIPER_CPLD_REG(_VIPER_LO_IRQ_STATUS)
# define VIPER_HI_IRQ_STATUS __VIPER_CPLD_REG(_VIPER_HI_IRQ_STATUS)
# define VIPER_VERSION __VIPER_CPLD_REG(_VIPER_VERSION_PHYS)
# define VIPER_ICR __VIPER_CPLD_REG(_VIPER_ICR_PHYS)
/* Decode VIPER_VERSION register */
# define VIPER_CPLD_REVISION(x) (((x) >> 5) & 0x7)
# define VIPER_BOARD_VERSION(x) (((x) >> 3) & 0x3)
# define VIPER_BOARD_ISSUE(x) (((x) >> 0) & 0x7)
/* Interrupt and Configuration Register (VIPER_ICR) */
/* This is a write only register. Only CF_RST is used under Linux */
# define VIPER_ICR_RETRIG (1 << 0)
# define VIPER_ICR_AUTO_CLR (1 << 1)
# define VIPER_ICR_R_DIS (1 << 2)
# define VIPER_ICR_CF_RST (1 << 3)
# endif