⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 xlli_mainstone_defs.inc

📁 优龙pxa270平台试验程序
💻 INC
📖 第 1 页 / 共 2 页
字号:
@*********************************************************************************
@
@        COPYRIGHT (c) 2002 - 2004 Intel Corporation
@
@   The information in this file is furnished for informational use only,
@   is subject to change without notice, and should not be construed as
@   a commitment by Intel Corporation. Intel Corporation assumes no
@   responsibility or liability for any errors or inaccuracies that may appear
@   in this document or any software that may be provided in association with
@   this document.
@
@*********************************************************************************
@
@  FILENAME:       xlli_Mainstone_defs.inc (Platform specific addresses and
@                  defalut values for Mainstone II platform bring up)
@                  NOTE: - This file has a def to configure xlli for MCP and non-MCP processors
@
@ LAST MODIFIED:   13-Feb-2004
@
@******************************************************************************
@
@
@ Include file for Mainstone II specific Cross Platform Low Level Initialization (XLLI)
@
@
@ PLATFORM REGISTERS base address and register offsets from the base address
@
              .equ    xlli_PLATFORM_REGISTERS,0x08000000

     .equ    xlli_PLATFORM_HEXLED_DATA_offset,(0x10)   @ Hex LED Data Register
     .equ    xlli_PLATFORM_LED_CONTROL_offset,(0x40)   @ LED Control Register
          .equ    xlli_PLATFORM_SWITCH_offset,(0x60)   @ General Purpose Switch Register
     .equ    xlli_PLATFORM_MISC_WRITE1_offset,(0x80)   @ Misc Write Register 1
     .equ    xlli_PLATFORM_MISC_WRITE2_offset,(0x84)   @ Misc Write Register 2
      .equ    xlli_PLATFORM_MISC_READ1_offset,(0x90)   @ Misc Read Register 1
       .equ    xlli_PLATFORM_INTERR_ME_offset,(0xC0)   @ Platform Interrupt Mask/Enable Register 1
       .equ    xlli_PLATFORM_INTERR_SC_offset,(0xD0)   @ Platform Interrupt Set/Clear Register 1
      .equ    xlli_PLATFORM_PCMCIA0_SC_offset,(0xE0)   @ PCMCIA Socket 0 Status/Control Register
      .equ    xlli_PLATFORM_PCMCIA1_SC_offset,(0xE4)   @ PCMCIA Socket 1 Status/Control Register

@
@ Platform specific bits
@
                       .equ    xlli_SYS_RESET,(0x01)   @ System reset bit

@
@ platform GPIO pin settings (Bulverde/Mainstone)
@
          .equ   xlli_GPSR0_value,(0x00008004)   @ Set registers
          .equ   xlli_GPSR1_value,(0x00020080)
          .equ   xlli_GPSR2_value,(0x16C14000)
          .equ   xlli_GPSR3_value,(0x0003E000)

          .equ   xlli_GPCR0_value,(0x0)          @ Clear registers
          .equ   xlli_GPCR1_value,(0x00000380)   @ FFUART related
          .equ   xlli_GPCR2_value,(0x0)
          .equ   xlli_GPCR3_value,(0x0)

          .equ   xlli_GRER0_value,(0x0)          @ Rising Edge Detect
          .equ   xlli_GRER1_value,(0x0)
          .equ   xlli_GRER2_value,(0x0)
          .equ   xlli_GRER3_value,(0x0)

          .equ   xlli_GFER0_value,(0x0)          @ Falling Edge Detect
          .equ   xlli_GFER1_value,(0x0)
          .equ   xlli_GFER2_value,(0x0)
          .equ   xlli_GFER3_value,(0x0)

          .equ   xlli_GPLR0_value,(0x0)          @ Pin Level Registers
          .equ   xlli_GPLR1_value,(0x0)
          .equ   xlli_GPLR2_value,(0x0)
          .equ   xlli_GPLR3_value,(0x0)

          .equ   xlli_GEDR0_value,(0x0)          @ Edge Detect Status
          .equ   xlli_GEDR1_value,(0x0)
          .equ   xlli_GEDR2_value,(0x0)
          .equ   xlli_GEDR3_value,(0x0)

          .equ   xlli_GPDR0_value,(0xCFE3BDE4)   @ Direction Registers
          .equ   xlli_GPDR1_value,(0x003FAB81)
          .equ   xlli_GPDR2_value,(0x1EC3FC00)
          .equ   xlli_GPDR3_value,(0x018FFE8F)

 .equ  xlli_GAFR0_L_value,(0x84400000)   @ Alternate function registers
 .equ  xlli_GAFR0_U_value,(0xA5000510)
 .equ  xlli_GAFR1_L_value,(0x000A9558)
 .equ  xlli_GAFR1_U_value,(0x0005A1AA)
 .equ  xlli_GAFR2_L_value,(0x60000000)
 .equ  xlli_GAFR2_U_value,(0x00000802)
 .equ  xlli_GAFR3_L_value,(0x00000000)
 .equ  xlli_GAFR3_U_value,(0x00000000)

