application.c 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  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. /* init lwip system */
  38. lwip_sys_init();
  39. rt_kprintf("TCP/IP initialized!\n");
  40. }
  41. #endif
  42. //FS
  43. //GUI
  44. }
  45. float f_var1;
  46. float f_var2;
  47. float f_var3;
  48. float f_var4;
  49. ALIGN(RT_ALIGN_SIZE)
  50. static char thread_led1_stack[1024];
  51. struct rt_thread thread_led1;
  52. static void rt_thread_entry_led1(void* parameter)
  53. {
  54. GPIO_InitTypeDef GPIO_InitStructure;
  55. /* GPIOD Periph clock enable */
  56. RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD, ENABLE);
  57. /* Configure PD12, PD13, PD14 and PD15 in output pushpull mode */
  58. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12 | GPIO_Pin_13| GPIO_Pin_14| GPIO_Pin_15;
  59. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
  60. GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  61. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
  62. GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  63. GPIO_Init(GPIOD, &GPIO_InitStructure);
  64. f_var1 = 3.141592653;
  65. f_var2 = 123.456;
  66. f_var3 = 0.123456789;
  67. f_var4 = 1.00001;
  68. while (1)
  69. {
  70. /* PD12 to be toggled */
  71. GPIO_SetBits(GPIOD, GPIO_Pin_12);
  72. /* Insert delay */
  73. rt_thread_delay(RT_TICK_PER_SECOND/2);
  74. f_var3 += f_var4;
  75. f_var4 = f_var4 * f_var4;
  76. /* PD13 to be toggled */
  77. GPIO_SetBits(GPIOD, GPIO_Pin_13);
  78. /* Insert delay */
  79. rt_thread_delay(RT_TICK_PER_SECOND/2);
  80. f_var3 += f_var4;
  81. f_var4 = f_var4 * f_var4;
  82. /* PD14 to be toggled */
  83. GPIO_SetBits(GPIOD, GPIO_Pin_14);
  84. /* Insert delay */
  85. rt_thread_delay(RT_TICK_PER_SECOND/2);
  86. f_var3 += f_var4;
  87. f_var4 = f_var4 * f_var4;
  88. /* PD15 to be toggled */
  89. GPIO_SetBits(GPIOD, GPIO_Pin_15);
  90. /* Insert delay */
  91. rt_thread_delay(RT_TICK_PER_SECOND*2);
  92. f_var3 += f_var4;
  93. f_var4 = f_var4 * f_var4;
  94. GPIO_ResetBits(GPIOD, GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14|GPIO_Pin_15);
  95. /* Insert delay */
  96. rt_thread_delay(RT_TICK_PER_SECOND);
  97. f_var3 += f_var4;
  98. f_var4 = f_var4 * f_var4;
  99. }
  100. }
  101. ALIGN(RT_ALIGN_SIZE)
  102. static char thread_led2_stack[1024];
  103. struct rt_thread thread_led2;
  104. static void rt_thread_entry_led2(void* parameter)
  105. {
  106. float f_var_me;
  107. char str_buffer[256];
  108. while(1)
  109. {
  110. f_var_me = f_var1 * f_var2 + f_var3;
  111. sprintf(str_buffer, "%f", f_var_me);
  112. rt_kprintf("thread1 %s\r\n", str_buffer);
  113. rt_thread_delay(RT_TICK_PER_SECOND);
  114. }
  115. }
  116. int rt_application_init()
  117. {
  118. rt_thread_t init_thread;
  119. #if (RT_THREAD_PRIORITY_MAX == 32)
  120. init_thread = rt_thread_create("init",
  121. rt_init_thread_entry, RT_NULL,
  122. 2048, 8, 20);
  123. #else
  124. init_thread = rt_thread_create("init",
  125. rt_init_thread_entry, RT_NULL,
  126. 2048, 80, 20);
  127. #endif
  128. if (init_thread != RT_NULL)
  129. rt_thread_startup(init_thread);
  130. //------- init led1 thread
  131. rt_thread_init(&thread_led1,
  132. "led1",
  133. rt_thread_entry_led1,
  134. RT_NULL,
  135. &thread_led1_stack[0],
  136. sizeof(thread_led1_stack),11,5);
  137. rt_thread_startup(&thread_led1);
  138. //------- init led2 thread
  139. rt_thread_init(&thread_led2,
  140. "led2",
  141. rt_thread_entry_led2,
  142. RT_NULL,
  143. &thread_led2_stack[0],
  144. sizeof(thread_led2_stack),11,5);
  145. rt_thread_startup(&thread_led2);
  146. return 0;
  147. }
  148. /*@}*/