Advertisement
Guest User

Untitled

a guest
Jan 22nd, 2018
59
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 3.36 KB | None | 0 0
  1. /**
  2.  ******************************************************************************
  3.  * @file    main.c
  4.  * @author  Ac6
  5.  * @version V1.0
  6.  * @date    01-December-2013
  7.  * @brief   Default main function.
  8.  ******************************************************************************
  9.  */
  10.  
  11. #include "stm32f4xx.h"
  12. #include "stm32f4_discovery.h"
  13. #include "stm32f4xx_syscfg.h"
  14. #include "tm_stm32f4_lis302dl_lis3dsh.h"
  15.  
  16.  
  17. int main(void)
  18. {
  19.     //===============dioda=================
  20.         RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD, ENABLE);
  21.         GPIO_InitTypeDef  gpio;
  22.         GPIO_PinAFConfig(GPIOD, GPIO_PinSource12, GPIO_AF_TIM4);
  23.         GPIO_PinAFConfig(GPIOD, GPIO_PinSource13, GPIO_AF_TIM4);
  24.         GPIO_PinAFConfig(GPIOD, GPIO_PinSource14, GPIO_AF_TIM4);
  25.         //GPIO_PinAFConfig(GPIOD, GPIO_PinSource15, GPIO_AF_TIM4);
  26.         gpio.GPIO_Pin = GPIO_Pin_12 | GPIO_Pin_13 | GPIO_Pin_14 ;// GPIO_Pin_15;
  27.         gpio.GPIO_Mode = GPIO_Mode_AF;
  28.         gpio.GPIO_OType = GPIO_OType_PP;
  29.         gpio.GPIO_Speed = GPIO_Speed_100MHz;
  30.         gpio.GPIO_PuPd = GPIO_PuPd_NOPULL;
  31.         GPIO_Init(GPIOD, &gpio);
  32.  
  33.         //===============timer======================
  34.         RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4, ENABLE);
  35.         TIM_TimeBaseInitTypeDef tim1;
  36.         tim1.TIM_Period = 9999;
  37.         tim1.TIM_Prescaler = 83;
  38.         tim1.TIM_ClockDivision = TIM_CKD_DIV1;
  39.         tim1.TIM_CounterMode = TIM_CounterMode_Up;
  40.         TIM_TimeBaseInit(TIM4, &tim1);
  41.  
  42.         //=============PWM========================
  43.         TIM_OCInitTypeDef channel;
  44.         channel.TIM_OCMode = TIM_OCMode_PWM1;
  45.         channel.TIM_OutputState = TIM_OutputState_Enable;
  46.         channel.TIM_Pulse = 0;
  47.         channel.TIM_OCPolarity = TIM_OCPolarity_High;
  48.  
  49.         //=======================KANAŁY CCR==========================
  50.         TIM_OC1Init(TIM4, &channel);
  51.         TIM_OC1PreloadConfig(TIM4, TIM_OCPreload_Enable);
  52.         TIM_OC2Init(TIM4, &channel);
  53.         TIM_OC2PreloadConfig(TIM4, TIM_OCPreload_Enable);
  54.         TIM_OC3Init(TIM4, &channel);
  55.         TIM_OC3PreloadConfig(TIM4, TIM_OCPreload_Enable);
  56.  
  57.         TIM4->CCR3 = 0;
  58.         TIM4->CCR2 = 0;
  59.         TIM4->CCR1 = 0;
  60.       //  TIM_SetCompare2(TIM4,5);
  61.         //TIM4->CCR2 = 10;
  62.  
  63.  
  64.         //=====================przerwanie========================
  65.         // ustawienie trybu pracy priorytetów przerwań
  66.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
  67.         NVIC_InitTypeDef nvicTIM4;
  68.         // numer przerwania
  69.         nvicTIM4.NVIC_IRQChannel = TIM4_IRQn;
  70.         // priorytet główny
  71.         nvicTIM4.NVIC_IRQChannelPreemptionPriority = 0x00;
  72.         // subpriorytet
  73.         nvicTIM4.NVIC_IRQChannelSubPriority = 0x00;
  74.         // uruchom dany kanał
  75.         nvicTIM4.NVIC_IRQChannelCmd = ENABLE;
  76.         // zapisz wypełnioną strukturę do rejestrów
  77.         NVIC_Init(&nvicTIM4);
  78.  
  79.         TIM_ClearITPendingBit(TIM4, TIM_IT_Update);
  80.         TIM_ITConfig(TIM4, TIM_IT_Update|TIM_IT_CC1, ENABLE);
  81.         TIM_Cmd(TIM4, ENABLE);
  82.  
  83.  while (1)
  84.  {
  85.  
  86.  }
  87. }
  88. void TIM4_IRQHandler(void)
  89. {
  90.             if(TIM_GetITStatus(TIM4, TIM_IT_Update) != RESET)
  91.             {
  92.                 // miejsce na kod wywoływany w momencie wystąpienia przerwania
  93.                 TIM4->CCR1 = TIM4->CCR1 + 20;
  94.                 TIM4->CCR2 = TIM4->CCR2 + 20;
  95.                 TIM4->CCR3 = TIM4->CCR3 + 20;
  96.                 if(TIM4->CCR1 >= 9999)
  97.                     {
  98.                     TIM4->CCR1 = 0;
  99.                     TIM4->CCR2 = 0;
  100.                     TIM4->CCR3 = 0;
  101.                     }
  102.                     // wyzerowanie flagi wyzwolonego przerwania
  103.                     TIM_ClearITPendingBit(TIM4, TIM_IT_Update);
  104.             }
  105.  
  106.  
  107. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement