hardware.h
上传用户:szlgq88
上传日期:2009-04-28
资源大小:48287k
文件大小:6k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. /*
  2.  *  linux/include/asm-arm/arch-clps711x/hardware.h
  3.  *
  4.  *  This file contains the hardware definitions of the Prospector P720T.
  5.  *
  6.  *  Copyright (C) 2000 Deep Blue Solutions Ltd.
  7.  *
  8.  * This program is free software; you can redistribute it and/or modify
  9.  * it under the terms of the GNU General Public License as published by
  10.  * the Free Software Foundation; either version 2 of the License, or
  11.  * (at your option) any later version.
  12.  *
  13.  * This program is distributed in the hope that it will be useful,
  14.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  16.  * GNU General Public License for more details.
  17.  *
  18.  * You should have received a copy of the GNU General Public License
  19.  * along with this program; if not, write to the Free Software
  20.  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
  21.  */
  22. #ifndef __ASM_ARCH_HARDWARE_H
  23. #define __ASM_ARCH_HARDWARE_H
  24. #include <linux/config.h>
  25. #define CLPS7111_VIRT_BASE 0xff000000
  26. #define CLPS7111_BASE CLPS7111_VIRT_BASE
  27. /*
  28.  * The physical addresses that the external chip select signals map to is
  29.  * dependent on the setting of the nMEDCHG signal on EP7211 and EP7212
  30.  * processors.  CONFIG_EP72XX_BOOT_ROM is only available if these
  31.  * processors are in use.
  32.  */
  33. #ifndef CONFIG_EP72XX_ROM_BOOT
  34. #define CS0_PHYS_BASE (0x00000000)
  35. #define CS1_PHYS_BASE (0x10000000)
  36. #define CS2_PHYS_BASE (0x20000000)
  37. #define CS3_PHYS_BASE (0x30000000)
  38. #define CS4_PHYS_BASE (0x40000000)
  39. #define CS5_PHYS_BASE (0x50000000)
  40. #define CS6_PHYS_BASE (0x60000000)
  41. #define CS7_PHYS_BASE (0x70000000)
  42. #else
  43. #define CS0_PHYS_BASE (0x70000000)
  44. #define CS1_PHYS_BASE (0x60000000)
  45. #define CS2_PHYS_BASE (0x50000000)
  46. #define CS3_PHYS_BASE (0x40000000)
  47. #define CS4_PHYS_BASE (0x30000000)
  48. #define CS5_PHYS_BASE (0x20000000)
  49. #define CS6_PHYS_BASE (0x10000000)
  50. #define CS7_PHYS_BASE (0x00000000)
  51. #endif
  52. #if defined (CONFIG_ARCH_EP7211)
  53. #define EP7211_VIRT_BASE CLPS7111_VIRT_BASE
  54. #define EP7211_BASE CLPS7111_VIRT_BASE
  55. #include <asm/hardware/ep7211.h>
  56. #elif defined (CONFIG_ARCH_EP7212)
  57. #define EP7212_VIRT_BASE CLPS7111_VIRT_BASE
  58. #define EP7212_BASE CLPS7111_VIRT_BASE
  59. #include <asm/hardware/ep7212.h>
  60. #endif
  61. #define SYSPLD_VIRT_BASE 0xfe000000
  62. #define SYSPLD_BASE SYSPLD_VIRT_BASE
  63. #ifndef __ASSEMBLER__
  64. #define PCIO_BASE IO_BASE
  65. #endif
  66. #if  defined (CONFIG_ARCH_AUTCPU12)
  67. #define  CS89712_VIRT_BASE CLPS7111_VIRT_BASE
  68. #define  CS89712_BASE CLPS7111_VIRT_BASE
  69. #include <asm/hardware/clps7111.h>
  70. #include <asm/hardware/ep7212.h>
  71. #include <asm/hardware/cs89712.h>
  72. #endif
  73. #if defined (CONFIG_ARCH_CDB89712)
  74. #include <asm/hardware/clps7111.h>
  75. #include <asm/hardware/ep7212.h>
  76. #include <asm/hardware/cs89712.h>
  77. /* dynamic ioremap() areas */
  78. #define FLASH_START      0x00000000
  79. #define FLASH_SIZE       0x800000
  80. #define FLASH_WIDTH      4
  81. #define SRAM_START       0x60000000
  82. #define SRAM_SIZE        0xc000
  83. #define SRAM_WIDTH       4
  84. #define BOOTROM_START    0x70000000
  85. #define BOOTROM_SIZE     0x80
  86. #define BOOTROM_WIDTH    4
  87. /* static cdb89712_map_io() areas */
  88. #define REGISTER_START   0x80000000
  89. #define REGISTER_SIZE    0x4000
  90. #define REGISTER_BASE    0xff000000
  91. #define ETHER_START      0x20000000
  92. #define ETHER_SIZE       0x1000
  93. #define ETHER_BASE       0xfe000000
  94. #endif
  95. #if defined (CONFIG_ARCH_EDB7211)
  96. /*
  97.  * The extra 8 lines of the keyboard matrix are wired to chip select 3 (nCS3) 
  98.  * and repeat across it. This is the mapping for it.
  99.  *
  100.  * In jumpered boot mode, nCS3 is mapped to 0x4000000, not 0x3000000. This 
  101.  * was cause for much consternation and headscratching. This should probably
  102.  * be made a compile/run time kernel option.
  103.  */
  104. #define EP7211_PHYS_EXTKBD CS3_PHYS_BASE /* physical */
  105. #define EP7211_VIRT_EXTKBD (0xfd000000) /* virtual */
  106. /*
  107.  * The CS8900A ethernet chip has its I/O registers wired to chip select 2 
  108.  * (nCS2). This is the mapping for it.
  109.  *
  110.  * In jumpered boot mode, nCS2 is mapped to 0x5000000, not 0x2000000. This 
  111.  * was cause for much consternation and headscratching. This should probably
  112.  * be made a compile/run time kernel option.
  113.  */
  114. #define EP7211_PHYS_CS8900A CS2_PHYS_BASE /* physical */
  115. #define EP7211_VIRT_CS8900A (0xfc000000) /* virtual */
  116. /*
  117.  * The two flash banks are wired to chip selects 0 and 1. This is the mapping
  118.  * for them.
  119.  *
  120.  * nCS0 and nCS1 are at 0x70000000 and 0x60000000, respectively, when running
  121.  * in jumpered boot mode.
  122.  */
  123. #define EP7211_PHYS_FLASH1 CS0_PHYS_BASE /* physical */
  124. #define EP7211_PHYS_FLASH2 CS1_PHYS_BASE /* physical */
  125. #define EP7211_VIRT_FLASH1 (0xfa000000) /* virtual */
  126. #define EP7211_VIRT_FLASH2 (0xfb000000) /* virtual */
  127. #endif /* CONFIG_ARCH_EDB7211 */
  128. /*
  129.  * Relevant bits in port D, which controls power to the various parts of
  130.  * the LCD on the EDB7211.
  131.  */
  132. #define EDB_PD1_LCD_DC_DC_EN (1<<1)
  133. #define EDB_PD2_LCDEN (1<<2)
  134. #define EDB_PD3_LCDBL (1<<3)
  135. #if defined (CONFIG_ARCH_CEIVA)
  136. #define  CEIVA_VIRT_BASE CLPS7111_VIRT_BASE
  137. #define  CEIVA_BASE CLPS7111_VIRT_BASE
  138. #include <asm/hardware/clps7111.h>
  139. #include <asm/hardware/ep7212.h>
  140. /*
  141.  * The two flash banks are wired to chip selects 0 and 1. This is the mapping
  142.  * for them.
  143.  *
  144.  * nCS0 and nCS1 are at 0x70000000 and 0x60000000, respectively, when running
  145.  * in jumpered boot mode.
  146.  */
  147. #define CEIVA_PHYS_FLASH1 CS0_PHYS_BASE /* physical */
  148. #define CEIVA_PHYS_FLASH2 CS1_PHYS_BASE /* physical */
  149. #define CEIVA_VIRT_FLASH1 (0xfa000000) /* virtual */
  150. #define CEIVA_VIRT_FLASH2 (0xfb000000) /* virtual */
  151. #define CEIVA_FLASH_SIZE        0x100000
  152. #define CEIVA_FLASH_WIDTH       2
  153. #define SRAM_START       0x60000000
  154. #define SRAM_SIZE        0xc000
  155. #define SRAM_WIDTH       4
  156. #define BOOTROM_START    0x70000000
  157. #define BOOTROM_SIZE     0x80
  158. #define BOOTROM_WIDTH    4
  159. /*
  160.  * SED1355 LCD controller
  161.  */
  162. #define CEIVA_PHYS_SED1355 CS2_PHYS_BASE
  163. #define CEIVA_VIRT_SED1355 (0xfc000000)
  164. /*
  165.  * Relevant bits in port D, which controls power to the various parts of
  166.  * the LCD on the Ceiva Photo Max, and reset to the LCD controller.
  167.  */
  168. // Reset line to SED1355 (must be high to operate)
  169. #define CEIVA_PD1_LCDRST (1<<1)
  170. // LCD panel enable (set to one, to enable LCD)
  171. #define CEIVA_PD4_LCDEN (1<<4)
  172. // Backlight (set to one, to turn on backlight
  173. #define CEIVA_PD5_LCDBL (1<<5)
  174. /*
  175.  * Relevant bits in port B, which report the status of the buttons.
  176.  */
  177. // White button
  178. #define CEIVA_PB4_WHT_BTN (1<<4)
  179. // Black button
  180. #define CEIVA_PB0_BLK_BTN (1<<0)
  181. #endif // #if defined (CONFIG_ARCH_CEIVA)
  182. #endif