Browse Source

新增MODBUS

master
tianjialong 3 years ago
parent
commit
3596c02b45
  1. 1
      app/Core/Inc/stm32f1xx_it.h
  2. 2
      app/Core/Inc/tim.h
  3. 1
      app/Core/Src/main.c
  4. 15
      app/Core/Src/stm32f1xx_it.c
  5. 63
      app/Core/Src/tim.c
  6. 5
      app/Core/Src/usart.c
  7. 9
      app/MDK-ARM/EventRecorderStub.scvd
  8. 1807
      app/MDK-ARM/app.uvguix.zwsd_cad3
  9. 41
      app/MDK-ARM/app.uvoptx
  10. 8
      app/MDK-ARM/app.uvprojx
  11. 17
      app/app.ioc
  12. 21
      src/port.c
  13. 7
      src/port.h
  14. 142
      src/user_main.c
  15. 12
      src/zboard.h

1
app/Core/Inc/stm32f1xx_it.h

@ -56,7 +56,6 @@ void SVC_Handler(void);
void DebugMon_Handler(void);
void PendSV_Handler(void);
void SysTick_Handler(void);
void USART1_IRQHandler(void);
void USART2_IRQHandler(void);
/* USER CODE BEGIN EFP */

2
app/Core/Inc/tim.h

@ -32,12 +32,14 @@ extern "C" {
/* USER CODE END Includes */
extern TIM_HandleTypeDef htim1;
extern TIM_HandleTypeDef htim4;
/* USER CODE BEGIN Private defines */
/* USER CODE END Private defines */
void MX_TIM1_Init(void);
void MX_TIM4_Init(void);
void HAL_TIM_MspPostInit(TIM_HandleTypeDef *htim);

1
app/Core/Src/main.c

@ -92,6 +92,7 @@ int main(void)
MX_USART2_UART_Init();
MX_USART1_UART_Init();
MX_TIM1_Init();
MX_TIM4_Init();
/* USER CODE BEGIN 2 */
extern int user_main();
user_main();

15
app/Core/Src/stm32f1xx_it.c

@ -56,7 +56,6 @@
/* USER CODE END 0 */
/* External variables --------------------------------------------------------*/
extern UART_HandleTypeDef huart1;
extern UART_HandleTypeDef huart2;
/* USER CODE BEGIN EV */
@ -201,20 +200,6 @@ void SysTick_Handler(void)
/******************************************************************************/
/**
* @brief This function handles USART1 global interrupt.
*/
void USART1_IRQHandler(void)
{
/* USER CODE BEGIN USART1_IRQn 0 */
/* USER CODE END USART1_IRQn 0 */
HAL_UART_IRQHandler(&huart1);
/* USER CODE BEGIN USART1_IRQn 1 */
/* USER CODE END USART1_IRQn 1 */
}
/**
* @brief This function handles USART2 global interrupt.
*/
void USART2_IRQHandler(void)

63
app/Core/Src/tim.c

@ -25,6 +25,7 @@
/* USER CODE END 0 */
TIM_HandleTypeDef htim1;
TIM_HandleTypeDef htim4;
/* TIM1 init function */
void MX_TIM1_Init(void)
@ -96,6 +97,46 @@ void MX_TIM1_Init(void)
HAL_TIM_MspPostInit(&htim1);
}
/* TIM4 init function */
void MX_TIM4_Init(void)
{
/* USER CODE BEGIN TIM4_Init 0 */
/* USER CODE END TIM4_Init 0 */
TIM_ClockConfigTypeDef sClockSourceConfig = {0};
TIM_MasterConfigTypeDef sMasterConfig = {0};
/* USER CODE BEGIN TIM4_Init 1 */
/* USER CODE END TIM4_Init 1 */
htim4.Instance = TIM4;
htim4.Init.Prescaler = 72;
htim4.Init.CounterMode = TIM_COUNTERMODE_UP;
htim4.Init.Period = 65535;
htim4.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
htim4.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
if (HAL_TIM_Base_Init(&htim4) != HAL_OK)
{
Error_Handler();
}
sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
if (HAL_TIM_ConfigClockSource(&htim4, &sClockSourceConfig) != HAL_OK)
{
Error_Handler();
}
sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
if (HAL_TIMEx_MasterConfigSynchronization(&htim4, &sMasterConfig) != HAL_OK)
{
Error_Handler();
}
/* USER CODE BEGIN TIM4_Init 2 */
/* USER CODE END TIM4_Init 2 */
}
void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* tim_baseHandle)
{
@ -111,6 +152,17 @@ void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* tim_baseHandle)
/* USER CODE END TIM1_MspInit 1 */
}
else if(tim_baseHandle->Instance==TIM4)
{
/* USER CODE BEGIN TIM4_MspInit 0 */
/* USER CODE END TIM4_MspInit 0 */
/* TIM4 clock enable */
__HAL_RCC_TIM4_CLK_ENABLE();
/* USER CODE BEGIN TIM4_MspInit 1 */
/* USER CODE END TIM4_MspInit 1 */
}
}
void HAL_TIM_MspPostInit(TIM_HandleTypeDef* timHandle)
{
@ -152,6 +204,17 @@ void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef* tim_baseHandle)
/* USER CODE END TIM1_MspDeInit 1 */
}
else if(tim_baseHandle->Instance==TIM4)
{
/* USER CODE BEGIN TIM4_MspDeInit 0 */
/* USER CODE END TIM4_MspDeInit 0 */
/* Peripheral clock disable */
__HAL_RCC_TIM4_CLK_DISABLE();
/* USER CODE BEGIN TIM4_MspDeInit 1 */
/* USER CODE END TIM4_MspDeInit 1 */
}
}
/* USER CODE BEGIN 1 */

