mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 07:00:48 +00:00
d2912cb15b
Based on 2 normalized pattern(s): this program is free software you can redistribute it and or modify it under the terms of the gnu general public license version 2 as published by the free software foundation this program is free software you can redistribute it and or modify it under the terms of the gnu general public license version 2 as published by the free software foundation # extracted by the scancode license scanner the SPDX license identifier GPL-2.0-only has been chosen to replace the boilerplate/reference in 4122 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Enrico Weigelt <info@metux.net> Reviewed-by: Kate Stewart <kstewart@linuxfoundation.org> Reviewed-by: Allison Randal <allison@lohutok.net> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190604081206.933168790@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
92 lines
2.8 KiB
C
92 lines
2.8 KiB
C
/* 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
|
|
|