@
@ MEMORY CONTROLLER SETTINGS FOR MAINSTONE
@

  .equ   xlli_MDREFR_value,(0x0000001E)
        .ifdef   xlli_FLASH_WIDTH_16_BIT
 .equ   xlli_MSC0_DC_value,(0x7FF07FFA)     @ Bulverde Card Flash value (MCP version)
        .else
 .equ   xlli_MSC0_DC_value,(0x7FF0B8F2)     @ Bulverde Card Flash value (Non-MCP version)
        .endif
 .equ   xlli_MSC0_MS_value,(0x23F2B8F2)     @ Mainstone Board Flash value
    .equ   xlli_MSC1_value,(0x0000CCD1)
    .equ   xlli_MSC2_value,(0x0000B884)
    .equ   xlli_MECR_value,(0x00000001)
  .equ   xlli_MCMEM0_value,(0x0001C391)
  .equ   xlli_MCMEM1_value,(0x0001C391)
  .equ   xlli_MCATT0_value,(0x0001C391)
  .equ   xlli_MCATT1_value,(0x0001C391)
   .equ   xlli_MCIO0_value,(0x0001C391)
   .equ   xlli_MCIO1_value,(0x0001C391)
 .equ   xlli_FLYCNFG_value,(0x00010001)
 .equ   xlli_MDMRSLP_value,(0x0000C008)
  .equ   xlli_SXCNFG_value,(0x40044004)   @ Default value at boot up


@
@ Optimal values for MSCO for various MemClk frequencies are listed below
@ These values are for L18 async flash
@
 .ifdef xlli_C0_BULVERDE

       .equ   xlli_MSC0_13,(0x11101110)
       .equ   xlli_MSC0_19,(0x11101110)
       .equ   xlli_MSC0_26,(0x11201120)   @ 26 MHz setting
       .equ   xlli_MSC0_32,(0x11201120)
       .equ   xlli_MSC0_39,(0x11301130)   @ 39 MHz setting
       .equ   xlli_MSC0_45,(0x11301130)
       .equ   xlli_MSC0_52,(0x11401140)   @ 52 MHz setting
       .equ   xlli_MSC0_58,(0x11401140)
       .equ   xlli_MSC0_65,(0x11501150)   @ 65 MHz setting
       .equ   xlli_MSC0_68,(0x11501150)
       .equ   xlli_MSC0_71,(0x11501150)   @ 71.5 MHz setting
       .equ   xlli_MSC0_74,(0x11601160)
       .equ   xlli_MSC0_78,(0x12601260)   @ 78 MHz setting
       .equ   xlli_MSC0_81,(0x12601260)
       .equ   xlli_MSC0_84,(0x12601260)   @ 84.5 MHz setting
       .equ   xlli_MSC0_87,(0x12701270)
       .equ   xlli_MSC0_91,(0x12701270)   @ 91 MHz setting
       .equ   xlli_MSC0_94,(0x12701270)   @ 94.2 MHz setting
       .equ   xlli_MSC0_97,(0x12701270)   @ 97.5 MHz setting
      .equ   xlli_MSC0_100,(0x12801280)   @ 100.7 MHz setting
      .equ   xlli_MSC0_104,(0x12801280)   @ 104 MHz setting
      .equ   xlli_MSC0_110,(0x12901290)
      .equ   xlli_MSC0_117,(0x13901390)   @ 117 MHz setting
      .equ   xlli_MSC0_124,(0x13A013A0)
      .equ   xlli_MSC0_130,(0x13A013A0)   @ 130 MHz setting
      .equ   xlli_MSC0_136,(0x13B013B0)
      .equ   xlli_MSC0_143,(0x13B013B0)
      .equ   xlli_MSC0_149,(0x13C013C0)
      .equ   xlli_MSC0_156,(0x14C014C0)
      .equ   xlli_MSC0_162,(0x14C014C0)
      .equ   xlli_MSC0_169,(0x14C014C0)
      .equ   xlli_MSC0_175,(0x14C014C0)
      .equ   xlli_MSC0_182,(0x14C014C0)
      .equ   xlli_MSC0_188,(0x14C014C0)
      .equ   xlli_MSC0_195,(0x15C015C0)
      .equ   xlli_MSC0_201,(0x15D015D0)
      .equ   xlli_MSC0_208,(0x15D015D0)

    .else

