hc
2024-12-19 9370bb92b2d16684ee45cf24e879c93c509162da
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * 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