热度 23
2012-9-28 16:00
7652 次阅读|
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 }