@ This is a hack to get around some stupid B0 timing issue where it doesn't like the optimal
@ values according to it's own SPEC!?!  These timing values are relaxed from the above optimal
@ but they work for B-step Bulverde... ugh....

       .equ   xlli_MSC0_13,(0x12101210)
       .equ   xlli_MSC0_19,(0x12101210)
       .equ   xlli_MSC0_26,(0x12201220)   @ 26 MHz setting
       .equ   xlli_MSC0_32,(0x12201220)
       .equ   xlli_MSC0_39,(0x13301330)   @ 39 MHz setting
       .equ   xlli_MSC0_45,(0x13301330)
       .equ   xlli_MSC0_52,(0x13401340)   @ 52 MHz setting
       .equ   xlli_MSC0_58,(0x13601360)
       .equ   xlli_MSC0_65,(0x13501350)   @ 65 MHz setting
       .equ   xlli_MSC0_68,(0x13501350)
       .equ   xlli_MSC0_71,(0x14601460)   @ 71.5 MHz setting
       .equ   xlli_MSC0_74,(0x14601460)
       .equ   xlli_MSC0_78,(0x14601460)   @ 78 MHz setting
       .equ   xlli_MSC0_81,(0x14701470)
       .equ   xlli_MSC0_84,(0x14701470)   @ 84.5 MHz setting
       .equ   xlli_MSC0_87,(0x14701470)
       .equ   xlli_MSC0_91,(0x14701470)   @ 91 MHz setting
       .equ   xlli_MSC0_94,(0x14801480)   @ 94.2 MHz setting
       .equ   xlli_MSC0_97,(0x14801480)   @ 97.5 MHz setting
      .equ   xlli_MSC0_100,(0x15801580)   @ 100.7 MHz setting
      .equ   xlli_MSC0_104,(0x15801580)   @ 104 MHz setting
      .equ   xlli_MSC0_110,(0x15901590)
      .equ   xlli_MSC0_117,(0x15A015A0)   @ 117 MHz setting
      .equ   xlli_MSC0_124,(0x15A015A0)
      .equ   xlli_MSC0_130,(0x15B015B0)   @ 130 MHz setting
      .equ   xlli_MSC0_136,(0x16B016B0)
      .equ   xlli_MSC0_143,(0x16C016C0)
      .equ   xlli_MSC0_149,(0x16C016C0)
      .equ   xlli_MSC0_156,(0x16C016C0)
      .equ   xlli_MSC0_162,(0x16C016C0)
      .equ   xlli_MSC0_169,(0x17D017D0)   @ Given that the optimal value would be 13 (RDF), but according to B0 manual, it's different
      .equ   xlli_MSC0_175,(0x17C017C0)
      .equ   xlli_MSC0_182,(0x17C017C0)
      .equ   xlli_MSC0_188,(0x17D017D0)
      .equ   xlli_MSC0_195,(0x17E017E0)
      .equ   xlli_MSC0_201,(0x18E018E0)
      .equ   xlli_MSC0_208,(0x18E018E0)

    .endif @ xlli_C0_BULVERDE

@
@ Optimal values for DTC settings for various MemClk settings (MDCNFG)
@
    .ifdef   xlli_SDRAM_WIDTH_16_BIT

@ Really, we should have yet another flag that is dependant on the SDRAM part, but since only
@ the MCP's SDRAM parameters are different than the MSII platform, I'm choosing to pick the 16-bit
@ width to trigger for the different timing values

        .equ   xlli_DTC_13,(0x00000000)   @ 13 MHz setting
        .equ   xlli_DTC_19,(0x00000000)   @ 19 MHz setting

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -