找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4135|回复: 0
打印 上一主题 下一主题
收起左侧

stm32单片机ucosiii例程分享

[复制链接]
跳转到指定楼层
楼主
这是32单片机ucosiii一部分源码


所有资料51hei提供下载:
2-ucosiii例程.7z (1.18 MB, 下载次数: 89)



其中一个单片机源程序如下:
  1. /*
  2. *********************************************************************************************************
  3. *                                              EXAMPLE CODE
  4. *
  5. *                             (c) Copyright 2013; Micrium, Inc.; Weston, FL
  6. *
  7. *                   All rights reserved.  Protected by international copyright laws.
  8. *                   Knowledge of the source code may not be used to write a similar
  9. *                   product.  This file may only be used in accordance with a license
  10. *                   and should not be redistributed in any way.
  11. *********************************************************************************************************
  12. */

  13. /*
  14. *********************************************************************************************************
  15. *
  16. *                                            EXAMPLE CODE
  17. *
  18. *                                       IAR Development Kits
  19. *                                              on the
  20. *
  21. *                                    STM32F429II-SK KICKSTART KIT
  22. *
  23. * Filename      : app.c
  24. * Version       : V1.00
  25. * Programmer(s) : YS
  26. *                 DC
  27. *********************************************************************************************************
  28. */

  29. /*
  30. *********************************************************************************************************
  31. *                                             INCLUDE FILES
  32. *********************************************************************************************************
  33. */

  34. #include <includes.h>


  35. /*
  36. *********************************************************************************************************
  37. *                                            LOCAL DEFINES
  38. *********************************************************************************************************
  39. */

  40. OS_SEM SemOfKey;          //标志KEY1是否被单击的多值信号量


  41. /*
  42. *********************************************************************************************************
  43. *                                                 TCB
  44. *********************************************************************************************************
  45. */

  46. static  OS_TCB   AppTaskStartTCB;                                //任务控制块

  47. static  OS_TCB   AppTaskKeyTCB;
  48. static  OS_TCB   AppTaskLed1TCB;


  49. /*
  50. *********************************************************************************************************
  51. *                                                STACKS
  52. *********************************************************************************************************
  53. */

  54. static  CPU_STK  AppTaskStartStk[APP_TASK_START_STK_SIZE];       //任务堆栈

  55. static  CPU_STK  AppTaskKeyStk [ APP_TASK_KEY_STK_SIZE ];
  56. static  CPU_STK  AppTaskLed1Stk [ APP_TASK_LED1_STK_SIZE ];


  57. /*
  58. *********************************************************************************************************
  59. *                                         FUNCTION PROTOTYPES
  60. *********************************************************************************************************
  61. */

  62. static  void  AppTaskStart  (void *p_arg);                       //任务函数声明

  63. static  void  AppTaskKey  ( void * p_arg );
  64. static  void  AppTaskLed1 ( void * p_arg );


  65. /*
  66. *********************************************************************************************************
  67. *                                                main()
  68. *
  69. * Description : This is the standard entry point for C code.  It is assumed that your code will call
  70. *               main() once you have performed all necessary initialization.
  71. *
  72. * Arguments   : none
  73. *
  74. * Returns     : none
  75. *********************************************************************************************************
  76. */

  77. int  main (void)
  78. {
  79.     OS_ERR  err;


  80.     OSInit(&err);                                                           //初始化 uC/OS-III

  81.           /* 创建起始任务 */
  82.     OSTaskCreate((OS_TCB     *)&AppTaskStartTCB,                            //任务控制块地址
  83.                  (CPU_CHAR   *)"App Task Start",                            //任务名称
  84.                  (OS_TASK_PTR ) AppTaskStart,                               //任务函数
  85.                  (void       *) 0,                                          //传递给任务函数(形参p_arg)的实参
  86.                  (OS_PRIO     ) APP_TASK_START_PRIO,                        //任务的优先级
  87.                  (CPU_STK    *)&AppTaskStartStk[0],                         //任务堆栈的基地址
  88.                  (CPU_STK_SIZE) APP_TASK_START_STK_SIZE / 10,               //任务堆栈空间剩下1/10时限制其增长
  89.                  (CPU_STK_SIZE) APP_TASK_START_STK_SIZE,                    //任务堆栈空间(单位:sizeof(CPU_STK))
  90.                  (OS_MSG_QTY  ) 5u,                                         //任务可接收的最大消息数
  91.                  (OS_TICK     ) 0u,                                         //任务的时间片节拍数(0表默认值OSCfg_TickRate_Hz/10)
  92.                  (void       *) 0,                                          //任务扩展(0表不扩展)
  93.                  (OS_OPT      )(OS_OPT_TASK_STK_CHK | OS_OPT_TASK_STK_CLR), //任务选项
  94.                  (OS_ERR     *)&err);                                       //返回错误类型

  95.     OSStart(&err);                                                          //启动多任务管理(交由uC/OS-III控制)

  96. }


  97. /*
  98. *********************************************************************************************************
  99. *                                          STARTUP TASK
  100. *
  101. * Description : This is an example of a startup task.  As mentioned in the book's text, you MUST
  102. *               initialize the ticker only once multitasking has started.
  103. *
  104. * Arguments   : p_arg   is the argument passed to 'AppTaskStart()' by 'OSTaskCreate()'.
  105. *
  106. * Returns     : none
  107. *
  108. * Notes       : 1) The first line of code is used to prevent a compiler warning because 'p_arg' is not
  109. *                  used.  The compiler should not generate any code for this statement.
  110. *********************************************************************************************************
  111. */

  112. static  void  AppTaskStart (void *p_arg)
  113. {
  114.     CPU_INT32U  cpu_clk_freq;
  115.     CPU_INT32U  cnts;
  116.     OS_ERR      err;


  117.    (void)p_arg;

  118.     BSP_Init();                                                 //板级初始化
  119.     CPU_Init();                                                 //初始化 CPU 组件(时间戳、关中断时间测量和主机名)

  120.     cpu_clk_freq = BSP_CPU_ClkFreq();                           //获取 CPU 内核时钟频率(SysTick 工作时钟)
  121.     cnts = cpu_clk_freq / (CPU_INT32U)OSCfg_TickRate_Hz;        //根据用户设定的时钟节拍频率计算 SysTick 定时器的计数值
  122.     OS_CPU_SysTickInit(cnts);                                   //调用 SysTick 初始化函数,设置定时器计数值和启动定时器

  123.     Mem_Init();                                                 //初始化内存管理组件(堆内存池和内存池表)

  124. #if OS_CFG_STAT_TASK_EN > 0u                                    //如果使能(默认使能)了统计任务
  125.     OSStatTaskCPUUsageInit(&err);                               //计算没有应用任务(只有空闲任务)运行时 CPU 的(最大)
  126. #endif                                                          //容量(决定 OS_Stat_IdleCtrMax 的值,为后面计算 CPU
  127.                                                                 //使用率使用)。
  128. #ifdef CPU_CFG_INT_DIS_MEAS_EN
  129.     CPU_IntDisMeasMaxCurReset();                                //复位(清零)当前最大关中断时间
  130. #endif

  131.    
  132.                 /* 创建多值信号量 SemOfKey */
  133.     OSSemCreate((OS_SEM      *)&SemOfKey,    //指向信号量变量的指针
  134.                (CPU_CHAR    *)"SemOfKey",    //信号量的名字
  135.                (OS_SEM_CTR   )0,             //信号量这里是指示事件发生,所以赋值为0,表示事件还没有发生
  136.                (OS_ERR      *)&err);         //错误类型
  137.                                                          

  138.                 /* 创建 AppTaskKey 任务 */
  139.     OSTaskCreate((OS_TCB     *)&AppTaskKeyTCB,                              //任务控制块地址
  140.                  (CPU_CHAR   *)"App Task Key",                              //任务名称
  141.                  (OS_TASK_PTR ) AppTaskKey,                                 //任务函数
  142.                  (void       *) 0,                                          //传递给任务函数(形参p_arg)的实参
  143.                  (OS_PRIO     ) APP_TASK_KEY_PRIO,                          //任务的优先级
  144.                  (CPU_STK    *)&AppTaskKeyStk[0],                           //任务堆栈的基地址
  145.                  (CPU_STK_SIZE) APP_TASK_KEY_STK_SIZE / 10,                 //任务堆栈空间剩下1/10时限制其增长
  146.                  (CPU_STK_SIZE) APP_TASK_KEY_STK_SIZE,                      //任务堆栈空间(单位:sizeof(CPU_STK))
  147.                  (OS_MSG_QTY  ) 5u,                                         //任务可接收的最大消息数
  148.                  (OS_TICK     ) 0u,                                         //任务的时间片节拍数(0表默认值OSCfg_TickRate_Hz/10)
  149.                  (void       *) 0,                                          //任务扩展(0表不扩展)
  150.                  (OS_OPT      )(OS_OPT_TASK_STK_CHK | OS_OPT_TASK_STK_CLR), //任务选项
  151.                  (OS_ERR     *)&err);                                       //返回错误类型
  152.    
  153.                 /* 创建 LED1 任务 */
  154.     OSTaskCreate((OS_TCB     *)&AppTaskLed1TCB,                             //任务控制块地址
  155.                  (CPU_CHAR   *)"App Task Led1",                             //任务名称
  156.                  (OS_TASK_PTR ) AppTaskLed1,                                //任务函数
  157.                  (void       *) 0,                                          //传递给任务函数(形参p_arg)的实参
  158.                  (OS_PRIO     ) APP_TASK_LED1_PRIO,                         //任务的优先级
  159.                  (CPU_STK    *)&AppTaskLed1Stk[0],                          //任务堆栈的基地址
  160.                  (CPU_STK_SIZE) APP_TASK_LED1_STK_SIZE / 10,                //任务堆栈空间剩下1/10时限制其增长
  161.                  (CPU_STK_SIZE) APP_TASK_LED1_STK_SIZE,                     //任务堆栈空间(单位:sizeof(CPU_STK))
  162.                  (OS_MSG_QTY  ) 5u,                                         //任务可接收的最大消息数
  163.                  (OS_TICK     ) 0u,                                         //任务的时间片节拍数(0表默认值OSCfg_TickRate_Hz/10)
  164.                  (void       *) 0,                                          //任务扩展(0表不扩展)
  165.                  (OS_OPT      )(OS_OPT_TASK_STK_CHK | OS_OPT_TASK_STK_CLR), //任务选项
  166.                  (OS_ERR     *)&err);                                       //返回错误类型
  167.                
  168.                 OSTaskDel ( & AppTaskStartTCB, & err );                     //删除起始任务本身,该任务不再运行
  169.                
  170.                
  171. }


  172. /*
  173. *********************************************************************************************************
  174. *                                          KEY TASK
  175. *********************************************************************************************************
  176. */
  177. static  void  AppTaskKey ( void * p_arg )
  178. {
  179.         OS_ERR      err;

  180.         uint8_t ucKey1Press = 0;
  181.         
  182.         
  183.         (void)p_arg;

  184.                                          
  185.         while (DEF_TRUE) {                                                         //任务体
  186.                 if( Key_Scan ( macKEY1_GPIO_PORT, macKEY1_GPIO_PIN, 1, & ucKey1Press ) ) //如果KEY1被单击
  187.                   OSSemPost((OS_SEM  *)&SemOfKey,                                        //发布SemOfKey
  188.                                                          (OS_OPT   )OS_OPT_POST_ALL,                                   //发布给所有等待任务
  189.                                                          (OS_ERR  *)&err);                                             //返回错误类型

  190.                 OSTimeDlyHMSM ( 0, 0, 0, 20, OS_OPT_TIME_DLY, & err );                   //每20ms扫描一次
  191.                
  192.         }
  193.         
  194. }


  195. /*
  196. *********************************************************************************************************
  197. *                                          LED1 TASK
  198. *********************************************************************************************************
  199. */

  200. static  void  AppTaskLed1 ( void * p_arg )
  201. {
  202.     OS_ERR         err;
  203.           CPU_INT32U     cpu_clk_freq;
  204.           CPU_TS         ts_sem_post, ts_sem_get;
  205.                 CPU_SR_ALLOC();  //使用到临界段(在关/开中断时)时必需该宏,该宏声明和定义一个局部变
  206.                                                                                  //量,用于保存关中断前的 CPU 状态寄存器 SR(临界段关中断只需保存SR)
  207.                                                                                  //,开中断时将该值还原。
  208.     (void)p_arg;


  209.           cpu_clk_freq = BSP_CPU_ClkFreq();               //获取CPU时钟,时间戳是以该时钟计数
  210.         
  211.         
  212.     while (DEF_TRUE) {                              //任务体
  213.                                        
  214.                         OSSemPend ((OS_SEM   *)&SemOfKey,             //等待该信号量被发布
  215.                                                                  (OS_TICK   )0,                     //无期限等待
  216.                                                                  (OS_OPT    )OS_OPT_PEND_BLOCKING,  //如果没有信号量可用就等待
  217.                                                                  (CPU_TS   *)&ts_sem_post,          //获取信号量最后一次被发布的时间戳
  218.                                                                  (OS_ERR   *)&err);                 //返回错误类型
  219.                                 
  220.                         ts_sem_get = OS_TS_GET();                     //获取解除等待时的时间戳
  221.                                 
  222.                         macLED1_TOGGLE ();                            //切换LED1的亮灭状态
  223.                                 
  224.                         OS_CRITICAL_ENTER();                          //进入临界段,不希望下面串口打印遭到中断
  225.                         
  226.                         printf ( "\r\n发布信号量的时间戳是%d", ts_sem_post );
  227.                         printf ( "\r\n解除等待状态的时间戳是%d", ts_sem_get );
  228.                         printf ( "\r\n接收到信号量与发布信号量的时间相差%dus\r\n",
  229.                                 ( ts_sem_get - ts_sem_post ) / ( cpu_clk_freq / 1000000 ) );
  230.                         
  231.                         OS_CRITICAL_EXIT();

  232.     }
  233.                
  234.                
  235. }
复制代码



分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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