/* SPDX-License-Identifier: GPL-2.0-or-later */
/*
* This file contains the hardware definitions of the Integrator.
*
* Copyright (C) 1998-1999 ARM Limited.
*/
#ifndef INTEGRATOR_HARDWARE_H
#define INTEGRATOR_HARDWARE_H
/*
* Where in virtual memory the IO devices (timers, system controllers
* and so on)
*/
#define IO_BASE 0 xF0000000 // VA of IO
#define IO_SIZE 0 x0B000000 // How much?
#define IO_START INTEGRATOR_HDR_BASE // PA of IO
/* macro to get at IO space when running virtually */
#define IO_ADDRESS(x) (((x) & 0 x000fffff) | (((x) >> 4 ) & 0 x0ff00000) | IO_BASE)
#define __io_address(n) ((void __iomem *)IO_ADDRESS(n))
/*
* Integrator memory map
*/
#define INTEGRATOR_BOOT_ROM_LO 0 x00000000
#define INTEGRATOR_BOOT_ROM_HI 0 x20000000
#define INTEGRATOR_BOOT_ROM_BASE INTEGRATOR_BOOT_ROM_HI /* Normal position */
#define INTEGRATOR_BOOT_ROM_SIZE SZ_512K
/*
* New Core Modules have different amounts of SSRAM, the amount of SSRAM
* fitted can be found in HDR_STAT.
*
* The symbol INTEGRATOR_SSRAM_SIZE is kept, however this now refers to
* the minimum amount of SSRAM fitted on any core module.
*
* New Core Modules also alias the SSRAM.
*
*/
#define INTEGRATOR_SSRAM_BASE 0 x00000000
#define INTEGRATOR_SSRAM_ALIAS_BASE 0 x10800000
#define INTEGRATOR_SSRAM_SIZE SZ_256K
#define INTEGRATOR_FLASH_BASE 0 x24000000
#define INTEGRATOR_FLASH_SIZE SZ_32M
#define INTEGRATOR_MBRD_SSRAM_BASE 0 x28000000
#define INTEGRATOR_MBRD_SSRAM_SIZE SZ_512K
/*
* SDRAM is a SIMM therefore the size is not known.
*/
#define INTEGRATOR_SDRAM_BASE 0 x00040000
#define INTEGRATOR_SDRAM_ALIAS_BASE 0 x80000000
#define INTEGRATOR_HDR0_SDRAM_BASE 0 x80000000
#define INTEGRATOR_HDR1_SDRAM_BASE 0 x90000000
#define INTEGRATOR_HDR2_SDRAM_BASE 0 xA0000000
#define INTEGRATOR_HDR3_SDRAM_BASE 0 xB0000000
/*
* Logic expansion modules
*
*/
#define INTEGRATOR_LOGIC_MODULES_BASE 0 xC0000000
#define INTEGRATOR_LOGIC_MODULE0_BASE 0 xC0000000
#define INTEGRATOR_LOGIC_MODULE1_BASE 0 xD0000000
#define INTEGRATOR_LOGIC_MODULE2_BASE 0 xE0000000
#define INTEGRATOR_LOGIC_MODULE3_BASE 0 xF0000000
/*
* Integrator header card registers
*/
#define INTEGRATOR_HDR_ID_OFFSET 0 x00
#define INTEGRATOR_HDR_PROC_OFFSET 0 x04
#define INTEGRATOR_HDR_OSC_OFFSET 0 x08
#define INTEGRATOR_HDR_CTRL_OFFSET 0 x0C
#define INTEGRATOR_HDR_STAT_OFFSET 0 x10
#define INTEGRATOR_HDR_LOCK_OFFSET 0 x14
#define INTEGRATOR_HDR_SDRAM_OFFSET 0 x20
#define INTEGRATOR_HDR_INIT_OFFSET 0 x24 /* CM9x6 */
#define INTEGRATOR_HDR_IC_OFFSET 0 x40
#define INTEGRATOR_HDR_SPDBASE_OFFSET 0 x100
#define INTEGRATOR_HDR_SPDTOP_OFFSET 0 x200
#define INTEGRATOR_HDR_BASE 0 x10000000
#define INTEGRATOR_HDR_ID (INTEGRATOR_HDR_BASE + INTEGRATOR_HDR_ID_OFFSET)
#define INTEGRATOR_HDR_PROC (INTEGRATOR_HDR_BASE + INTEGRATOR_HDR_PROC_OFFSET)
#define INTEGRATOR_HDR_OSC (INTEGRATOR_HDR_BASE + INTEGRATOR_HDR_OSC_OFFSET)
#define INTEGRATOR_HDR_CTRL (INTEGRATOR_HDR_BASE + INTEGRATOR_HDR_CTRL_OFFSET)
#define INTEGRATOR_HDR_STAT (INTEGRATOR_HDR_BASE + INTEGRATOR_HDR_STAT_OFFSET)
#define INTEGRATOR_HDR_LOCK (INTEGRATOR_HDR_BASE + INTEGRATOR_HDR_LOCK_OFFSET)
#define INTEGRATOR_HDR_SDRAM (INTEGRATOR_HDR_BASE + INTEGRATOR_HDR_SDRAM_OFFSET)
#define INTEGRATOR_HDR_INIT (INTEGRATOR_HDR_BASE + INTEGRATOR_HDR_INIT_OFFSET)
#define INTEGRATOR_HDR_IC (INTEGRATOR_HDR_BASE + INTEGRATOR_HDR_IC_OFFSET)
#define INTEGRATOR_HDR_SPDBASE (INTEGRATOR_HDR_BASE + INTEGRATOR_HDR_SPDBASE_OFFSET)
#define INTEGRATOR_HDR_SPDTOP (INTEGRATOR_HDR_BASE + INTEGRATOR_HDR_SPDTOP_OFFSET)
#define INTEGRATOR_HDR_CTRL_LED 0 x01
#define INTEGRATOR_HDR_CTRL_MBRD_DETECH 0 x02
#define INTEGRATOR_HDR_CTRL_REMAP 0 x04
#define INTEGRATOR_HDR_CTRL_RESET 0 x08
#define INTEGRATOR_HDR_CTRL_HIGHVECTORS 0 x10
#define INTEGRATOR_HDR_CTRL_BIG_ENDIAN 0 x20
#define INTEGRATOR_HDR_CTRL_FASTBUS 0 x40
#define INTEGRATOR_HDR_CTRL_SYNC 0 x80
#define INTEGRATOR_HDR_OSC_CORE_10MHz 0 x102
#define INTEGRATOR_HDR_OSC_CORE_15MHz 0 x107
#define INTEGRATOR_HDR_OSC_CORE_20MHz 0 x10C
#define INTEGRATOR_HDR_OSC_CORE_25MHz 0 x111
#define INTEGRATOR_HDR_OSC_CORE_30MHz 0 x116
#define INTEGRATOR_HDR_OSC_CORE_35MHz 0 x11B
#define INTEGRATOR_HDR_OSC_CORE_40MHz 0 x120
#define INTEGRATOR_HDR_OSC_CORE_45MHz 0 x125
#define INTEGRATOR_HDR_OSC_CORE_50MHz 0 x12A
#define INTEGRATOR_HDR_OSC_CORE_55MHz 0 x12F
#define INTEGRATOR_HDR_OSC_CORE_60MHz 0 x134
#define INTEGRATOR_HDR_OSC_CORE_65MHz 0 x139
#define INTEGRATOR_HDR_OSC_CORE_70MHz 0 x13E
#define INTEGRATOR_HDR_OSC_CORE_75MHz 0 x143
#define INTEGRATOR_HDR_OSC_CORE_80MHz 0 x148
#define INTEGRATOR_HDR_OSC_CORE_85MHz 0 x14D
#define INTEGRATOR_HDR_OSC_CORE_90MHz 0 x152
#define INTEGRATOR_HDR_OSC_CORE_95MHz 0 x157
#define INTEGRATOR_HDR_OSC_CORE_100MHz 0 x15C
#define INTEGRATOR_HDR_OSC_CORE_105MHz 0 x161
#define INTEGRATOR_HDR_OSC_CORE_110MHz 0 x166
#define INTEGRATOR_HDR_OSC_CORE_115MHz 0 x16B
#define INTEGRATOR_HDR_OSC_CORE_120MHz 0 x170
#define INTEGRATOR_HDR_OSC_CORE_125MHz 0 x175
#define INTEGRATOR_HDR_OSC_CORE_130MHz 0 x17A
#define INTEGRATOR_HDR_OSC_CORE_135MHz 0 x17F
#define INTEGRATOR_HDR_OSC_CORE_140MHz 0 x184
#define INTEGRATOR_HDR_OSC_CORE_145MHz 0 x189
#define INTEGRATOR_HDR_OSC_CORE_150MHz 0 x18E
#define INTEGRATOR_HDR_OSC_CORE_155MHz 0 x193
#define INTEGRATOR_HDR_OSC_CORE_160MHz 0 x198
#define INTEGRATOR_HDR_OSC_CORE_MASK 0 x7FF
#define INTEGRATOR_HDR_OSC_MEM_10MHz 0 x10C000
#define INTEGRATOR_HDR_OSC_MEM_15MHz 0 x116000
#define INTEGRATOR_HDR_OSC_MEM_20MHz 0 x120000
#define INTEGRATOR_HDR_OSC_MEM_25MHz 0 x12A000
#define INTEGRATOR_HDR_OSC_MEM_30MHz 0 x134000
#define INTEGRATOR_HDR_OSC_MEM_33MHz 0 x13A000
#define INTEGRATOR_HDR_OSC_MEM_40MHz 0 x148000
#define INTEGRATOR_HDR_OSC_MEM_50MHz 0 x15C000
#define INTEGRATOR_HDR_OSC_MEM_60MHz 0 x170000
#define INTEGRATOR_HDR_OSC_MEM_66MHz 0 x17C000
#define INTEGRATOR_HDR_OSC_MEM_MASK 0 x7FF000
#define INTEGRATOR_HDR_OSC_BUS_MODE_CM7x0 0 x0
#define INTEGRATOR_HDR_OSC_BUS_MODE_CM9x0 0 x0800000
#define INTEGRATOR_HDR_OSC_BUS_MODE_CM9x6 0 x1000000
#define INTEGRATOR_HDR_OSC_BUS_MODE_CM10x00 0 x1800000
#define INTEGRATOR_HDR_OSC_BUS_MODE_MASK 0 x1800000
#define INTEGRATOR_HDR_SDRAM_SPD_OK (1 << 5 )
/*
* Integrator system registers
*/
/*
* System Controller
*/
#define INTEGRATOR_SC_ID_OFFSET 0 x00
#define INTEGRATOR_SC_OSC_OFFSET 0 x04
#define INTEGRATOR_SC_CTRLS_OFFSET 0 x08
#define INTEGRATOR_SC_CTRLC_OFFSET 0 x0C
#define INTEGRATOR_SC_DEC_OFFSET 0 x10
#define INTEGRATOR_SC_ARB_OFFSET 0 x14
#define INTEGRATOR_SC_LOCK_OFFSET 0 x1C
#define INTEGRATOR_SC_BASE 0 x11000000
#define INTEGRATOR_SC_ID (INTEGRATOR_SC_BASE + INTEGRATOR_SC_ID_OFFSET)
#define INTEGRATOR_SC_OSC (INTEGRATOR_SC_BASE + INTEGRATOR_SC_OSC_OFFSET)
#define INTEGRATOR_SC_CTRLS (INTEGRATOR_SC_BASE + INTEGRATOR_SC_CTRLS_OFFSET)
#define INTEGRATOR_SC_CTRLC (INTEGRATOR_SC_BASE + INTEGRATOR_SC_CTRLC_OFFSET)
#define INTEGRATOR_SC_DEC (INTEGRATOR_SC_BASE + INTEGRATOR_SC_DEC_OFFSET)
#define INTEGRATOR_SC_ARB (INTEGRATOR_SC_BASE + INTEGRATOR_SC_ARB_OFFSET)
#define INTEGRATOR_SC_PCIENABLE (INTEGRATOR_SC_BASE + INTEGRATOR_SC_PCIENABLE_OFFSET)
#define INTEGRATOR_SC_LOCK (INTEGRATOR_SC_BASE + INTEGRATOR_SC_LOCK_OFFSET)
#define INTEGRATOR_SC_OSC_SYS_10MHz 0 x20
#define INTEGRATOR_SC_OSC_SYS_15MHz 0 x34
#define INTEGRATOR_SC_OSC_SYS_20MHz 0 x48
#define INTEGRATOR_SC_OSC_SYS_25MHz 0 x5C
#define INTEGRATOR_SC_OSC_SYS_33MHz 0 x7C
#define INTEGRATOR_SC_OSC_SYS_MASK 0 xFF
#define INTEGRATOR_SC_OSC_PCI_25MHz 0 x100
#define INTEGRATOR_SC_OSC_PCI_33MHz 0 x0
#define INTEGRATOR_SC_OSC_PCI_MASK 0 x100
#define INTEGRATOR_SC_CTRL_SOFTRST (1 << 0 )
#define INTEGRATOR_SC_CTRL_nFLVPPEN (1 << 1 )
#define INTEGRATOR_SC_CTRL_nFLWP (1 << 2 )
#define INTEGRATOR_SC_CTRL_URTS0 (1 << 4 )
#define INTEGRATOR_SC_CTRL_UDTR0 (1 << 5 )
#define INTEGRATOR_SC_CTRL_URTS1 (1 << 6 )
#define INTEGRATOR_SC_CTRL_UDTR1 (1 << 7 )
/*
* External Bus Interface
*/
#define INTEGRATOR_EBI_BASE 0 x12000000
#define INTEGRATOR_EBI_CSR0_OFFSET 0 x00
#define INTEGRATOR_EBI_CSR1_OFFSET 0 x04
#define INTEGRATOR_EBI_CSR2_OFFSET 0 x08
#define INTEGRATOR_EBI_CSR3_OFFSET 0 x0C
#define INTEGRATOR_EBI_LOCK_OFFSET 0 x20
#define INTEGRATOR_EBI_CSR0 (INTEGRATOR_EBI_BASE + INTEGRATOR_EBI_CSR0_OFFSET)
#define INTEGRATOR_EBI_CSR1 (INTEGRATOR_EBI_BASE + INTEGRATOR_EBI_CSR1_OFFSET)
#define INTEGRATOR_EBI_CSR2 (INTEGRATOR_EBI_BASE + INTEGRATOR_EBI_CSR2_OFFSET)
#define INTEGRATOR_EBI_CSR3 (INTEGRATOR_EBI_BASE + INTEGRATOR_EBI_CSR3_OFFSET)
#define INTEGRATOR_EBI_LOCK (INTEGRATOR_EBI_BASE + INTEGRATOR_EBI_LOCK_OFFSET)
#define INTEGRATOR_EBI_8_BIT 0 x00
#define INTEGRATOR_EBI_16_BIT 0 x01
#define INTEGRATOR_EBI_32_BIT 0 x02
#define INTEGRATOR_EBI_WRITE_ENABLE 0 x04
#define INTEGRATOR_EBI_SYNC 0 x08
#define INTEGRATOR_EBI_WS_2 0 x00
#define INTEGRATOR_EBI_WS_3 0 x10
#define INTEGRATOR_EBI_WS_4 0 x20
#define INTEGRATOR_EBI_WS_5 0 x30
#define INTEGRATOR_EBI_WS_6 0 x40
#define INTEGRATOR_EBI_WS_7 0 x50
#define INTEGRATOR_EBI_WS_8 0 x60
#define INTEGRATOR_EBI_WS_9 0 x70
#define INTEGRATOR_EBI_WS_10 0 x80
#define INTEGRATOR_EBI_WS_11 0 x90
#define INTEGRATOR_EBI_WS_12 0 xA0
#define INTEGRATOR_EBI_WS_13 0 xB0
#define INTEGRATOR_EBI_WS_14 0 xC0
#define INTEGRATOR_EBI_WS_15 0 xD0
#define INTEGRATOR_EBI_WS_16 0 xE0
#define INTEGRATOR_EBI_WS_17 0 xF0
#define INTEGRATOR_CT_BASE 0 x13000000 /* Counter/Timers */
#define INTEGRATOR_IC_BASE 0 x14000000 /* Interrupt Controller */
#define INTEGRATOR_RTC_BASE 0 x15000000 /* Real Time Clock */
#define INTEGRATOR_UART0_BASE 0 x16000000 /* UART 0 */
#define INTEGRATOR_UART1_BASE 0 x17000000 /* UART 1 */
#define INTEGRATOR_KBD_BASE 0 x18000000 /* Keyboard */
#define INTEGRATOR_MOUSE_BASE 0 x19000000 /* Mouse */
/*
* LED's & Switches
*/
#define INTEGRATOR_DBG_ALPHA_OFFSET 0 x00
#define INTEGRATOR_DBG_LEDS_OFFSET 0 x04
#define INTEGRATOR_DBG_SWITCH_OFFSET 0 x08
#define INTEGRATOR_DBG_BASE 0 x1A000000
#define INTEGRATOR_DBG_ALPHA (INTEGRATOR_DBG_BASE + INTEGRATOR_DBG_ALPHA_OFFSET)
#define INTEGRATOR_DBG_LEDS (INTEGRATOR_DBG_BASE + INTEGRATOR_DBG_LEDS_OFFSET)
#define INTEGRATOR_DBG_SWITCH (INTEGRATOR_DBG_BASE + INTEGRATOR_DBG_SWITCH_OFFSET)
#define INTEGRATOR_AP_GPIO_BASE 0 x1B000000 /* GPIO */
#define INTEGRATOR_CP_MMC_BASE 0 x1C000000 /* MMC */
#define INTEGRATOR_CP_AACI_BASE 0 x1D000000 /* AACI */
#define INTEGRATOR_CP_ETH_BASE 0 xC8000000 /* Ethernet */
#define INTEGRATOR_CP_GPIO_BASE 0 xC9000000 /* GPIO */
#define INTEGRATOR_CP_SIC_BASE 0 xCA000000 /* SIC */
#define INTEGRATOR_CP_CTL_BASE 0 xCB000000 /* CP system control */
/* PS2 Keyboard interface */
#define KMI0_BASE INTEGRATOR_KBD_BASE
/* PS2 Mouse interface */
#define KMI1_BASE INTEGRATOR_MOUSE_BASE
/*
* Integrator Interrupt Controllers
*
*
* Offsets from interrupt controller base
*
* System Controller interrupt controller base is
*
* INTEGRATOR_IC_BASE + (header_number << 6)
*
* Core Module interrupt controller base is
*
* INTEGRATOR_HDR_IC
*/
#define IRQ_STATUS 0
#define IRQ_RAW_STATUS 0 x04
#define IRQ_ENABLE 0 x08
#define IRQ_ENABLE_SET 0 x08
#define IRQ_ENABLE_CLEAR 0 x0C
#define INT_SOFT_SET 0 x10
#define INT_SOFT_CLEAR 0 x14
#define FIQ_STATUS 0 x20
#define FIQ_RAW_STATUS 0 x24
#define FIQ_ENABLE 0 x28
#define FIQ_ENABLE_SET 0 x28
#define FIQ_ENABLE_CLEAR 0 x2C
/*
* LED's
*/
#define GREEN_LED 0 x01
#define YELLOW_LED 0 x02
#define RED_LED 0 x04
#define GREEN_LED_2 0 x08
#define ALL_LEDS 0 x0F
#define LED_BANK INTEGRATOR_DBG_LEDS
/*
* Timer definitions
*
* Only use timer 1 & 2
* (both run at 24MHz and will need the clock divider set to 16).
*
* Timer 0 runs at bus frequency
*/
#define INTEGRATOR_TIMER0_BASE INTEGRATOR_CT_BASE
#define INTEGRATOR_TIMER1_BASE (INTEGRATOR_CT_BASE + 0 x100)
#define INTEGRATOR_TIMER2_BASE (INTEGRATOR_CT_BASE + 0 x200)
#define INTEGRATOR_CSR_BASE 0 x10000000
#define INTEGRATOR_CSR_SIZE 0 x10000000
#endif /* INTEGRATOR_HARDWARE_H */
Messung V0.5 in Prozent C=96 H=90 G=93
¤ Dauer der Verarbeitung: 0.11 Sekunden
(vorverarbeitet am 2026-06-07)
¤
*© Formatika GbR, Deutschland