能在DSP的片内Flash调试程序吗?

[复制链接]
 楼主| shell.albert 发表于 2012-8-19 21:12 | 显示全部楼层 |阅读模式
使用TMS320F2812,不想外扩RAM了,片内有128K flash,请问一下能直接使用片内调 试程序吗?

马达控制程序有多大,片内flash能存储得了吗?
jlass 发表于 2012-8-20 10:33 | 显示全部楼层
我用STM32VC5416的,程序小,从来不外扩RAM
2812没用过,但我觉得只要你的程序放的下,肯定可以啊
jlass 发表于 2012-8-20 10:37 | 显示全部楼层
看了你的另一片帖子,我觉得应该改一下

程序要烧在ram里
 楼主| shell.albert 发表于 2012-8-20 17:12 | 显示全部楼层
程序一般在RAM中调试,
我的意思是如果RAM不够的话,可以烧写进Flash,在Flash中调试吗?
好像不能吧。程序运行必须要在RAM中。
jlass 发表于 2012-8-21 09:39 | 显示全部楼层
因为我用的DSP没有内置flash,我不敢打包票
不过我觉得只要空间够,内置的flash与外置的flash没差别
你只要确认一下内置的flash是否是程序空间即可(区别于数据空间与IO空间)
你可以在datasheet中确认一下,也可以实测一下
RivFlood 发表于 2012-8-21 15:42 | 显示全部楼层
2812可以在Flash中调试程序,不太方便的是断点太少,另外还要经常烧录Flash,可能会因意外烧死Flash,调试速度也偏慢,如果可以,可以在RAM中调试好在转到Flash中,前提是你的程序不要太大,否次因为RAM容量限制,无法完全在RAM中调试运行
595332542 发表于 2014-5-16 11:20 | 显示全部楼层
cmd文件如下所示
  1. /*         
  2.          Contiguous SARAM memory blocks can be combined
  3.          if required to create a larger memory block.
  4. */


  5. MEMORY
  6. {
  7. PAGE 0 :
  8.    /* BEGIN is used for the "boot to SARAM" bootloader mode      */
  9.    /* BOOT_RSVD is used by the boot ROM for stack.               */
  10.    /* This section is only reserved to keep the BOOT ROM from    */
  11.    /* corrupting this area during the debug process              */
  12.    
  13.    BEGIN      : origin = 0x000000, length = 0x000002     /* Boot to M0 will go here                      */
  14.    BOOT_RSVD  : origin = 0x000002, length = 0x00004E     /* Part of M0, BOOT rom will use this for stack */               
  15.    RAMM0      : origin = 0x000050, length = 0x0003B0
  16. /*
  17.    RAML0      : origin = 0x008000, length = 0x001000   
  18.    RAML1      : origin = 0x009000, length = 0x001000   
  19.    RAML2      : origin = 0x00A000, length = 0x001000   
  20.    RAML3      : origin = 0x00B000, length = 0x001000
  21. */
  22.    RAML       : origin = 0x008000, length = 0x004000
  23.    ZONE7A     : origin = 0x200000, length = 0x00FC00    /* XINTF zone 7 - program space */
  24.    CSM_RSVD   : origin = 0x33FF80, length = 0x000076     /* Part of FLASHA.  Program with all 0x0000 when CSM is in use. */
  25.    CSM_PWL    : origin = 0x33FFF8, length = 0x000008     /* Part of FLASHA.  CSM password locations in FLASHA            */
  26.    ADC_CAL    : origin = 0x380080, length = 0x000009
  27.    RESET      : origin = 0x3FFFC0, length = 0x000002
  28.    IQTABLES   : origin = 0x3FE000, length = 0x000b50
  29.    IQTABLES2  : origin = 0x3FEB50, length = 0x00008c
  30.    FPUTABLES  : origin = 0x3FEBDC, length = 0x0006A0
  31.    BOOTROM    : origin = 0x3FF27C, length = 0x000D44               

  32.          
  33. PAGE 1 :
  34.    RAMM       : origin = 0x000400, length = 0x000400     /* on-chip RAM block M1 */
  35. /*
  36.    RAML4      : origin = 0x00C000, length = 0x001000   
  37.    RAML5      : origin = 0x00D000, length = 0x001000   
  38.    RAML6      : origin = 0x00E000, length = 0x001000   
  39.    RAML7      : origin = 0x00F000, length = 0x001000
  40. */
  41.    RAMH       : origin = 0x00C000, length = 0x004000
  42.    ZONE7B     : origin = 0x20FC00, length = 0x000400     /* XINTF zone 7 - data space */
  43. }


  44. SECTIONS
  45. {
  46.    /* Setup for "boot to SARAM" mode:
  47.       The codestart section (found in DSP28_CodeStartBranch.asm)
  48.       re-directs execution to the start of user code.  */
  49.    codestart        : > BEGIN,     PAGE = 0
  50.    ramfuncs         : > RAML,      PAGE = 0  
  51.    .text            : > RAML,      PAGE = 0
  52.    .cinit           : > RAML,      PAGE = 0
  53.    .pinit           : > RAML,      PAGE = 0
  54.    .switch          : > RAML,      PAGE = 0
  55.    
  56.    .stack           : > RAMM,      PAGE = 1
  57.    .ebss            : > RAMH,      PAGE = 1
  58.    .econst          : > RAMH,      PAGE = 1   
  59.    .esysmem         : > RAMM,      PAGE = 1

  60.    IQmath           : > RAML,      PAGE = 0
  61.    IQmathTables     : > IQTABLES,  PAGE = 0, TYPE = NOLOAD
  62.    IQmathTables2    : > IQTABLES2, PAGE = 0, TYPE = NOLOAD
  63.    FPUmathTables    : > FPUTABLES, PAGE = 0, TYPE = NOLOAD
  64. /*      
  65.    DMARAML4         : > RAML4,     PAGE = 1
  66.    DMARAML5         : > RAML5,     PAGE = 1
  67.    DMARAML6         : > RAML6,     PAGE = 1
  68.    DMARAML7         : > RAML7,     PAGE = 1
  69. */   
  70.    ZONE7DATA        : > ZONE7B,    PAGE = 1  

  71.    .reset           : > RESET,     PAGE = 0, TYPE = DSECT /* not used                    */
  72.    csm_rsvd         : > CSM_RSVD   PAGE = 0, TYPE = DSECT /* not used for SARAM examples */
  73.    csmpasswds       : > CSM_PWL    PAGE = 0, TYPE = DSECT /* not used for SARAM examples */
  74.    
  75.    /* Allocate ADC_cal function (pre-programmed by factory into TI reserved memory) */
  76.    .adc_cal     : load = ADC_CAL,   PAGE = 0, TYPE = NOLOAD
  77.      
  78. }

  79. /*
  80. //===========================================================================
  81. // End of file.
  82. //===========================================================================
  83. */
yanerwuming 发表于 2015-11-5 11:23 | 显示全部楼层
Flash中直接运行,速度很慢
您需要登录后才可以回帖 登录 | 注册

本版积分规则

个人签名:烟台电工@張紹言

32

主题

1934

帖子

8

粉丝
快速回复 在线客服 返回列表 返回顶部
个人签名:烟台电工@張紹言

32

主题

1934

帖子

8

粉丝
快速回复 在线客服 返回列表 返回顶部