多核的映像文件是由二级加载器Loader和多个核应用的根表合并而成的文件。多个核对应多个独立的工程,并由CCS 产生多个out 文件,再由hex6x.exe 产生各核的根表文件。后对Core0 的根表文件先去掉末尾4 个0字节,再将各辅助核的根表文件的开始的入口地址_C_int00和末尾4个0字节去掉,加到Core0被去掉了末尾字节的根表文件后,然后再将每个核的_C_int00当成一个4字节的数据段来保存到上面的合成文件的后面,而各_C_int00在片上的存放地址即为各核的专门固定地址Boot Magic Address,如Core1 的Boot Magic Ad-dress 为0x1187fffc,Core2 为0x1287fffc,…,Core7 为0x1787fffc.所有根表数据段构成后,再将4个0字节作为结尾标志加到文件的最后,这样合并后的根表文件如表2所示。同样,将二级Loader的代码数据加到该文件头部即形成多核的映像文件。由hex6x 生成的单核根表文件到合成映像文件的产生,全是文件操作,可以用一般的C语言工具,甚至Matlab等工具都可以完成。
text-indent: 2em; font-family: 宋体, Georgia, verdana, serif; ">同表1相比,表2仅仅只是增加了所有辅助核数据段和各核的_C_int00特殊数据段而已,表头和结束字节都相同,因此完全适用于二级Loader按统一Boot Table格式搬移数据。需特别注意,各辅助核的out文件通过hex6x.exe 产生的根表数据段中,当映射到L2(0×00800000~0x0087FFFF)的范围时,与Core0 的地址是相互覆盖的,产生合成根表时必须加上各核的L2基地址0×10000000 + n*0×1000000(n 为辅助核号),如Core1 的地址0×00825000,映射为0×11825000,同样地址Core2映射为0×12825000,Core7映射为0×17825000.
|