博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
WINCE RAM的扩展(64M->128M)
阅读量:2351 次
发布时间:2019-05-10

本文共 2318 字,大约阅读时间需要 7 分钟。

   都是之前的东西了,现在才记录,发现有的东西都不记得了。

   RAM的扩展分两种,一种是内存地址空间是连续的,另一种就是非连续的。

 

   对于连续的RAM空间扩展。我们同样用环境变量以示区分原来的代码,利用”SDRAM128M“来表示。内存的初始化,应该在Bootloader里有应该初始化,这样才能充分利用128M RAM。

    首先需要扩大映射的地址空间,在BSP/Src/Inc目录下有个”oemaddrtab_cfg.inc“文件,在这里需要扩展RAM的大小,如下:

 

g_oalAddressTable

 [ {TRUE}

 IF :DEF: SDRAM128M
        DCD     0x80000000, 0x30000000, 128      ; 128 MB DRAM BANK 6
 ELSE
        DCD     0x80000000, 0x30000000, 64      ; 64 MB DRAM BANK 6
        DCD     0x84000000, 0x10000000, 32      ; 32 MB SROM(SRAM/ROM) BANK 2
        DCD     0x86000000, 0x18000000, 32      ; 32 MB SROM(SRAM/ROM) BANK 3
        DCD     0x88000000, 0x20000000, 32      ; 32 MB SROM(SRAM/ROM) BANK 4
        DCD     0x8A000000, 0x28000000, 32      ; 32 MB SROM(SRAM/ROM) BANK 5
        DCD     0x8C000000, 0x08000000, 32      ; 32 MB SROM(SRAM/ROM) BANK 1
 ENDIF

......

这个Table记录了硬件信息的映射地址。还是利用宏开关,如果设置”SDRAM128M“,则系统是128M RAM,否则就是原来系统默认的。

然后我们就需要在Eboot里去初始化RAM,但是在初始化之前需要定义在汇编里可以用的宏开关,BSP/Src/Inc目录下有个本平台的inc文件,如我这里的就是s3c2443.inc,在这个文件里定义一个全局变量:

GBLA    SDRAM128M_S

 IF :DEF: SDRAM128M
SDRAM128M_S SETA 1 

 ELSE

SDRAM128M_S SETA 0 
 ENDIF

这里主要就是定义一个算数变量SDRAM128M_S,这个变量我们会在Eboot里的startup.s里用到。

在startup.s里我们需要初始化RAM,使其能扩展到128M,如下:

[ SDRAM128M_S=1 ;

 mov  r3, #128
 ]
 [ SDRAM128M_S=0 ;
 mov  r3, #64
 ]
45 mov  r2, r1    ; (r2) = virtual address to map Bank at
 cmp  r2, #0x20000000:SHR:BANK_SHIFT
 add  r2, r10, r2, LSL #BANK_SHIFT-18
 strlo    r0, [r2]
 add  r0, r0, #0x00100000  ; (r0) = PTE for next physical page
 subs     r3, r3, #1
 add  r1, r1, #1
 bgt  %b45

对r3进行赋值,这样的话,就可以在蓝色部分里全部初始化这128M RAM。

此时,128M的RAM就扩展成功了。

 

另一种就是非连续的RAM扩展,这部分东西当时好像就是参照MSDN上的文档做的。

首先也是需要在BSP/Src/Inc目录下找到”oemaddrtab_cfg.inc“文件,添加没有映射的那部分地址,如下:

g_oalAddressTable

    [ {TRUE}
       DCD     0x80000000, 0x30000000, 64      ; 64 MB DRAM BANK 6
       IF :DEF: SDRAM128M
       DCD     0x84000000, 0x38000000, 64
       ENDIF

......

从上面可以看到地址空间不是连续的。通过宏开关,当设置时,就是128M的RAM,不设置时就是默认的64M。

仅仅添加上面的系统还是认不出128M的RAM,还需要在memory的驱动里定义函数OEMGetExtensionDRAM才行。这个memory目录一般位于BSP/Src/Common/memory中,在memory.c中添加该函数的实现。如下简单实现:

#ifdef SDRAM128M

BOOL OEMGetExtensionDRAM(LPDWORD pMemoryStart, LPDWORD pMemoryLength)
{
 BOOL bRet = FALSE;
 *pMemoryStart = 0x84000000;
     *pMemoryLength   = 0x4000000;
     bRet=TRUE;
    return bRet;
}
#endif

此时系统可以识别到不连续的128M的RAM。

 

宏开关设置和上篇NAND Flash 128M的设置相似。在BSP下的bat文件添加环境变量"set SDRAM128M=1"

然后在BSP下的sources.cmn下添加如下代码,系统就可以识别128M的RAM。

!IF "$(SDRAM128M)" == "1"

CDEFINES=$(CDEFINES) -DSDRAM128M
ADEFINES=$(ADEFINES) -pd "SDRAM128M SETS /"1/""
!ENDIF

以上就是对RAM 128M的扩展,两种方法我都试过,应该没有问题。

转载地址:http://eprvb.baihongyu.com/

你可能感兴趣的文章
SourceInsight添加对汇编语言文件.s和.S的支持
查看>>
windows 下实现函数打桩:拦截API方式
查看>>
获取Windows系统版本
查看>>
漫谈兼容内核之十二:Windows的APC机制
查看>>
21.windbg-.lastevent、!analyze(dump分析、异常错误码查询)
查看>>
16.windbg-.frame、dt(切换局部上下文、查找结构体)
查看>>
为何new出的对象数组必须要用delete[]删除,而普通数组delete和delete[]都一样-------_CrtMemBlockHeader
查看>>
windbg调试命令:!peb、!teb
查看>>
开源任务管理器 Process Hacker (Windows)
查看>>
快速发现Windows中毒的工具:Process Hacker
查看>>
Process Hacker源码中的用户态hook的做法
查看>>
Get IT技能知识库 50个领域一键直达
查看>>
浅析C++中的this指针及汇编实现
查看>>
关于32位程序在64位系统下运行中需要注意的重定向问题(有图有真相)(***)
查看>>
解决win10系统中截图异常放大的问题
查看>>
关于Windows高DPI的一些简单总结
查看>>
tlb文件为何而生?
查看>>
IE9 GPU硬件加速到底是实用创新还是噱头
查看>>
UpdateLayeredWindow与SetLayeredWindowAttributes的使用
查看>>
IM消息送达保证机制实现(二):保证离线消息的可靠投递
查看>>