tag 标签: sci

相关帖子
相关博文
  • 热度 5
    2019-6-9 22:02
    2080 次阅读|
    2 个评论
    最近突然在想是不是得水一点期刊,遂跟人讨论SCI的内容,以下是大致的精华。 写文章首先得清楚你自己写文章的意义,在学术上讲也就是所谓的contribution。 比如你为什么要做这个技术,除了赚钱以外的,我相信大家可能都答不出来。 那我们换一个问题,你为什么选择STM32而不是51,51可是比32便宜啊。 假如我项目有十个传感器,51肯定做不了,已经PASS了。 这十个传感器,我们需要考虑速度、精度、价格等等,这些我们就能做成optimization。 单纯学术角度,这就是一篇文章了。 文章就是这样,发现问题,解决问题,或者把你碰到的问题,用一个理论的角度去解释。 比如我公司在做的东西可以理解成smart grid,就可以写出很多篇文章,例如那种充电桩分布的优化,用到复杂网络+排队论的概念,就可以写一篇SCI。
  • 热度 20
    2014-5-29 16:24
    1990 次阅读|
    0 个评论
    TI 28系列MCU的SCI boot     在使用TI的28系列芯片过程中,可能由于没有JATG仿真器,或者在发布的时候已经将JATG接口取消,这时如果要进行一些简单功能的验证测试可以借助FLASH串口烧录工具(如  codeskin公司的C2Prog软件 ),将代码直接烧录到目标板检查结果。如果不希望反复的擦写FLASH,可以将需要验证的功能模块的代码编写成在RAM中运行,然后通过串口根据SCI BOOT流程将代码暂时发送给cpu运行。通过SCI BOOT,可以编写类似C2Prog的串口FLASH工具,也可以用作简单的仿真调试验证工具。         要使用SCI boot功能,首先程序要编译成RAM运行,还要将.out文件转变成SCI boot格式文件,以CCS V5.x为例,可以在项目属性Properties---Build---Steps---Post-Build steps的command中填入 hex2000 "${ProjName}.out" -o "${ProjName}.hex" -boot -sci8 -a         这样就会生成一个SCI8格式的hex文件。然后根据BOOT ROM参考手册的数据格式发送给MCU即可。碰到许多朋友对SCI boot 过程不理解,我写了一个小工具可以完成BOOT过程,由于附件的大小将近10M,需要的可以留下邮箱或者发信息给我。    
  • 热度 24
    2012-9-28 16:00
    7696 次阅读|
    1 个评论
            最近开始学TMS20f28335 便想从简单的串口开始 熟悉下寄存器的配置,现将实验过程和大家分享: 1.实验过程: 通过串口调试助手 向dsp发送一个8字符的字符串 如12345678/abcdefgh,  dsp将接受到的字符串返回给上位机串口助手显示,(每次发送的要是8个字符的,不然返回会乱序) 2.使用资源: ①tms320f28335 SCIB模块 : (芯片18脚第三功能SCITXDB即 SCIB 的TXD  芯片20脚第三功能SCIRXDB即 SCIB 的RXD ) ②max3232电平转换模块 ③usb转串口线 ④上位机串口助手 3.实验结果:     4.实验代码:(自己在ti例程上稍作修改) 已验证完 可很好地工作 //################################################################### // Original Source by S.D. // $TI Release: DSP2833x/DSP2823x Header Files V1.20 $ // $Release Date: August 1, 2008 $ // Modified by wzc // $Modification Date: September 28, 2012 $ //################################################################### #include "DSP28x_Project.h"// Device Headerfile and Examples Include File   interrupt void scibTxFifoIsr( void );//fifo发送中断函数 interrupt void scibRxFifoIsr( void );//fifo接收中断函数 void scib_fifo_init( void );//scib fifo模式 初始化函数   char buffer ;//数据缓冲数组   void main( void ) {    Uint16 i;      InitSysCtrl();//系统时钟等初始化      InitSciGpio();//sci端口初始化      DINT; //关掉中断      InitPieCtrl(); //pie模块初始化      IER = 0x0000;//关cpu中断    IFR = 0x0000;//清cpu中断标志      InitPieVectTable();//初始化中断向量表,  经试验   此句注释掉也可以 ,因为下边对中断向量表进行了重新赋值      EALLOW; // This is needed to write to EALLOW protected registers    PieVectTable.SCIRXINTB = scibRxFifoIsr; //中断向量表重新赋值(自定义中断函数的入口地址)    PieVectTable.SCITXINTB = scibTxFifoIsr; //中断向量表重新赋值    EDIS;   // This is needed to disable write to EALLOW protected registers       scib_fifo_init();  // 初始化 SCI-B寄存器配置      for (i = 0; i100; i++) //缓存初始化    {       buffer = 0;    }      // Enable interrupts required for this. example 中断使能    PieCtrlRegs.PIECTRL.bit.ENPIE = 1;   // Enable the PIE block    PieCtrlRegs.PIEIER9.bit.INTx3=1;     // PIE Group 9, INT3   SCIRXINTB SCIB    PieCtrlRegs.PIEIER9.bit.INTx4=1;     // PIE Group 9, INT4   SCITXINTB SCIB    IER = 0x100;   // Enable CPU INT    EINT;//开总中断 INTM      // Step 6. IDLE loop. Just sit and loop forever (optional):    for (;;);   }   interrupt void scibTxFifoIsr( void ) //fifo发送中断服务子程序 {     Uint16 i;     for (i=0; i 8; i++)     {        ScibRegs.SCITXBUF=buffer ;     // Send data 将缓存中的数据发出     }     //ScibRegs.SCIFFTX.bit.TXFFINTCLR=1; //如果在发送中断里清发送中断标志,则会一直不停地发送     PieCtrlRegs.PIEACK.all|=0x100;      // Issue PIE ACK }   interrupt void scibRxFifoIsr( void )//fifo接收中断服务子程序 {     Uint16 i;     for (i=0; i8; i++)     {        buffer =ScibRegs.SCIRXBUF.all; // 将fifo中的数据读到缓存     }        ScibRegs.SCIFFTX.bit.TXFFINTCLR=1;  // 很重要 若不清fifo发送中断标志则,不进入发送中断     ScibRegs.SCIFFRX.bit.RXFFINTCLR=1; // 清接收中断标志     PieCtrlRegs.PIEACK.all|=0x100;      // Issue PIE ack }   void scib_fifo_init() {    ScibRegs.SCICCR.all =0x0007;    // 1 stop bit,  No loopback                                    // No parity,8 char bits,                                    // async mode, idle-line protocol    ScibRegs.SCICTL1.all =0x0003;   // enable TX, RX, internal SCICLK,                                    // Disable RX ERR, SLEEP, TXWAKE    ScibRegs.SCIHBAUD    =0x0001;    ScibRegs.SCILBAUD    =0x00e7;  //波特率9600      ScibRegs.SCIFFTX.bit.SCIFFENA = 1;//使能sci fifo功能    ScibRegs.SCIFFTX.bit.TXFFIENA = 1;//fifo 发送中断使能    ScibRegs.SCIFFTX.bit.TXFFIL = 0; //发送中断级别,此时为上电默认值0       ScibRegs.SCIFFRX.bit.RXFFOVRCLR = 1;//清接收fifo溢出标志    ScibRegs.SCIFFRX.bit.RXFFINTCLR = 1;//清除接收fifo中断标志位    ScibRegs.SCIFFRX.bit.RXFFIENA = 1;//使能fifo 接收中断    ScibRegs.SCIFFRX.bit.RXFFIL = 8; //fifo接收中断级别为8      ScibRegs.SCIFFCT.all=0x00; //为默认值 效果为  禁用自动波特率调整  fifo传送延时为0      ScibRegs.SCIFFTX.bit.TXFIFOXRESET=1;//重新使能发送fifo操作    ScibRegs.SCIFFRX.bit.RXFIFORESET=1;//重新使能接收fifo操作    ScibRegs.SCICTL1.all =0x0023;     // Relinquish SCI from Reset  重启sci   }  
相关资源