tms320f28379 launchpad 内存扩展板 的 调试问题
tms320f28379 launchpad内存扩展板256k x 16 bit sram .设计文件https://github.com/zzsczz/ram4f28379d
正面 https://raw.githubusercontent.com/zzsczz/ram4f28379d/master/top.jpg
原理图https://github.com/zzsczz/ram4f28379d/blob/master/memboard.pdf
c2000wareemif1 sram example for f28379d ("C2000Ware_1_00_06_00\device_support\f2837xd\examples\cpu1\emif1_16bit_asram") 工作正常
默认
#define ASRAM_CS2_START_ADDR 0x100000
#define ASRAM_CS2_SIZE 0x8000
32kx16 大小测试
改了 之后各种 错误
1
ASRAM_CS2_SIZE to 0x8100 ,调试 得到 "ErrCount equals 1"
但
ASRAM_CS2_START_ADDR 0x107000
ASRAM_CS2_SIZE to 0x2100
又正常
2
ASRAM_CS2_START_ADDR 0x100000
ASRAM_CS2_SIZE to 0x40000
程序 进 函数 "mem_read_write" 就死循环了 ,就是这几行
for (i=0; i < mem_size; i++)
{ *XMEM_ps++ = mem_wds;
mem_wds += 0x11111111; }
如何解决 大于32kx16 内存的 测试? 有 c2000ware的电工能帮忙看看么?
c2000 ccs 中 的int 是 16位么?
https://raw.githubusercontent.com/zzsczz/ram4f28379d/master/top.jpg
sizeof(int )看一下不就知道了 rom 发表于 2019-7-6 20:24
sizeof(int )看一下不就知道了
sizeof(int ) 1
sizeof(Uint16 )1
sizeof(Uint32 )2
本帖最后由 zzsczz 于 2019-7-7 12:50 编辑
已经定位了 问题所在:
char
mem_read_write(Uint32 start_addr, Uint32 mem_size)
{
unsigned long mem_rds;
unsigned long mem_wds;
long *XMEM_ps;
//unsigned int i;
Uint32i1,i2;
//
//Write data
//
XMEM_ps = (long *)start_addr;
//
//Fill memory
//
mem_wds = 0x01234567;
for (i1=0; i1 < mem_size; i1++)
{
*XMEM_ps++ = mem_wds;
mem_wds += 0x11111111;
}
for 循环 变量i是 16 位的 , mem_size 大于 64k之后 进入循环 无法退出;
修改 for 循环 变量 为 32位,当 mem_size 在 32k 以上 , *XMEM_ps++ = mem_wds; 自增 0x8000之后 会 重复 写 地址 造成随后的Verify 错误。 指针最大寻址32k x 16 位空间 。
参考 spraby4
涉及到指针运算 ,结果都是16位。。。。。 {:huffy:}说好的32位 c28x呢?
好处也是有的 ,指针 和 stack point 再怎么折腾 ,都是 在 64kB 范围内, 破坏范围有限 ,加上看门狗 , 系统看上去 稳定。。
感觉 c28x 处理 内存 是 一小块 一小块地处理, 先把外部内存或外设 的 一小块数据 拷贝到 芯片内部,规定时间内处理完 ,回写到外设或外部内存。。。。程序流程和代码 和 芯片结构高度耦合,portable c code是不存在的。在c28x基础上做一个 虚拟机 模拟其它 的 cpu运行倒是 可以的 绕过 代码空间22位和 指针 16位 的限制,数据寻址范围大么 ,都扔到 sdram中 ,空间管够。
btw
最新的 2838x中 c28x支持双精度浮点, 集成了 cortex-m4 来处理通讯, 要是 以太网 蓝牙什么的c28x 能hold住 ,集成3到4个c28x 不就完事了么
已经修改完毕
内存模式是 large ,指针 都是32位的 ,有多少位有效 需要翻Ti文档 ,包括 指令,编译器 还有abi ...
例程配置了 地址线的BA1 + A0-A14, 所以只能测试到32k x32 的内存
修改
"C:\ti\ccs900\c2000\C2000Ware_1_00_06_00\device_support\f2837xd\common\source\F2837xD_Emif.c"
GPIO_SetupPinMux(88,cpu_sel,3);
GPIO_SetupPinMux(89,cpu_sel,3);
TO
GPIO_SetupPinMux(88,cpu_sel,2); //a15
GPIO_SetupPinMux(89,cpu_sel,2); //a16
再修改 测试 范围
#define ASRAM_CS2_START_ADDR 0x100000
#define ASRAM_CS2_SIZE 0x20000
测试0x20000 x32bit 大小的空间,既 256k x 16
把循环变量 设置为Uint32 类型
即可
页:
[1]