【HAL库每天一例】freemodbus移植

例程下载:
资料包括程序、相关说明资料以及软件使用截图

百度云盘:https://pan.baidu.com/s/1slN8rIt 密码:u6m1

360云盘:https://yunpan.cn/OcPiRp3wEcA92u密码 cfb6

(硬石YS-F1Pro开发板HAL库例程持续更新\6. 软件设计之Modbus(HAL库版本)\YSF1_HAL_freemodbus_001. freemodbus移植)
/**
  ******************************************************************************
  *                           硬石YS-F1Pro开发板例程功能说明
  *
  *  例程名称: YSF1_HAL_freemodbus_001. freemodbus移植
  *   
  ******************************************************************************
  * 说明:
  * 本例程配套硬石stm32开发板YS-F1Pro使用。
  * 
  * 淘宝:
  * 论坛:硬石电子社区
  * 版权归硬石嵌入式开发团队所有,请勿商用。
  ******************************************************************************
  */

【1】例程简介
  它是一个针对嵌入式应用的一个免费(自由)的通用MODBUS协议的移植。Modbus是一个工业
制造环境中应用的一个通用协议。Modbus通信协议栈包括两层:Modbus应用层协议,该层定义
了数据模式和功能;另外一层是网络层。

【2】跳线帽情况
******* 为保证例程正常运行,必须插入以下跳线帽 **********
丝印编号     IO端口      目标功能引脚        出厂默认设置
  JP1        PA10        TXD(CH340G)          已接入
  JP2        PA9         RXD(CH340G)          已接入
  CN6        PB10        TX(SP485E)           未接入
  CN6        PB11        RX(SP485E)           未接入
  
【3】操作及现象
使用两根导线连接两个开发板上的CN7接收端子,对应连接“A -- A”和“B -- B”,使用开发板配
套的MINI USB线连接到开发板标示“调试串口”字样的MIMI USB接口(需要安装驱动),在电脑端打
开串口调试助手工具,设置参数为115200 8-N-1。下载完程序之后,在串口调试助手窗口可接收到信
息。
/******************* (C) COPYRIGHT 2015-2020 硬石嵌入式开发团队 *****END OF FILE****/

