TMS320F28335的存储空间

TMS320F28335的存储空间 

MS320F28335为哈佛结构的DSP,在逻辑上有4M×16位的程序空间和4M×16位点的数据空间,但在物理上已将程序空间和数据空间统一成一个4M×16位的空间。TMS320F28335片上有256K×16位的FLASH,34K×16位的SRAM,8K×16位的BOOT ROM,2K×16位的OPT ROM。

1、 TMS320F28335片上SARAM

TMS320F28335片内共有34K×16位单周期单次访问随机存储器的SARAM,分成10个块,他们分别称为M0、M1、L0-L7。

 

MO和M1块SARAM的大小均为1K×16位,当复位后,堆栈指针指向M1块的起始地址,堆栈指针向上生长。M0和M1段都可以映射到程序区和数据区。

 

L0-L7块SARAM的大小均为4K×16位,既可映射到程序空间,也可映射到数据空间,其中L0-L3可映射到两块不同的地址空间并且受片上的FLASH中的密码保护,以免存在上面的程序或数据,被他人非法拷贝。

 

2、 TMS320F28335片上FLASH和OTP

    TMS320F28335片上有256K×16位嵌入式FLASH存储器和1K×16位一次可编程EEPROM存储器,他们均受片上FLASH中的密码保护。FLASH存储器由8个32K×16位扇区组成,用户可以对其中任何一个扇区进行擦除、编程和校验,而其他扇区不变。但是,不能在其中一个扇区上执行程序来擦除和编程其他的扇区。

 

3、 TMS320F28335外部存储器接口

   TMS320F28335的外部存储器接口包括:20位地址线,16(最大32)位数据线,3个片选控制线及读写控制线。这3个片选线映射到3个存储区域,Zone0,Zone6和Zone7。这3个存储器可分别设置不同的等待周期。

Zone0  存储区域:    0X004000—0X004FFF, 4K×16位   可编程最少一个等待周期

Zone6  存储区域:    0X100000—0X1FFFFF, 1M×16位  10ns   最少一个等待周期

Zone7  存储区域:    0X200000—0X2FFFFF, 1M×16位  70ns   最少一个等待周期

    以下是我写的一个RAM仿真的CMD文件,已经调试通过了,硬件设计的外扩的RAM为Zone6空间,存储区域:0X100000—0X1FFFFF。


MEMORY
{
PAGE 0 :
   /* BEGIN is used for the "boot to SARAM" bootloader mode      */
   /* BOOT_RSVD is used by the boot ROM for stack.               */
   /* This section is only reserved to keep the BOOT ROM from    */
   /* corrupting this area during the debug process              */
  
   BEGIN      : origin = 0x000000, length = 0x000002     /* Boot to M0 will go here                      */
   BOOT_RSVD  : origin = 0x000002, length = 0x00004E     /* Part of M0, BOOT rom will use this for stack */              
   RAMM0      : origin = 0x000050, length = 0x0003B0

   RAML0      : origin = 0x008000, length = 0x001000   
   RAML1      : origin = 0x009000, length = 0x001000   
   RAML2      : origin = 0x00A000, length = 0x001000   
   RAML3      : origin = 0x00B000, length = 0x001000

   CSM_RSVD   : origin = 0x33FF80, length = 0x000076     /* Part of FLASHA.  Program with all 0x0000 when CSM is in use. */
   CSM_PWL    : origin = 0x33FFF8, length = 0x000008     /* Part of FLASHA.  CSM password locations in FLASHA            */
   ADC_CAL    : origin = 0x380080, length = 0x000009
   RESET      : origin = 0x3FFFC0, length = 0x000002
   IQTABLES   : origin = 0x3FE000, length = 0x000b50
   IQTABLES2  : origin = 0x3FEB50, length = 0x00008c
   FPUTABLES  : origin = 0x3FEBDC, length = 0x0006A0
   BOOTROM    : origin = 0x3FF27C, length = 0x000D44              
   ZONE6      : origin = 0x100000, length = 0x040000     /* XINTF zone 6 - data space */
        
PAGE 1 :
   RAMM1      : origin = 0x000400, length = 0x000400     /* on-chip RAM block M1 */
   RAML      : origin = 0x00C000, length = 0x004000   
 
   ZONE6     : origin = 0x140000, length = 0x040000     /* XINTF zone 6 - data space */

}
 
 
SECTIONS
{
   /* Setup for "boot to SARAM" mode:
      The codestart section (found in DSP28_CodeStartBranch.asm)
      re-directs execution to the start of user code.  */
   codestart        : > BEGIN,     PAGE = 0
   ramfuncs         : > RAML0,     PAGE = 0 
   .text            : > ZONE6,     PAGE = 0
   .cinit           : > RAML0,     PAGE = 0
   .pinit           : > RAML0,     PAGE = 0
   .switch          : > RAML0,     PAGE = 0
  
   .stack           : > RAML,     PAGE = 1
   .ebss            : > RAML,     PAGE = 1
   .econst          : > ZONE6,     PAGE = 1     
   .esysmem         : > RAML,     PAGE = 1

   IQmath           : > RAML1,     PAGE = 0
   IQmathTables     : > IQTABLES,  PAGE = 0, TYPE = NOLOAD
   IQmathTables2    : > IQTABLES2, PAGE = 0, TYPE = NOLOAD
   FPUmathTables    : > FPUTABLES, PAGE = 0, TYPE = NOLOAD
     

  
 

   .reset           : > RESET,     PAGE = 0, TYPE = DSECT /* not used                    */
   csm_rsvd         : > CSM_RSVD   PAGE = 0, TYPE = DSECT /* not used for SARAM examples */
   csmpasswds       : > CSM_PWL    PAGE = 0, TYPE = DSECT /* not used for SARAM examples */
  

    
}

下图为存储空间地址分配。

 

  • 5
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TMS320F28335是TI公司的一款TMS320C28X系列浮点DSP控制器,具有高精度、低成本、低功耗、高性能等特点。它采用内部1.9V供电和外部3.3V供电,功耗较低,主频高达150MHz,处理速度快,适用于需要浮点运算的便携式产品。\[2\] 在设计TMS320F28335时,需要注意以下几点: 1. 布局设计:TI官网提供了《Hardware Design Guidelines for TMS320F28xx and TMS320F28xxx DSCs》文档,详细介绍了如何进行布局设计,完全消化该文档可以确保Demo板功能正常运行。\[1\] 2. GPIO引脚:TMS320F28335具有88个可编程的复用GPIO引脚,可以根据需要进行配置和使用。 3. 低功耗模式:TMS320F28335支持低功耗模式,可以在不需要高性能时降低功耗。 4. 存储器映射:需要注意TMS320F28335的存储器映射,片上外设寄存器块0~3只能用于数据存储区,OTP ROM区为只读空间,不能写入程序。还需注意设置安全代码时的存储器区域的使用限制。\[3\] 综上所述,设计TMS320F28335时需要遵循TI官方提供的布局设计指南,注意GPIO引脚的配置和使用,合理利用低功耗模式,并遵循存储器映射的相关规定。这样可以确保设计的稳定性和性能。 #### 引用[.reference_title] - *1* [一款验证浮点DSP-TMS320F28335的Demo板——电源设计(1)](https://blog.csdn.net/rootxie124/article/details/37574271)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [TMS320F28335及其最小系统设计](https://blog.csdn.net/Augusdi/article/details/7578185)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值