原创 C5402CFG.H/C(结构及结构指针版)及应用演示包

2008-12-17 18:59 2863 2 2 分类: MCU/ 嵌入式

/*---------------------------------------------------------------------------
文   件   名 :  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结构指针查看.
声        明 : 雁塔菜农拥有对本文件的最终解释和灌溉权。               
---------------------------------------------------------------------------*/


 


应用演示包下载: https://static.assets-stash.eet-china.com/album/old-resources/2008/12/17/2b15a0a4-0978-4bf0-b6ee-9300c8ab7a8b.rar (包内自带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 与大雁塔菜地

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
EE直播间
更多
我要评论
0
2
关闭 站长推荐上一条 /3 下一条