查看: 1628|回复: 1

C5402CFG.H/C(结构及结构指针版)及应用演示包 [复制链接]

HotTiDSP (离线)
积分
2082
帖子
4
发表于 2009-4-2 21:51:55 |显示全部楼层
关键词: 结构 , 指针 , C5402CFG
/*---------------------------------------------------------------------------
文   件   名 :  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 与大雁塔菜地
虞美人 (离线)
积分
35736
帖子
101
发表于 2009-4-2 21:54:24 |显示全部楼层
沙发
500 字节以内
不支持自定义 Discuz! 代码
您需要登录后才可以发表评论 登录 | 立即注册

关于我们  -  服务条款  -  使用指南  -  站点地图  -  友情链接  -  联系我们
电子工程网 © 版权所有   京ICP备11013910号 | 京公网安备11010502021702
回顶部