5
app/Core/Src/usart.c

@ -113,9 +113,6 @@ void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
GPIO_InitStruct.Pull = GPIO_NOPULL;
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
/* USART1 interrupt Init */
HAL_NVIC_SetPriority(USART1_IRQn, 0, 0);
HAL_NVIC_EnableIRQ(USART1_IRQn);
/* USER CODE BEGIN USART1_MspInit 1 */
/* USER CODE END USART1_MspInit 1 */
@ -169,8 +166,6 @@ void HAL_UART_MspDeInit(UART_HandleTypeDef* uartHandle)
*/
HAL_GPIO_DeInit(GPIOA, GPIO_PIN_9|GPIO_PIN_10);
/* USART1 interrupt Deinit */
HAL_NVIC_DisableIRQ(USART1_IRQn);
/* USER CODE BEGIN USART1_MspDeInit 1 */
/* USER CODE END USART1_MspDeInit 1 */

9
app/MDK-ARM/EventRecorderStub.scvd

@ -0,0 +1,9 @@
<?xml version="1.0" encoding="utf-8"?>
<component_viewer schemaVersion="0.1" xmlns:xs="http://www.w3.org/2001/XMLSchema-instance" xs:noNamespaceSchemaLocation="Component_Viewer.xsd">
<component name="EventRecorderStub" version="1.0.0"/> <!--name and version of the component-->
<events>
</events>
</component_viewer>

1807
app/MDK-ARM/app.uvguix.zwsd_cad3
File diff suppressed because it is too large
View File

41
app/MDK-ARM/app.uvoptx

