DSP_TMS32F2812的串口操作


void scia_fifo_init(int ibaud)
{
   SciaRegs.SCICCR.all =0x0007;    // 1 stop bit,  No loopback
                                   // No parity,8 char bits,
                                   // async mode, idle-line protocol
   SciaRegs.SCICTL1.all =0x0003;   // enable TX, RX, internal SCICLK,
                                   // Disable RX ERR, SLEEP, TXWAKE
   SciaRegs.SCICTL2.bit.TXINTENA =1;
   SciaRegs.SCICTL2.bit.RXBKINTENA =1;
	

   if(ibaud==9600) 
   {
     SciaRegs.SCIHBAUD    =0x0001;//9600
     SciaRegs.SCILBAUD    =0x00e7;
   }
   
   if(ibaud==19200)
   {
      SciaRegs.SCIHBAUD    =0x0000;
      SciaRegs.SCILBAUD    =0x00f3;
   }
   
   if(ibaud==38400)
   {
      SciaRegs.SCIHBAUD    =0x0000;
      SciaRegs.SCILBAUD    =0x0079;
   }

   SciaRegs.SCICCR.bit.LOOPBKENA =0; // Enable loop back
   SciaRegs.SCIFFTX.all=0xC028;
   SciaRegs.SCIFFRX.all=0x0021;//
   SciaRegs.SCIFFCT.all=0x00;

   SciaRegs.SCICTL1.all =0x0023;     // Relinquish SCI from Reset
   SciaRegs.SCIFFTX.bit.TXFIFOXRESET=1;
   SciaRegs.SCIFFRX.bit.RXFIFORESET=1;
}

unsigned char r232data[3]={0,0,0};
int int232cnt=0;

void scia_xmit(int a)
{   
    while (SciaRegs.SCIFFTX.bit.TXFFST != 0) {}
    SciaRegs.SCITXBUF=a;

}

interrupt void sciaRxFifoIsr(void)
{

	   unsigned short ReceivedChar=SciaRegs.SCIRXBUF.all;	 // Read data
	   //
	r232data[int232cnt%3]=ReceivedChar;

	int232cnt++;

    if((r232data[0]==0X42)&&(r232data[1]==0X42)&&(int232cnt%3==0))
	{
	        //lslData = *(unsigned short*)(0x80000+0xb);//bit0 输出1的值,bit1 输出2的值
		    EALLOW;
			GpioMuxRegs.GPEMUX.bit.XNMI_XINT13_GPIOE2 = 0;  //   IO 输入 拉低
			GpioMuxRegs.GPEDIR.bit.GPIOE2 = 1;    	//B6输出
			GpioDataRegs.GPEDAT.bit.GPIOE2 = (r232data[2]&0x2)>>1;  
		//	GpioMuxRegs.GPBQUAL.all=0x0000;	// Input qualifier disabled
			EDIS;
			
			//
			EALLOW;
			GpioMuxRegs.GPBMUX.bit.T3PWM_GPIOB6=0;  //   IO 输入 拉低
			GpioMuxRegs.GPBDIR.bit.GPIOB6=1;    	//E2输出
			GpioDataRegs.GPBDAT.bit.GPIOB6 = r232data[2]&0x1;  
		//	GpioMuxRegs.GPBQUAL.all=0x0000;	// Input qualifier disabled
			EDIS;
			scia_xmit(0x41);
			scia_xmit(0x41);
	}

    
	SciaRegs.SCIFFRX.bit.RXFFOVRCLR=1;  // Clear Overflow flag
	SciaRegs.SCIFFRX.bit.RXFFINTCLR=1; 	// Clear Interrupt flag
	PieCtrlRegs.PIEACK.all|=0x100;  	// Issue PIE ack
		
}
void main(void)
{		

	int ch=0;
	
	InitSysCtrl();//设置外部时钟和系统时钟
    /for sci-b
       EALLOW;
	   GpioMuxRegs.GPFMUX.all=0x0030;	// Select GPIOs to be Scia pins
	                                    // Port F MUX - x000 0000 0011 0000
	 //  GpioMuxRegs.GPGMUX.all=0x0030;	// Select GPIOs to be Scib pins
	                                    // Port G MUX - x000 0000 0011 0000
	   EDIS;
    ///
	DINT;

	InitGpio();  // 2812原配,未改动

	InitPieCtrl();

	// Disable CPU interrupts and clear all CPU interrupt flags:
	IER = 0x0000;
	IFR = 0x0000;


	InitPieVectTable();
    EALLOW;  // This is needed to write to EALLOW protected registers
  //  PieVectTable.TINT0 = &cpu_timer0_isr;
    PieVectTable.RXAINT = &sciaRxFifoIsr;
    EDIS; 

	scia_fifo_init(9600); 
///*
	PieCtrlRegs.PIECRTL.bit.ENPIE = 1;   // Enable the PIE block
	PieCtrlRegs.PIEIER9.bit.INTx1=1;     // PIE Group 9, INT1
	 //  PieCtrlRegs.PIEIER9.bit.INTx2=1;     // PIE Group 9, INT2
	 //  PieCtrlRegs.PIEIER9.bit.INTx3=1;     // PIE Group 9, INT3
	  // PieCtrlRegs.PIEIER9.bit.INTx4=1;     // PIE Group 9, INT4
	   IER |= 0x100;	// Enable CPU INT
	   EINT;
	   ERTM;	
	   //*/
	// 将中断处理函数和InitFlash函数拷贝到RAM中运行,FLASH中运行时MemCopy和InitFlash必须有效
	MemCopy(&RamfuncsLoadStart, &RamfuncsLoadEnd, &RamfuncsRunStart);
	InitFlash();
   
	// 对外部器件初始化必需放在InitFlash后

	// 初始化timer0
//	InitCpuTimers();   	
 //  	ConfigCpuTimer(&CpuTimer0, 150, 0xffffffff);
   		
	// 初始化

	while (1)
	{
         ;
	}
	

	
} 	


  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
TMS320F2812是德州仪器(TI)公司的一款数字信号处理器(DSP)芯片。要实现远程升级TMS320F2812的程序,可以采用以下方法: 1. 基于串口通信:可以通过串口通信方式,将新的程序固件从远程设备发送到TMS320F2812中。这需要使用合适的串口通信协议和通信接口,如RS232、RS485、USB等。在远程设备通过串口发送程序时,TMS320F2812接收并写入新的程序固件,最后进行重启操作。 2. 基于以太网通信:可以通过以太网接口实现远程升级功能。远程设备通过以太网将新的程序固件发送到TMS320F2812,然后TMS320F2812接收并写入新的程序固件,最后进行重启操作。这种方法需要在TMS320F2812上实现对应的以太网通信协议,常用的有TCP/IP协议栈。 3. 基于无线通信:可以利用无线通信方式,如Wi-Fi或蓝牙,将新的程序固件从远程设备发送到TMS320F2812。远程设备通过无线通信将新的程序固件发送给TMS320F2812,然后TMS320F2812接收并写入新的程序固件,最后进行重启操作。这需要在TMS320F2812上实现对应的无线通信协议和通信接口。 无论使用哪种方法进行远程升级,都需要保证通信的可靠性和数据的完整性。在升级过程中,需要进行适当的校验和错误处理,以确保新的程序固件能够正确地写入并正常运行。同时,也需要注意安全性问题,防止恶意程序固件的远程升级。+

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

毛毛虫的爹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值