2440外接有SDRAM,Nor Flash,Nand Flash(通过Nand Flash控制,CPU可以直接控制SRAM,SDRAM,Nor Flash,但不能直接控制Nand),同时内部还有4K的SRAM(Nor启动时,起始位置为0x4000,0000;Nand启动时,起始位置为0)。
1.4.1 段的概念_重定位的引入
使用Nand启动时,不可访问Nor,因为Nor的片选接到了nGCS0。另外,Nor可以像内存一样读,但不可以像内存一样写,这是由Nor的物理结构决定的
1.4.1 段的概念_重定位的引入
使用Nand启动时,前4K的代码会由硬件复制到SRAM中,程序也会从地址0即SRAM中开始执行,这样做可以保证程序正常启动(Steppingstone,垫脚石),但如果程序超过4K,则需要用这前4K的代码将整个程序读出放到SDRAM中(重定位),否则程序无法正常运行。
1.4.1 段的概念_重定位的引入
一个程序,主要含有代码段和数据段。

  1. 代码段(code):text
  2. 数据段(rwdata):含初值的全局变量和静态变量
  3. 只读数据段(rodata):被const修饰的全局变量
  4. 未初始化数据段(bss段,(Block Started by Symbol)):未赋初值的全局变量和静态变量(不保存在bin中,我们程序里面将它清零即可)

除了这些,还有一个comment段,里面是一些注释信息,如下图,474343为ASCII的GCC。
1.4.1 段的概念_重定位的引入

相关文章:

  • 2021-07-18
  • 2022-12-23
  • 2022-12-23
  • 2021-10-30
  • 2021-04-05
  • 2021-08-31
猜你喜欢
  • 2021-12-27
  • 2021-06-14
  • 2021-12-12
  • 2021-09-15
  • 2022-12-23
  • 2021-06-28
  • 2022-01-06
相关资源
相似解决方案