main.c文件内容

  1. /**
  2. ******************************************************************************
  3. * 文件名程: main.c
  4. * 作    者: 硬石嵌入式开发团队
  5. * 版    本: V1.0
  6. * 编写日期: 2015-10-04
  7. * 功    能: RS485双机通信--从机设备实现
  8. ******************************************************************************
  9. * 说明:
  10. * 本例程配套硬石stm32开发板YS-F1Pro使用。
  11. *
  12. * 淘宝:
  13. * 论坛:http://www.ing10bbs.com
  14. * 版权归硬石嵌入式开发团队所有,请勿商用。
  15. ******************************************************************************
  16. */
  17. /* 包含头文件 ----------------------------------------------------------------*/
  18. #include "stm32f1xx_hal.h"
  19. #include "usart/bsp_debug_usart.h"
  20. #include "RS485/bsp_usartx_RS485.h"
  21. #include "mb.h"
  22. #include "mbport.h"
  23. /* 私有类型定义 --------------------------------------------------------------*/
  24. /* 私有宏定义 ----------------------------------------------------------------*/
  25. #define REG_INPUT_START 0
  26. #define REG_INPUT_NREGS 4
  27. /* 私有变量 ------------------------------------------------------------------*/
  28. static USHORT   usRegInputStart = REG_INPUT_START;
  29. static USHORT   usRegInputBuf[REG_INPUT_NREGS];
  30. /**
  31. * 函数功能: 主函数.
  32. * 输入参数: 无
  33. * 返 回 值: 无
  34. * 说    明: 无
  35. */
  36. int main(void)
  37. {
  38. /* 复位所有外设,初始化Flash接口和系统滴答定时器 */
  39. HAL_Init();
  40. /* 配置系统时钟 */
  41. SystemClock_Config();
  42. /* 初始化串口并配置串口中断优先级 */
  43. MX_DEBUG_USART_Init();
  44. printf("freemodbus 移植测试\n");
  45. RS485_USARTx_Init();
  46. eMBInit(MB_RTU, 0x01, 3, 9600, MB_PAR_NONE);
  47. /* Enable the Modbus Protocol Stack. */
  48. eMBEnable();
  49. /* 无限循环 */
  50. while (1)
  51. {
  52. (void)eMBPoll();
  53. }
  54. }
  55. eMBErrorCode eMBRegInputCB( UCHAR * pucRegBuffer, USHORT usAddress, USHORT usNRegs )
  56. {
  57. eMBErrorCode    eStatus = MB_ENOERR;
  58. int             iRegIndex;
  59. printf("eMBRegInputCB\n");
  60. //        用作例子
  61. usRegInputBuf[0] = 0x11;
  62. usRegInputBuf[1] = 0x22;
  63. usRegInputBuf[2] = 0x33;
  64. usRegInputBuf[3] = 0x44;
  65. //        例子结束
  66. if((usAddress>=REG_INPUT_START)&&(usAddress+usNRegs<=REG_INPUT_START+REG_INPUT_NREGS))
  67. {
  68. iRegIndex=(int)(usAddress-usRegInputStart);
  69. while( usNRegs > 0 )
  70. {
  71. *pucRegBuffer++ = (unsigned char)(usRegInputBuf[iRegIndex]>>8);
  72. *pucRegBuffer++ = (unsigned char)(usRegInputBuf[iRegIndex]&0xFF);
  73. iRegIndex++;
  74. usNRegs--;
  75. }
  76. }
  77. else
  78. {
  79. eStatus = MB_ENOREG;
  80. }
  81. return eStatus;
  82. }
  83. eMBErrorCode eMBRegHoldingCB( UCHAR * pucRegBuffer, USHORT usAddress, USHORT usNRegs,eMBRegisterMode eMode )
  84. {
  85. printf("eMBRegHoldingCB\n");
  86. return MB_ENOREG;
  87. }
  88. eMBErrorCode eMBRegCoilsCB( UCHAR * pucRegBuffer, USHORT usAddress, USHORT usNCoils,eMBRegisterMode eMode )
  89. {
  90. printf("eMBRegCoilsCB\n");
  91. return MB_ENOREG;
  92. }
  93. eMBErrorCode eMBRegDiscreteCB( UCHAR * pucRegBuffer, USHORT usAddress, USHORT usNDiscrete )
  94. {
  95. printf("eMBRegDiscreteCB\n");
  96. return MB_ENOREG;
  97. }
  98. /******************* (C) COPYRIGHT 2015-2020 硬石嵌入式开发团队 *****END OF FILE****/

复制代码

时间: 2024-11-11 10:39:09

【HAL库每天一例】freemodbus移植的相关文章

STM32标准外设库、 HAL库、LL库

工作以来一直使用ST的STM32系列芯片,ST为开发者提供了非常方便的开发库.到目前为止,有标准外设库(STD库).HAL库.LL库 三种.前两者都是常用的库,后面的LL库是ST最近才添加,目前支持的芯片也偏少.各库如下所示: 其中STD库和HAL库两者相互独立,互不兼容.几种库的比较如下: 目前几种库对不同芯片的支持情况如下: 上图中,LL库目前有部分芯片不支持,官方计划2017年逐步完善. STM32Snippets 它是代码示例的集合,直接基于STM32外设寄存器,可在文档和软件包中使用.

【安富莱】V6,V5开发板用户手册,重在BSP驱动包设计方法,HAL库的框架学习,授人以渔(2019-07-21)

说明: 1.本教程重在BSP驱动包设计方法和HAL库的框架学习,并将HAL库里面的各种弯弯绕捋顺,从而方便我们的程序设计. 2.本次工程延续以往的代码风格,从底层BSP驱动包到应用代码,变量命名,文件命名,程序框架,注释等都比较规范,大家阅读或者移植都会比较方便.      另外,阅读代码时,务必将编辑器的缩进参数和TAB设置为4来阅读本文件,否则显示不整齐. 3.本教程每周会继续更新1-2章,之后将开启配套的视频教程制作,加大对初学者的支持力度. 4.V5,V6,V7将通过这次升级,达到底层驱

