2440外接有SDRAM,Nor Flash,Nand Flash(通过Nand Flash控制,CPU可以直接控制SRAM,SDRAM,Nor Flash,但不能直接控制Nand),同时内部还有4K的SRAM(Nor启动时,起始位置为0x4000,0000;Nand启动时,起始位置为0)。
使用Nand启动时,不可访问Nor,因为Nor的片选接到了nGCS0。另外,Nor可以像内存一样读,但不可以像内存一样写,这是由Nor的物理结构决定的
使用Nand启动时,前4K的代码会由硬件复制到SRAM中,程序也会从地址0即SRAM中开始执行,这样做可以保证程序正常启动(Steppingstone,垫脚石),但如果程序超过4K,则需要用这前4K的代码将整个程序读出放到SDRAM中(重定位),否则程序无法正常运行。
一个程序,主要含有代码段和数据段。
- 代码段(code):text
- 数据段(rwdata):含初值的全局变量和静态变量
- 只读数据段(rodata):被const修饰的全局变量
- 未初始化数据段(bss段,(Block Started by Symbol)):未赋初值的全局变量和静态变量(不保存在bin中,我们程序里面将它清零即可)
除了这些,还有一个comment段,里面是一些注释信息,如下图,474343为ASCII的GCC。