浏览代码

(MKL26Z64) update for F_PLL <= 16MHz

teensy4-core
duff2013 10 年前
父节点
当前提交
06f4defa2d
共有 5 个文件被更改,包括 51 次插入11 次删除
  1. +8
    -0
      teensy3/HardwareSerial.h
  2. +3
    -3
      teensy3/kinetis.h
  3. +33
    -7
      teensy3/mk20dx128.c
  4. +6
    -0
      teensy3/pins_teensy.c
  5. +1
    -1
      teensy3/serial1.c

+ 8
- 0
teensy3/HardwareSerial.h 查看文件

#define BAUD2DIV2(baud) (((F_CPU * 2) + ((baud) >> 1)) / (baud)) #define BAUD2DIV2(baud) (((F_CPU * 2) + ((baud) >> 1)) / (baud))
#define BAUD2DIV3(baud) (((F_BUS * 2) + ((baud) >> 1)) / (baud)) #define BAUD2DIV3(baud) (((F_BUS * 2) + ((baud) >> 1)) / (baud))
#elif defined(KINETISL) #elif defined(KINETISL)

#if F_CPU <= 2000000
#define BAUD2DIV(baud) (((F_PLL / 16 ) + ((baud) >> 1)) / (baud))
#elif F_CPU <= 16000000
#define BAUD2DIV(baud) (((F_PLL / (F_PLL / 1000000)) + ((baud) >> 1)) / (baud))
#else
#define BAUD2DIV(baud) (((F_PLL / 2 / 16) + ((baud) >> 1)) / (baud)) #define BAUD2DIV(baud) (((F_PLL / 2 / 16) + ((baud) >> 1)) / (baud))
#endif

#define BAUD2DIV2(baud) (((F_BUS / 16) + ((baud) >> 1)) / (baud)) #define BAUD2DIV2(baud) (((F_BUS / 16) + ((baud) >> 1)) / (baud))
#define BAUD2DIV3(baud) (((F_BUS / 16) + ((baud) >> 1)) / (baud)) #define BAUD2DIV3(baud) (((F_BUS / 16) + ((baud) >> 1)) / (baud))
#endif #endif

+ 3
- 3
teensy3/kinetis.h 查看文件

#define F_BUS 24000000 #define F_BUS 24000000
#define F_MEM 24000000 #define F_MEM 24000000
#elif (F_CPU == 16000000) #elif (F_CPU == 16000000)
#define F_PLL 96000000
#define F_PLL 16000000
#define F_BUS 16000000 #define F_BUS 16000000
#define F_MEM 16000000 #define F_MEM 16000000
#elif (F_CPU == 8000000) #elif (F_CPU == 8000000)
#define F_PLL 96000000
#define F_PLL 8000000
#define F_BUS 8000000 #define F_BUS 8000000
#define F_MEM 8000000 #define F_MEM 8000000
#elif (F_CPU == 4000000) #elif (F_CPU == 4000000)
#define F_PLL 96000000
#define F_PLL 4000000
#define F_BUS 4000000 #define F_BUS 4000000
#define F_MEM 4000000 #define F_MEM 4000000
#elif (F_CPU == 2000000) #elif (F_CPU == 2000000)

+ 33
- 7
teensy3/mk20dx128.c 查看文件