【STM32H7教程】第36章 STM32H7的LPTIM低功耗定时器基础知识和HAL库API

完整教程下载地址:http://www.armbbs.cn/forum.php?mod=viewthread&tid=86980 第36章       STM32H7的LPTIM低功耗定时器基础知识和HAL库API 本章节为大家讲解LPTIM1 – LPTIM5共计5个定时器的基础知识和对应的HAL库API. 36.1 初学者重要提示 36.2 低功耗定时器基础知识 36.3 低功耗定时器的HAL库用户 36.4 源文件stm32h7xx_hal_lptim.c 36.5 总结 36.1 初学者

【STM32H7教程】第57章 STM32H7硬件JPEG编解码基础知识和HAL库API

完整教程下载地址:http://www.armbbs.cn/forum.php?mod=viewthread&tid=86980 第57章       STM32H7硬件JPEG编解码基础知识和HAL库API 本章节为大家讲解硬件JPEG,实际项目用到图像显示的地方比较多,有了硬件JPEG可以大大加速JPEG图片显示速度. 57.1 初学者重要提示 57.2 硬件JPEG基础知识 57.3 硬件JPEG的HAL库用法 57.4 源文件stm32h7xx_hal_jpeg.c 57.5 总结 57

(七)boost库之单例类

(七)boost库之单例类 一.boost.serialzation的单件实现 单例模式是一种常用的软件设计模式.在它的核心结构中只包含一个被称为单例类的特殊类.通过单例模式可以保证系统中一个类只有一个实例而且该实例易于外界访问,从而方便对实例个数的控制并节约系统资源.如果希望在系统中某个类的对象只能存在一个,单例模式是最好的解决方案. 单例,通常在一个大型项目中单例是非常常见的,boost库没有提供专门的单例类,但可以在其它库中找到他的实现 #include <boost/serializat

STM32 HAL库和LL库的区别

上次开发一个项目,使用一个小容量的STM32 ARM CORTEX核心的单片机,使用STM32CUBEMX自动生成配置代码,正准备编写程序的时候,发现容量竟然有6K多.这个容量在使用大容量FLASH的单片机时不感到什么,可是使用小容量单片机的时候,就明显不够用了. 没有办法,只好打算回去使用原来的StdLib库,前两年不就这么干的嘛,也没什么难的.可是回头找对应库的时候,发现悲剧了,没有这个序列的标准库. 这也难不倒我们老司机!我就从HAL库里面把必须的寄存器语句摘出来,把冗余的有效检验和冲突处

STM32F103 PWM输出实验(HAL库)

1.芯片输出PWM波形打码步骤 1.0主函数 int main(void) { HAL_Init(); //初始化HAL库 Stm32_Clock_Init(RCC_PLL_MUL9); //设置时钟,72M delay_init(72); //初始化延时函数 uart_init(115200); //初始化串口 LED_Init(); //初始化LED TIM1_PWM_Init(20000,72); //72分频,即1M . 1000000/20000 = 50 Hz ,即20ms whil

USART与USB接收不定数据方法,标准库、HAL库都适用

很多时候,我们使用串口或USB接收数据时,往往不知道PC端会发多长的数据下来, 为了解决这个不定数据接收问题,在此各提供一个解决思路. 串口数据不定接收: 由于STM32单片机带IDLE中断,所以利用这个中断,可以接收不定长字节的数据, 由于STM32属于ARM单片机,所以这篇文章的方法也适合其他的ARM单片机. IDLE就是串口收到一帧数据后,发生的中断.什么是一帧数据呢?比如说给单片机一 次发来1个字节,或者一次发来8个字节,这些一次发来的数据,就称为一帧数据,也可以 叫做一包数据. 还有一

STM32CubeMX HAL库串口+DMA数据发送不定长度数据接收

参考资料:1.ST HAL库官网资料 2.https://blog.csdn.net/u014470361/article/details/79206352#comments 一.STM32CubeMX配置外部时钟 注意在进行外部时钟配置时,即"High Speed Clock"和"Low Speed Clock"需配置成"Crytal/Ceramic Resonator(低温/陶瓷谐振器)"不能配置为"BYASS Clock Sour