diff --git a/Hardware/led/led.c b/Hardware/led/led.c
index a866326..a227ada 100644
--- a/Hardware/led/led.c
+++ b/Hardware/led/led.c
@@ -12,14 +12,14 @@
#include "led.h"
/**
- * @brief LED 初始化
- */
+ * @brief LED 初始化
+ */
void LED_Init(void)
{
GPIO_InitTypeDef GPIO_Initure;
__HAL_RCC_GPIOC_CLK_ENABLE(); //开启 PA 时钟
- GPIO_Initure.Pin = GPIO_PIN_13; //PC13
+ GPIO_Initure.Pin = GPIO_PIN_13; // PC13
GPIO_Initure.Mode = GPIO_MODE_OUTPUT_PP; //推挽输出
GPIO_Initure.Pull = GPIO_PULLUP; //上拉
GPIO_Initure.Speed = GPIO_SPEED_FREQ_HIGH; //高速
@@ -30,9 +30,9 @@ void LED_Init(void)
}
/**
- * @brief LED1 慢速翻转,无阻塞,防止因调用过快导致无法观察
- * @param led_num: 序号
- */
+ * @brief LED1 慢速翻转,无阻塞,防止因调用过快导致无法观察
+ * @param led_num: 序号
+ */
void LED_Slow_Toggle(uint8_t led_num)
{
switch (led_num)
diff --git a/Hardware/lora/README.md b/Hardware/lora/README.md
new file mode 100644
index 0000000..f8fc0a2
--- /dev/null
+++ b/Hardware/lora/README.md
@@ -0,0 +1,7 @@
+## LoRa-02
+
+基于 [wdomski/SX1278](https://github.com/wdomski/SX1278) 库封装的简单的 LoRa 模块操作库。
+
+由于实验板在设计时忽略了 DIO0 引脚的引出,导致无法使用 DIO0 上的接收、发送中断。因此,对 wdomski/SX1278 库进行了修改,采用检测 FifoRxCurrentaddr 是否移动的方法判断是否有新的接收。在发送时不检测发送中断。
+
+本实现采用了手册上未定义的方法,可能出现各种问题,建议在可能的情况下引出 DIO0 使用。
diff --git a/Hardware/lora/lora.c b/Hardware/lora/lora.c
new file mode 100644
index 0000000..88e2394
--- /dev/null
+++ b/Hardware/lora/lora.c
@@ -0,0 +1,163 @@
+/**
+ * @file lora.c
+ * @author Myth
+ * @version 0.1
+ * @date 2021.10.15
+ * @brief LoRa sx1278 Library for STM32 HAL
+ */
+
+#include "softspi.h"
+#include "SX1278.h"
+
+#include "lora.h"
+
+SX1278_hw_t SX1278_hw;
+SX1278_t SX1278;
+SoftSPI_TypeDef sx1278_spi;
+
+uint8_t is_in_rx_mode = 0;
+
+uint8_t LoRa_EnterTxMode(uint8_t len);
+uint8_t LoRa_EnterRxMode(void);
+
+/**
+ * @brief LoRa 模块初始化
+ */
+void LoRa_Init(void)
+{
+ //初始化各个引脚
+ sx1278_spi.SCLK_GPIO = SX1278_SCLK_GPIO;
+ sx1278_spi.SCLK_Pin = SX1278_SCLK_PIN;
+
+ sx1278_spi.MOSI_GPIO = SX1278_MOSI_GPIO;
+ sx1278_spi.MOSI_Pin = SX1278_MOSI_PIN;
+
+ sx1278_spi.MISO_GPIO = SX1278_MISO_GPIO;
+ sx1278_spi.MISO_Pin = SX1278_MISO_PIN;
+
+ sx1278_spi.SS_GPIO = SX1278_SS_GPIO;
+ sx1278_spi.SS_Pin = SX1278_SS_PIN;
+
+ sx1278_spi.Delay_Time = 5;
+
+ SX1278_hw.nss.port = GPIOA;
+ SX1278_hw.nss.pin = GPIO_PIN_6;
+ SX1278_hw.reset.port = GPIOA;
+ SX1278_hw.reset.pin = GPIO_PIN_7;
+ SX1278_hw.spi = &sx1278_spi;
+
+ SX1278.hw = &SX1278_hw;
+
+ SoftSPI_Init(&sx1278_spi);
+
+ switch ((uint32_t)(SX1278_RESET_GPIO))
+ {
+ case (uint32_t)GPIOA:
+ {
+ GPIO_InitTypeDef GPIO_Initure;
+ __HAL_RCC_GPIOA_CLK_ENABLE();
+
+ GPIO_Initure.Pin = SX1278_RESET_PIN;
+ GPIO_Initure.Mode = GPIO_MODE_OUTPUT_PP;
+ GPIO_Initure.Speed = GPIO_SPEED_FREQ_HIGH;
+ HAL_GPIO_Init(GPIOA, &GPIO_Initure);
+ }
+ break;
+
+ case (uint32_t)GPIOB:
+ {
+ GPIO_InitTypeDef GPIO_Initure;
+ __HAL_RCC_GPIOB_CLK_ENABLE();
+
+ GPIO_Initure.Pin = SX1278_RESET_PIN;
+ GPIO_Initure.Mode = GPIO_MODE_OUTPUT_PP;
+ GPIO_Initure.Speed = GPIO_SPEED_FREQ_HIGH;
+ HAL_GPIO_Init(GPIOB, &GPIO_Initure);
+ }
+ break;
+
+ case (uint32_t)GPIOC:
+ {
+ GPIO_InitTypeDef GPIO_Initure;
+ __HAL_RCC_GPIOC_CLK_ENABLE();
+
+ GPIO_Initure.Pin = SX1278_RESET_PIN;
+ GPIO_Initure.Mode = GPIO_MODE_OUTPUT_PP;
+ GPIO_Initure.Speed = GPIO_SPEED_FREQ_HIGH;
+ HAL_GPIO_Init(GPIOC, &GPIO_Initure);
+ }
+ break;
+
+ case (uint32_t)GPIOD:
+ {
+ GPIO_InitTypeDef GPIO_Initure;
+ __HAL_RCC_GPIOD_CLK_ENABLE();
+
+ GPIO_Initure.Pin = SX1278_RESET_PIN;
+ GPIO_Initure.Mode = GPIO_MODE_OUTPUT_PP;
+ GPIO_Initure.Speed = GPIO_SPEED_FREQ_HIGH;
+ HAL_GPIO_Init(GPIOD, &GPIO_Initure);
+ }
+ }
+
+ SX1278_init(
+ &SX1278,
+ 434000000,
+ SX1278_POWER_17DBM,
+ SX1278_LORA_SF_7,
+ SX1278_LORA_BW_125KHZ,
+ SX1278_LORA_CR_4_5,
+ SX1278_LORA_CRC_EN,
+ 255);
+}
+
+uint8_t LoRa_EnterTxMode(uint8_t len)
+{
+ is_in_rx_mode = 0;
+ return SX1278_LoRaEntryTx(&SX1278, len, 1000);
+}
+
+uint8_t LoRa_EnterRxMode(void)
+{
+ if (is_in_rx_mode)
+ return 1;
+
+ if (SX1278_LoRaEntryRx(&SX1278, 255, 1000))
+ is_in_rx_mode = 1;
+
+ return is_in_rx_mode;
+}
+
+/**
+ * @brief LoRa 模块发送
+ * @param pdata
+ * @param len
+ * @retval 发送成功返回 1,发送失败返回 0
+ */
+uint8_t LoRa_Send(uint8_t *pdata, uint8_t len)
+{
+ if (LoRa_EnterTxMode(len) == 0)
+ return 0;
+
+ SX1278_LoRaTxPacket(&SX1278, pdata, len, 1000); //超时时间无意义,此函数立即返回
+ return 1;
+}
+
+/**
+ * @brief LoRa 模块接收
+ * @param pdata
+ * @retval 接收到包的长度,0 表示未收到数据
+ */
+uint8_t LoRa_Receive(uint8_t *pdata)
+{
+ if (LoRa_EnterRxMode() == 0)
+ return 0;
+
+ uint8_t len = SX1278_LoRaRxPacket(&SX1278);
+
+ if (len == 0)
+ return 0;
+
+ SX1278_read(&SX1278, pdata, len);
+ return len;
+}
diff --git a/Hardware/lora/lora.h b/Hardware/lora/lora.h
new file mode 100644
index 0000000..91c0089
--- /dev/null
+++ b/Hardware/lora/lora.h
@@ -0,0 +1,35 @@
+/**
+ * @file lora.h
+ * @author Myth
+ * @version 0.1
+ * @date 2021.10.15
+ * @brief LoRa sx1278 Library for STM32 HAL
+ * @note DO NOT USE THIS LIB IF YOU HAVE DIO0
+ */
+
+#ifndef __LORA_H
+#define __LORA_H
+
+#include "sys.h"
+
+// SX1278 引脚设置
+#define SX1278_SCLK_GPIO GPIOA
+#define SX1278_SCLK_PIN GPIO_PIN_3
+
+#define SX1278_MOSI_GPIO GPIOA
+#define SX1278_MOSI_PIN GPIO_PIN_5
+
+#define SX1278_MISO_GPIO GPIOA
+#define SX1278_MISO_PIN GPIO_PIN_4
+
+#define SX1278_SS_GPIO GPIOA
+#define SX1278_SS_PIN GPIO_PIN_6
+
+#define SX1278_RESET_GPIO GPIOA
+#define SX1278_RESET_PIN GPIO_PIN_7
+
+void LoRa_Init(void);
+uint8_t LoRa_Send(uint8_t *pdata, uint8_t len);
+uint8_t LoRa_Receive(uint8_t *pdata);
+
+#endif
diff --git a/Libraries/SX1278 b/Libraries/SX1278
index d6d8936..a7a4236 160000
--- a/Libraries/SX1278
+++ b/Libraries/SX1278
@@ -1 +1 @@
-Subproject commit d6d89363cef5642de8265371f15a1bdf47f3581e
+Subproject commit a7a42360525ea26f45b459f37c06580706f030b6
diff --git a/Libraries/SoftSPI_HAL_Lib b/Libraries/SoftSPI_HAL_Lib
index e129b21..b56448d 160000
--- a/Libraries/SoftSPI_HAL_Lib
+++ b/Libraries/SoftSPI_HAL_Lib
@@ -1 +1 @@
-Subproject commit e129b212f50433714371eb2460308c1440a8eb97
+Subproject commit b56448d008643005da02162361fa17fd162f279a
diff --git a/Project/SlaveNode.uvprojx b/Project/SlaveNode.uvprojx
index 4f71a92..7fe1d5f 100644
--- a/Project/SlaveNode.uvprojx
+++ b/Project/SlaveNode.uvprojx
@@ -339,7 +339,7 @@
USE_HAL_DRIVER, STM32F103x6
- ..\Core;..\Libraries\HAL_Lib\Inc;..\Libraries\SoftSPI_HAL_Lib;..\Libraries\SoftI2C_HAL_Lib;..\User\Main;..\System\sys;..\System\systick;..\System\uart;..\Hardware\led;..\Hardware\aht20;..\Hardware\bh1750
+ ..\Core;..\Libraries\HAL_Lib\Inc;..\Libraries\SoftSPI_HAL_Lib;..\Libraries\SoftI2C_HAL_Lib;..\Libraries\SX1278\driver;..\User\Main;..\System\sys;..\System\systick;..\System\uart;..\Hardware\led;..\Hardware\aht20;..\Hardware\bh1750;..\Hardware\lora
@@ -665,6 +665,21 @@
+
+ SX1278
+
+
+ SX1278.c
+ 1
+ ..\Libraries\SX1278\driver\SX1278.c
+
+
+ SX1278_hw.c
+ 1
+ ..\Libraries\SX1278\driver\SX1278_hw.c
+
+
+
System
@@ -703,6 +718,11 @@
1
..\Hardware\bh1750\bh1750.c
+
+ lora.c
+ 1
+ ..\Hardware\lora\lora.c
+
diff --git a/System/sys/sys.c b/System/sys/sys.c
index cfbbab5..e5b5a47 100644
--- a/System/sys/sys.c
+++ b/System/sys/sys.c
@@ -10,18 +10,18 @@
#include "sys.h"
/**
- * @brief 系统时钟配置
- * System Clock source = PLL (HSE)
- * SYSCLK(Hz) = 72000000
- * HCLK(Hz) = 72000000
- * AHB Prescaler = 1
- * APB1 Prescaler = 2
- * APB2 Prescaler = 1
- * HSE Frequency(Hz) = 8000000
- * HSE PREDIV1 = 1
- * PLLMUL = 9
- * Flash Latency(WS) = 2
- */
+ * @brief 系统时钟配置
+ * System Clock source = PLL (HSE)
+ * SYSCLK(Hz) = 72000000
+ * HCLK(Hz) = 72000000
+ * AHB Prescaler = 1
+ * APB1 Prescaler = 2
+ * APB2 Prescaler = 1
+ * HSE Frequency(Hz) = 8000000
+ * HSE PREDIV1 = 1
+ * PLLMUL = 9
+ * Flash Latency(WS) = 2
+ */
void SystemClock_Config(void)
{
RCC_ClkInitTypeDef clkinitstruct = {0};
@@ -39,7 +39,7 @@ void SystemClock_Config(void)
Error_Handler(__FILE__, __LINE__);
}
- /* Select PLL as system clock source and configure the HCLK, PCLK1 and PCLK2
+ /* Select PLL as system clock source and configure the HCLK, PCLK1 and PCLK2
clocks dividers */
clkinitstruct.ClockType = (RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2);
clkinitstruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
@@ -53,8 +53,8 @@ void SystemClock_Config(void)
}
/**
- * @brief 禁用 JTAG,释放相应 GPIO
- */
+ * @brief 禁用 JTAG,释放相应 GPIO
+ */
void DisableJTAG(void)
{
__HAL_RCC_AFIO_CLK_ENABLE();
@@ -62,11 +62,11 @@ void DisableJTAG(void)
}
/**
- * @brief 错误处理函数。调用后通过 printf 报告错误文件、行数并进入死循环
- * @param file: pointer to the source file name
- * @param line: assert_param error line source number
- * @retval None
- */
+ * @brief 错误处理函数。调用后通过 printf 报告错误文件、行数并进入死循环
+ * @param file: pointer to the source file name
+ * @param line: assert_param error line source number
+ * @retval None
+ */
void Error_Handler(uint8_t *file, uint32_t line)
{
printf("Error occurred: file %s on line %d\r\n", file, line);
@@ -78,10 +78,10 @@ void Error_Handler(uint8_t *file, uint32_t line)
#ifdef USE_FULL_ASSERT
/**
- * @brief assert_param 依赖函数
- * @param file: pointer to the source file name
- * @param line: assert_param error line source number
- */
+ * @brief assert_param 依赖函数
+ * @param file: pointer to the source file name
+ * @param line: assert_param error line source number
+ */
void assert_failed(uint8_t *file, uint32_t line)
{
printf("Wrong parameters value: file %s on line %d\r\n", file, line);
diff --git a/System/systick/systick.c b/System/systick/systick.c
index 3c691b5..df9ac4b 100644
--- a/System/systick/systick.c
+++ b/System/systick/systick.c
@@ -22,8 +22,8 @@ void SysTick_ISR(void);
static void SysTick_SoftTimerDec(SOFT_TMR *_tmr);
/**
- * @brief 配置 SysTick 中断,并初始化软件定时器
- */
+ * @brief 配置 SysTick 中断,并初始化软件定时器
+ */
void SysTick_Init(void)
{
//清零所有的软件定时器
@@ -42,8 +42,8 @@ void SysTick_Init(void)
}
/**
- * @brief 供中断服务程序调用
- */
+ * @brief 供中断服务程序调用
+ */
void SysTick_ISR(void)
{
static uint8_t s_count = 0;
@@ -97,9 +97,9 @@ static void SysTick_SoftTimerDec(SOFT_TMR *_tmr)
}
/**
- * @brief ms 延时
- * @param n: 延时数
- */
+ * @brief ms 延时
+ * @param n: 延时数
+ */
void Delay_ms(uint32_t n)
{
if (n == 0)
@@ -122,9 +122,9 @@ void Delay_ms(uint32_t n)
}
/**
- * @brief us 延时
- * @param n: 延时数
- */
+ * @brief us 延时
+ * @param n: 延时数
+ */
void Delay_us(uint32_t n)
{
uint32_t ticks;
@@ -158,10 +158,10 @@ void Delay_us(uint32_t n)
}
/**
- * @brief 启动一个定时器,并设置定时周期
- * @param _id: 定时器 ID
- * @param _period: 定时周期,单位 ms
- */
+ * @brief 启动一个定时器,并设置定时周期
+ * @param _id: 定时器 ID
+ * @param _period: 定时周期,单位 ms
+ */
void SysTick_StartTimer(uint8_t _id, uint32_t _period)
{
DISABLE_INT();
@@ -175,10 +175,10 @@ void SysTick_StartTimer(uint8_t _id, uint32_t _period)
}
/**
- * @brief 启动一个自动定时器,并设置定时周期
- * @param _id: 定时器 ID
- * @param _period: 定时周期,单位 ms
- */
+ * @brief 启动一个自动定时器,并设置定时周期
+ * @param _id: 定时器 ID
+ * @param _period: 定时周期,单位 ms
+ */
void SysTick_StartAutoTimer(uint8_t _id, uint32_t _period)
{
DISABLE_INT();
@@ -192,9 +192,9 @@ void SysTick_StartAutoTimer(uint8_t _id, uint32_t _period)
}
/**
- * @brief 停止一个定时器
- * @param _id: 定时器 ID
- */
+ * @brief 停止一个定时器
+ * @param _id: 定时器 ID
+ */
void SysTick_StopTimer(uint8_t _id)
{
DISABLE_INT();
@@ -207,11 +207,11 @@ void SysTick_StopTimer(uint8_t _id)
}
/**
- * @brief 检测定时器是否超时
- * @param _id: 定时器 ID
- * @param _period: 定时周期
- * @retval 返回 0 表示定时未到,1 表示定时到
- */
+ * @brief 检测定时器是否超时
+ * @param _id: 定时器 ID
+ * @param _period: 定时周期
+ * @retval 返回 0 表示定时未到,1 表示定时到
+ */
uint8_t SysTick_CheckTimer(uint8_t _id)
{
if (_id >= TMR_COUNT)
@@ -229,9 +229,9 @@ uint8_t SysTick_CheckTimer(uint8_t _id)
}
/**
- * @brief 获取运行时间,单位 ms。最长可以表示 24.85 天
- * @retval 运行时间
- */
+ * @brief 获取运行时间,单位 ms。最长可以表示 24.85 天
+ * @retval 运行时间
+ */
int32_t SysTick_GetRunTime(void)
{
int32_t runtime;
@@ -246,10 +246,10 @@ int32_t SysTick_GetRunTime(void)
}
/**
- * @brief 计算当前运行时间和给定时刻之间的差值。处理了计数器循环
- * @param _LastTime: 上个时刻
- * @retval 当前时间和过去时间的差值,单位 ms
- */
+ * @brief 计算当前运行时间和给定时刻之间的差值。处理了计数器循环
+ * @param _LastTime: 上个时刻
+ * @retval 当前时间和过去时间的差值,单位 ms
+ */
int32_t SysTick_CheckRunTime(int32_t _LastTime)
{
int32_t now_time;
@@ -270,8 +270,8 @@ int32_t SysTick_CheckRunTime(int32_t _LastTime)
}
/**
- * @brief SysTick 中断服务程序
- */
+ * @brief SysTick 中断服务程序
+ */
void SysTick_Handler(void)
{
HAL_IncTick();
diff --git a/System/uart/uart.c b/System/uart/uart.c
index a5d73cd..d385a42 100644
--- a/System/uart/uart.c
+++ b/System/uart/uart.c
@@ -18,7 +18,7 @@
COM_PORT_E printf_Com = COM1;
COM_PORT_E getchar_Com = COM1;
-//USART1 PA9 PA10
+// USART1 PA9 PA10
#define USART1_CLK_ENABLE() __HAL_RCC_USART1_CLK_ENABLE()
#define USART1_TX_GPIO_CLK_ENABLE() __HAL_RCC_GPIOA_CLK_ENABLE()
@@ -29,7 +29,7 @@ COM_PORT_E getchar_Com = COM1;
#define USART1_RX_GPIO_PORT GPIOA
#define USART1_RX_PIN GPIO_PIN_10
-//USART2 PA2 PA3
+// USART2 PA2 PA3
#define USART2_CLK_ENABLE() __HAL_RCC_USART2_CLK_ENABLE()
#define USART2_TX_GPIO_CLK_ENABLE() __HAL_RCC_GPIOA_CLK_ENABLE()
@@ -60,8 +60,8 @@ static uint8_t UART_T_GetChar(UART_T *_pUART, uint8_t *_pByte);
static void UART_T_IRQ(UART_T *_pUART);
/**
- * @brief 初始化串口
- */
+ * @brief 初始化串口
+ */
void UART_Init(void)
{
UART_Var_Init(); //初始化全局变量
@@ -70,10 +70,10 @@ void UART_Init(void)
}
/**
- * @brief 将 COM 端口号转换为 UART 指针
- * @param _ucPort: 端口号 (COM1-2)
- * @retval UART 指针
- */
+ * @brief 将 COM 端口号转换为 UART 指针
+ * @param _ucPort: 端口号 (COM1-2)
+ * @retval UART 指针
+ */
UART_T *ComToUART(COM_PORT_E _ucPort)
{
if (_ucPort == COM1)
@@ -99,10 +99,10 @@ UART_T *ComToUART(COM_PORT_E _ucPort)
}
/**
- * @brief 将 COM 端口号转换为 USART_TypeDef*
- * @param _ucPort: 端口号 (COM1-2)
- * @retval USART_TypeDef*
- */
+ * @brief 将 COM 端口号转换为 USART_TypeDef*
+ * @param _ucPort: 端口号 (COM1-2)
+ * @retval USART_TypeDef*
+ */
USART_TypeDef *ComToUSARTx(COM_PORT_E _ucPort)
{
if (_ucPort == COM1)
@@ -128,11 +128,11 @@ USART_TypeDef *ComToUSARTx(COM_PORT_E _ucPort)
}
/**
- * @brief 向串口发送一组数据。数据放到发送缓冲区后立即返回,由中断服务程序在后台完成发送
- * @param _ucPort: 端口号 (COM1-2)
- * @param _ucaBuf: 待发送的数据缓冲区
- * @param _usLen : 数据长度
- */
+ * @brief 向串口发送一组数据。数据放到发送缓冲区后立即返回,由中断服务程序在后台完成发送
+ * @param _ucPort: 端口号 (COM1-2)
+ * @param _ucaBuf: 待发送的数据缓冲区
+ * @param _usLen : 数据长度
+ */
void UART_SendBuff(COM_PORT_E _ucPort, uint8_t *_ucaBuf, uint16_t _usLen)
{
UART_T *pUART;
@@ -147,21 +147,21 @@ void UART_SendBuff(COM_PORT_E _ucPort, uint8_t *_ucaBuf, uint16_t _usLen)
}
/**
- * @brief 向串口发送 1 个字节。数据放到发送缓冲区后立即返回,由中断服务程序在后台完成发送
- * @param _ucPort: 端口号 (COM1-2)
- * @param _ucByte: 待发送的数据
- */
+ * @brief 向串口发送 1 个字节。数据放到发送缓冲区后立即返回,由中断服务程序在后台完成发送
+ * @param _ucPort: 端口号 (COM1-2)
+ * @param _ucByte: 待发送的数据
+ */
void UART_SendChar(COM_PORT_E _ucPort, uint8_t _ucByte)
{
UART_SendBuff(_ucPort, &_ucByte, 1);
}
/**
- * @brief 从接收缓冲区读取 1 字节,非阻塞。无论有无数据均立即返回
- * @param _ucPort: 端口号 (COM1-2)
- * @param _pByte: 接收到的数据指针
- * @retval 0 表示无数据,1 表示读取到有效字节
- */
+ * @brief 从接收缓冲区读取 1 字节,非阻塞。无论有无数据均立即返回
+ * @param _ucPort: 端口号 (COM1-2)
+ * @param _pByte: 接收到的数据指针
+ * @retval 0 表示无数据,1 表示读取到有效字节
+ */
uint8_t UART_GetChar(COM_PORT_E _ucPort, uint8_t *_pByte)
{
UART_T *pUART;
@@ -176,13 +176,13 @@ uint8_t UART_GetChar(COM_PORT_E _ucPort, uint8_t *_pByte)
}
/**
- * @brief 从接收缓冲区读取到特定字节,阻塞,有超时
- * @param _ucPort: 端口号 (COM1-2)
- * @param _pBuf: 接收到的数据指针
- * @param _endByte: 终止字节
- * @param _timeout: 超时时间
- * @retval 0 表示超时,1 表示成功
- */
+ * @brief 从接收缓冲区读取到特定字节,阻塞,有超时
+ * @param _ucPort: 端口号 (COM1-2)
+ * @param _pBuf: 接收到的数据指针
+ * @param _endByte: 终止字节
+ * @param _timeout: 超时时间
+ * @retval 0 表示超时,1 表示成功
+ */
uint8_t UART_GetBuffUntil(COM_PORT_E _ucPort, uint8_t *_pBuf, uint8_t _endByte, uint16_t _timeout)
{
uint8_t ch;
@@ -210,9 +210,9 @@ uint8_t UART_GetBuffUntil(COM_PORT_E _ucPort, uint8_t *_pBuf, uint8_t _endByte,
}
/**
- * @brief 清零串口发送缓冲区
- * @param _ucPort: 端口号 (COM1-2)
- */
+ * @brief 清零串口发送缓冲区
+ * @param _ucPort: 端口号 (COM1-2)
+ */
void UART_ClearTxFIFO(COM_PORT_E _ucPort)
{
UART_T *pUART;
@@ -229,9 +229,9 @@ void UART_ClearTxFIFO(COM_PORT_E _ucPort)
}
/**
- * @brief 清零串口接收缓冲区
- * @param _ucPort: 端口号 (COM1-2)
- */
+ * @brief 清零串口接收缓冲区
+ * @param _ucPort: 端口号 (COM1-2)
+ */
void UART_ClearRxFIFO(COM_PORT_E _ucPort)
{
UART_T *pUART;
@@ -248,10 +248,10 @@ void UART_ClearRxFIFO(COM_PORT_E _ucPort)
}
/**
- * @brief 设置串口的波特率。无校验,收发都使能
- * @param _ucPort: 端口号 (COM1-2)
- * @param _BaudRate: 波特率
- */
+ * @brief 设置串口的波特率。无校验,收发都使能
+ * @param _ucPort: 端口号 (COM1-2)
+ * @param _BaudRate: 波特率
+ */
void UART_SetBaud(COM_PORT_E _ucPort, uint32_t _BaudRate)
{
USART_TypeDef *USARTx;
@@ -266,10 +266,10 @@ void UART_SetBaud(COM_PORT_E _ucPort, uint32_t _BaudRate)
}
/**
- * @brief 设置串口接受中断处理函数
- * @param _ucPort: 端口号 (COM1-2)
- * @param Receive: 中断处理函数
- */
+ * @brief 设置串口接受中断处理函数
+ * @param _ucPort: 端口号 (COM1-2)
+ * @param Receive: 中断处理函数
+ */
void UART_BindReceiveHandle(COM_PORT_E _ucPort, UARTReceiveHandler Receive)
{
UART_T *pUART;
@@ -284,8 +284,8 @@ void UART_BindReceiveHandle(COM_PORT_E _ucPort, UARTReceiveHandler Receive)
}
/**
- * @brief 初始化串口相关的变量
- */
+ * @brief 初始化串口相关的变量
+ */
static void UART_Var_Init(void)
{
#if UART1_FIFO_EN == 1
@@ -322,12 +322,12 @@ static void UART_Var_Init(void)
}
/**
- * @brief 配置串口的硬件参数
- * @param Instance: USART_TypeDef*
- * @param BaudRate: 波特率
- * @param Parity: 校验类型,奇校验或者偶校验
- * @param Mode: 发送和接收模式使能
- */
+ * @brief 配置串口的硬件参数
+ * @param Instance: USART_TypeDef*
+ * @param BaudRate: 波特率
+ * @param Parity: 校验类型,奇校验或者偶校验
+ * @param Mode: 发送和接收模式使能
+ */
void UART_SetUARTParam(USART_TypeDef *Instance, uint32_t BaudRate, uint32_t Parity, uint32_t Mode)
{
UART_HandleTypeDef UARTHandle;
@@ -346,8 +346,8 @@ void UART_SetUARTParam(USART_TypeDef *Instance, uint32_t BaudRate, uint32_t Pari
}
/**
- * @brief 配置串口的硬件参数
- */
+ * @brief 配置串口的硬件参数
+ */
static void UART_Hard_Init(void)
{
GPIO_InitTypeDef GPIO_InitStruct;
@@ -406,11 +406,11 @@ static void UART_Hard_Init(void)
}
/**
- * @brief 填写数据到 UART 发送缓冲区,并启动发送中断。中断处理函数发送完毕后,自动关闭发送中断
- * @param _pUART
- * @param _ucaBuf
- * @param _usLen
- */
+ * @brief 填写数据到 UART 发送缓冲区,并启动发送中断。中断处理函数发送完毕后,自动关闭发送中断
+ * @param _pUART
+ * @param _ucaBuf
+ * @param _usLen
+ */
static void UART_T_Send(UART_T *_pUART, uint8_t *_ucaBuf, uint16_t _usLen)
{
uint16_t i;
@@ -455,11 +455,11 @@ static void UART_T_Send(UART_T *_pUART, uint8_t *_ucaBuf, uint16_t _usLen)
}
/**
- * @brief 填写数据到 UART 发送缓冲区,并启动发送中断。中断处理函数发送完毕后,自动关闭发送中断
- * @param _pUART
- * @param _pByte
- * @retval 成功返回 1,失败返回 0
- */
+ * @brief 填写数据到 UART 发送缓冲区,并启动发送中断。中断处理函数发送完毕后,自动关闭发送中断
+ * @param _pUART
+ * @param _pByte
+ * @retval 成功返回 1,失败返回 0
+ */
static uint8_t UART_T_GetChar(UART_T *_pUART, uint8_t *_pByte)
{
uint16_t usCount;
@@ -490,10 +490,10 @@ static uint8_t UART_T_GetChar(UART_T *_pUART, uint8_t *_pByte)
}
/**
- * @brief 判断发送缓冲区是否为空
- * @param _ucPort
- * @retval 1 为空,0 为不空
- */
+ * @brief 判断发送缓冲区是否为空
+ * @param _ucPort
+ * @retval 1 为空,0 为不空
+ */
uint8_t UART_IsTxEmpty(COM_PORT_E _ucPort)
{
UART_T *pUART;
@@ -515,9 +515,9 @@ uint8_t UART_IsTxEmpty(COM_PORT_E _ucPort)
}
/**
- * @brief 供中断服务程序调用,通用串口中断处理函数
- * @param _pUART
- */
+ * @brief 供中断服务程序调用,通用串口中断处理函数
+ * @param _pUART
+ */
static void UART_T_IRQ(UART_T *_pUART)
{
uint32_t isrflags = READ_REG(_pUART->uart->SR);
diff --git a/User/Main/main.c b/User/Main/main.c
index fcac7e6..2a8f7c8 100644
--- a/User/Main/main.c
+++ b/User/Main/main.c
@@ -1,14 +1,13 @@
/**
* @file main.c
* @author Myth
- * @version 0.7
+ * @version 0.8
* @date 2021.10.15
* @brief 工程主函数文件
* @details 初始化及主循环
* @note 此版本实现功能:
* 串口回显,回显时 PC13 上的 LED 闪烁
- * AHT20 温度湿度读取及 BH1750 光照度读取
- * 此版本 AHT20 和 BH1750 在两次读取期间关闭 GPIO 时钟以降低功耗。每一次读取结束后 LED 闪烁
+ * 接收来自主节点的字符串数据
* JTAG 已禁用,请使用 SWD 调试
*/
@@ -17,8 +16,7 @@
#include "uart.h"
#include "led.h"
-#include "aht20.h"
-#include "bh1750.h"
+#include "lora.h"
void Echo(uint8_t byte);
@@ -33,38 +31,24 @@ int main(void)
SysTick_Init(); //初始化 SysTick 和软件定时器
UART_Init(); //初始化串口
- LED_Init(); //初始化 LED
+ LED_Init(); //初始化 LED
+ LoRa_Init(); //初始化 LoRa 模块
UART_BindReceiveHandle(COM1, Echo); //绑定 COM1 串口接收中断至 Echo 函数
- AHT20_Init(); //初始化 AHT20
- float humi, temp;
-
- BH1750_Init(); //初始化 BH1750
- float light;
+ uint8_t buffer[255];
+ uint8_t size;
while (1)
{
//程序主循环
- __HAL_RCC_GPIOB_CLK_ENABLE(); //开启 GPIOB 时钟
+ size = LoRa_Receive(buffer); //接收
+ if (size == 0)
+ continue;
- AHT20_Start(); // AHT20 开始测量
- BH1750_Start(); // BH1750 开始测量
+ printf("Receive %d bytes: %s\n", size, buffer);
- Delay_ms(80);
-
- AHT20_Read(&humi, &temp); //读取 AHT20
-
- Delay_ms(100);
-
- light = BH1750_Read(); //读取 BH1750
-
- printf("humi: %.1f temp: %.1f light: %.1f\n", humi, temp, light);
LED1_Toggle;
-
- __HAL_RCC_GPIOB_CLK_DISABLE(); //关闭 GPIOB 时钟以降低功耗
-
- Delay_ms(500);
}
return 1;