久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费
標題:
STM32 CAN通訊實現(發射機與接收機測試源程序)
[打印本頁]
作者:
ZeroTo
時間:
2018-5-18 08:11
標題:
STM32 CAN通訊實現(發射機與接收機測試源程序)
STM32 CAN通訊實現源碼分享給大家
接收機單片機源程序如下:
/**************************************************************************************
作者:藍想電子
功能介紹:發射機作用每一S鐘變量data自動加1,加到255又重0開始,循環發射。
接收機收到數據,在串口上顯示.
注意:接收機的ID號必須跟發射機發射的ID號一致。
****************************************************************************************/
#include "stm32f10x.h"
#include <stdio.h>
#include "delay.h"
#include "can.h"
extern u32 canid;
extern u8 ReceiveData;
//使用printf要在target里將 Use Micro LIB選中 必須加頭文件stdio.h
int fputc(int ch,FILE *f)
{
USART_SendData(USART1, (u8) ch);
while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
return ch;
}
/*************************************************
函數: void RCC_Configuration(void)
功能: 復位和時鐘控制 配置
參數: 無
返回: 無
**************************************************/
void RCC_Configuration(void)
{
ErrorStatus HSEStartUpStatus; //定義外部高速晶體啟動狀態枚舉變量
RCC_DeInit(); //復位RCC外部設備寄存器到默認值
RCC_HSEConfig(RCC_HSE_ON); //打開外部高速晶振
HSEStartUpStatus = RCC_WaitForHSEStartUp(); //等待外部高速時鐘準備好
if(HSEStartUpStatus == SUCCESS) //外部高速時鐘已經準別好
{
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); //開啟FLASH預讀緩沖功能,加速FLASH的讀取。所有程序中必須的用法.位置:RCC初始化子函數里面,時鐘起振之后
FLASH_SetLatency(FLASH_Latency_2); //flash操作的延時
RCC_HCLKConfig(RCC_SYSCLK_Div1); //配置AHB(HCLK)時鐘等于==SYSCLK
RCC_PCLK2Config(RCC_HCLK_Div1); //配置APB2(PCLK2)鐘==AHB時鐘
RCC_PCLK1Config(RCC_HCLK_Div2); //配置APB1(PCLK1)鐘==AHB1/2時鐘
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9); //配置PLL時鐘 == 外部高速晶體時鐘 * 9 = 72MHz
RCC_PLLCmd(ENABLE); //使能PLL時鐘
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET) //等待PLL時鐘就緒
{
}
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); //配置系統時鐘 = PLL時鐘
while(RCC_GetSYSCLKSource() != 0x08) //檢查PLL時鐘是否作為系統時鐘
{
}
}
}
/*******************************************************************************
* Function Name : NVIC_Configuration
* Description : Configures NVIC and Vector Table base location.
* Input : None
* Output : None
* Return : None
*******************************************************************************/
void NVIC_Configuration(void)
{
NVIC_InitTypeDef NVIC_InitStructure;
/* Set the Vector Table base location at 0x08000000 */
NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);
/* Configure the NVIC Preemption Priority Bits */
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);
/* Enable the USART1 Interrupt */
NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn; //通道設置為串口1中斷
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; //中斷響應優先級0
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //打開中斷
NVIC_Init(&NVIC_InitStructure); //初始化
}
/*******************************************************************************
函數名:USART1_Configuration
輸 入:
輸 出:
功能說明:
初始化串口硬件設備,啟用中斷
配置步驟:
(1)打開GPIO和USART1的時鐘
(2)設置USART1兩個管腳GPIO模式
(3)配置USART1數據格式、波特率等參數
(4)使能USART1接收中斷功能
(5)最后使能USART1功能
*/
void USART1_Configuration(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
USART_InitTypeDef USART_InitStructure;
/* 第1步:打開GPIO和USART部件的時鐘 */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);
/* 第2步:將USART Tx的GPIO配置為推挽復用模式 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* 第3步:將USART Rx的GPIO配置為浮空輸入模式
由于CPU復位后,GPIO缺省都是浮空輸入模式,因此下面這個步驟不是必須的
但是,我還是建議加上便于閱讀,并且防止其它地方修改了這個口線的設置參數
*/
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* 第3步已經做了,因此這步可以不做
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
*/
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* 第4步:配置USART1參數
- BaudRate = 115200 baud
- Word Length = 8 Bits
- One Stop Bit
- No parity
- Hardware flow control disabled (RTS and CTS signals)
- Receive and transmit enabled
*/
USART_InitStructure.USART_BaudRate = 9600;
USART_InitStructure.USART_WordLength = USART_WordLength_8b;
USART_InitStructure.USART_StopBits = USART_StopBits_1;
USART_InitStructure.USART_Parity = USART_Parity_No;
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
USART_Init(USART1, &USART_InitStructure);
/* 若接收數據寄存器滿,則產生中斷 */
USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
/* 第5步:使能 USART1, 配置完畢 */
USART_Cmd(USART1, ENABLE);
/* 如下語句解決第1個字節無法正確發送出去的問題 */
USART_ClearFlag(USART1, USART_FLAG_TC); // 清標志
}
/*******************************************************************/
/* */
/* STM32向串口1發送1字節 */
/* */
/* */
/*******************************************************************/
/*void Uart1_PutChar(u8 ch)
{
USART_SendData(USART1, (u8) ch);
while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
} */
/*************************************************
函數: int main(void)
功能: main主函數
參數: 無
返回: 無
**************************************************/
int main(void)
{
//u8 data;
RCC_Configuration();
NVIC_Configuration();
USART1_Configuration();
delay_init(72);
canid=1; //這里的ID號根據發射機要發射的ID號來設置
CAN_Configuration();
while(1)
{
//Can_Send_Msg(1,data);//發送的ID號要與接收機一致。
//data++;
//delay_ms(1000);
printf("接收到的數據 ReceiveData=%d\r\n",ReceiveData); //ReceiveData為接收到發射機發來的數據,在CAN的中斷函數里接收,在電腦串口中顯示。
delay_ms(500);
}
}
復制代碼
發射機單片機源程序如下:
/**************************************************************************************
作者:藍想電子
功能介紹:發射機作用每一S鐘變量data自動加1,加到255又重0開始,循環發射。
接收機收到數據,在串口上顯示.
注意:接收機的ID號必須跟發射機發射的ID號一致。
****************************************************************************************/
#include "stm32f10x.h"
#include <stdio.h>
#include "delay.h"
#include "can.h"
extern u32 canid;
extern u8 ReceiveData;
CanTxMsg TxMessage;
u8 DY[8]={0x03,0xf0,0x00,0x21,0x44,0x16,0x00,0x00};
//
u8 GJ[8]={0x03,0xf0,0x00,0x35,0x00,0x01,0x00,0x00};
//使用printf要在target里將 Use Micro LIB選中 必須加頭文件stdio.h
int fputc(int ch,FILE *f)
{
USART_SendData(USART1, (u8) ch);
while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
return ch;
}
/*************************************************
函數: void RCC_Configuration(void)
功能: 復位和時鐘控制 配置
參數: 無
返回: 無
**************************************************/
void RCC_Configuration(void)
{
ErrorStatus HSEStartUpStatus; //定義外部高速晶體啟動狀態枚舉變量
RCC_DeInit(); //復位RCC外部設備寄存器到默認值
RCC_HSEConfig(RCC_HSE_ON); //打開外部高速晶振
HSEStartUpStatus = RCC_WaitForHSEStartUp(); //等待外部高速時鐘準備好
if(HSEStartUpStatus == SUCCESS) //外部高速時鐘已經準別好
{
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); //開啟FLASH預讀緩沖功能,加速FLASH的讀取。所有程序中必須的用法.位置:RCC初始化子函數里面,時鐘起振之后
FLASH_SetLatency(FLASH_Latency_2); //flash操作的延時
RCC_HCLKConfig(RCC_SYSCLK_Div1); //配置AHB(HCLK)時鐘等于==SYSCLK
RCC_PCLK2Config(RCC_HCLK_Div1); //配置APB2(PCLK2)鐘==AHB時鐘
RCC_PCLK1Config(RCC_HCLK_Div2); //配置APB1(PCLK1)鐘==AHB1/2時鐘
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9); //配置PLL時鐘 == 外部高速晶體時鐘 * 9 = 72MHz
RCC_PLLCmd(ENABLE); //使能PLL時鐘
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET) //等待PLL時鐘就緒
{
}
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); //配置系統時鐘 = PLL時鐘
while(RCC_GetSYSCLKSource() != 0x08) //檢查PLL時鐘是否作為系統時鐘
{
}
}
}
/*******************************************************************************
* Function Name : NVIC_Configuration
* Description : Configures NVIC and Vector Table base location.
* Input : None
* Output : None
* Return : None
*******************************************************************************/
void NVIC_Configuration(void)
{
NVIC_InitTypeDef NVIC_InitStructure;
/* Set the Vector Table base location at 0x08000000 */
NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);
/* Configure the NVIC Preemption Priority Bits */
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);
/* Enable the USART1 Interrupt */
NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn; //通道設置為串口1中斷
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; //中斷響應優先級0
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //打開中斷
NVIC_Init(&NVIC_InitStructure); //初始化
}
/*******************************************************************************
函數名:USART1_Configuration
輸 入:
輸 出:
功能說明:
初始化串口硬件設備,啟用中斷
配置步驟:
(1)打開GPIO和USART1的時鐘
(2)設置USART1兩個管腳GPIO模式
(3)配置USART1數據格式、波特率等參數
(4)使能USART1接收中斷功能
(5)最后使能USART1功能
*/
void USART1_Configuration(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
USART_InitTypeDef USART_InitStructure;
/* 第1步:打開GPIO和USART部件的時鐘 */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);
/* 第2步:將USART Tx的GPIO配置為推挽復用模式 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* 第3步:將USART Rx的GPIO配置為浮空輸入模式
由于CPU復位后,GPIO缺省都是浮空輸入模式,因此下面這個步驟不是必須的
但是,我還是建議加上便于閱讀,并且防止其它地方修改了這個口線的設置參數
*/
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* 第3步已經做了,因此這步可以不做
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
*/
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* 第4步:配置USART1參數
- BaudRate = 115200 baud
- Word Length = 8 Bits
- One Stop Bit
- No parity
- Hardware flow control disabled (RTS and CTS signals)
- Receive and transmit enabled
*/
USART_InitStructure.USART_BaudRate = 115200;
USART_InitStructure.USART_WordLength = USART_WordLength_8b;
USART_InitStructure.USART_StopBits = USART_StopBits_1;
USART_InitStructure.USART_Parity = USART_Parity_No;
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
USART_Init(USART1, &USART_InitStructure);
/* 若接收數據寄存器滿,則產生中斷 */
USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
/* 第5步:使能 USART1, 配置完畢 */
USART_Cmd(USART1, ENABLE);
/* 如下語句解決第1個字節無法正確發送出去的問題 */
USART_ClearFlag(USART1, USART_FLAG_TC); // 清標志
}
/*******************************************************************/
/* */
/* STM32向串口1發送1字節 */
/* */
/* */
/*******************************************************************/
/*void Uart1_PutChar(u8 ch)
{
USART_SendData(USART1, (u8) ch);
while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
} */
/*************************************************
函數: int main(void)
功能: main主函數
參數: 無
返回: 無
**************************************************/
int main(void)
{
RCC_Configuration();
NVIC_Configuration();
USART1_Configuration();
delay_init(72);
canid=1; //這里的ID號根據發射機要發射的ID號來設置
CAN_Configuration();
while(1)
{
……………………
…………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼
程序很老,用的老版本的庫:
STM32 CAN.7z
(332.38 KB, 下載次數: 88)
2022-12-16 04:29 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
歡迎光臨 (http://m.zg4o1577.cn/bbs/)
Powered by Discuz! X3.1
主站蜘蛛池模板:
日本一级淫片色费放
|
色窝
|
日韩一级在线观看
|
久热中文字幕
|
99免费视频
|
日本黄色一级视频
|
色综合一区
|
天天操天天操
|
日韩一区二区三免费高清在线观看
|
国产高清视频在线
|
国产视频一区二区在线
|
九九九视频
|
黄色一级大片在线免费看国产一
|
夜夜操夜夜
|
免费国产视频
|
五月天黄色网址
|
中文字幕网址在线
|
国产三级视频在线
|
日韩黄色网址
|
国产激情在线观看
|
国产第一福利
|
国产中文字幕在线播放
|
久久xxx
|
欧美日本国产
|
成年女人毛片
|
亚洲精品一区二区三区在线
|
色噜噜狠狠一区二区三区
|
在线免费看黄网站
|
国产精品一区二区在线播放
|
成人av一区
|
在线看av网址
|
日韩视频在线观看免费
|
国产精品第一区
|
午夜视频一区二区
|
青草国产
|
国产一区在线播放
|
精品国产999久久久免费
|
欧美不卡
|
久久久在线
|
一级做a爱片性色毛片
|
在线观看视频国产
|