@ -119,8 +119,28 @@
<TargetDriverDllRegistry>
<SetRegEntry>
<Number>0</Number>
<Key>ARMRTXEVENTFLAGS</Key>
<Name>-L70 -Z18 -C0 -M0 -T1</Name>
</SetRegEntry>
<SetRegEntry>
<Number>0</Number>
<Key>DLGTARM</Key>
<Name>(1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)</Name>
</SetRegEntry>
<SetRegEntry>
<Number>0</Number>
<Key>ARMDBGFLAGS</Key>
<Name></Name>
</SetRegEntry>
<SetRegEntry>
<Number>0</Number>
<Key>DLGUARM</Key>
<Name></Name>
</SetRegEntry>
<SetRegEntry>
<Number>0</Number>
<Key>CMSIS_AGDI</Key>
<Name>-X"ATK CMSIS-DAP-Debugger" -UATK 05022018 -O206 -S8 -C0 -P00000000 -N00("ARM CoreSight SW-DP") -D00(2BA01477) -L00(0) -TO65554 -TC10000000 -TT10000000 -TP20 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO15 -FD20000000 -FC1000 -FN1 -FF0STM32F10x_128.FLM -FS08000000 -FL020000 -FP0($$Device:STM32F103C8$Flash\STM32F10x_128.FLM)</Name>
<Name>-X"ATK CMSIS-DAP-Debugger" -UATK 05022018 -O206 -S8 -C0 -P00000000 -N00("ARM CoreSight SW-DP") -D00(1BA01477) -L00(0) -TO65554 -TC10000000 -TT10000000 -TP20 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO15 -FD20000000 -FC1000 -FN1 -FF0STM32F10x_128.FLM -FS08000000 -FL020000 -FP0($$Device:STM32F103C8$Flash\STM32F10x_128.FLM)</Name>
</SetRegEntry>
<SetRegEntry>
<Number>0</Number>
@ -133,7 +153,24 @@
<Name>-U-O142 -O2254 -S0 -C0 -N00("ARM CoreSight SW-DP") -D00(2BA01477) -L00(0) -TO18 -TC10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO7 -FD20000000 -FC800 -FN1 -FF0STM32F10x_128 -FS08000000 -FL010000 -FP0($$Device:STM32F103C8$Flash\STM32F10x_128.FLM)</Name>
</SetRegEntry>
</TargetDriverDllRegistry>
<Breakpoint/>
<Breakpoint>
<Bp>
<Number>0</Number>
<Type>0</Type>
<LineNumber>79</LineNumber>
<EnabledFlag>1</EnabledFlag>
<Address>0</Address>
<ByteObject>0</ByteObject>
<HtxType>0</HtxType>
<ManyObjects>0</ManyObjects>
<SizeOfObject>0</SizeOfObject>
<BreakByAccess>0</BreakByAccess>
<BreakIfRCount>0</BreakIfRCount>
<Filename>..\..\src\user_main.c</Filename>
<ExecCommand></ExecCommand>
<Expression></Expression>
</Bp>
</Breakpoint>
<Tracepoint>
<THDelay>0</THDelay>
</Tracepoint>

8
app/MDK-ARM/app.uvprojx

@ -313,7 +313,7 @@
</ArmAdsMisc>
<Cads>
<interw>1</interw>
<Optim>4</Optim>
<Optim>1</Optim>
<oTime>0</oTime>
<SplitLS>0</SplitLS>
<OneElfS>1</OneElfS>
@ -322,7 +322,7 @@
<PlainCh>0</PlainCh>
<Ropi>0</Ropi>
<Rwpi>0</Rwpi>
<wLevel>3</wLevel>
<wLevel>2</wLevel>
<uThumb>0</uThumb>
<uSurpInc>0</uSurpInc>
<uC99>1</uC99>
@ -336,10 +336,10 @@
<v6WtE>0</v6WtE>
<v6Rtti>0</v6Rtti>
<VariousControls>
<MiscControls></MiscControls>
<MiscControls>--diag_suppress=381 --diag_suppress=1 --diag_suppress=177 --diag_suppress=111 --diag_suppress=1295</MiscControls>
<Define>USE_HAL_DRIVER,STM32F103xB</Define>
<Undefine></Undefine>
<IncludePath>../Core/Inc; ../Drivers/STM32F1xx_HAL_Driver/Inc; ../Drivers/STM32F1xx_HAL_Driver/Inc/Legacy; ../Drivers/CMSIS/Device/ST/STM32F1xx/Include; ../Drivers/CMSIS/Include; ..\..\src; ..\..\; ..\..\iflytop_microcontroller</IncludePath>
<IncludePath>../Core/Inc; ../Drivers/STM32F1xx_HAL_Driver/Inc; ../Drivers/STM32F1xx_HAL_Driver/Inc/Legacy; ../Drivers/CMSIS/Device/ST/STM32F1xx/Include; ../Drivers/CMSIS/Include; ..\..\src; ..\..\; ..\..\iflytop_microcontroller</IncludePath>
</VariousControls>
</Cads>
<Aads>

17
app/app.ioc

