当前位置:首页 > 单片机 > 单片机
[导读]///*****************************************************************************//下面是test.c里面的函数///*****************************************************************************////////////////


///*****************************************************************************

//下面是test.c里面的函数

///*****************************************************************************

////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

//串口猎人用的程序 //////////

//值得说明的是,CRC协议同样适用于串口猎人适用,也就是”协议”是通用的 ////////

// USART1->DR=num; ////////

//串口猎人只能发送hex值,即只能发送16进制的数据,才能显示出波形 /////////

// while((USART1->SR&0X40)==0); ////////

// delay_ms(500); ////////

// num-=1; ////////

// if(num==0x00) ////////

// num=0xff; ///////

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

//值得说明的是,CRC协议同样适用于串口猎人适用,也就是”协议”是通用的 ////////

//串口助手用的程序 ////////

// printf("%d ",0XA5); ////////

// printf("%d ",t); ////////

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

// Visualscope串口示波器的程序 ////////

////////

for(i=0;i<4;i++)//先装载数据 ////////

{ ////////

OutData[i]= num; ////////

num-=70; ////////

} ////////

num=0xff; ////////

OutPut_Data();//调用主函数 ////////

delay_ms(10);//定义发送频率 ////////

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////


///*****************************************************************************

//下面是USART.H里面的函数

///*****************************************************************************

//串口示波器的变量

extern float OutData[4];//这是全局变量

unsigned short CRC_CHECK(unsigned short *Buf, unsigned short CRC_CNT);

void voTxIsr(void);

void OutPut_Data();



///*****************************************************************************//下面的是USART.C里面的文件

//这里用到了串口接收数据中断函数,所以需要把原先的数据串口中断函数屏蔽了

///*****************************************************************************

//the following is MCU code for CRC16 ,please refer.

//-------------------------------------------------------------------------------------------

#define ULONG unsigned long

#define RxCountMax 18

//float OutData[4]; 这个是全局变量,在main函数和USART.H中都有定义

unsigned short TxBuf[10];

unsigned short RxBuf[RxCountMax];

unsigned short RxCnt;

unsigned short TxCnt;

unsigned short Rx50msCnt;

unsigned long pAddr1,pAddr2,pAddr3,pAddr4;


//CRC16校验算法

unsigned short CRC_CHECK(unsigned short *Buf, unsigned short CRC_CNT)

{

unsigned short CRC_Temp;

unsigned char i,j;

CRC_Temp = 0xffff;


for (i=0;i

CRC_Temp ^= Buf[i];

for (j=0;j<8;j++) {

if (CRC_Temp & 0x01)

CRC_Temp = (CRC_Temp >>1 ) ^ 0xa001;

else

CRC_Temp = CRC_Temp >> 1;

}

}

return(CRC_Temp);

}


//Receive interrupt routine 串口接收中断函数

void USART1_IRQHandler(void)

{

unsigned short i,CRC_RX,CRC_Tmp;

RxBuf[RxCnt] = USART1->DR; //acquire data 接收数据

RxCnt++;

if(RxCnt == RxCountMax) {

CRC_Tmp = CRC_CHECK(RxBuf,16); //CRC Calculation 计算接收到的数据的CRC校验值

CRC_RX = ((unsigned short)RxBuf[RxCountMax-1]<<8) + RxBuf[RxCountMax-2]; //接收的数据中的最后两位就是CRC校验值

if(CRC_Tmp == CRC_RX){ //比较两个校验值是否相同

LED0=~LED0; //这里是我做的一个现象,通信成功就亮/灭一下灯

pAddr1 = ((ULONG)(RxBuf[0x3])<<24)"((ULONG)(RxBuf[0x2])<<16)|((ULONG)(RxBuf[0x1])<<8)|RxBuf[0x0]; //然后把数据保存起来

pAddr2 = ((ULONG)(RxBuf[0x7])<<24)|((ULONG)(RxBuf[0x6])<<16)|((ULONG)(RxBuf[0x5])<<8)|RxBuf[0x4];

pAddr3 = ((ULONG)(RxBuf[0xB])<<24)|((ULONG)(RxBuf[0xA])<<16)|((ULONG)(RxBuf[0x9])<<8)|RxBuf[0x8];

pAddr4 = ((ULONG)(RxBuf[0xF])<<24)|((ULONG)(RxBuf[0xE])<<16)|((ULONG)(RxBuf[0xD])<<8)|RxBuf[0xC];

}

RxCnt = 0;

}

Rx50msCnt = 0;

//to add--Clear Receive Data Register Fll flag;

// USART1->DR=res;

// while((USART1->SR&0X40)==0);//


}


