FastPWM clone

Committer:
Sissors
Date:
Tue Sep 30 19:00:27 2014 +0000
Revision:
14:b30038fbba51
Child:
31:10e2e171f430
Added KSDK support, probably smashed buggy on KLxx platform.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Sissors 14:b30038fbba51 1 #if defined(TARGET_KPSDK_MCUS)
Sissors 14:b30038fbba51 2
Sissors 14:b30038fbba51 3 #include "FastPWM.h"
Sissors 14:b30038fbba51 4 #include "fsl_clock_manager.h"
Sissors 14:b30038fbba51 5
Sissors 14:b30038fbba51 6
Sissors 14:b30038fbba51 7 #define PWM_CNV (*(((fastpwm_struct*)fast_obj)->CnV))
Sissors 14:b30038fbba51 8 #define PWM_MOD (*(((fastpwm_struct*)fast_obj)->MOD))
Sissors 14:b30038fbba51 9 #define PWM_SC (*(((fastpwm_struct*)fast_obj)->SC))
Sissors 14:b30038fbba51 10
Sissors 14:b30038fbba51 11 typedef struct {
Sissors 14:b30038fbba51 12 __IO uint32_t *CnV;
Sissors 14:b30038fbba51 13 __IO uint32_t *MOD;
Sissors 14:b30038fbba51 14 __IO uint32_t *SC;
Sissors 14:b30038fbba51 15 } fastpwm_struct;
Sissors 14:b30038fbba51 16
Sissors 14:b30038fbba51 17 static uint32_t pwm_prescaler;
Sissors 14:b30038fbba51 18
Sissors 14:b30038fbba51 19 void FastPWM::initFastPWM( void ) {
Sissors 14:b30038fbba51 20 fast_obj = new fastpwm_struct;
Sissors 14:b30038fbba51 21 bits = 16;
Sissors 14:b30038fbba51 22
Sissors 14:b30038fbba51 23 uint32_t pwm_base_clock;
Sissors 14:b30038fbba51 24 CLOCK_SYS_GetFreq(kBusClock, &pwm_base_clock);
Sissors 14:b30038fbba51 25 pwm_prescaler = SystemCoreClock / pwm_base_clock;
Sissors 14:b30038fbba51 26
Sissors 14:b30038fbba51 27 uint32_t ftms[] = FTM_BASE_ADDRS;
Sissors 14:b30038fbba51 28 unsigned int ch_n = (_pwm.pwm_name & 0xFF);
Sissors 14:b30038fbba51 29 FTM_Type *ftm = (FTM_Type *)ftms[_pwm.pwm_name >> TPM_SHIFT];
Sissors 14:b30038fbba51 30
Sissors 14:b30038fbba51 31 ((fastpwm_struct*)fast_obj)->CnV = &ftm->CONTROLS[ch_n].CnV;
Sissors 14:b30038fbba51 32 ((fastpwm_struct*)fast_obj)->MOD = &ftm->MOD;
Sissors 14:b30038fbba51 33 ((fastpwm_struct*)fast_obj)->SC = &ftm->SC;
Sissors 14:b30038fbba51 34 }
Sissors 14:b30038fbba51 35
Sissors 14:b30038fbba51 36 void FastPWM::pulsewidth_ticks( uint32_t ticks ) {
Sissors 14:b30038fbba51 37 PWM_CNV = ticks;
Sissors 14:b30038fbba51 38 }
Sissors 14:b30038fbba51 39
Sissors 14:b30038fbba51 40 void FastPWM::period_ticks( uint32_t ticks ) {
Sissors 14:b30038fbba51 41 PWM_MOD = ticks - 1;
Sissors 14:b30038fbba51 42 }
Sissors 14:b30038fbba51 43
Sissors 14:b30038fbba51 44 uint32_t FastPWM::getPeriod( void ) {
Sissors 14:b30038fbba51 45 return PWM_MOD + 1;
Sissors 14:b30038fbba51 46 }
Sissors 14:b30038fbba51 47
Sissors 14:b30038fbba51 48 uint32_t FastPWM::setPrescaler(uint32_t reqScale) {
Sissors 14:b30038fbba51 49
Sissors 14:b30038fbba51 50 uint32_t prescalers[] = {1, 2, 4, 8, 16, 32, 64, 128};
Sissors 14:b30038fbba51 51
Sissors 14:b30038fbba51 52 for (int i = 0; i<8; i++)
Sissors 14:b30038fbba51 53 prescalers[i] = prescalers[i] * pwm_prescaler;
Sissors 14:b30038fbba51 54
Sissors 14:b30038fbba51 55 //If prescaler is 0, return current one
Sissors 14:b30038fbba51 56 if (reqScale == 0)
Sissors 14:b30038fbba51 57 return (prescalers[(PWM_SC) & 0x07]);
Sissors 14:b30038fbba51 58
Sissors 14:b30038fbba51 59 uint32_t retval = 0;
Sissors 14:b30038fbba51 60 char bin;
Sissors 14:b30038fbba51 61
Sissors 14:b30038fbba51 62 for (bin = 0; bin<8; bin++) {
Sissors 14:b30038fbba51 63 retval = prescalers[bin];
Sissors 14:b30038fbba51 64 if (retval >= reqScale)
Sissors 14:b30038fbba51 65 break;
Sissors 14:b30038fbba51 66 }
Sissors 14:b30038fbba51 67 if (bin == 8)
Sissors 14:b30038fbba51 68 bin = 7;
Sissors 14:b30038fbba51 69
Sissors 14:b30038fbba51 70 //Clear lower 5 bits, write new value:
Sissors 14:b30038fbba51 71 char clockbits = PWM_SC & (3<<3);
Sissors 14:b30038fbba51 72
Sissors 14:b30038fbba51 73 //For some reason clearing them takes some effort
Sissors 14:b30038fbba51 74 while ((PWM_SC & 0x1F) != 0)
Sissors 14:b30038fbba51 75 PWM_SC &= ~0x1F;
Sissors 14:b30038fbba51 76
Sissors 14:b30038fbba51 77
Sissors 14:b30038fbba51 78 PWM_SC = bin + clockbits;
Sissors 14:b30038fbba51 79
Sissors 14:b30038fbba51 80 return retval;
Sissors 14:b30038fbba51 81 }
Sissors 14:b30038fbba51 82 #endif