/*--------------------------------------------------------------------------- 文 件 名 : C5402CFG.H(结构及结构指针版) 创 建 人 : DSP菜鸟 HotPower@126.com 创 建 日 期 : 2006.6.09 11:19 最近修改日期 : 2008.12.16 16:18 创 建 地 点 : 西安大雁塔村队部(http://www.hotpower.org/) 版 本 号 : V4.16 修 改 理 由 : 修正和增订内容 新增结构uVectorEntry以支持废除汇编启动代码(中断向量表),实现 程序代码全部由C/C++语言编写. 增加对通用寄存器物理地址的直接访问,达到汇编级的代码速度 新版本(SREGs结构型,优化)与老版本(SREG结构指针型,方便)高度兼容 备 注 : 由此文件出现的问题,DSP菜鸟不负任何责任 菜农将不断更新和完善本头文件。 必须在系统中同时加入C5402CFG.C 升 级 方 法 : 在父亲节版的基础上全面升级为统一结构指针 只需在旧版C5402DEF.H或C5402CFG.H的结构成员后加.Regs即可 应 用 举 例: SREG->ST0 &= ~(1 << ST0_C); 改为: SREG->ST0.Regs &= ~(1 << ST0_C); 或: SREG->ST0.Bits.C = 0; 父亲节版新旧版近似兼容使其更强大: SREG->ST1.Bits.XF = true; SREG->ST1.Bits.CPL = 1; SREG->ST1.Regs = (1 << ST1_XF) | (1 << ST1_CPL); TIMER0->TCR.Bits.TSS = 1;//关闭定时器0 TIMER0->TIM = 62500 - 1;//设置定时计数器 或: SREG->TIMER0.TCR.Bits.TSS = 1;//关闭定时器0 SREG->TIMER0.TIM = 62500 - 1;//设置定时计数器 结构的访问使代码更简洁更优化: SREGs.ST0.Bits.C = true; SREGs.ST1.Bits.XF = true; SREGs.ST1.Bits.CPL = 1; SREGs.ST1.Regs = (1 << ST1_XF) | (1 << ST1_CPL); SREGs.TIMER0.TCR.Bits.TSS = 1;//关闭定时器0 SREGs.TIMER0.TIM = 62500 - 1;//设置定时计数器 对McBSP实现结构型位域汇编级代码访问: 指针型:McBSP1->SPSA = PCR; McBSP1->SPSD.PCR_Bits.FSXP= 1; McBSP0->DXR1 = 0x1234; 或:SREG->McBSPADDR1.SPSA = PCR; SREG->McBSPADDR1.SPSD.PCR_Bits.FSXP= 1; SREG->McBSPDATA0.DXR1 = 0x1234; 结构型:SREGs.McBSPADDR1.SPSA = PCR; SREGs.McBSPADDR1.SPSD.PCR_Bits.FSXP = 1; SREGs.McBSPDATA0.DXR1 = 0x1234; 注 意 事 项 : 用SREGs结构要比SREG结构指针代码优化,可达到汇编级. 但查看变量时由于CCS的问题, SREGs结构查看不到成员, 可在Watch窗口用SREG结构指针查看SREGs的结构成员. 用McBSP0/McBSP1结构指针查看McBSP更方便. 声 明 : 雁塔菜农拥有对本文件的最终解释和灌溉权。 ---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------- 文 件 名 : C5402CFG.C(结构及结构指针版) 创 建 人 : DSP菜鸟 HotPower@126.com 创 建 日 期 : 2006.6.09 11:19 最近修改日期 : 2008.12.16 16:18 创 建 地 点 : 西安大雁塔村队部(http://www.hotpower.org/) 版 本 号 : V4.16 修 改 理 由 : 修正和增订内容 新增结构uVectorEntry以支持废除汇编启动代码(中断向量表),实现 程序代码全部由C/C++语言编写. 增加对寄存器的直接物理地址的访问,最优化的速度 新版本(SREGs结构型,优化)与老版本(SREG结构指针型,方便)高度兼 容 备 注 : 由此文件出现的问题,DSP菜鸟不负任何责任 菜农将不断更新和完善本头文件。 必须在系统中同时加入C5402CFG.C 应 用 : 废除汇编的启动代码(中断向量表) #pragma DATA_SECTION("vectors") const uVectorEntry g_pfnVectors[] = { ISR_Reset(), //reset 0x0080 #0//软硬件复位nISR_REST ISR_Default(), //nmi 0x0084 #1//非屏蔽中断nISR_NMI ISR_Default(), //sint17 0x0088 #2//软件中断17 ISR_Default(), //sint18 0x008c #3//软件中断18 ISR_Default(), //sint19 0x0090 #4//软件中断19 ISR_Default(), //sint20 0x0094 #5//软件中断20 ISR_Default(), //sint21 0x0098 #6//软件中断21 ISR_Default(), //sint22 0x009c #7//软件中断22 ISR_Default(), //sint23 0x00a0 #8//软件中断23 ISR_Default(), //sint24 0x00a4 #9//软件中断24 ISR_Default(), //sint25 0x00a8 #10//软件中断25 ISR_Default(), //sint26 0x00ac #11//软件中断26 ISR_Default(), //sint27 0x00b0 #12//软件中断27 ISR_Default(), //sint28 0x00b4 #13//软件中断28 ISR_Default(), //sint29 0x00b8 #14//软件中断29 ISR_Default(), //sint30 0x00bc #15//软件中断30 ISR(Eint0Isr), //int0 0x00c0 #16//外部中断0 ISR(Eint1Isr), //int1 0x00c4 #17//外部中断1 ISR(Eint2Isr), //int2 0x00c8 #18//外部中断2 ISR(Timer0Isr),//tint 0x00cc #19//定时器中断0 ISR(McBSPIsr), //rint0 0x00d0 #20//McBSP0接收中断 ISR_Default(), //xint0 0x00d4 #21//McBSP0发送中断 ISR_Default(), //rint1 0x00d8 #22//McBSP1接收中断 ISR(Timer1Isr),//xint1 0x00dc #23//定时器中断1 ISR(Eint3Isr), //int3 0x00e0 #24//外部中断3 ISR_Default(), //hpint 0x00e4 #25//HPI中断 ISR_Default(), // 0x00e8 #26//软件中断10 ISR_Default(), // 0x00ec #27//软件中断11 ISR_Default(), // 0x00f0 #28//软件中断12 ISR_Default(), // 0x00f4 #29//软件中断13 ISR_Default(), // 0x00f8 #30//保留0 ISR_Default(), // 0x00fc #31//保留1 }; extern "C" interrupt void DefaultIsr(void) { }
注 意 事 项 : 用SREGs结构要比SREG结构指针代码优化,但查看变量时由于CCS的问题 SREGs结构查看不到成员,但可用SREG结构指针查看. 声 明 : 雁塔菜农拥有对本文件的最终解释和灌溉权。 ---------------------------------------------------------------------------*/
应用演示包下载: (包内自带C5402cfg.h/C5402cfg.c/interrupt.h/cpp能文件) 本版本经过半年多的应用已非常稳定.它支持C/C++工程多文件系统,不象 C5402def.h只支持工程单文件系统 最大改动: 1.废除汇编的启动代码(中断向量表) 新增结构uVectorEntry以支持废除汇编启动代码(中断向量表),实现 程序代码全部由C/C++语言编写. 2.用SREGs结构要比SREG结构指针代码优化,可达到汇编级访问. 3.增设对McBSP的虚拟地址的位域访问. 4.升级后用旧版本C5402DEF.H编写的软件只需稍加更改即可. #pragma DATA_SECTION(SREGs, ".registers") //结构型,建议使用,可达到汇编级的访问速度和代码优化 TI_SREG SREGs;//定义全局结构变量SREGs(5402通用寄存器) //结构指针型以后可能将被淘汰,目前只用于仿真时监视SREGs const TI_PSREG SREG = TI_BASE_SREG;//定义全局结构指针变量SREG const TI_PMcBSP0 McBSP0 = TI_BASE_McBSP0;//定义全局结构指针变量McBSP0 const TI_PMcBSP1 McBSP1 = TI_BASE_McBSP1;//定义全局结构指针变量McBSP1 const TI_PDMA DMA = TI_BASE_DMA;//定义全局结构指针变量DMA const TI_PTIMER TIMER0 = TI_BASE_TIMER0;//定义全局结构指针变量TIMER0 const TI_PTIMER TIMER1 = TI_BASE_TIMER1;//定义全局结构指针变量TIMER1 再次声明 : 雁塔菜农拥有对本文件的最终解释和灌溉权。 转载和提供下载请注明出处. 不久将会发布HotBios. 多谢多年来大家对"C5402def.h"的厚爱,看到网上有众多网友应用很高兴. 菜农很倒塌地说---本版本TI也很难超越~~~ HotPower@126.com 2008.12.16 与大雁塔菜地 相关链接:http://blog.**/hotpower/189385/message.aspx |