Advertisement
Guest User

Untitled

a guest
Jan 23rd, 2018
79
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 2.71 KB | None | 0 0
  1. #include "stm32f4xx.h"
  2. #include "stm32f4_discovery.h"
  3. int counter;
  4.  
  5. int main(void)
  6. {
  7.  
  8. RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4, ENABLE);
  9. RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD, ENABLE);
  10. RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3, ENABLE);
  11.  
  12. GPIO_InitTypeDef GPIO_InitStructure;
  13. GPIO_PinAFConfig(GPIOD, GPIO_PinSource12, GPIO_AF_TIM4);
  14. GPIO_PinAFConfig(GPIOD, GPIO_PinSource13, GPIO_AF_TIM4);
  15. GPIO_PinAFConfig(GPIOD, GPIO_PinSource14, GPIO_AF_TIM4);
  16. GPIO_PinAFConfig(GPIOD, GPIO_PinSource15, GPIO_AF_TIM4);
  17.  
  18. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12 | GPIO_Pin_13| GPIO_Pin_14| GPIO_Pin_15 ;
  19. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
  20. GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  21. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
  22. GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  23. GPIO_Init(GPIOD, &GPIO_InitStructure);
  24.  
  25. TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
  26. TIM_TimeBaseStructure.TIM_Period = 999;
  27. TIM_TimeBaseStructure.TIM_Prescaler = 83;
  28. TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;
  29. TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
  30. TIM_TimeBaseInit(TIM4, &TIM_TimeBaseStructure);
  31.  
  32. TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure2;
  33. TIM_TimeBaseStructure2.TIM_Period = 9999;
  34. TIM_TimeBaseStructure2.TIM_Prescaler = 8399;
  35. TIM_TimeBaseStructure2.TIM_ClockDivision = TIM_CKD_DIV1;
  36. TIM_TimeBaseStructure2.TIM_CounterMode = TIM_CounterMode_Up;
  37. TIM_TimeBaseInit(TIM3, &TIM_TimeBaseStructure2);
  38.  
  39. TIM_OCInitTypeDef TIM_OCInitStructure;
  40. TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
  41. TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
  42. TIM_OCInitStructure.TIM_Pulse = 0;
  43. TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
  44.  
  45. TIM_OC1Init(TIM4, &TIM_OCInitStructure);
  46. TIM_OC1PreloadConfig(TIM4, TIM_OCPreload_Enable);
  47.  
  48. TIM_OC2Init(TIM4, &TIM_OCInitStructure);
  49. TIM_OC2PreloadConfig(TIM4, TIM_OCPreload_Enable);
  50.  
  51. TIM_OC3Init(TIM4, &TIM_OCInitStructure);
  52. TIM_OC3PreloadConfig(TIM4, TIM_OCPreload_Enable);
  53.  
  54. TIM_OC4Init(TIM4, &TIM_OCInitStructure);
  55. TIM_OC4PreloadConfig(TIM4, TIM_OCPreload_Enable);
  56.  
  57.  
  58.  
  59. TIM_Cmd(TIM4, ENABLE);
  60. TIM_Cmd(TIM3, ENABLE);
  61.  
  62.  
  63. unsigned int i=0;
  64. unsigned int j=0;
  65. unsigned int k=0;
  66. unsigned int l=0;
  67. for(;;)
  68. {
  69.  
  70.  
  71. if(TIM_GetFlagStatus(TIM4, TIM_FLAG_Update)) {
  72.  
  73. TIM_ClearFlag(TIM4, TIM_FLAG_Update);
  74. }
  75. if(TIM_GetFlagStatus(TIM3, TIM_FLAG_Update)) {
  76. if(i==14)
  77. i=0;
  78. if(j==13)
  79. j=0;
  80. if(k==12)
  81. k=0;
  82. if(l==11)
  83. l=0;
  84. TIM4->CCR1 = i*100;
  85. TIM4->CCR2 = j*100;
  86. TIM4->CCR3 = k*100;
  87. TIM4->CCR4 = l*100;
  88. i++;
  89. if(i>1)
  90. j++;
  91. if(j>1)
  92. k++;
  93. if(k>1)
  94. l++;
  95. TIM_ClearFlag(TIM3, TIM_FLAG_Update);
  96. }
  97.  
  98.  
  99.  
  100.  
  101. }
  102. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement