application.c 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. /*
  2. * File : application.c
  3. * This file is part of RT-Thread RTOS
  4. * COPYRIGHT (C) 2006, RT-Thread Development Team
  5. *
  6. * The license and distribution terms for this file may be
  7. * found in the file LICENSE in this distribution or at
  8. * http://www.rt-thread.org/license/LICENSE
  9. *
  10. * Change Logs:
  11. * Date Author Notes
  12. * 2009-01-05 Bernard the first version
  13. */
  14. /**
  15. * @addtogroup STM32
  16. */
  17. /*@{*/
  18. #include <stdio.h>
  19. #include "stm32f4xx.h"
  20. #include <board.h>
  21. #include <rtthread.h>
  22. #ifdef RT_USING_LWIP
  23. #include <lwip/sys.h>
  24. #include <lwip/api.h>
  25. #include <netif/ethernetif.h>
  26. #include "stm32_eth.h"
  27. #endif
  28. void rt_init_thread_entry(void* parameter)
  29. {
  30. /* LwIP Initialization */
  31. #ifdef RT_USING_LWIP
  32. {
  33. extern void lwip_sys_init(void);
  34. /* register ethernetif device */
  35. eth_system_device_init();
  36. rt_hw_stm32_eth_init();
  37. /* re-init device driver */
  38. rt_device_init_all();
  39. /* init lwip system */
  40. lwip_sys_init();
  41. rt_kprintf("TCP/IP initialized!\n");
  42. }
  43. #endif
  44. //FS
  45. //GUI
  46. }
  47. float f_var1;
  48. float f_var2;
  49. float f_var3;
  50. float f_var4;
  51. ALIGN(RT_ALIGN_SIZE)
  52. static char thread_led1_stack[1024];
  53. struct rt_thread thread_led1;
  54. static void rt_thread_entry_led1(void* parameter)
  55. {
  56. GPIO_InitTypeDef GPIO_InitStructure;
  57. /* GPIOD Periph clock enable */
  58. RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD, ENABLE);
  59. /* Configure PD12, PD13, PD14 and PD15 in output pushpull mode */
  60. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12 | GPIO_Pin_13| GPIO_Pin_14| GPIO_Pin_15;
  61. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
  62. GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  63. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
  64. GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  65. GPIO_Init(GPIOD, &GPIO_InitStructure);
  66. f_var1 = 3.141592653;
  67. f_var2 = 123.456;
  68. f_var3 = 0.123456789;
  69. f_var4 = 1.00001;
  70. while (1)
  71. {
  72. /* PD12 to be toggled */
  73. GPIO_SetBits(GPIOD, GPIO_Pin_12);
  74. /* Insert delay */
  75. rt_thread_delay(RT_TICK_PER_SECOND/2);
  76. f_var3 += f_var4;
  77. f_var4 = f_var4 * f_var4;
  78. /* PD13 to be toggled */
  79. GPIO_SetBits(GPIOD, GPIO_Pin_13);
  80. /* Insert delay */
  81. rt_thread_delay(RT_TICK_PER_SECOND/2);
  82. f_var3 += f_var4;
  83. f_var4 = f_var4 * f_var4;
  84. /* PD14 to be toggled */
  85. GPIO_SetBits(GPIOD, GPIO_Pin_14);
  86. /* Insert delay */
  87. rt_thread_delay(RT_TICK_PER_SECOND/2);
  88. f_var3 += f_var4;
  89. f_var4 = f_var4 * f_var4;
  90. /* PD15 to be toggled */
  91. GPIO_SetBits(GPIOD, GPIO_Pin_15);
  92. /* Insert delay */
  93. rt_thread_delay(RT_TICK_PER_SECOND*2);
  94. f_var3 += f_var4;
  95. f_var4 = f_var4 * f_var4;
  96. GPIO_ResetBits(GPIOD, GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14|GPIO_Pin_15);
  97. /* Insert delay */
  98. rt_thread_delay(RT_TICK_PER_SECOND);
  99. f_var3 += f_var4;
  100. f_var4 = f_var4 * f_var4;
  101. }
  102. }
  103. ALIGN(RT_ALIGN_SIZE)
  104. static char thread_led2_stack[1024];
  105. struct rt_thread thread_led2;
  106. static void rt_thread_entry_led2(void* parameter)
  107. {
  108. float f_var_me;
  109. char str_buffer[256];
  110. while(1)
  111. {
  112. f_var_me = f_var1 * f_var2 + f_var3;
  113. sprintf(str_buffer, "%f", f_var_me);
  114. rt_kprintf("thread1 %s\r\n", str_buffer);
  115. rt_thread_delay(RT_TICK_PER_SECOND);
  116. }
  117. }
  118. int rt_application_init()
  119. {
  120. rt_thread_t init_thread;
  121. #if (RT_THREAD_PRIORITY_MAX == 32)
  122. init_thread = rt_thread_create("init",
  123. rt_init_thread_entry, RT_NULL,
  124. 2048, 8, 20);
  125. #else
  126. init_thread = rt_thread_create("init",
  127. rt_init_thread_entry, RT_NULL,
  128. 2048, 80, 20);
  129. #endif
  130. if (init_thread != RT_NULL)
  131. rt_thread_startup(init_thread);
  132. //------- init led1 thread
  133. rt_thread_init(&thread_led1,
  134. "led1",
  135. rt_thread_entry_led1,
  136. RT_NULL,
  137. &thread_led1_stack[0],
  138. sizeof(thread_led1_stack),11,5);
  139. rt_thread_startup(&thread_led1);
  140. //------- init led2 thread
  141. rt_thread_init(&thread_led2,
  142. "led2",
  143. rt_thread_entry_led2,
  144. RT_NULL,
  145. &thread_led2_stack[0],
  146. sizeof(thread_led2_stack),11,5);
  147. rt_thread_startup(&thread_led2);
  148. return 0;
  149. }
  150. /*@}*/