阅读:7517回复:24
【原创】MULTI BIN的wince 5.0,smdk2440下的实现
原本早就要发出来了,但是看到king_sundi网友已经发过一个帖子了,所以犹豫了没有发,相对而言,我这个总结更具有实用性,基本上照着这个步骤来就能成功,我给我几个朋友试过了,他们一开始对这个基本不懂都能搞定。
XIP实现总结. step1:修改config.bib文件.内核子集XIPKERNEL的SIZE根据你自己编译出来的XIPKERNEL.BIN实际大小调整, XIPKERNEL BASE=8C200000,XIPKERNEL SIZE = 0013F000 内存类型是RAMIMAGE CHAIN BASE = XIPKERNEL BASE + XIPKERNEL SIZE; CHAIN SIZE = 00001000 内存类型是RESERVED NK BASE = CHAIN BASE + CHAIN SIZE;NK SIZE根据你平台定制的实际NK.BIN的大小调整, 内存类型是 NANDIMAGE RAM BASE = NK BASE + NK SIZE; RAM SIZE = 90000000 - RAM BASE, 内存类型是 RAM. pdwXIPLoc 是一个指定地址的全局变量,用于InitRomChain(),它的地址必须等于CHAIN BASE. XIPSCHAIN=8C33F000 也必须等于CHAIN BASE. 关于BIB文件中的MEMORY部分的定义可以从帮助文档中找到答案,搜索MEMORY Section Name Address Size Type 内存区域名字 起始地址 区域空间 内存类型 内存类型的取值分别有FIXUPVAR,NANDIMAGE,RAM,RAMIMAGE,RESERVED. 大家可以特别注意看一下NANDIMAGE的解释 Specifies that RAM should overlap these regions when building an run-time image that uses BINFS. The overlapping regions are stored in NAND but are fixed up to virtually appear as though they do not overlap. When the kernel accesses these regions, BINFS responds by intercepting the request. BINFS accesses NAND and returns the proper data to the kernel. This enables a device with NAND to execute in place out of NAND, freeing up RAM for use by the system. Romimage generates one binary (.bin) file for each NANDIMAGE entry. NANDIMAGE sections must be page aligned. MEMORY XIPKERNEL 8C200000 0013F000 RAMIMAGE CHAIN 8C33F000 00001000 RESERVED NK 8C340000 00D00000 NANDIMAGE RAM 8D040000 02FC0000 RAM ; RAM 8C340000 03CC0000 RAM pdwXIPLoc 00000000 8C33F000 FIXUPVAR ; FLASH 92000000 00100000 RESERVED ; Common RAM areas AUD_DMA 8c002000 00000800 RESERVED SDIO_DMA 8c010000 00010000 RESERVED ARGS 8C020800 00000800 RESERVED DBGSER_DMA 8c022000 00002000 RESERVED SER_DMA 8c024000 00002000 RESERVED IR_DMA 8c026000 00002000 RESERVED ; EDBG 8c030000 00020000 RESERVED ; CAMERA 8c050000 000A0000 RESERVED DISPLAY 8c100000 00100000 RESERVED ; ; ROMFLAGS is a bitmask of options for the kernel ; ROMFLAGS 0x0001 Disallow Paging ; ROMFLAGS 0x0002 Not all KMode ; ROMFLAGS 0x0010 Trust Module only ; CONFIG AUTOSIZE=ON ; ROM_AUTOSIZE=ON DLLADDR_AUTOSIZE=ON COMPRESSION=ON KERNELFIXUPS=ON XIPSCHAIN=8C33F000 PROFILE=OFF ROMFLAGS=00 ROMSTART=8C200000 ROMWIDTH=32 ROMSIZE=00D00000 【注】PB能生成XIP.BIN,这项一定要定义XIPSCHAIN=8C33F000,不然生成不了XIP.BIN的。 step2: 注册表的修改,platform.reg ; HIVE BOOT SECTION ; @CESYSGEN IF CE_MODULES_SDNPCID ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; Support BINFS Section ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ; Add BinFS to partition table [HKEY_LOCAL_MACHINE\System\StorageManager\PartitionTable] "21"="BINFS" [HKEY_LOCAL_MACHINE\System\StorageManager\BINFS] "Folder"="BINFS" "FriendlyName"="Bin FileSystem" "Dll"="binfs.dll" "Paging"=dword:1 ; MountFlags: ; 0x10 specifies that this file system is to be mounted as an external ; ROM filesystem shadowing the \windows directory ; 0x1 specifies that the mountpoint \BINFS is to be hidden ; "MountFlags"=dword:10 "BootPhase"=dword:0 [HKEY_LOCAL_MACHINE\System\StorageManager\AutoLoad\MSFlash] "DriverPath"="Drivers\\BuiltIn\\MSFlash" ; LoadFlags 0x01 == load synchronously "LoadFlags"=dword:1 "Order"=dword:0 ; "MountFlags"=dword:10 "BootPhase"=dword:0 "Flags"=dword:1000 [HKEY_LOCAL_MACHINE\Drivers\BuiltIn\MSFlash] "Prefix"="DSK" "Order"=dword:0 "Dll"="smflash.dll" "Profile"="MSFlash" ; "MountFlags"=dword:10 "FriendlyName"="MSFLASH Driver" "BootPhase"=dword:0 "Flags"=dword:1000 ; Bind BINFS to the block driver [HKEY_LOCAL_MACHINE\System\StorageManager\Profiles\MSFlash] "DefaultFileSystem"="BINFS" "PartitionDriver"="mspart.dll" "AutoMount"=dword:1 "AutoPart"=dword:1 "Folder"="NandFlash" "Name"="Microsoft Flash Disk" "BootPhase"=dword:0 "Flags"=dword:1000 "MountAsHidden"=dword:1 "MountAsRom"=dword:1 ; "MountFlags"=dword:00000004 ; "MountHidden"=dword:00000000 [HKEY_LOCAL_MACHINE\System\StorageManager\Profiles\MSFlash\FATFS] "FriendlyName"="FAT FileSystem" "Dll"="fatfsd.dll" "Flags"=dword:00280014 "Paging"=dword:1 "CacheSize"=dword:0 "EnableCacheWarm"=dword:0 "EnableCache"=dword:1 "MountAsBootable"=dword:1 "MountAsRom"=dword:1 ; "MountAsRoot"=dword:1 ; @CESYSGEN ENDIF CE_MODULES_SDNPCID ; END HIVE BOOT SECTION step3: 系统选用的文件系统必须是RAM and ROM Filesystem,不能用ROM Only. step4: 要知道内核子集XIPKERNEL.BIN必须包含的modules和Files是那些,根据我的实践得出,下面这些文件是必需的: "nk.exe", "coredll.dll", "filesys.exe", "fatfsd.dll", "diskcache.dll", "fatutil.dll", "binfs.dll", "fsdmgr.dll", "mspart.dll", "smflash.dll", "boot.hv", 其它的可选. step5: 使用preromimage.bat和processbib.exe程序,把它们拷贝到你的PLATFORM/SMDK2440/FILES/目录下. 到此改动就算结束了,下面就是开始Build and Sysgen. 生成了XIP.BIN之后烧写到NAND FLASH上,需要你的BOOT支持分区,在烧写的时候自动创建BINFS分区和FAT分区,如果不幸的你用的不是EBOOT的话又不能创建BINFS和FAT分区的话就麻烦大了. 系统起来之后可以看到有个BINFS目录和一个NandFlash目录. step6: 最后一步,修改一下ce.bib的 XIPKERNEL 8C200000 0013F000 RAMIMAGE CHAIN 8C33F000 00001000 RESERVED NK 8C340000 00D00000 NANDIMAGE ; RAM 8D040000 02FC0000 RAM RAM 8C340000 03CC0000 RAM 使RAM的起始地址等于NK的起始地址,这里就是放大了RAM的空间,用命令行方式romimage ce.bib,生成XIPKERNEL.BIN的文件烧到NAND FLASH中去就可以了,有人有问题了发现XIPKERNEL.BIN太小烧不进去,在OEMVerifyMemory()判断里把它判断成了IMAGE_TYPE_RAMIMAGE,所以不写到FLASH了.把这段代码注释掉就好了. /* comment for fix if the image too small and locate in range,then the image type will change to ram image and cause the image can not write to flash. // Is it a ram image? else if ((dwStartAddr >= ROM_RAMIMAGE_START) && ((dwStartAddr + dwLength - 1) < (ROM_RAMIMAGE_START + ROM_RAMIMAGE_SIZE))) { // RETAILMSG(1, (TEXT("Downloading RAM image\r\n"))); g_ImageType = IMAGE_TYPE_RAMIMAGE; return TRUE; } */ 好了,完成,你的程序内存将会是61774K左右. 有疑问吗?我没有提到InitRomChain()函数,实践证明,你不写这个函数,不在OEMInit()里调用它也没有问题.让人感觉是多此一举. |
|
最新喜欢:zoro |
沙发#
发布于:2007-09-30 11:54
to heyong_401:
注意当你做XIP的时候,XIP.BIN才是完整的image,而这时候的NK.BIN只是其中的一部分,还有分两步实现,第5,第6步骤看仔细了。当你利用EBOOT烧写,EBOOT启动,它会自动在第六步烧写的时候把块数调整到XIPKERNEL.BIN的空间大小。这样启动的时候只会启动XIPKERNEL.BIN部分。 to wenzai: 注意第5步,第6步,第5步烧写XIP.BIN,第6步重新烧写XIPKERNEL.BIN部分,这一步来确定XIPKERNEL.BIN的大小,利用EBOOT的BLOCK对齐原则,无需像harktrip提到的指定比你的 XIPKERNEL.BIN略大即可 例如1.5M 或 2M。 to shuiii: 第六步是有点重复了,如果不要第六步,在第五步直接改ce.bib让RAM和NK的起始地址重叠,这样系统是起不来的,第五步让系统跑起来是基础,在此基础上通过第六步实现节省内存,加速启动。有一种变通的方法,你还是烧写第五步生成XIP.BIN,需要你在oal/init.c中实现一个扩展内存的函数,把NK部分的内存抠出来,只是这样你启动的时候将会拷贝整个XIP.BIN到内存,当然你可以指定BOOT只拷贝XIPKERNEL.BIN稍大的部分到内存应该也是可以的。 |
|
板凳#
发布于:2007-09-30 12:59
to shuiii:
你用的是K9F1G08的NAND FLASH,我也用过,前面给BOOT的都是RESERVE块,第一个BLOCK是给NBOOT,第二个BLOCK是给TOC,第三个BLOCK给EBOOT,前面3个BLOCK在烧写完之后都要置成坏块,低格FLASH,下载XIP.BIN烧写,烧写的时候创建了BINFS分区,再创建FAT分区,CE启动后,filesys.exe根据注册表来mount文件系统时会找到MBR块,读出里面的分区信息,来加载。我不知道有没有现成的工具,你可以自己在EBOOT把MBR块的512个字节打印出来分析。 |
|
地板#
发布于:2007-09-30 18:02
to shuiii:
看来你对EBOOT的代码没有研究过,问这么多为什么还不如自己老老实实看代码,把你认为有疑问的地方改掉自己实验好了,实践出真知,有些问题因为你看不到CE启动的源码,不知道它是怎么找MBR记录的。 还有你总是以批量生产来提出疑问,每个产家有自己的解决方法,在这里我只能提供实验学习方法,不能做出最终产品的样子。 我不知道你说的烧片器是什么东西,我使用的是简易JTAG,利用SJF2440程序烧写NBOOT,它不管置不置坏块,总能烧写,而且只需要烧写一次,其它的利用NBOOT启动下载烧写EBOOT,利用EBOOT烧写XIP.BIN等,NBOOT具备升级EBOOT的功能,而EBOOT则具备升级CE系统和本身以及NBOOT等,你可以做EBOOT从SD卡升级所有的东西,这样只要把需要升级的相关文件放到SD卡上,每块板子一插SD卡就可以了。 |
|