1. 使用CCS V6.1版本,目前已经不局限于仅仅把实验搞清楚了,要深入去探究内部的原理,本章看下GPIO实验
2. 在CCS启动的时候,提示,这个问题是什么,XDAIS是什么?XDAIS (eXpress DSP Algorithm Interoperability Standard)
See details below... Unrecognized product of type 'com.ti.rtsc.XDAIS' is required by project '5509gpio' - please install at least one product of this type before building this project.
在Codec Engine文档中经常看到的xdais,实际上就是TMS320 DSP Algorithm Standard的另一个名字。根据TI官方白皮书,xdais标准一共提供了39条规则,15条指南。大致了解下,不深入研究。
3. eXpress 是什么?大致理解技术TI制定了一套写代码的标准,大家按这个标准写的代码比较统一,相互之间看的懂。
4. 出现问题如下:这句话究竟是什么意思?是指定内存RAM大小的?
5. 还是之前的问题,一点击连接,CCS就自动关闭,看一下CCS的log日志,怀疑是JRE出了问题。
1 vm_info: Java HotSpot(TM) Client VM (24.60-b09) for windows-x86 JRE (1.7.0_60-b19), built on May
7 2014 13:09:52 by "java_re" with unknown MS VC++:1600
6. 看下CCS的日志,异常的访问变量,什么鬼?
# A fatal error has been detected by the Java Runtime Environment: # # EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x66b63432, pid=6488, tid=4088 # # JRE version: Java(TM) SE Runtime Environment (7.0_60-b19) (build 1.7.0_60-b19) # Java VM: Java HotSpot(TM) Client VM (24.60-b09 mixed mode windows-x86 ) # Problematic frame: # C [DebugServer.dll+0x393432] # # Failed to write core dump. Minidumps are not enabled by default on client versions of Windows
7.根据上面的好像是DebugServer.dll这个动态连接库有问题,看下面的,JAVA不识别微软的VC++,真心不知道这个是什么鬼。
1 vm_info: Java HotSpot(TM) Client VM (24.60-b09) for windows-x86 JRE (1.7.0_60-b19), 2 built on May 7 2014 13:09:52 by "java_re" with unknown MS VC++:1600
8. 重新安装CCSV6.1,问题解决。连接目标开发板,这个时候还没有烧写.out文件,可以看到程序指向0xFF8000这个地址,这个地址是什么用途?这个是芯片内部固化的bootloader,它根据外部的GPIO引脚高低电平,决定启动模式。
9. 0xFF8000这个地址保存的什么代码?看不太懂
10. 加载.out文件,pc指针正确,启动地址是0x0040be
11. 看下cmd文件,我觉的很有必要去研究下这个cmd文件,cmd文件是对物理存储器的管理,分配,和使用情况。R可读,W可写,X可执行,I可初始化,一般PAGE 0存放程序空间,PAGE 1存放数据空间。origin其实地址,length是空间大小。
1 MEMORY //MEMMORY声明有哪些存储器,他们的位置和大小。 2 { 3 PAGE 0: 4 PROG0(RWX) : origin = 04000h length = 08000h 5 P_VECT(RIX) : origin = 0FF80h length = 00080h 6 PAGE 1: 7 DATA0(RW) : origin = 0C000h length = 04000h 8 }
12. 看下SECTION,
1 SECTIONS 2 { 3 .vectors : { } > P_VECT PAGE 0 //中断向量表 4 .text : { } > PROG0 PAGE 0 //代码段 5 .cinit : { } > PROG0 PAGE 0 //变量 6 .csldata : { } > DATA0 PAGE 1 7 .stack : { } > DATA0 PAGE 1 //系统栈空间 8 .sysstack : { } > DATA0 PAGE 1 9 .bss : { } > DATA0 PAGE 1 //全局变量和静态变量 10 .cio : { } > DATA0 PAGE 1 11 .const : { } > DATA0 PAGE 1 //const声明的变量,浮点数 12 .sysmem : { } > DATA0 PAGE 1 //malloc等使用的空间,那就是堆喽 13 }
13. 最后一个问题,看下代码,问题在于,我不知道这次用的是那个GPIO引脚?The 5509A provides eight dedicated general-purpose input/output pins, GPIO0−GPIO7,还要只有8个GPIO,手指头都数的过来,IODIR设置8个都输出,IODATA设置高低电平的。这次是GPIO7,芯片第6脚。
1 main() //其实不过 2 { 3 /*初始化CSL库*/ 4 CSL_init(); 5 /*设置系统的运行速度为144MHz*/ 6 PLL_config(&myConfig); 7 /*确定方向为输出*/ 8 GPIO_RSET(IODIR,0xFF); 9 while(1) 10 { 11 GPIO_RSET(IODATA,0x00); 12 delay(); 13 GPIO_RSET(IODATA,0x80); 14 delay(); 15 } 16 }
14.新的疑问,C5509A的引脚都不复用的吗?