cregit-Linux how code gets into the kernel

Release 4.11 arch/arm/mach-pxa/viper.h

/*
 * 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.
 *
 * 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.
 */

#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


Overall Contributors

PersonTokensPropCommitsCommitProp
Marc Zyngier238100.00%1100.00%
Total238100.00%1100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.