//Transfer interrupt routine 串口发送数据函数

void voTxIsr(void)

{

if(TxCnt <= 9)

{

USART1->DR = TxBuf[TxCnt];

//Clear Tx interrupt flag

TxCnt++;

if(TxCnt >= 10)

{

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

在嵌入式开发中,STM32的时钟系统因其灵活性和复杂性成为开发者关注的焦点。然而,看似简单的时钟配置背后,隐藏着诸多易被忽视的陷阱,轻则导致系统不稳定,重则引发硬件损坏。本文从时钟源选择、PLL配置、总线时钟分配等关键环...

关键字: STM32 时钟系统

在嵌入式系统开发中,STM32系列微控制器的内部温度传感器因其低成本、高集成度特性,广泛应用于设备自检、环境监测等场景。然而,受芯片工艺差异和电源噪声影响,其原始数据存在±1.5℃的固有误差。本文从硬件配置、校准算法、软...

关键字: STM32 温度传感器

在能源效率与智能化需求双重驱动下,AC-DC转换器的数字控制技术正经历从传统模拟方案向全数字架构的深刻变革。基于STM32微控制器的PFM(脉冲频率调制)+PWM(脉冲宽度调制)混合调制策略,结合动态电压调整(Dynam...

关键字: AC-DC STM32

当前智能家居产品需求不断增长 ,在这一背景下 ,对现有浇花装置缺陷进行了改进 ,设计出基于STM32单片机的全 自动家用浇花机器人。该设计主要由机械结构和控制系统构成 ,机械结构通过麦克纳姆轮底盘与喷洒装置的结合实现机器...

关键字: STM32 麦克纳姆轮 安全可靠 通过性强

用c++编程似乎是让你的Arduino项目起步的障碍吗?您想要一种更直观的微控制器编程方式吗?那你需要了解一下Visuino!这个图形化编程平台将复杂电子项目的创建变成了拖动和连接块的简单任务。在本文中,我们将带您完成使...

关键字: Visuino Arduino ESP32 STM32

基于STM32与LoRa技术的无线传感网络凭借其低功耗、广覆盖、抗干扰等特性,成为环境监测、工业自动化等场景的核心解决方案。然而,如何在复杂电磁环境中实现高效休眠调度与动态信道优化,成为提升网络能效与可靠性的关键挑战。本...

关键字: STM32 LoRa

在实时控制系统、高速通信协议处理及高精度数据采集等对时间敏感的应用场景中,中断响应延迟的优化直接决定了系统的可靠性与性能上限。STM32系列微控制器凭借其灵活的嵌套向量中断控制器(NVIC)、多通道直接内存访问(DMA)...

关键字: STM32 DMA

数字电源技术向高功率密度、高效率与高动态响应方向加速演进,STM32微控制器凭借其基于DSP库的算法加速能力与对LLC谐振变换器的精准控制架构,成为优化电源动态性能的核心平台。相较于传统模拟控制或通用型数字控制器,STM...

关键字: STM32 数字电源

STM32微控制器凭借其针对电机控制场景的深度优化,成为高精度、高可靠性驱动系统的核心选择。相较于通用型MCU,STM32在电机控制领域的核心优势集中体现在FOC(磁场定向控制)算法的硬件加速引擎与PWM死区时间的动态补...

关键字: STM32 电机控制

无线充电技术加速渗透消费电子与汽车电子领域,基于Qi协议的无线充电发射端开发成为智能设备能量补给的核心课题。传统模拟控制方案存在响应滞后、参数调整困难等问题,而基于STM32的数字PID控制结合FOD(Foreign O...

关键字: STM32 无线充电
关闭