@ -8,9 +8,10 @@ Mcu.IP1=NVIC
Mcu.IP2=RCC
Mcu.IP3=SYS
Mcu.IP4=TIM1
Mcu.IP5=USART1
Mcu.IP6=USART2
Mcu.IPNb=7
Mcu.IP5=TIM4
Mcu.IP6=USART1
Mcu.IP7=USART2
Mcu.IPNb=8
Mcu.Name=STM32F103C(8-B)Tx
Mcu.Package=LQFP48
Mcu.Pin0=PD0-OSC_IN
@ -18,6 +19,7 @@ Mcu.Pin1=PD1-OSC_OUT
Mcu.Pin10=VP_IWDG_VS_IWDG
Mcu.Pin11=VP_SYS_VS_Systick
Mcu.Pin12=VP_TIM1_VS_ClockSourceINT
Mcu.Pin13=VP_TIM4_VS_ClockSourceINT
Mcu.Pin2=PA2
Mcu.Pin3=PA3
Mcu.Pin4=PA8
@ -26,7 +28,7 @@ Mcu.Pin6=PA10
Mcu.Pin7=PA13
Mcu.Pin8=PA14
Mcu.Pin9=PB5
Mcu.PinsNb=13
Mcu.PinsNb=14
Mcu.ThirdPartyNb=0
Mcu.UserConstants=
Mcu.UserName=STM32F103C8Tx
@ -42,7 +44,6 @@ NVIC.PendSV_IRQn=true\:0\:0\:false\:false\:true\:false\:false
NVIC.PriorityGroup=NVIC_PRIORITYGROUP_4
NVIC.SVCall_IRQn=true\:0\:0\:false\:false\:true\:false\:false
NVIC.SysTick_IRQn=true\:0\:0\:false\:false\:true\:false\:true
NVIC.USART1_IRQn=true\:0\:0\:false\:false\:true\:true\:true
NVIC.USART2_IRQn=true\:0\:0\:false\:false\:true\:true\:true
NVIC.UsageFault_IRQn=true\:0\:0\:false\:false\:true\:false\:false
PA10.Mode=Asynchronous
@ -92,7 +93,7 @@ ProjectManager.StackSize=0x400
ProjectManager.TargetToolchain=MDK-ARM V5.27
ProjectManager.ToolChainLocation=
ProjectManager.UnderRoot=false
ProjectManager.functionlistsort=1-MX_GPIO_Init-GPIO-false-HAL-true,2-SystemClock_Config-RCC-false-HAL-false,3-MX_IWDG_Init-IWDG-false-HAL-true,4-MX_TIM4_Init-TIM4-false-HAL-true,5-MX_USART2_UART_Init-USART2-false-HAL-true,6-MX_USART1_UART_Init-USART1-false-HAL-true
ProjectManager.functionlistsort=1-MX_GPIO_Init-GPIO-false-HAL-true,2-SystemClock_Config-RCC-false-HAL-false,3-MX_IWDG_Init-IWDG-false-HAL-true,4-MX_USART2_UART_Init-USART2-false-HAL-true,5-MX_USART1_UART_Init-USART1-false-HAL-true,6-MX_TIM1_Init-TIM1-false-HAL-true
RCC.ADCFreqValue=36000000
RCC.AHBFreq_Value=72000000
RCC.APB1CLKDivider=RCC_HCLK_DIV2
@ -118,6 +119,8 @@ SH.S_TIM1_CH1.0=TIM1_CH1,PWM Generation1 CH1
SH.S_TIM1_CH1.ConfNb=1
TIM1.Channel-PWM\ Generation1\ CH1=TIM_CHANNEL_1
TIM1.IPParameters=Channel-PWM Generation1 CH1
TIM4.IPParameters=Prescaler
TIM4.Prescaler=72
USART1.IPParameters=VirtualMode
USART1.VirtualMode=VM_ASYNC
USART2.IPParameters=VirtualMode
@ -128,4 +131,6 @@ VP_SYS_VS_Systick.Mode=SysTick
VP_SYS_VS_Systick.Signal=SYS_VS_Systick
VP_TIM1_VS_ClockSourceINT.Mode=Internal
VP_TIM1_VS_ClockSourceINT.Signal=TIM1_VS_ClockSourceINT
VP_TIM4_VS_ClockSourceINT.Mode=Internal
VP_TIM4_VS_ClockSourceINT.Signal=TIM4_VS_ClockSourceINT
board=custom

21
src/port.c

@ -37,7 +37,7 @@ void port_do_debug_light_state(void) {
static uart_t m_uarts[] = {
{&DEBUG_UART, 0},
{&UART_TEST, 0},
{&MODBUS_UART, 0},
};
__weak void port_mock_on_uart_rx(uart_t* uart) {}
static void uarts_start_receive(uart_t* uart) { HAL_UART_Receive_IT(uart->uarthandler, &uart->rxbuf, 1); }
@ -64,3 +64,22 @@ void port_uart_start_all_uart_receive(void) {
uarts_start_receive(&m_uarts[i]);
}
}
bool port_electric_relay_get_state(int relayindex) {
/*
example:
if (relayindex == 1) {
return GPIO_GET(C, 8, !!);
}
*/
return false;
}
void port_electric_relay_set_state(int relayindex, bool state) {
/*
example:
if (relayindex == 1) {
GPIO_SET(C, 8, !!, state);
}
*/
}

