找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4306|回复: 1
收起左侧

rtthread stm32f103 modbus 从机例程

[复制链接]
ID:483892 发表于 2019-9-28 20:02 | 显示全部楼层 |阅读模式
stm32F103 最小系统,modbus slave RTU 示例代码,采用freemodbus

单片机源程序如下:
  1. #include <rtthread.h>
  2. #include <rtdevice.h>
  3. #include <board.h>

  4. #include "wdt.h"
  5. //#include "uart.h"
  6. //#include "mpu6050.h"
  7. #include "mb_slave.h"
  8. #include "bsp_flash.h"

  9. /* 私用宏定义----------------------------------------------------------------*/
  10. #define THREAD_PRIORITY         25
  11. #define THREAD_STACK_SIZE       512
  12. #define THREAD_TIMESLICE        5

  13. #define EVENT_BIT_0         (1 << 0)
  14. #define EVENT_BIT_1         (1 << 1)
  15. //#define EVENT_BIT_2         (1 << 2)
  16. //#define EVENT_BIT_3         (1 << 3)
  17. //#define EVENT_BIT_4         (1 << 4)
  18. //#define EVENT_BIT_5         (1 << 5)


  19. /* 私用变量----------------------------------------------------------------*/


  20. /**************************** 任务句柄 ********************************/

  21. static rt_thread_t th_wdg = RT_NULL; //看门狗

  22. static rt_thread_t th_Gyro = RT_NULL; //陀螺仪

  23. /*事件控制块*/
  24. static struct rt_event event;

  25. /*wdg 入口函数*/
  26. static void th_wdg_entry(void *parameter)
  27. {
  28.     rt_uint32_t count = 0;

  29.     while (1)
  30.     {
  31.         
  32. //        rt_kprintf("wdg thread count: %d\n", count ++);
  33.         rt_thread_mdelay(50);
  34.                         /* 收到所有事件,复位看门狗*/
  35.                                 rt_uint32_t e;
  36.                                 if (rt_event_recv(&event, (EVENT_BIT_0     ),
  37.                                                                                                         RT_EVENT_FLAG_AND | RT_EVENT_FLAG_CLEAR,
  38.                                                                                                         RT_WAITING_FOREVER, &e) == RT_EOK)
  39.                                 {
  40. //                                                rt_kprintf("wdg: AND recv event 0x%x\n", e);
  41.                                                 //喂狗
  42.                                                 iwdg_feed();
  43.                                 }
  44.                                
  45.     }
  46. }


  47. /* gyro 入口函数*/
  48. static void th_Gyro_entry(void *parameter)
  49. {
  50. //        float angle_Y = 0;                //初始状态值       
  51. //        float angle_X = 0;
  52. //        float angle_Z = 0;
  53. //       
  54. //    rt_int16_t temp;        //温度
  55. //    rt_int16_t gx,gy,gz;    //三轴加速度
  56. //    rt_int16_t ax,ay,az;    //三轴角速度
  57. //   
  58. //    rt_err_t ret;
  59. //   
  60.     while(1)
  61.     {
  62. //        ret = mpu6050_temperature_get(&temp);
  63. //        if (ret != RT_EOK)
  64. //        {
  65. //            rt_kprintf("mpu6050 : get temperature error\r\n");
  66. //        }            
  67. //        ret = mpu6050_accelerometer_get(&ax, &ay, &az);
  68. //        if (ret != RT_EOK)
  69. //        {
  70. //            rt_kprintf("mpu6050 : get acc error\r\n");
  71. //        }
  72. //        ret = mpu6050_gyroscope_get(&gx, &gy, &gz);
  73. //        if (ret != RT_EOK)
  74. //        {
  75. //            rt_kprintf("mpu6050 : get gyro error\r\n");
  76. //        }
  77. //        if (ret == RT_EOK)
  78. //        {
  79. //            rt_kprintf("mpu6050: temperature=%-6d gx=%-6d gy=%-6d gz=%-6d ax=%-6d ay=%-6d az=%-6d\r\n",temp/100,gx,gy,gz,ax,ay,az);
  80. //                        angle_X=Kalman_X(ax/100,ay/100,az/100,gx,gy,gz);
  81. //                        angle_Y=Kalman_Y(ax/100,ay/100,az/100,gx,gy,gz);
  82. //                        angle_Z=Kalman_Z(ax/100,ay/100,az/100,gx,gy,gz);
  83. //                        rt_kprintf("x=%-6d  y=%-6d   z=%-6d \r\n ",angle_X,angle_Y,angle_Z);
  84. //        }
  85. //        rt_thread_delay(rt_tick_from_millisecond(1000));

  86.                                 rt_event_send(&event, EVENT_BIT_0);
  87.                                 rt_thread_delay(200);
  88.     }



  89. }


  90. //动态创建线程
  91. void th_create(){
  92.          rt_err_t result;

  93.     /* 初始化事件对象 */
  94.     result = rt_event_init(&event, "event", RT_IPC_FLAG_FIFO);
  95.     if (result != RT_EOK)
  96.     {
  97.         rt_kprintf("init event failed.\n");
  98.         return ;
  99.     }
  100.        
  101.        
  102.                 /*动态创建WDG线程*/
  103.     th_wdg = rt_thread_create("wdg",
  104.                             th_wdg_entry, RT_NULL,
  105.                             THREAD_STACK_SIZE-256,
  106.                             THREAD_PRIORITY, THREAD_TIMESLICE);
  107.    
  108.     /* 如果获取线程控制块,启动这个线程 */
  109.     if (th_wdg != RT_NULL)
  110.                         {
  111.         rt_thread_startup(th_wdg);
  112.                         }
  113.                                
  114.                 /*动态创建姿态获取线程*/
  115.     th_Gyro = rt_thread_create("Gyro",
  116.                             th_Gyro_entry, RT_NULL,
  117.                             THREAD_STACK_SIZE,
  118.                             THREAD_PRIORITY-1, THREAD_TIMESLICE);
  119.    
  120.     /* 如果获取线程控制块,启动这个线程 */
  121.     if (th_Gyro != RT_NULL)
  122.         rt_thread_startup(th_Gyro);
  123.                
  124.        
  125.                
  126.                
  127. }


  128. int main(void)
  129. {
  130.        
  131. //         //485 初始化
  132. //                uart5_init();
  133.        
  134.    //创建线程
  135.                 th_create();
  136.        
  137.          //modbus 初始化
  138.                 mb_slave_init();
  139.        
  140.                 //看门狗初始化

  141.                 if(iwdg_init()==RT_EOK){
  142.                         rt_kprintf("iwdg init success.\n");
  143.                 };
  144.                
  145. //                rt_pin_mode(MODBUS_MASTER_RT_CONTROL_PIN_INDEX, PIN_MODE_OUTPUT);
  146. //                 rt_pin_write(MODBUS_MASTER_RT_CONTROL_PIN_INDEX, PIN_HIGH);
  147. //                #define RT_MODBUS_MASTER_USE_CONTROL_PIN 1
  148. //                #define MODBUS_MASTER_RT_CONTROL_PIN_INDEX 19
  149.                
  150. //                uint16_t Data [6] = {7,1,2,3,4,5};
  151. //                uint32_t  Address = 0x0800FC00 ;                
  152. //                FLASH_WriteData(Address,Data,1);
  153. //               
  154. //                uint16_t Text [6] = {0};
  155. //                FLASH_ReadMoreData(Address,Text,6);
  156. //                for(int i=0;i<6;i++){
  157. //                        rt_kprintf("%d \r\n",Text[i]);
  158. //                }
  159.                

  160.     return RT_EOK;
  161. }
复制代码

所有资料51hei提供下载:
stm32f103_modbus.rar (111.17 KB, 下载次数: 74)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:270740 发表于 2019-12-9 17:10
版主,请屏蔽此贴,从其它地方抄的内容,赚不知情的人员的黑币。我反对

ID:208337 发表于 2021-3-2 16:45 | 显示全部楼层
能不能直接用?
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表