// MCG_SC[FCDIV] defaults to divide by two for internal ref clock // MCG_SC[FCDIV] defaults to divide by two for internal ref clock
// I tried changing MSG_SC to divide by 1, it didn't work for me // I tried changing MSG_SC to divide by 1, it didn't work for me
#if F_CPU <= 2000000 #if F_CPU <= 2000000
#if defined(KINETISK)
MCG_C1 = MCG_C1_CLKS(1) | MCG_C1_IREFS;
#elif defined(KINETISL)
// use the internal oscillator // use the internal oscillator
MCG_C1 = MCG_C1_CLKS(1) | MCG_C1_IREFS;
MCG_C1 = MCG_C1_CLKS(1) | MCG_C1_IREFS | MCG_C1_IRCLKEN;
#endif
// wait for MCGOUT to use oscillator // wait for MCGOUT to use oscillator
while ((MCG_S & MCG_S_CLKST_MASK) != MCG_S_CLKST(1)) ; while ((MCG_S & MCG_S_CLKST_MASK) != MCG_S_CLKST(1)) ;
for (n=0; n<10; n++) ; // TODO: why do we get 2 mA extra without this delay? for (n=0; n<10; n++) ; // TODO: why do we get 2 mA extra without this delay?
// C2[LP] bit is written to 1 // C2[LP] bit is written to 1
#else #else
// enable capacitors for crystal // enable capacitors for crystal
OSC0_CR = OSC_SC8P | OSC_SC2P;
OSC0_CR = OSC_SC8P | OSC_SC2P | 0x80;
// enable osc, 8-32 MHz range, low power mode // enable osc, 8-32 MHz range, low power mode
MCG_C2 = MCG_C2_RANGE0(2) | MCG_C2_EREFS; MCG_C2 = MCG_C2_RANGE0(2) | MCG_C2_EREFS;
// switch to crystal as clock source, FLL input = 16 MHz / 512 // switch to crystal as clock source, FLL input = 16 MHz / 512
#endif #endif
#elif F_CPU == 16000000 #elif F_CPU == 16000000
// config divisors: 16 MHz core, 16 MHz bus, 16 MHz flash // config divisors: 16 MHz core, 16 MHz bus, 16 MHz flash
SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(0) | SIM_CLKDIV1_OUTDIV4(0);
#if defined(KINETISK)
SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(0) | SIM_CLKDIV1_OUTDIV4(0);
#elif defined(KINETISL)
SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV4(0);
#endif
#elif F_CPU == 8000000 #elif F_CPU == 8000000
// config divisors: 8 MHz core, 8 MHz bus, 8 MHz flash // config divisors: 8 MHz core, 8 MHz bus, 8 MHz flash
SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(1) | SIM_CLKDIV1_OUTDIV2(1) | SIM_CLKDIV1_OUTDIV4(1);
#if defined(KINETISK)
SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(1) | SIM_CLKDIV1_OUTDIV2(1) | SIM_CLKDIV1_OUTDIV4(1);
#elif defined(KINETISL)
SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(1) | SIM_CLKDIV1_OUTDIV4(1);
#endif
#elif F_CPU == 4000000 #elif F_CPU == 4000000
// config divisors: 4 MHz core, 4 MHz bus, 2 MHz flash // config divisors: 4 MHz core, 4 MHz bus, 2 MHz flash
// since we are running from external clock 16MHz // since we are running from external clock 16MHz
// fix outdiv too -> cpu 16/4, bus 16/4, flash 16/4 // fix outdiv too -> cpu 16/4, bus 16/4, flash 16/4
// here we can go into vlpr? // here we can go into vlpr?
// config divisors: 4 MHz core, 4 MHz bus, 4 MHz flash // config divisors: 4 MHz core, 4 MHz bus, 4 MHz flash
SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(3) | SIM_CLKDIV1_OUTDIV2(3) | SIM_CLKDIV1_OUTDIV4(3);
#if defined(KINETISK)
SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(3) | SIM_CLKDIV1_OUTDIV2(3) | SIM_CLKDIV1_OUTDIV4(3);
#elif defined(KINETISL)
SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(3) | SIM_CLKDIV1_OUTDIV4(3);
#endif
#elif F_CPU == 2000000 #elif F_CPU == 2000000
// since we are running from the fast internal reference clock 4MHz // since we are running from the fast internal reference clock 4MHz
// but is divided down by 2 so we actually have a 2MHz, MCG_SC[FCDIV] default is 2 // but is divided down by 2 so we actually have a 2MHz, MCG_SC[FCDIV] default is 2
// fix outdiv -> cpu 2/1, bus 2/1, flash 2/2 // fix outdiv -> cpu 2/1, bus 2/1, flash 2/2
// config divisors: 2 MHz core, 2 MHz bus, 1 MHz flash // config divisors: 2 MHz core, 2 MHz bus, 1 MHz flash
SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(0) | SIM_CLKDIV1_OUTDIV4(1);
#if defined(KINETISK)
SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(0) | SIM_CLKDIV1_OUTDIV4(1);
#elif defined(KINETISL)
SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV4(1);
#endif
#else #else
#error "Error, F_CPU must be 168, 144, 120, 96, 72, 48, 24, 16, 8, 4, or 2 MHz" #error "Error, F_CPU must be 168, 144, 120, 96, 72, 48, 24, 16, 8, 4, or 2 MHz"
#endif #endif
| SIM_SOPT2_UART0SRC(1) | SIM_SOPT2_TPMSRC(1); | SIM_SOPT2_UART0SRC(1) | SIM_SOPT2_TPMSRC(1);
#endif #endif
#else #else
SIM_SOPT2 = SIM_SOPT2_TRACECLKSEL | SIM_SOPT2_CLKOUTSEL(3);
#if F_CPU == 2000000
SIM_SOPT2 = SIM_SOPT2_TRACECLKSEL | SIM_SOPT2_CLKOUTSEL(4) | SIM_SOPT2_UART0SRC(3);
#else
SIM_SOPT2 = SIM_SOPT2_TRACECLKSEL | SIM_SOPT2_CLKOUTSEL(6) | SIM_SOPT2_UART0SRC(2);
#endif
#endif #endif


#if F_CPU <= 2000000 #if F_CPU <= 2000000

+ 6
- 0
teensy3/pins_teensy.c 查看文件

#if defined(KINETISK) #if defined(KINETISK)
#define F_TIMER F_BUS #define F_TIMER F_BUS
#elif defined(KINETISL) #elif defined(KINETISL)

#if F_CPU > 16000000
#define F_TIMER (F_PLL/2) #define F_TIMER (F_PLL/2)
#else
#define F_TIMER (F_PLL)
#endif//Low Power

#endif #endif


#if F_TIMER == 60000000 #if F_TIMER == 60000000

+ 1
- 1
teensy3/serial1.c 查看文件

UART0_C1 = 0; UART0_C1 = 0;
UART0_PFIFO = 0; UART0_PFIFO = 0;
#endif #endif
#elif defined(KINETISL_UART1)
#elif defined(KINETISL_UART0)
UART0_BDH = (divisor >> 8) & 0x1F; UART0_BDH = (divisor >> 8) & 0x1F;
UART0_BDL = divisor & 0xFF; UART0_BDL = divisor & 0xFF;
UART0_C1 = 0; UART0_C1 = 0;

正在加载...
取消
保存