teensy35 FTM1 fixes for Boost and VVT controls (#318)
This commit is contained in:
parent
10c59d5c4b
commit
89e19d1432
|
@ -5,7 +5,6 @@
|
|||
#include "idle.h"
|
||||
#include "scheduler.h"
|
||||
|
||||
|
||||
void initBoard()
|
||||
{
|
||||
/*
|
||||
|
@ -73,15 +72,83 @@ void initBoard()
|
|||
//Enable channel compare interrupt (This is currently disabled as not in use)
|
||||
//FTM2_C1SC |= FTM_CSC_CHIE;
|
||||
|
||||
FTM2_C1SC &= ~FTM_CSC_MSB; //According to Pg 965 of the K64 datasheet, this should not be needed as MSB is reset to 0 upon reset, but the channel interrupt fails to fire without it
|
||||
FTM2_C1SC |= FTM_CSC_MSA; //Enable Compare mode
|
||||
//Enable channel compare interrupt (This is currently disabled as not in use)
|
||||
//FTM2_C1SC |= FTM_CSC_CHIE;
|
||||
|
||||
//Enable IRQ Interrupt
|
||||
NVIC_ENABLE_IRQ(IRQ_FTM2);
|
||||
}
|
||||
|
||||
/*
|
||||
***********************************************************************************************************
|
||||
* Auxilliaries
|
||||
*/
|
||||
|
||||
/*
|
||||
***********************************************************************************************************
|
||||
* BOOST and VVT
|
||||
*/
|
||||
if (configPage6.boostEnabled == 1 || configPage6.vvtEnabled == 1)
|
||||
{
|
||||
//FlexTimer 2, compare channel 0 is used for idle
|
||||
FTM1_MODE |= FTM_MODE_WPDIS; // Write Protection Disable
|
||||
FTM1_MODE |= FTM_MODE_FTMEN; //Flex Timer module enable
|
||||
FTM1_MODE |= FTM_MODE_INIT;
|
||||
|
||||
FTM1_SC = 0x00; // Set this to zero before changing the modulus
|
||||
FTM1_CNTIN = 0x0000; //Shouldn't be needed, but just in case
|
||||
FTM1_CNT = 0x0000; // Reset the count to zero
|
||||
FTM1_MOD = 0xFFFF; // max modulus = 65535
|
||||
|
||||
/*
|
||||
* Enable the clock for FTM0/1
|
||||
* 00 No clock selected. Disables the FTM counter.
|
||||
* 01 System clock
|
||||
* 10 Fixed frequency clock (32kHz)
|
||||
* 11 External clock
|
||||
*/
|
||||
FTM1_SC |= FTM_SC_CLKS(0b10);
|
||||
|
||||
/*
|
||||
* Trim the slow clock from 32kHz down to 31.25kHz (The slowest it will go)
|
||||
* This is somewhat imprecise and documentation is not good.
|
||||
* I poked the chip until I figured out the values associated with 31.25kHz
|
||||
*/
|
||||
MCG_C3 = 0x9B;
|
||||
|
||||
/*
|
||||
* Set Prescaler
|
||||
* This is the slowest that the timer can be clocked (Without used the slow timer, which is too slow). It results in ticks of 2.13333uS on the teensy 3.5:
|
||||
* 32000 Hz = F_BUS
|
||||
* 128 * 1000000uS / F_BUS = 2.133uS
|
||||
*
|
||||
* 000 = Divide by 1
|
||||
* 001 Divide by 2
|
||||
* 010 Divide by 4
|
||||
* 011 Divide by 8
|
||||
* 100 Divide by 16
|
||||
* 101 Divide by 32
|
||||
* 110 Divide by 64
|
||||
* 111 Divide by 128
|
||||
*/
|
||||
FTM2_SC |= FTM_SC_PS(0b0); //No prescaler
|
||||
|
||||
//Setup the channels (See Pg 1014 of K64 DS).
|
||||
FTM1_C0SC &= ~FTM_CSC_MSB; //According to Pg 965 of the K64 datasheet, this should not be needed as MSB is reset to 0 upon reset, but the channel interrupt fails to fire without it
|
||||
FTM1_C0SC |= FTM_CSC_MSA; //Enable Compare mode
|
||||
//The below enables channel compare interrupt, but this is done in idleControl()
|
||||
//FTM1_C0SC |= FTM_CSC_CHIE;
|
||||
|
||||
FTM1_C1SC &= ~FTM_CSC_MSB; //According to Pg 965 of the K64 datasheet, this should not be needed as MSB is reset to 0 upon reset, but the channel interrupt fails to fire without it
|
||||
FTM1_C1SC |= FTM_CSC_MSA; //Enable Compare mode
|
||||
//Enable channel compare interrupt (This is currently disabled as not in use)
|
||||
//FTM1_C1SC |= FTM_CSC_CHIE;
|
||||
|
||||
//Enable IRQ Interrupt
|
||||
NVIC_ENABLE_IRQ(IRQ_FTM1);
|
||||
|
||||
boost_pwm_max_count = 1000000L / (32 * configPage6.boostFreq * 2); //Converts the frequency in Hz to the number of ticks (at 16uS) it takes to complete 1 cycle. Note that the frequency is divided by 2 coming from TS to allow for up to 512hz
|
||||
vvt_pwm_max_count = 1000000L / (32 * configPage6.vvtFreq * 2); //Converts the frequency in Hz to the number of ticks (at 16uS) it takes to complete 1 cycle. Note that the frequency is divided by 2 coming from TS to allow for up to 512hz
|
||||
|
||||
}
|
||||
|
||||
/*
|
||||
***********************************************************************************************************
|
||||
* Timers
|
||||
|
@ -89,31 +156,6 @@ void initBoard()
|
|||
//Uses the PIT timer on Teensy.
|
||||
lowResTimer.begin(oneMSInterval, 1000);
|
||||
|
||||
/*
|
||||
***********************************************************************************************************
|
||||
* Auxilliaries
|
||||
*/
|
||||
//FlexTimer 1 is used for boost and VVT. There are 8 channels on this module
|
||||
FTM1_MODE |= FTM_MODE_WPDIS; // Write Protection Disable
|
||||
FTM1_MODE |= FTM_MODE_FTMEN; //Flex Timer module enable
|
||||
FTM1_MODE |= FTM_MODE_INIT;
|
||||
FTM1_SC |= FTM_SC_CLKS(0b1); // Set internal clocked
|
||||
FTM1_SC |= FTM_SC_PS(0b111); //Set prescaler to 128 (2.1333uS tick time)
|
||||
|
||||
//Enable each compare channel individually
|
||||
FTM1_C0SC &= ~FTM_CSC_MSB; //According to Pg 965 of the K64 datasheet, this should not be needed as MSB is reset to 0 upon reset, but the channel interrupt fails to fire without it
|
||||
FTM1_C0SC |= FTM_CSC_MSA; //Enable Compare mode
|
||||
FTM1_C0SC |= FTM_CSC_CHIE; //Enable channel compare interrupt
|
||||
FTM1_C1SC &= ~FTM_CSC_MSB; //According to Pg 965 of the K64 datasheet, this should not be needed as MSB is reset to 0 upon reset, but the channel interrupt fails to fire without it
|
||||
FTM1_C1SC |= FTM_CSC_MSA; //Enable Compare mode
|
||||
FTM1_C1SC |= FTM_CSC_CHIE; //Enable channel compare interrupt
|
||||
|
||||
//NVIC_ENABLE_IRQ(IRQ_FTM1);
|
||||
|
||||
//2uS resolution Min 8Hz, Max 5KHz
|
||||
boost_pwm_max_count = 1000000L / (2 * configPage6.boostFreq * 2); //Converts the frequency in Hz to the number of ticks (at 2uS) it takes to complete 1 cycle. The x2 is there because the frequency is stored at half value (in a byte) to allow freqneucies up to 511Hz
|
||||
vvt_pwm_max_count = 1000000L / (2 * configPage6.vvtFreq * 2); //Converts the frequency in Hz to the number of ticks (at 2uS) it takes to complete 1 cycle
|
||||
|
||||
/*
|
||||
***********************************************************************************************************
|
||||
* Schedules
|
||||
|
@ -239,8 +281,7 @@ void initBoard()
|
|||
|
||||
// enable IRQ Interrupt
|
||||
NVIC_ENABLE_IRQ(IRQ_FTM0);
|
||||
NVIC_ENABLE_IRQ(IRQ_FTM1);
|
||||
|
||||
NVIC_ENABLE_IRQ(IRQ_FTM3);
|
||||
}
|
||||
|
||||
uint16_t freeRam()
|
||||
|
@ -260,5 +301,4 @@ uint16_t freeRam()
|
|||
return (uint16_t)stackTop - heapTop;
|
||||
}
|
||||
|
||||
|
||||
#endif
|
Loading…
Reference in New Issue