14#define COMPARE_TYPE uint16_t
15#define TS_SERIAL_BUFFER_SIZE 517
16#define FPU_MAX_SIZE 32
17#define BOARD_MAX_DIGITAL_PINS 54
18#define BOARD_MAX_IO_PINS 54
19#define BOARD_MAX_ADC_PINS 17
20#define EEPROM_LIB_H <EEPROM.h>
24#define RTC_LIB_H "TimeLib.h"
25#define SD_CONFIG SdioConfig(FIFO_SDIO)
58#define FUEL1_COUNTER TMR1_CNTR0
59#define FUEL2_COUNTER TMR1_CNTR1
60#define FUEL3_COUNTER TMR1_CNTR2
61#define FUEL4_COUNTER TMR1_CNTR3
62#define FUEL5_COUNTER TMR3_CNTR0
63#define FUEL6_COUNTER TMR3_CNTR1
64#define FUEL7_COUNTER TMR3_CNTR2
65#define FUEL8_COUNTER TMR3_CNTR3
67#define IGN1_COUNTER TMR2_CNTR0
68#define IGN2_COUNTER TMR2_CNTR1
69#define IGN3_COUNTER TMR2_CNTR2
70#define IGN4_COUNTER TMR2_CNTR3
71#define IGN5_COUNTER TMR4_CNTR0
72#define IGN6_COUNTER TMR4_CNTR1
73#define IGN7_COUNTER TMR4_CNTR2
74#define IGN8_COUNTER TMR4_CNTR3
76#define FUEL1_COMPARE TMR1_COMP10
77#define FUEL2_COMPARE TMR1_COMP11
78#define FUEL3_COMPARE TMR1_COMP12
79#define FUEL4_COMPARE TMR1_COMP13
80#define FUEL5_COMPARE TMR3_COMP10
81#define FUEL6_COMPARE TMR3_COMP11
82#define FUEL7_COMPARE TMR3_COMP12
83#define FUEL8_COMPARE TMR3_COMP13
85#define IGN1_COMPARE TMR2_COMP10
86#define IGN2_COMPARE TMR2_COMP11
87#define IGN3_COMPARE TMR2_COMP12
88#define IGN4_COMPARE TMR2_COMP13
89#define IGN5_COMPARE TMR4_COMP10
90#define IGN6_COMPARE TMR4_COMP11
91#define IGN7_COMPARE TMR4_COMP12
92#define IGN8_COMPARE TMR4_COMP13
94static inline void FUEL1_TIMER_ENABLE(
void) {TMR1_CSCTRL0 &= ~TMR_CSCTRL_TCF1; TMR1_CSCTRL0 |= TMR_CSCTRL_TCF1EN;}
95static inline void FUEL2_TIMER_ENABLE(
void) {TMR1_CSCTRL1 &= ~TMR_CSCTRL_TCF1; TMR1_CSCTRL1 |= TMR_CSCTRL_TCF1EN;}
96static inline void FUEL3_TIMER_ENABLE(
void) {TMR1_CSCTRL2 &= ~TMR_CSCTRL_TCF1; TMR1_CSCTRL2 |= TMR_CSCTRL_TCF1EN;}
97static inline void FUEL4_TIMER_ENABLE(
void) {TMR1_CSCTRL3 &= ~TMR_CSCTRL_TCF1; TMR1_CSCTRL3 |= TMR_CSCTRL_TCF1EN;}
98static inline void FUEL5_TIMER_ENABLE(
void) {TMR3_CSCTRL0 &= ~TMR_CSCTRL_TCF1; TMR3_CSCTRL0 |= TMR_CSCTRL_TCF1EN;}
99static inline void FUEL6_TIMER_ENABLE(
void) {TMR3_CSCTRL1 &= ~TMR_CSCTRL_TCF1; TMR3_CSCTRL1 |= TMR_CSCTRL_TCF1EN;}
100static inline void FUEL7_TIMER_ENABLE(
void) {TMR3_CSCTRL2 &= ~TMR_CSCTRL_TCF1; TMR3_CSCTRL2 |= TMR_CSCTRL_TCF1EN;}
101static inline void FUEL8_TIMER_ENABLE(
void) {TMR3_CSCTRL3 &= ~TMR_CSCTRL_TCF1; TMR3_CSCTRL3 |= TMR_CSCTRL_TCF1EN;}
112static inline void IGN1_TIMER_ENABLE(
void) {TMR2_CSCTRL0 &= ~TMR_CSCTRL_TCF1; TMR2_CSCTRL0 |= TMR_CSCTRL_TCF1EN;}
113static inline void IGN2_TIMER_ENABLE(
void) {TMR2_CSCTRL1 &= ~TMR_CSCTRL_TCF1; TMR2_CSCTRL1 |= TMR_CSCTRL_TCF1EN;}
114static inline void IGN3_TIMER_ENABLE(
void) {TMR2_CSCTRL2 &= ~TMR_CSCTRL_TCF1; TMR2_CSCTRL2 |= TMR_CSCTRL_TCF1EN;}
115static inline void IGN4_TIMER_ENABLE(
void) {TMR2_CSCTRL3 &= ~TMR_CSCTRL_TCF1; TMR2_CSCTRL3 |= TMR_CSCTRL_TCF1EN;}
116static inline void IGN5_TIMER_ENABLE(
void) {TMR4_CSCTRL0 &= ~TMR_CSCTRL_TCF1; TMR4_CSCTRL0 |= TMR_CSCTRL_TCF1EN;}
117static inline void IGN6_TIMER_ENABLE(
void) {TMR4_CSCTRL1 &= ~TMR_CSCTRL_TCF1; TMR4_CSCTRL1 |= TMR_CSCTRL_TCF1EN;}
118static inline void IGN7_TIMER_ENABLE(
void) {TMR4_CSCTRL2 &= ~TMR_CSCTRL_TCF1; TMR4_CSCTRL2 |= TMR_CSCTRL_TCF1EN;}
119static inline void IGN8_TIMER_ENABLE(
void) {TMR4_CSCTRL3 &= ~TMR_CSCTRL_TCF1; TMR4_CSCTRL3 |= TMR_CSCTRL_TCF1EN;}
133#if F_CPU == 600000000
135 #define MAX_TIMER_PERIOD 55923UL
136 #define uS_TO_TIMER_COMPARE(uS) (COMPARE_TYPE)(((uS) * 75UL) >> 6)
137#elif F_CPU == 528000000
139 #define MAX_TIMER_PERIOD 63549UL
140 #define uS_TO_TIMER_COMPARE(uS) (COMPARE_TYPE)(((uS) * 66UL) >> 6)
141#elif F_CPU == 450000000
143 #define MAX_TIMER_PERIOD 55923UL
144 #define uS_TO_TIMER_COMPARE(uS) (COMPARE_TYPE)(((uS) * 75UL) >> 6)
145#elif F_CPU == 396000000
147 #define MAX_TIMER_PERIOD 63549UL
148 #define uS_TO_TIMER_COMPARE(uS) (COMPARE_TYPE)(((uS) * 66UL) >> 6)
149#elif F_CPU == 150000000
151 #define MAX_TIMER_PERIOD 111846UL
152 #define uS_TO_TIMER_COMPARE(uS) (COMPARE_TYPE)(((uS) * 75UL) >> 7)
154 #error Unsupported CPU frequency.
168#define ENABLE_BOOST_TIMER() PIT_TCTRL1 |= PIT_TCTRL_TEN
169#define DISABLE_BOOST_TIMER() PIT_TCTRL1 &= ~PIT_TCTRL_TEN
171#define ENABLE_VVT_TIMER() PIT_TCTRL2 |= PIT_TCTRL_TEN
172#define DISABLE_VVT_TIMER() PIT_TCTRL2 &= ~PIT_TCTRL_TEN
175#define ENABLE_FAN_TIMER() TMR3_CSCTRL1 |= TMR_CSCTRL_TCF2EN
176#define DISABLE_FAN_TIMER() TMR3_CSCTRL1 &= ~TMR_CSCTRL_TCF2EN
178#define BOOST_TIMER_COMPARE PIT_LDVAL1
179#define BOOST_TIMER_COUNTER 0
180#define VVT_TIMER_COMPARE PIT_LDVAL2
181#define VVT_TIMER_COUNTER 0
184#define FAN_TIMER_COMPARE TMR3_COMP22
185#define FAN_TIMER_COUNTER TMR3_CNTR1
191#define IDLE_COUNTER 0
192#define IDLE_COMPARE PIT_LDVAL0
194#define IDLE_TIMER_ENABLE() PIT_TCTRL0 |= PIT_TCTRL_TEN
195#define IDLE_TIMER_DISABLE() PIT_TCTRL0 &= ~PIT_TCTRL_TEN
201#define SECONDARY_SERIAL_T HardwareSerial
203#include <FlexCAN_T4.h>
204#define NATIVE_CAN_AVAILABLE
static void IGN1_TIMER_ENABLE(void)
Definition board_teensy41.h:112
static void IGN3_TIMER_DISABLE(void)
Definition board_teensy41.h:123
static void IGN1_TIMER_DISABLE(void)
Definition board_teensy41.h:121
static void FUEL2_TIMER_ENABLE(void)
Definition board_teensy41.h:95
static void FUEL1_TIMER_DISABLE(void)
Definition board_teensy41.h:103
static void FUEL4_TIMER_DISABLE(void)
Definition board_teensy41.h:106
static void IGN3_TIMER_ENABLE(void)
Definition board_teensy41.h:114
static void FUEL4_TIMER_ENABLE(void)
Definition board_teensy41.h:97
int eeprom_address_t
Definition board_teensy41.h:21
bool pinIsSerial(uint8_t)
static void FUEL5_TIMER_DISABLE(void)
Definition board_teensy41.h:107
static void FUEL2_TIMER_DISABLE(void)
Definition board_teensy41.h:104
static void FUEL3_TIMER_DISABLE(void)
Definition board_teensy41.h:105
static void IGN5_TIMER_ENABLE(void)
Definition board_teensy41.h:116
static bool pinIsReserved(uint8_t pin)
Definition board_teensy41.h:30
static void FUEL7_TIMER_DISABLE(void)
Definition board_teensy41.h:109
constexpr uint16_t BLOCKING_FACTOR
Definition board_teensy41.h:26
static void FUEL7_TIMER_ENABLE(void)
Definition board_teensy41.h:100
static void FUEL3_TIMER_ENABLE(void)
Definition board_teensy41.h:96
static void FUEL6_TIMER_ENABLE(void)
Definition board_teensy41.h:99
static void IGN6_TIMER_DISABLE(void)
Definition board_teensy41.h:126
static void FUEL6_TIMER_DISABLE(void)
Definition board_teensy41.h:108
static void IGN7_TIMER_DISABLE(void)
Definition board_teensy41.h:127
static void IGN2_TIMER_DISABLE(void)
Definition board_teensy41.h:122
static void IGN8_TIMER_DISABLE(void)
Definition board_teensy41.h:128
static void IGN6_TIMER_ENABLE(void)
Definition board_teensy41.h:117
static void IGN2_TIMER_ENABLE(void)
Definition board_teensy41.h:113
static void IGN8_TIMER_ENABLE(void)
Definition board_teensy41.h:119
static void FUEL8_TIMER_DISABLE(void)
Definition board_teensy41.h:110
static void IGN4_TIMER_ENABLE(void)
Definition board_teensy41.h:115
static void IGN7_TIMER_ENABLE(void)
Definition board_teensy41.h:118
static void IGN5_TIMER_DISABLE(void)
Definition board_teensy41.h:125
static void IGN4_TIMER_DISABLE(void)
Definition board_teensy41.h:124
static void FUEL1_TIMER_ENABLE(void)
Definition board_teensy41.h:94
static void FUEL8_TIMER_ENABLE(void)
Definition board_teensy41.h:101
static void FUEL5_TIMER_ENABLE(void)
Definition board_teensy41.h:98
constexpr uint16_t TABLE_BLOCKING_FACTOR
Definition board_teensy41.h:27