7f30491ccd
After moving the the include files there were a few clean-ups: 1) Some files used #include <asm-ia64/xyz.h>, changed to <asm/xyz.h> 2) Some comments alerted maintainers to look at various header files to make matching updates if certain code were to be changed. Updated these comments to use the new include paths. 3) Some header files mentioned their own names in initial comments. Just deleted these self references. Signed-off-by: Tony Luck <tony.luck@intel.com>
503 lines
26 KiB
C
503 lines
26 KiB
C
/*
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
* for more details.
|
|
*
|
|
* Copyright (c) 2001-2005 Silicon Graphics, Inc. All rights reserved.
|
|
*/
|
|
|
|
#ifndef _ASM_IA64_SN_SHUB_MMR_H
|
|
#define _ASM_IA64_SN_SHUB_MMR_H
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_IPI_INT" */
|
|
/* SHub Inter-Processor Interrupt Registers */
|
|
/* ==================================================================== */
|
|
#define SH1_IPI_INT __IA64_UL_CONST(0x0000000110000380)
|
|
#define SH2_IPI_INT __IA64_UL_CONST(0x0000000010000380)
|
|
|
|
/* SH_IPI_INT_TYPE */
|
|
/* Description: Type of Interrupt: 0=INT, 2=PMI, 4=NMI, 5=INIT */
|
|
#define SH_IPI_INT_TYPE_SHFT 0
|
|
#define SH_IPI_INT_TYPE_MASK __IA64_UL_CONST(0x0000000000000007)
|
|
|
|
/* SH_IPI_INT_AGT */
|
|
/* Description: Agent, must be 0 for SHub */
|
|
#define SH_IPI_INT_AGT_SHFT 3
|
|
#define SH_IPI_INT_AGT_MASK __IA64_UL_CONST(0x0000000000000008)
|
|
|
|
/* SH_IPI_INT_PID */
|
|
/* Description: Processor ID, same setting as on targeted McKinley */
|
|
#define SH_IPI_INT_PID_SHFT 4
|
|
#define SH_IPI_INT_PID_MASK __IA64_UL_CONST(0x00000000000ffff0)
|
|
|
|
/* SH_IPI_INT_BASE */
|
|
/* Description: Optional interrupt vector area, 2MB aligned */
|
|
#define SH_IPI_INT_BASE_SHFT 21
|
|
#define SH_IPI_INT_BASE_MASK __IA64_UL_CONST(0x0003ffffffe00000)
|
|
|
|
/* SH_IPI_INT_IDX */
|
|
/* Description: Targeted McKinley interrupt vector */
|
|
#define SH_IPI_INT_IDX_SHFT 52
|
|
#define SH_IPI_INT_IDX_MASK __IA64_UL_CONST(0x0ff0000000000000)
|
|
|
|
/* SH_IPI_INT_SEND */
|
|
/* Description: Send Interrupt Message to PI, This generates a puls */
|
|
#define SH_IPI_INT_SEND_SHFT 63
|
|
#define SH_IPI_INT_SEND_MASK __IA64_UL_CONST(0x8000000000000000)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_EVENT_OCCURRED" */
|
|
/* SHub Interrupt Event Occurred */
|
|
/* ==================================================================== */
|
|
#define SH1_EVENT_OCCURRED __IA64_UL_CONST(0x0000000110010000)
|
|
#define SH1_EVENT_OCCURRED_ALIAS __IA64_UL_CONST(0x0000000110010008)
|
|
#define SH2_EVENT_OCCURRED __IA64_UL_CONST(0x0000000010010000)
|
|
#define SH2_EVENT_OCCURRED_ALIAS __IA64_UL_CONST(0x0000000010010008)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_PI_CAM_CONTROL" */
|
|
/* CRB CAM MMR Access Control */
|
|
/* ==================================================================== */
|
|
#define SH1_PI_CAM_CONTROL __IA64_UL_CONST(0x0000000120050300)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_SHUB_ID" */
|
|
/* SHub ID Number */
|
|
/* ==================================================================== */
|
|
#define SH1_SHUB_ID __IA64_UL_CONST(0x0000000110060580)
|
|
#define SH1_SHUB_ID_REVISION_SHFT 28
|
|
#define SH1_SHUB_ID_REVISION_MASK __IA64_UL_CONST(0x00000000f0000000)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_RTC" */
|
|
/* Real-time Clock */
|
|
/* ==================================================================== */
|
|
#define SH1_RTC __IA64_UL_CONST(0x00000001101c0000)
|
|
#define SH2_RTC __IA64_UL_CONST(0x00000002101c0000)
|
|
#define SH_RTC_MASK __IA64_UL_CONST(0x007fffffffffffff)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_PIO_WRITE_STATUS_0|1" */
|
|
/* PIO Write Status for CPU 0 & 1 */
|
|
/* ==================================================================== */
|
|
#define SH1_PIO_WRITE_STATUS_0 __IA64_UL_CONST(0x0000000120070200)
|
|
#define SH1_PIO_WRITE_STATUS_1 __IA64_UL_CONST(0x0000000120070280)
|
|
#define SH2_PIO_WRITE_STATUS_0 __IA64_UL_CONST(0x0000000020070200)
|
|
#define SH2_PIO_WRITE_STATUS_1 __IA64_UL_CONST(0x0000000020070280)
|
|
#define SH2_PIO_WRITE_STATUS_2 __IA64_UL_CONST(0x0000000020070300)
|
|
#define SH2_PIO_WRITE_STATUS_3 __IA64_UL_CONST(0x0000000020070380)
|
|
|
|
/* SH_PIO_WRITE_STATUS_0_WRITE_DEADLOCK */
|
|
/* Description: Deadlock response detected */
|
|
#define SH_PIO_WRITE_STATUS_WRITE_DEADLOCK_SHFT 1
|
|
#define SH_PIO_WRITE_STATUS_WRITE_DEADLOCK_MASK \
|
|
__IA64_UL_CONST(0x0000000000000002)
|
|
|
|
/* SH_PIO_WRITE_STATUS_0_PENDING_WRITE_COUNT */
|
|
/* Description: Count of currently pending PIO writes */
|
|
#define SH_PIO_WRITE_STATUS_PENDING_WRITE_COUNT_SHFT 56
|
|
#define SH_PIO_WRITE_STATUS_PENDING_WRITE_COUNT_MASK \
|
|
__IA64_UL_CONST(0x3f00000000000000)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_PIO_WRITE_STATUS_0_ALIAS" */
|
|
/* ==================================================================== */
|
|
#define SH1_PIO_WRITE_STATUS_0_ALIAS __IA64_UL_CONST(0x0000000120070208)
|
|
#define SH2_PIO_WRITE_STATUS_0_ALIAS __IA64_UL_CONST(0x0000000020070208)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_EVENT_OCCURRED" */
|
|
/* SHub Interrupt Event Occurred */
|
|
/* ==================================================================== */
|
|
/* SH_EVENT_OCCURRED_UART_INT */
|
|
/* Description: Pending Junk Bus UART Interrupt */
|
|
#define SH_EVENT_OCCURRED_UART_INT_SHFT 20
|
|
#define SH_EVENT_OCCURRED_UART_INT_MASK __IA64_UL_CONST(0x0000000000100000)
|
|
|
|
/* SH_EVENT_OCCURRED_IPI_INT */
|
|
/* Description: Pending IPI Interrupt */
|
|
#define SH_EVENT_OCCURRED_IPI_INT_SHFT 28
|
|
#define SH_EVENT_OCCURRED_IPI_INT_MASK __IA64_UL_CONST(0x0000000010000000)
|
|
|
|
/* SH_EVENT_OCCURRED_II_INT0 */
|
|
/* Description: Pending II 0 Interrupt */
|
|
#define SH_EVENT_OCCURRED_II_INT0_SHFT 29
|
|
#define SH_EVENT_OCCURRED_II_INT0_MASK __IA64_UL_CONST(0x0000000020000000)
|
|
|
|
/* SH_EVENT_OCCURRED_II_INT1 */
|
|
/* Description: Pending II 1 Interrupt */
|
|
#define SH_EVENT_OCCURRED_II_INT1_SHFT 30
|
|
#define SH_EVENT_OCCURRED_II_INT1_MASK __IA64_UL_CONST(0x0000000040000000)
|
|
|
|
/* SH2_EVENT_OCCURRED_EXTIO_INT2 */
|
|
/* Description: Pending SHUB 2 EXT IO INT2 */
|
|
#define SH2_EVENT_OCCURRED_EXTIO_INT2_SHFT 33
|
|
#define SH2_EVENT_OCCURRED_EXTIO_INT2_MASK __IA64_UL_CONST(0x0000000200000000)
|
|
|
|
/* SH2_EVENT_OCCURRED_EXTIO_INT3 */
|
|
/* Description: Pending SHUB 2 EXT IO INT3 */
|
|
#define SH2_EVENT_OCCURRED_EXTIO_INT3_SHFT 34
|
|
#define SH2_EVENT_OCCURRED_EXTIO_INT3_MASK __IA64_UL_CONST(0x0000000400000000)
|
|
|
|
#define SH_ALL_INT_MASK \
|
|
(SH_EVENT_OCCURRED_UART_INT_MASK | SH_EVENT_OCCURRED_IPI_INT_MASK | \
|
|
SH_EVENT_OCCURRED_II_INT0_MASK | SH_EVENT_OCCURRED_II_INT1_MASK | \
|
|
SH_EVENT_OCCURRED_II_INT1_MASK | SH2_EVENT_OCCURRED_EXTIO_INT2_MASK | \
|
|
SH2_EVENT_OCCURRED_EXTIO_INT3_MASK)
|
|
|
|
|
|
/* ==================================================================== */
|
|
/* LEDS */
|
|
/* ==================================================================== */
|
|
#define SH1_REAL_JUNK_BUS_LED0 0x7fed00000UL
|
|
#define SH1_REAL_JUNK_BUS_LED1 0x7fed10000UL
|
|
#define SH1_REAL_JUNK_BUS_LED2 0x7fed20000UL
|
|
#define SH1_REAL_JUNK_BUS_LED3 0x7fed30000UL
|
|
|
|
#define SH2_REAL_JUNK_BUS_LED0 0xf0000000UL
|
|
#define SH2_REAL_JUNK_BUS_LED1 0xf0010000UL
|
|
#define SH2_REAL_JUNK_BUS_LED2 0xf0020000UL
|
|
#define SH2_REAL_JUNK_BUS_LED3 0xf0030000UL
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH1_PTC_0" */
|
|
/* Puge Translation Cache Message Configuration Information */
|
|
/* ==================================================================== */
|
|
#define SH1_PTC_0 __IA64_UL_CONST(0x00000001101a0000)
|
|
|
|
/* SH1_PTC_0_A */
|
|
/* Description: Type */
|
|
#define SH1_PTC_0_A_SHFT 0
|
|
|
|
/* SH1_PTC_0_PS */
|
|
/* Description: Page Size */
|
|
#define SH1_PTC_0_PS_SHFT 2
|
|
|
|
/* SH1_PTC_0_RID */
|
|
/* Description: Region ID */
|
|
#define SH1_PTC_0_RID_SHFT 8
|
|
|
|
/* SH1_PTC_0_START */
|
|
/* Description: Start */
|
|
#define SH1_PTC_0_START_SHFT 63
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH1_PTC_1" */
|
|
/* Puge Translation Cache Message Configuration Information */
|
|
/* ==================================================================== */
|
|
#define SH1_PTC_1 __IA64_UL_CONST(0x00000001101a0080)
|
|
|
|
/* SH1_PTC_1_START */
|
|
/* Description: PTC_1 Start */
|
|
#define SH1_PTC_1_START_SHFT 63
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH2_PTC" */
|
|
/* Puge Translation Cache Message Configuration Information */
|
|
/* ==================================================================== */
|
|
#define SH2_PTC __IA64_UL_CONST(0x0000000170000000)
|
|
|
|
/* SH2_PTC_A */
|
|
/* Description: Type */
|
|
#define SH2_PTC_A_SHFT 0
|
|
|
|
/* SH2_PTC_PS */
|
|
/* Description: Page Size */
|
|
#define SH2_PTC_PS_SHFT 2
|
|
|
|
/* SH2_PTC_RID */
|
|
/* Description: Region ID */
|
|
#define SH2_PTC_RID_SHFT 4
|
|
|
|
/* SH2_PTC_START */
|
|
/* Description: Start */
|
|
#define SH2_PTC_START_SHFT 63
|
|
|
|
/* SH2_PTC_ADDR_RID */
|
|
/* Description: Region ID */
|
|
#define SH2_PTC_ADDR_SHFT 4
|
|
#define SH2_PTC_ADDR_MASK __IA64_UL_CONST(0x1ffffffffffff000)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_RTC1_INT_CONFIG" */
|
|
/* SHub RTC 1 Interrupt Config Registers */
|
|
/* ==================================================================== */
|
|
|
|
#define SH1_RTC1_INT_CONFIG __IA64_UL_CONST(0x0000000110001480)
|
|
#define SH2_RTC1_INT_CONFIG __IA64_UL_CONST(0x0000000010001480)
|
|
#define SH_RTC1_INT_CONFIG_MASK __IA64_UL_CONST(0x0ff3ffffffefffff)
|
|
#define SH_RTC1_INT_CONFIG_INIT __IA64_UL_CONST(0x0000000000000000)
|
|
|
|
/* SH_RTC1_INT_CONFIG_TYPE */
|
|
/* Description: Type of Interrupt: 0=INT, 2=PMI, 4=NMI, 5=INIT */
|
|
#define SH_RTC1_INT_CONFIG_TYPE_SHFT 0
|
|
#define SH_RTC1_INT_CONFIG_TYPE_MASK __IA64_UL_CONST(0x0000000000000007)
|
|
|
|
/* SH_RTC1_INT_CONFIG_AGT */
|
|
/* Description: Agent, must be 0 for SHub */
|
|
#define SH_RTC1_INT_CONFIG_AGT_SHFT 3
|
|
#define SH_RTC1_INT_CONFIG_AGT_MASK __IA64_UL_CONST(0x0000000000000008)
|
|
|
|
/* SH_RTC1_INT_CONFIG_PID */
|
|
/* Description: Processor ID, same setting as on targeted McKinley */
|
|
#define SH_RTC1_INT_CONFIG_PID_SHFT 4
|
|
#define SH_RTC1_INT_CONFIG_PID_MASK __IA64_UL_CONST(0x00000000000ffff0)
|
|
|
|
/* SH_RTC1_INT_CONFIG_BASE */
|
|
/* Description: Optional interrupt vector area, 2MB aligned */
|
|
#define SH_RTC1_INT_CONFIG_BASE_SHFT 21
|
|
#define SH_RTC1_INT_CONFIG_BASE_MASK __IA64_UL_CONST(0x0003ffffffe00000)
|
|
|
|
/* SH_RTC1_INT_CONFIG_IDX */
|
|
/* Description: Targeted McKinley interrupt vector */
|
|
#define SH_RTC1_INT_CONFIG_IDX_SHFT 52
|
|
#define SH_RTC1_INT_CONFIG_IDX_MASK __IA64_UL_CONST(0x0ff0000000000000)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_RTC1_INT_ENABLE" */
|
|
/* SHub RTC 1 Interrupt Enable Registers */
|
|
/* ==================================================================== */
|
|
|
|
#define SH1_RTC1_INT_ENABLE __IA64_UL_CONST(0x0000000110001500)
|
|
#define SH2_RTC1_INT_ENABLE __IA64_UL_CONST(0x0000000010001500)
|
|
#define SH_RTC1_INT_ENABLE_MASK __IA64_UL_CONST(0x0000000000000001)
|
|
#define SH_RTC1_INT_ENABLE_INIT __IA64_UL_CONST(0x0000000000000000)
|
|
|
|
/* SH_RTC1_INT_ENABLE_RTC1_ENABLE */
|
|
/* Description: Enable RTC 1 Interrupt */
|
|
#define SH_RTC1_INT_ENABLE_RTC1_ENABLE_SHFT 0
|
|
#define SH_RTC1_INT_ENABLE_RTC1_ENABLE_MASK \
|
|
__IA64_UL_CONST(0x0000000000000001)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_RTC2_INT_CONFIG" */
|
|
/* SHub RTC 2 Interrupt Config Registers */
|
|
/* ==================================================================== */
|
|
|
|
#define SH1_RTC2_INT_CONFIG __IA64_UL_CONST(0x0000000110001580)
|
|
#define SH2_RTC2_INT_CONFIG __IA64_UL_CONST(0x0000000010001580)
|
|
#define SH_RTC2_INT_CONFIG_MASK __IA64_UL_CONST(0x0ff3ffffffefffff)
|
|
#define SH_RTC2_INT_CONFIG_INIT __IA64_UL_CONST(0x0000000000000000)
|
|
|
|
/* SH_RTC2_INT_CONFIG_TYPE */
|
|
/* Description: Type of Interrupt: 0=INT, 2=PMI, 4=NMI, 5=INIT */
|
|
#define SH_RTC2_INT_CONFIG_TYPE_SHFT 0
|
|
#define SH_RTC2_INT_CONFIG_TYPE_MASK __IA64_UL_CONST(0x0000000000000007)
|
|
|
|
/* SH_RTC2_INT_CONFIG_AGT */
|
|
/* Description: Agent, must be 0 for SHub */
|
|
#define SH_RTC2_INT_CONFIG_AGT_SHFT 3
|
|
#define SH_RTC2_INT_CONFIG_AGT_MASK __IA64_UL_CONST(0x0000000000000008)
|
|
|
|
/* SH_RTC2_INT_CONFIG_PID */
|
|
/* Description: Processor ID, same setting as on targeted McKinley */
|
|
#define SH_RTC2_INT_CONFIG_PID_SHFT 4
|
|
#define SH_RTC2_INT_CONFIG_PID_MASK __IA64_UL_CONST(0x00000000000ffff0)
|
|
|
|
/* SH_RTC2_INT_CONFIG_BASE */
|
|
/* Description: Optional interrupt vector area, 2MB aligned */
|
|
#define SH_RTC2_INT_CONFIG_BASE_SHFT 21
|
|
#define SH_RTC2_INT_CONFIG_BASE_MASK __IA64_UL_CONST(0x0003ffffffe00000)
|
|
|
|
/* SH_RTC2_INT_CONFIG_IDX */
|
|
/* Description: Targeted McKinley interrupt vector */
|
|
#define SH_RTC2_INT_CONFIG_IDX_SHFT 52
|
|
#define SH_RTC2_INT_CONFIG_IDX_MASK __IA64_UL_CONST(0x0ff0000000000000)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_RTC2_INT_ENABLE" */
|
|
/* SHub RTC 2 Interrupt Enable Registers */
|
|
/* ==================================================================== */
|
|
|
|
#define SH1_RTC2_INT_ENABLE __IA64_UL_CONST(0x0000000110001600)
|
|
#define SH2_RTC2_INT_ENABLE __IA64_UL_CONST(0x0000000010001600)
|
|
#define SH_RTC2_INT_ENABLE_MASK __IA64_UL_CONST(0x0000000000000001)
|
|
#define SH_RTC2_INT_ENABLE_INIT __IA64_UL_CONST(0x0000000000000000)
|
|
|
|
/* SH_RTC2_INT_ENABLE_RTC2_ENABLE */
|
|
/* Description: Enable RTC 2 Interrupt */
|
|
#define SH_RTC2_INT_ENABLE_RTC2_ENABLE_SHFT 0
|
|
#define SH_RTC2_INT_ENABLE_RTC2_ENABLE_MASK \
|
|
__IA64_UL_CONST(0x0000000000000001)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_RTC3_INT_CONFIG" */
|
|
/* SHub RTC 3 Interrupt Config Registers */
|
|
/* ==================================================================== */
|
|
|
|
#define SH1_RTC3_INT_CONFIG __IA64_UL_CONST(0x0000000110001680)
|
|
#define SH2_RTC3_INT_CONFIG __IA64_UL_CONST(0x0000000010001680)
|
|
#define SH_RTC3_INT_CONFIG_MASK __IA64_UL_CONST(0x0ff3ffffffefffff)
|
|
#define SH_RTC3_INT_CONFIG_INIT __IA64_UL_CONST(0x0000000000000000)
|
|
|
|
/* SH_RTC3_INT_CONFIG_TYPE */
|
|
/* Description: Type of Interrupt: 0=INT, 2=PMI, 4=NMI, 5=INIT */
|
|
#define SH_RTC3_INT_CONFIG_TYPE_SHFT 0
|
|
#define SH_RTC3_INT_CONFIG_TYPE_MASK __IA64_UL_CONST(0x0000000000000007)
|
|
|
|
/* SH_RTC3_INT_CONFIG_AGT */
|
|
/* Description: Agent, must be 0 for SHub */
|
|
#define SH_RTC3_INT_CONFIG_AGT_SHFT 3
|
|
#define SH_RTC3_INT_CONFIG_AGT_MASK __IA64_UL_CONST(0x0000000000000008)
|
|
|
|
/* SH_RTC3_INT_CONFIG_PID */
|
|
/* Description: Processor ID, same setting as on targeted McKinley */
|
|
#define SH_RTC3_INT_CONFIG_PID_SHFT 4
|
|
#define SH_RTC3_INT_CONFIG_PID_MASK __IA64_UL_CONST(0x00000000000ffff0)
|
|
|
|
/* SH_RTC3_INT_CONFIG_BASE */
|
|
/* Description: Optional interrupt vector area, 2MB aligned */
|
|
#define SH_RTC3_INT_CONFIG_BASE_SHFT 21
|
|
#define SH_RTC3_INT_CONFIG_BASE_MASK __IA64_UL_CONST(0x0003ffffffe00000)
|
|
|
|
/* SH_RTC3_INT_CONFIG_IDX */
|
|
/* Description: Targeted McKinley interrupt vector */
|
|
#define SH_RTC3_INT_CONFIG_IDX_SHFT 52
|
|
#define SH_RTC3_INT_CONFIG_IDX_MASK __IA64_UL_CONST(0x0ff0000000000000)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_RTC3_INT_ENABLE" */
|
|
/* SHub RTC 3 Interrupt Enable Registers */
|
|
/* ==================================================================== */
|
|
|
|
#define SH1_RTC3_INT_ENABLE __IA64_UL_CONST(0x0000000110001700)
|
|
#define SH2_RTC3_INT_ENABLE __IA64_UL_CONST(0x0000000010001700)
|
|
#define SH_RTC3_INT_ENABLE_MASK __IA64_UL_CONST(0x0000000000000001)
|
|
#define SH_RTC3_INT_ENABLE_INIT __IA64_UL_CONST(0x0000000000000000)
|
|
|
|
/* SH_RTC3_INT_ENABLE_RTC3_ENABLE */
|
|
/* Description: Enable RTC 3 Interrupt */
|
|
#define SH_RTC3_INT_ENABLE_RTC3_ENABLE_SHFT 0
|
|
#define SH_RTC3_INT_ENABLE_RTC3_ENABLE_MASK \
|
|
__IA64_UL_CONST(0x0000000000000001)
|
|
|
|
/* SH_EVENT_OCCURRED_RTC1_INT */
|
|
/* Description: Pending RTC 1 Interrupt */
|
|
#define SH_EVENT_OCCURRED_RTC1_INT_SHFT 24
|
|
#define SH_EVENT_OCCURRED_RTC1_INT_MASK __IA64_UL_CONST(0x0000000001000000)
|
|
|
|
/* SH_EVENT_OCCURRED_RTC2_INT */
|
|
/* Description: Pending RTC 2 Interrupt */
|
|
#define SH_EVENT_OCCURRED_RTC2_INT_SHFT 25
|
|
#define SH_EVENT_OCCURRED_RTC2_INT_MASK __IA64_UL_CONST(0x0000000002000000)
|
|
|
|
/* SH_EVENT_OCCURRED_RTC3_INT */
|
|
/* Description: Pending RTC 3 Interrupt */
|
|
#define SH_EVENT_OCCURRED_RTC3_INT_SHFT 26
|
|
#define SH_EVENT_OCCURRED_RTC3_INT_MASK __IA64_UL_CONST(0x0000000004000000)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_IPI_ACCESS" */
|
|
/* CPU interrupt Access Permission Bits */
|
|
/* ==================================================================== */
|
|
|
|
#define SH1_IPI_ACCESS __IA64_UL_CONST(0x0000000110060480)
|
|
#define SH2_IPI_ACCESS0 __IA64_UL_CONST(0x0000000010060c00)
|
|
#define SH2_IPI_ACCESS1 __IA64_UL_CONST(0x0000000010060c80)
|
|
#define SH2_IPI_ACCESS2 __IA64_UL_CONST(0x0000000010060d00)
|
|
#define SH2_IPI_ACCESS3 __IA64_UL_CONST(0x0000000010060d80)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_INT_CMPB" */
|
|
/* RTC Compare Value for Processor B */
|
|
/* ==================================================================== */
|
|
|
|
#define SH1_INT_CMPB __IA64_UL_CONST(0x00000001101b0080)
|
|
#define SH2_INT_CMPB __IA64_UL_CONST(0x00000000101b0080)
|
|
#define SH_INT_CMPB_MASK __IA64_UL_CONST(0x007fffffffffffff)
|
|
#define SH_INT_CMPB_INIT __IA64_UL_CONST(0x0000000000000000)
|
|
|
|
/* SH_INT_CMPB_REAL_TIME_CMPB */
|
|
/* Description: Real Time Clock Compare */
|
|
#define SH_INT_CMPB_REAL_TIME_CMPB_SHFT 0
|
|
#define SH_INT_CMPB_REAL_TIME_CMPB_MASK __IA64_UL_CONST(0x007fffffffffffff)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_INT_CMPC" */
|
|
/* RTC Compare Value for Processor C */
|
|
/* ==================================================================== */
|
|
|
|
#define SH1_INT_CMPC __IA64_UL_CONST(0x00000001101b0100)
|
|
#define SH2_INT_CMPC __IA64_UL_CONST(0x00000000101b0100)
|
|
#define SH_INT_CMPC_MASK __IA64_UL_CONST(0x007fffffffffffff)
|
|
#define SH_INT_CMPC_INIT __IA64_UL_CONST(0x0000000000000000)
|
|
|
|
/* SH_INT_CMPC_REAL_TIME_CMPC */
|
|
/* Description: Real Time Clock Compare */
|
|
#define SH_INT_CMPC_REAL_TIME_CMPC_SHFT 0
|
|
#define SH_INT_CMPC_REAL_TIME_CMPC_MASK __IA64_UL_CONST(0x007fffffffffffff)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_INT_CMPD" */
|
|
/* RTC Compare Value for Processor D */
|
|
/* ==================================================================== */
|
|
|
|
#define SH1_INT_CMPD __IA64_UL_CONST(0x00000001101b0180)
|
|
#define SH2_INT_CMPD __IA64_UL_CONST(0x00000000101b0180)
|
|
#define SH_INT_CMPD_MASK __IA64_UL_CONST(0x007fffffffffffff)
|
|
#define SH_INT_CMPD_INIT __IA64_UL_CONST(0x0000000000000000)
|
|
|
|
/* SH_INT_CMPD_REAL_TIME_CMPD */
|
|
/* Description: Real Time Clock Compare */
|
|
#define SH_INT_CMPD_REAL_TIME_CMPD_SHFT 0
|
|
#define SH_INT_CMPD_REAL_TIME_CMPD_MASK __IA64_UL_CONST(0x007fffffffffffff)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_MD_DQLP_MMR_DIR_PRIVEC0" */
|
|
/* privilege vector for acc=0 */
|
|
/* ==================================================================== */
|
|
#define SH1_MD_DQLP_MMR_DIR_PRIVEC0 __IA64_UL_CONST(0x0000000100030300)
|
|
|
|
/* ==================================================================== */
|
|
/* Register "SH_MD_DQRP_MMR_DIR_PRIVEC0" */
|
|
/* privilege vector for acc=0 */
|
|
/* ==================================================================== */
|
|
#define SH1_MD_DQRP_MMR_DIR_PRIVEC0 __IA64_UL_CONST(0x0000000100050300)
|
|
|
|
/* ==================================================================== */
|
|
/* Some MMRs are functionally identical (or close enough) on both SHUB1 */
|
|
/* and SHUB2 that it makes sense to define a geberic name for the MMR. */
|
|
/* It is acceptible to use (for example) SH_IPI_INT to reference the */
|
|
/* the IPI MMR. The value of SH_IPI_INT is determined at runtime based */
|
|
/* on the type of the SHUB. Do not use these #defines in performance */
|
|
/* critical code or loops - there is a small performance penalty. */
|
|
/* ==================================================================== */
|
|
#define shubmmr(a,b) (is_shub2() ? a##2_##b : a##1_##b)
|
|
|
|
#define SH_REAL_JUNK_BUS_LED0 shubmmr(SH, REAL_JUNK_BUS_LED0)
|
|
#define SH_IPI_INT shubmmr(SH, IPI_INT)
|
|
#define SH_EVENT_OCCURRED shubmmr(SH, EVENT_OCCURRED)
|
|
#define SH_EVENT_OCCURRED_ALIAS shubmmr(SH, EVENT_OCCURRED_ALIAS)
|
|
#define SH_RTC shubmmr(SH, RTC)
|
|
#define SH_RTC1_INT_CONFIG shubmmr(SH, RTC1_INT_CONFIG)
|
|
#define SH_RTC1_INT_ENABLE shubmmr(SH, RTC1_INT_ENABLE)
|
|
#define SH_RTC2_INT_CONFIG shubmmr(SH, RTC2_INT_CONFIG)
|
|
#define SH_RTC2_INT_ENABLE shubmmr(SH, RTC2_INT_ENABLE)
|
|
#define SH_RTC3_INT_CONFIG shubmmr(SH, RTC3_INT_CONFIG)
|
|
#define SH_RTC3_INT_ENABLE shubmmr(SH, RTC3_INT_ENABLE)
|
|
#define SH_INT_CMPB shubmmr(SH, INT_CMPB)
|
|
#define SH_INT_CMPC shubmmr(SH, INT_CMPC)
|
|
#define SH_INT_CMPD shubmmr(SH, INT_CMPD)
|
|
|
|
/* ========================================================================== */
|
|
/* Register "SH2_BT_ENG_CSR_0" */
|
|
/* Engine 0 Control and Status Register */
|
|
/* ========================================================================== */
|
|
|
|
#define SH2_BT_ENG_CSR_0 __IA64_UL_CONST(0x0000000030040000)
|
|
#define SH2_BT_ENG_SRC_ADDR_0 __IA64_UL_CONST(0x0000000030040080)
|
|
#define SH2_BT_ENG_DEST_ADDR_0 __IA64_UL_CONST(0x0000000030040100)
|
|
#define SH2_BT_ENG_NOTIF_ADDR_0 __IA64_UL_CONST(0x0000000030040180)
|
|
|
|
/* ========================================================================== */
|
|
/* BTE interfaces 1-3 */
|
|
/* ========================================================================== */
|
|
|
|
#define SH2_BT_ENG_CSR_1 __IA64_UL_CONST(0x0000000030050000)
|
|
#define SH2_BT_ENG_CSR_2 __IA64_UL_CONST(0x0000000030060000)
|
|
#define SH2_BT_ENG_CSR_3 __IA64_UL_CONST(0x0000000030070000)
|
|
|
|
#endif /* _ASM_IA64_SN_SHUB_MMR_H */
|