7
src/port.h

@ -26,3 +26,10 @@ typedef struct {
} uart_t;
void port_mock_on_uart_rx(uart_t* uart);
void port_uart_start_all_uart_receive(void);
bool port_electric_relay_get_state(int relayindex);
void port_electric_relay_set_state(int relayindex, bool state);
static inline bool port_get_gpio_int(int index) {
return false;
}

142
src/user_main.c

@ -3,55 +3,155 @@
#include <stdio.h>
#include <string.h>
#include "iflytop_microcontroller/fancontroler/stm32/fan.h"
#include "iwdg.h"
#include "main.h"
#include "port.h"
//
#include "iflytop_microcontroller/fancontroler/stm32/fan.h"
#include "iflytop_microcontroller/zkey/std/zkey.h"
#include "iflytop_microcontroller/zmodbus/std/modbus_processer.h"
#include "iflytop_microcontroller/zmodbus/std/zmodbus_common.h"
#define interrupt_reception_send_buf_max 32
#define interrupt_reception_send_string "UART_TEST\r\n"
#define TAG "main"
bool interrupt_trigger_flag;
#define interrupt_reception_send_buf_max 32
#define interrupt_reception_send_string "MODBUS_UART\r\n"
/***********************************************************************************************************************
* ========================================================================================================= *
***********************************************************************************************************************/
static uint64_t s_key_press_state;
static fan_t s_fan[1] = {
FAN_INIT(NULL, 0, false, &FAN1_PWM_TIMER, FAN1_PWM_TIMER_CHANNEL, 1000, false, FAN1_FB_GPIO_PORT, FAN1_FB_PIN,
false),
};
static void uart_test_interrupt_reception() {
uint8_t send_buffer[interrupt_reception_send_buf_max] = interrupt_reception_send_string;
uint16_t send_string_size = strlen(interrupt_reception_send_string);
if (send_string_size >= interrupt_reception_send_buf_max) {
return;
}
if (interrupt_trigger_flag) {
HAL_UART_Transmit(&huart2, &send_buffer[0], send_string_size, 100);
interrupt_trigger_flag = false;
}
}
/**
* @brief
*/
void port_mock_on_uart_rx(uart_t* uart) {
//
if (uart->uarthandler == &UART_TEST) {
interrupt_trigger_flag = true;
if (uart->uarthandler == &MODBUS_UART) {
modbus_processer_push_data(uart->rxbuf);
}
}
/***********************************************************************************************************************
* ============================================ORDER_MODBUS_SLAVE============================================= *
***********************************************************************************************************************/
static uint8_t modbus_rx_buf[kmodbus_processer_rx_buf_size];
static uint8_t modbus_tx_buf[kmodbus_processer_tx_buf_size];
void process_10(uint16_t startreg, uint32_t regoff, uint16_t rxvalue);
void process_03(uint16_t startreg, uint32_t regoff);
void order_uart485_tx(uint8_t* rx, uint16_t len) { HAL_UART_Transmit(&MODBUS_UART, rx, len, 0xffffffff); }
void modbux_process_rx(modbus_processer_context_t* context);
static void delay_us(uint32_t us) { sys_delay_us(&US_TIMER, us); }
modbus_processer_t s_modbus_processer = {
.modbus_device_id = MODBUS_DEVICE_ID,
.modbus_processer_rx_buf = modbus_rx_buf,
.modbus_processer_rx_buf_size = sizeof(modbus_rx_buf),
.modbus_processer_tx_buf = modbus_tx_buf,
.modbus_processer_tx_buf_size = sizeof(modbus_tx_buf),
/*************************************/
.modbus_baundrate_one_packet_delay_us = kmodbus_baundrate_one_packet_delay_us,
.port_enter_critical = sys_critical_enter,
.port_exit_critical = sys_critical_exit,
.port_delay_us = delay_us,
.tx = order_uart485_tx,
/*************************************/
.process_rx = modbux_process_rx,
};
#if 0
:
Addr |
------------|-------------------------------
0 |
1 |
8(16Byte) | 0 ->15
9(16Byte) | 16->31
10(16Byte) | 0 ->15
11(16Byte) | 16->31
12(16Byte) |
15(16Byte) | KeyX|,|(Key0|0,1,2|,Key1|3,4,5|,Key2|6,7,8|,Key3|9,10,11|,Key4|12,13,14|)
#endif
void modbus_process_0_15(modbus_processer_context_t* context) {
ModbusFunctionCode fcode = modbus_get_function_code(context);
if (fcode == ModbusOrder10) {
/**
* @brief GPIO写
*/
if (modbus_if_register_exists_10(context, 8) && modbus_if_register_exists_10(context, 9) &&
modbus_if_register_exists_10(context, 10) && modbus_if_register_exists_10(context, 11)) {
uint32_t mask = modbus_get_reg_10(context, 8) | (modbus_get_reg_10(context, 9) << 16);
uint32_t value = modbus_get_reg_10(context, 10) | (modbus_get_reg_10(context, 11) << 16);
for (size_t i = 0; i < 32; i++) {
if (mask & (0x0001 << i)) port_electric_relay_set_state(i, !!(value & (0x0001 << i)));
}
}
} else if (fcode == ModbusOrder03) {
if (modbus_if_register_exists_03(context, 0)) {
modbus_set_tx_reg_03(context, 0, VERSION_MAIN_ID);
}
if (modbus_if_register_exists_03(context, 1)) {
modbus_set_tx_reg_03(context, 1, VERSION_SUB_ID);
}
if (modbus_if_register_exists_03(context, 10)) {
uint32_t value = 0;
for (size_t i = 0; i < 16; i++) {
if (port_electric_relay_get_state(i)) value |= (0x0001 << i);
}
modbus_set_tx_reg_03(context, 10, value);
}
if (modbus_if_register_exists_03(context, 11)) {
uint32_t value = 0;
for (size_t i = 16; i < 32; i++) {
if (port_electric_relay_get_state(i)) value |= (0x0001 << i);
}
modbus_set_tx_reg_03(context, 11, value);
}
if (modbus_if_register_exists_03(context, 12)) {
uint16_t value = 0;
for (size_t i = 0; i < 16; i++) {
if (port_get_gpio_int(i)) {
value |= (0x0001 << i);
}
}
modbus_set_tx_reg_03(context, 12, value);
}
if (modbus_if_register_exists_03(context, 15)) {
modbus_set_tx_reg_03(context, 15, s_key_press_state & 0xffff);
s_key_press_state = 0;
}
}
}
void modbux_process_rx(modbus_processer_context_t* context) {
ModbusFunctionCode fcode = modbus_get_function_code(context);
modbus_process_0_15(context);
if (fcode == ModbusOrder10) {
modbus_send_10(context, Modbus_OK);
} else if (fcode == ModbusOrder03) {
modbus_send_03(context, Modbus_OK);
}
}
void user_main() {
ZLOGI(TAG, "VERSION :%d.%d", VERSION_MAIN_ID, VERSION_SUB_ID);
//
port_uart_start_all_uart_receive();
modbus_processer_init(&s_modbus_processer);
//使PWM()
// 使PWM()
fan_set_power(&s_fan[0], 50);
while (1) {
// debug灯
port_do_debug_light_state();
//
uart_test_interrupt_reception();
// 485
modbus_processer_try_process_data();
//
HAL_IWDG_Refresh(&hiwdg);

12
src/zboard.h

@ -11,6 +11,11 @@
#define DEBUG_LIGHT_PIN GPIO_PIN_5
/***********************************************************************************************************************
* =========================================================================================================
***********************************************************************************************************************/
#define US_TIMER htim4
/***********************************************************************************************************************
* ============================-----==========================485MODBUS======================================================= *
***********************************************************************************************************************/
#define MODBUS_DEVICE_ID 0x01
@ -19,16 +24,11 @@
#define modbus_baundrate 115200
/*modebus判断一帧是以是否3.5byte时间内是否收到新的数据*/
#define kmodbus_baundrate_one_packet_delay_us ((1000000 / (modbus_baundrate / 8) + 1) * 3) // 211
#define UART_TEST huart2
#define MODBUS_UART huart2
#define kmodbus_processer_rx_buf_size 128
#define kmodbus_processer_tx_buf_size 128
/***********************************************************************************************************************
* =============================================================================================================== *
***********************************************************************************************************************/
#define KEY_SCAN_PERIOD 20
/***********************************************************************************************************************
* =========================================================================================================== *
***********************************************************************************************************************/
#define FAN1_PWM_TIMER htim1

Loading…
Cancel
Save