linux/arch/arm/mach-pxa/include/mach/viper.h
<<
>>
Prefs
   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