分类: LINUX
2009-06-14 12:52:39
在这里,exec_address1是RO区域的执行地址,它与RO区域在代码加载时的地址相同。exec_address2是RW的代码执行地址,它与RW区在加载时的地址是不一样的,RW在加载时是紧接在R0区域后面的,因此在C程序执行之前,它必须被移到正确的地址上去。同时,ZI区域也必须重新创建(因为在加载阶段,不存在ZI区域)。
在一个简单的image里面:
Image$$RO$$Base:是RO段的执行地址开始和装载地址开始,由-RO-BASE这个参数指定的
Image$$RO$$Limit:是RO段的装载地址结束的后一个地址,也就是RW的装载地址的开始。(在一个simple image里面,装载的时候,RO段被装载在-RO-BASE指定的地址,后面紧跟着的是RW的数据,注意,在simple image执行的时候,因为ro段的装载地址和执行地址相同,所以不需要移动,而RW的执行地址是由-RW-BASE指定的,所以需要移动!)
Image$$RW$$Base:是rw段的执行地址,由-rw-base这个参数指定!
总结一下:
没运行前:flash中的ro段是ro-base指定的地址开始,等ro段完了(也就是Image$$RO$$Base~Image$$RO$$limit-1),后面紧接着就是rw段(也就是Image$$RO$$limit~。。。)!
运行时:flash中的ro段地址没有动,还是Image$$RO$$Base~Image$$RO$$limit-1,原来flash中的rw段移到了sdram中,地址为Image$$RW$$Base~Image$$ZI$$Base,然后又初始化了一段ZI区!