大家好、我最近将代码从32位更改为64位、以获得更高的分辨率。 我也已从 COFF 更改为 EABI 设置、但我正在遇到文件链接方面的一些问题。 运行代码时、我的 float 和 int 变量不会更新。
我还使用 了 https://software-dl.ti.com/ccs/esd/documents/C2000_c28x_migration_from_coff_to_eabi.html 页面、并更改 了链接器命令文件更改、并替换了一些主要的下划线问题。 我将下面的编译器设置与.cmd 文件一起附加我所做的更改。
如果我能在这一问题上获得一些援助,那将是非常感谢的。
此致
阿拉法特


F28335.cmd 代码:
/*
//######################################################################################################################
//
//文件:F28335.cmd
//
//标题:F28335器件的链接器命令文件
//
//######################################################################################################################
//$TI 发行版:F2833x/F2823x 头文件和外设示例 V142 $
//$Release Date:2016年11月1日$
//版权所有:版权所有(C) 2007-2016德州仪器(TI)公司-
// http://www.ti.com/ 保留所有权利$
//######################################################################################################################
*
/*===================================================================
//适用于 Code Composer Studio V2.2和更高版本
//--------------------------------------------------------
//除了该内存链接器命令文件外,
//将头文件链接器命令文件直接添加到工程中。
//链接时需要标头链接器命令文件
//将外设结构设置到内部的适当位置
//存储器映射。
//
//在中找到了头文件链接器文件 \DSP2833x_Headers\cmd
//
//对于 BIOS 应用程序添加:DSP2833x_Headers_BIOS.cmd
//对于非 BIOS 应用程序添加:DSP2833x_Headers_nonBIOS.cmd
=================================================================================================== *
/*===================================================================
//对于 V2.2之前的 Code Composer Studio
//--------------------------------------------------------
// 1)使用以下-l 语句之一来包含
//项目中的头链接器命令文件。 头文件链接器
//将外设结构链接到正确的文件
//内存映射中的位置*/
/*取消注释此行以仅包括非 BIOS 应用程序的文件*/
/*-l DSP2833x_Headers_nonBIOS.cmd */
/*取消注释此行以仅包括 BIOS 应用程序的文件*/
/*-l DSP2833x_Headers_BIOS.cmd */
/* 2)在项目中添加路径 \DSP2833x_headers\cmd 至
库搜索路径位于 project->build options、linker tab、
库搜索路径(-I)。
/*================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================ *
/*定义 F28335的内存块开始/长度
PAGE 0将用于组织程序段
第1页将用于组织数据段
注:
F28335上的存储器块是一致的(即相同的
物理存储器)。
不应该是相同的存储器区域
同时为 PAGE 0和 PAGE 1定义。
这样做将导致程序损坏
和/或数据。
L0/L1/L2和 L3存储器块被镜像-即
它们可以在高内存或低内存中访问。
为简单起见、其中仅使用了一个实例
链接器文件。
可组合连续 SARAM 存储器块
如果需要创建更大的存储器块。
*
存储器
{
第0页:/*程序内存*/
/*内存(RAM/FLASH/OTP)块可移动到第1页进行数据分配*/
ZONE0:origin = 0x004000,length = 0x001000 // XINTF 区域0 */
RAML0:origin = 0x008000、length = 0x001000 //片上 RAM 块 L0 */
RAML1:origin = 0x009000,length = 0x001000 //片上 RAM 块 L1 */
RAML2:origin = 0x00A000、length = 0x001000 //片上 RAM 块 L2 */
RAML3:origin = 0x00B000、length = 0x001000 //片上 RAM 块 L3 *
ZONE6:origin = 0x0100000,length = 0x100000 // XINTF 区域6 */
ZONE7A:origin = 0x0200000,length = 0x00FC00 /* XINTF 区域7-程序空间*/
FLASHH:origin = 0x300000、length = 0x008000 //片上闪存*/
FLASHG:origin = 0x308000、length = 0x008000 //片上闪存*/
FLASHF:origin = 0x310000、length = 0x008000 //片上闪存*/
FLASHE:origin = 0x318000、length = 0x008000 //片上闪存*/
FLASHD:origin = 0x320000,length = 0x008000 //片上闪存*/
FLASHC:origin = 0x328000,length = 0x008000 //片上闪存*/
FLASHA:origin = 0x338000,length = 0x007F80 //片上闪存*/
csm_RSVD:origin = 0x33FF80,length = 0x000076 // FLASHA 的一部分。 当 CSM 正在使用时、使用所有0x0000进行编程。 *
begin:origin = 0x33FFF6,length = 0x000002/* FLASHA 的一部分。 用于"引导至闪存"引导加载程序模式。 *
CSM_PWL:origin = 0x33FFF8,length = 0x000008 // FLASHA 的一部分。 FLASHA 中的 CSM 密码位置*/
OTP:origin = 0x380400,length = 0x000400 //片上 OTP */
ADC_CAL:origin = 0x380080,length = 0x000009 //保留存储器中的 ADC_cal 函数*/
IQTABLES:origin = 0x3FE000,length = 0x000b50 //引导 ROM 中的 IQMath 表*/
IQTABLES2:origin = 0x3FEB50,length = 0x00008c //引导 ROM 中的 IQMath 表*/
FPUTABLES:origin = 0x3FEBDC,length = 0x0006A0 //引导 ROM 中的 FPU 表*/
ROM:origin = 0x3FF27C,length = 0x000D44 //引导 ROM */
复位:origin = 0x3FFFC0,length = 0x000002 //引导 ROM 的部分*/
向量:origin = 0x3FFFC2,length = 0x00003E //引导 ROM 的部分*/
第1页:/*数据存储器*/
/*内存(RAM/FLASK/OTP)块可被移动至 PAGE0以进行程序分配*/
/*寄存器保留在第1页中*/
BOOT_RSVD:origin = 0x000000,length = 0x000050 // M0的一部分,引导 ROM 将此用于栈*/
RAMM0:origin = 0x000050、length = 0x0003B0 //片上 RAM 块 M0 *
RAMM1:origin = 0x000400、length = 0x000400 //片上 RAM 块 M1 *
RAML4:origin = 0x00C000、length = 0x001000 //片上 RAM 块 L1 */
RAML5:origin = 0x00D000、length = 0x001000 //片上 RAM 块 L1 */
RAML6:origin = 0x00E000、length = 0x001000 //片上 RAM 块 L1 */
RAML7:origin = 0x00F000、length = 0x001000 //片上 RAM 块 L1 */
ZONE7B:origin = 0x20FC00,length = 0x000400 // XINTF 区域7- data space */
FLASHB:origin = 0x330000,length = 0x008000 //片上闪存*/
}
/*将段分配给内存块。
注:
DSP28_CodeStartBranch.asm 中用于重定向代码的 codestart 用户定义段
闪存时执行
ramfuncs 用户定义的段来存储将从闪存复制到 RAM 中的函数
*
部分
{
/*分配计划领域:*/
.cinit:> FLASHA PAGE = 0
init_array:> FLASHA,page = 0
.text:> FLASHA PAGE = 0
codestart:> begin page = 0
ramfuncs:load = FLASHD,
运行= RAML0、
Load_start (RamfuncsLoadStart)、
Load_End (RamfuncsLoadEnd)、
RUN_START (RamfuncsRunStart)、
load_size (RamfuncsLoadSize)、
PAGE = 0
csmpasswds:>csm_PWL page = 0
csm_rsvd:>csm_RSVD page = 0
/*分配未初始化的数据段:*/
.stack:>RAMM1 page = 1.
.bss:> RAML4 PAGE = 1.
.sysmem:>RAMM1 PAGE = 1.
/*初始化段进入闪存*/
/*要使 SDFlash 对这些内容进行编程、必须将它们分配到第0页*/
.const:> FLASHA PAGE = 0
.switch:> FLASHA PAGE = 0
/*分配 IQ 数学区域:*/
IQMath:> FLASHC page = 0 /*数学代码*/
IQmathTables :>IQTABLES,PAGE = 0,TYPE = NOLOAD
/*如果调用 IQNexp()或 IQexp(),请取消注释以下部分
库中的函数、以便利用
引导 ROM 中的相关 IQ Math 表(这可以节省空间和引导 ROM
1个等待状态)。 如果此部分未注释、则为 IQmathTables2
将被加载到其他存储器(SARAM、闪存等)中并将采用
上行空间、但0等待状态是可能的。
*
/*
IQmathTables2:> IQTABLES2,PAGE = 0,TYPE = NOLOAD
{
IQMath.lib (IQmathTablesRam)
}
*
FPUmathTables:> FPUTABLES,PAGE = 0,TYPE = NOLOAD
/*分配可通过 DMA 访问的 RAM 段:*/
DMARAML4:>RAML4,PAGE = 1
DMARAML5:>RAML5,PAGE = 1
DMARAML6:>RAML6,PAGE=1
DMARAML7:>RAML7,PAGE=1
/*分配 XINTF 区域7的0x400来存储数据*/
ZONE7DATA:> ZONE7B,PAGE = 1.
/*.reset 是编译器使用的标准段。 它包含*/
/* C 代码_c_int00起始地址。 /*
/*当使用引导 ROM 时,此部分和 CPU 矢量*/
/*不需要表。 因此、默认类型设置为*/
/* DSECT */
.reset:> reset,page = 0,type = DSECT
VECTORS:> VECTORS PAGE = 0,TYPE = DSECT
/*分配 ADC_cal 函数(出厂时已预先编程到 TI 保留存储器中)*/
ADC_cal:load = ADC_CAL、page = 0、type = NoLoad
}
/*
//============================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================
//文件结束。
//============================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================
*