|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569 |
- /* FreqMeasure Library, for measuring relatively low frequencies
- * http://www.pjrc.com/teensy/td_libs_FreqMeasure.html
- * Copyright (c) 2011 PJRC.COM, LLC - Paul Stoffregen <paul@pjrc.com>
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- * THE SOFTWARE.
- */
-
- #ifndef FreqMeasure_capture_h_
- #define FreqMeasure_capture_h_
-
- // Arduino Uno, Duemilanove, LilyPad, Mini, Fio, etc
- #if defined(__AVR_ATmega328P__) || defined(__AVR_ATmega168__)
- #define CAPTURE_USE_TIMER1 // ICP1 is pin 8
-
- // Teensy 3.1, 3.2, 3.5, 3.6
- #elif defined(__MK20DX256__) || defined(__MK64FX512__) || defined(__MK66FX1M0__)
- #define CAPTURE_USE_FTM1_CH0 3 // FTM1 CH0 is pin 3
- //#define CAPTURE_USE_FTM1_CH1 4 // FTM1 CH1 is pin 4
- //#define CAPTURE_USE_FTM2_CH0 32 // FTM2 CH0 is pin 32 (Teensy 3.1 and 3.2)
- //#define CAPTURE_USE_FTM2_CH1 25 // FTM2 CH1 is pin 25 (Teensy 3.1 and 3.2)
- //#define CAPTURE_USE_FTM2_CH0 29 // FTM2 CH0 is pin 29 (Teensy 3.5 and 3.6)
- //#define CAPTURE_USE_FTM2_CH1 30 // FTM2 CH1 is pin 30 (Teensy 3.5 and 3.6)
-
- // Teensy 3.0
- #elif defined(__MK20DX128__)
- #define CAPTURE_USE_FTM1_CH0 3 // FTM1 CH0 is pin 3
- //#define CAPTURE_USE_FTM1_CH1 4 // FTM1 CH1 is pin 4
-
- // Teensy-LC
- #elif defined(__MKL26Z64__)
- #define CAPTURE_USE_FTM1_CH0 16 // FTM1 CH0 is pin 16
- //#define CAPTURE_USE_FTM1_CH1 17 // FTM1 CH1 is pin 17
- //#define CAPTURE_USE_FTM2_CH0 3 // FTM2 CH0 is pin 3
- //#define CAPTURE_USE_FTM2_CH1 4 // FTM2 CH1 is pin 4
-
- #elif defined(__IMXRT1052__) || defined(__IMXRT1062__)
- #define CAPTURE_USE_FLEXPWM4_CH0A 22 // FlexPWM CH0-A is pin 22
-
- // Teensy 2.0
- #elif defined(__AVR_ATmega32U4__)
- // #define CAPTURE_USE_TIMER1 // ICP1 is pin 22
- #define CAPTURE_USE_TIMER3 // ICP3 is pin 10
-
- // Teensy++ 1.0 & 2.0
- #elif defined(__AVR_AT90USB646__) || defined(__AVR_AT90USB1286__)
- // #define CAPTURE_USE_TIMER1 // ICP1 is pin 4
- #define CAPTURE_USE_TIMER3 // ICP3 is pin 17
-
- // Teensy 1.0
- #elif defined(__AVR_AT90USB162__)
- #define CAPTURE_USE_TIMER1 // ICP1 is pin 16
-
- // Sanguino
- #elif defined(__AVR_ATmega644P__) || defined(__AVR_ATmega644__)
- #define CAPTURE_USE_TIMER1 // ICP1 is pin 14
-
- // Arduino Mega
- #elif defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__)
- // #define CAPTURE_USE_TIMER1 // ICP1 is not connected
- // #define CAPTURE_USE_TIMER3 // ICP3 is not connected
- #define CAPTURE_USE_TIMER4 // ICP4 is pin 49
- // #define CAPTURE_USE_TIMER5 // ICP5 is pin 48
-
- #else
- #error "Unknown chip, please edit me with timer+counter definitions"
-
- #endif
-
-
-
- #if defined(CAPTURE_USE_FTM1_CH0)
-
- #define FTM_SC_VALUE (FTM_SC_TOIE | FTM_SC_CLKS(1) | FTM_SC_PS(0))
- #define FTM_ISR_NAME ftm1_isr
-
- static inline void capture_init(void)
- {
- if (FTM1_MOD != 0xFFFF || (FTM1_SC & 0x7F) != FTM_SC_VALUE) {
- FTM1_SC = 0;
- FTM1_CNT = 0;
- FTM1_MOD = 0xFFFF;
- FTM1_SC = FTM_SC_VALUE;
- #ifdef KINETISK
- FTM1_MODE = 0;
- #endif
- }
- NVIC_SET_PRIORITY(IRQ_FTM1, 48);
- }
- static inline void capture_start(void)
- {
- #if defined(KINETISL)
- FTM1_C0SC = 0;
- delayMicroseconds(1);
- #endif
- FTM1_C0SC = 0b01000100;
- *portConfigRegister(CAPTURE_USE_FTM1_CH0) = PORT_PCR_MUX(3);
- NVIC_ENABLE_IRQ(IRQ_FTM1);
- }
- static inline uint16_t capture_event(void)
- {
- return (FTM1_C0SC & 0x80) ? 1 : 0;
- }
- static inline uint32_t capture_read(void)
- {
- uint32_t val = FTM1_C0V;
- #if defined(KINETISK)
- FTM1_C0SC = 0b01000100;
- #elif defined(KINETISL)
- FTM1_C0SC = 0b01000100 | FTM_CSC_CHF;
- #endif
- return val;
- }
- static inline uint8_t capture_overflow(void)
- {
- return (FTM1_SC & FTM_SC_TOF) ? 1 : 0;
- }
- static inline void capture_overflow_reset(void)
- {
- #if defined(KINETISK)
- FTM1_SC = FTM_SC_VALUE;
- #elif defined(KINETISL)
- FTM1_SC = FTM_SC_VALUE | FTM_SC_TOF;
- #endif
- }
- static inline void capture_shutdown(void)
- {
- FTM1_C0SC = 0;
- *portConfigRegister(CAPTURE_USE_FTM1_CH0) = 0;
- NVIC_DISABLE_IRQ(IRQ_FTM1);
- }
-
-
- #elif defined(CAPTURE_USE_FTM1_CH1)
-
- #define FTM_SC_VALUE (FTM_SC_TOIE | FTM_SC_CLKS(1) | FTM_SC_PS(0))
- #define FTM_ISR_NAME ftm1_isr
-
- static inline void capture_init(void)
- {
- if (FTM1_MOD != 0xFFFF || (FTM1_SC & 0x7F) != FTM_SC_VALUE) {
- FTM1_SC = 0;
- FTM1_CNT = 0;
- FTM1_MOD = 0xFFFF;
- FTM1_SC = FTM_SC_VALUE;
- #ifdef KINETISK
- FTM1_MODE = 0;
- #endif
- }
- NVIC_SET_PRIORITY(IRQ_FTM1, 48);
- }
- static inline void capture_start(void)
- {
- #if defined(KINETISL)
- FTM1_C1SC = 0;
- delayMicroseconds(1);
- #endif
- FTM1_C1SC = 0b01000100;
- *portConfigRegister(CAPTURE_USE_FTM1_CH1) = PORT_PCR_MUX(3);
- NVIC_ENABLE_IRQ(IRQ_FTM1);
- }
- static inline uint16_t capture_event(void)
- {
- return (FTM1_C1SC & 0x80) ? 1 : 0;
- }
- static inline uint32_t capture_read(void)
- {
- uint32_t val = FTM1_C1V;
- #if defined(KINETISK)
- FTM1_C1SC = 0b01000100;
- #elif defined(KINETISL)
- FTM1_C1SC = 0b01000100 | FTM_CSC_CHF;
- #endif
- return val;
- }
- static inline uint8_t capture_overflow(void)
- {
- return (FTM1_SC & FTM_SC_TOF) ? 1 : 0;
- }
- static inline void capture_overflow_reset(void)
- {
- FTM1_SC = FTM_SC_VALUE;
- #if defined(KINETISK)
- FTM1_SC = FTM_SC_VALUE;
- #elif defined(KINETISL)
- FTM1_SC = FTM_SC_VALUE | FTM_SC_TOF;
- #endif
- }
- static inline void capture_shutdown(void)
- {
- FTM1_C1SC = 0;
- *portConfigRegister(CAPTURE_USE_FTM1_CH1) = 0;
- NVIC_DISABLE_IRQ(IRQ_FTM1);
- }
-
-
- #elif defined(CAPTURE_USE_FTM2_CH0)
-
- #define FTM_SC_VALUE (FTM_SC_TOIE | FTM_SC_CLKS(1) | FTM_SC_PS(0))
- #define FTM_ISR_NAME ftm2_isr
-
- static inline void capture_init(void)
- {
- if (FTM2_MOD != 0xFFFF || (FTM2_SC & 0x7F) != FTM_SC_VALUE) {
- FTM2_SC = 0;
- FTM2_CNT = 0;
- FTM2_MOD = 0xFFFF;
- FTM2_SC = FTM_SC_VALUE;
- #ifdef KINETISK
- FTM2_MODE = 0;
- #endif
- }
- NVIC_SET_PRIORITY(IRQ_FTM2, 48);
- }
- static inline void capture_start(void)
- {
- #if defined(KINETISL)
- FTM2_C0SC = 0;
- delayMicroseconds(1);
- #endif
- FTM2_C0SC = 0b01000100;
- *portConfigRegister(CAPTURE_USE_FTM2_CH0) = PORT_PCR_MUX(3);
- NVIC_ENABLE_IRQ(IRQ_FTM2);
- }
- static inline uint16_t capture_event(void)
- {
- return (FTM2_C0SC & 0x80) ? 1 : 0;
- }
- static inline uint32_t capture_read(void)
- {
- uint32_t val = FTM2_C0V;
- #if defined(KINETISK)
- FTM2_C0SC = 0b01000100;
- #elif defined(KINETISL)
- FTM2_C0SC = 0b01000100 | FTM_CSC_CHF;
- #endif
- return val;
- }
- static inline uint8_t capture_overflow(void)
- {
- return (FTM2_SC & FTM_SC_TOF) ? 1 : 0;
- }
- static inline void capture_overflow_reset(void)
- {
- #if defined(KINETISK)
- FTM2_SC = FTM_SC_VALUE;
- #elif defined(KINETISL)
- FTM2_SC = FTM_SC_VALUE | FTM_SC_TOF;
- #endif
- }
- static inline void capture_shutdown(void)
- {
- FTM2_C0SC = 0;
- *portConfigRegister(CAPTURE_USE_FTM2_CH0) = 0;
- NVIC_DISABLE_IRQ(IRQ_FTM2);
- }
-
-
- #elif defined(CAPTURE_USE_FTM2_CH1)
-
- #define FTM_SC_VALUE (FTM_SC_TOIE | FTM_SC_CLKS(1) | FTM_SC_PS(0))
- #define FTM_ISR_NAME ftm2_isr
-
- static inline void capture_init(void)
- {
- if (FTM2_MOD != 0xFFFF || (FTM2_SC & 0x7F) != FTM_SC_VALUE) {
- FTM2_SC = 0;
- FTM2_CNT = 0;
- FTM2_MOD = 0xFFFF;
- FTM2_SC = FTM_SC_VALUE;
- #ifdef KINETISK
- FTM2_MODE = 0;
- #endif
- }
- NVIC_SET_PRIORITY(IRQ_FTM2, 48);
- }
- static inline void capture_start(void)
- {
- #if defined(KINETISL)
- FTM2_C1SC = 0;
- delayMicroseconds(1);
- #endif
- FTM2_C1SC = 0b01000100;
- *portConfigRegister(CAPTURE_USE_FTM2_CH1) = PORT_PCR_MUX(3);
- NVIC_ENABLE_IRQ(IRQ_FTM2);
- }
- static inline uint16_t capture_event(void)
- {
- return (FTM2_C1SC & 0x80) ? 1 : 0;
- }
- static inline uint32_t capture_read(void)
- {
- uint32_t val = FTM2_C1V;
- #if defined(KINETISK)
- FTM2_C1SC = 0b01000100;
- #elif defined(KINETISL)
- FTM2_C1SC = 0b01000100 | FTM_CSC_CHF;
- #endif
- return val;
- }
- static inline uint8_t capture_overflow(void)
- {
- return (FTM2_SC & FTM_SC_TOF) ? 1 : 0;
- }
- static inline void capture_overflow_reset(void)
- {
- #if defined(KINETISK)
- FTM2_SC = FTM_SC_VALUE;
- #elif defined(KINETISL)
- FTM2_SC = FTM_SC_VALUE | FTM_SC_TOF;
- #endif
- }
- static inline void capture_shutdown(void)
- {
- FTM2_C1SC = 0;
- *portConfigRegister(CAPTURE_USE_FTM2_CH1) = 0;
- NVIC_DISABLE_IRQ(IRQ_FTM2);
- }
-
- #elif defined(CAPTURE_USE_FLEXPWM4_CH0A)
-
- #define FTM_ISR_NAME flexpwm_4_0_isr
- void flexpwm_4_0_isr(void);
-
- static inline void capture_init(void)
- {
- FLEXPWM4_FCTRL0 |= FLEXPWM_FCTRL0_FLVL(1);
- FLEXPWM4_FSTS0 = 0x0001;
- FLEXPWM4_MCTRL |= FLEXPWM_MCTRL_CLDOK(1);
- FLEXPWM4_SM0CTRL2 = FLEXPWM_SMCTRL2_INDEP;
- FLEXPWM4_SM0CTRL = FLEXPWM_SMCTRL_HALF;
- FLEXPWM4_SM0INIT = 0;
- FLEXPWM4_SM0VAL0 = 0;
- FLEXPWM4_SM0VAL1 = 65535;
- FLEXPWM4_SM0VAL2 = 0;
- FLEXPWM4_SM0VAL3 = 0;
- FLEXPWM4_SM0VAL4 = 0;
- FLEXPWM4_SM0VAL5 = 0;
- FLEXPWM4_MCTRL |= FLEXPWM_MCTRL_LDOK(1) | FLEXPWM_MCTRL_RUN(1);
- attachInterruptVector(IRQ_FLEXPWM4_0, flexpwm_4_0_isr);
- NVIC_SET_PRIORITY(IRQ_FLEXPWM4_0, 48);
- FLEXPWM4_SM0INTEN = FLEXPWM_SMINTEN_CA0IE | FLEXPWM_SMINTEN_RIE;
- }
- static inline void capture_start(void)
- {
- FLEXPWM4_SM0CAPTCTRLA = FLEXPWM_SMCAPTCTRLA_EDGA0(2) | FLEXPWM_SMCAPTCTRLA_ARMA;
- IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_08 = 1 | 0x10; // pin 22, AD_B1_08, FLEXPWM4_PWM0_A
- IOMUXC_FLEXPWM4_PWMA0_SELECT_INPUT = 1;
- FLEXPWM4_SM0STS = FLEXPWM_SMSTS_CFA0 | FLEXPWM_SMSTS_RF;
- NVIC_ENABLE_IRQ(IRQ_FLEXPWM4_0);
- }
- static inline uint16_t capture_event(void)
- {
- return (FLEXPWM4_SM0STS & FLEXPWM_SMSTS_CFA0) ? 1 : 0;
- }
- static inline uint32_t capture_read(void)
- {
- uint32_t val = FLEXPWM4_SM0CVAL2;
- FLEXPWM4_SM0STS = FLEXPWM_SMSTS_CFA0;
- return val;
- }
- static inline uint8_t capture_overflow(void)
- {
- return (FLEXPWM4_SM0STS & FLEXPWM_SMSTS_RF) ? 1 : 0;
- }
- static inline void capture_overflow_reset(void)
- {
- FLEXPWM4_SM0STS = FLEXPWM_SMSTS_RF;
- }
- static inline void capture_shutdown(void)
- {
- FLEXPWM4_SM0INTEN = 0;
- FLEXPWM4_SM0CAPTCTRLA = 0;
- IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_08 = 5 | 0x10;
- NVIC_DISABLE_IRQ(IRQ_FLEXPWM4_0);
- }
-
- #elif defined(CAPTURE_USE_TIMER1)
-
- static uint8_t saveTCCR1A, saveTCCR1B;
-
- static inline void capture_init(void)
- {
- saveTCCR1A = TCCR1A;
- saveTCCR1B = TCCR1B;
- TCCR1B = 0;
- TCCR1A = 0;
- TCNT1 = 0;
- TIFR1 = (1<<ICF1) | (1<<TOV1);
- TIMSK1 = (1<<ICIE1) | (1<<TOIE1);
- }
- static inline void capture_start(void)
- {
- TCCR1B = (1<<ICNC1) | (1<<ICES1) | (1<<CS10);
- }
- static inline uint16_t capture_read(void)
- {
- return ICR1;
- }
- static inline uint8_t capture_overflow(void)
- {
- return TIFR1 & (1<<TOV1);
- }
- static inline void capture_overflow_reset(void)
- {
- TIFR1 = (1<<TOV1);
- }
- static inline void capture_shutdown(void)
- {
- TCCR1B = 0;
- TIMSK1 = 0;
- TCCR1A = saveTCCR1A;
- TCCR1B = saveTCCR1B;
- }
-
-
- #define TIMER_OVERFLOW_VECTOR TIMER1_OVF_vect
- #define TIMER_CAPTURE_VECTOR TIMER1_CAPT_vect
-
-
- #elif defined(CAPTURE_USE_TIMER3)
-
- static uint8_t saveTCCR3A, saveTCCR3B;
-
- static inline void capture_init(void)
- {
- saveTCCR3A = TCCR3A;
- saveTCCR3B = TCCR3B;
- TCCR3B = 0;
- TCCR3A = 0;
- TCNT3 = 0;
- TIFR3 = (1<<ICF3) | (1<<TOV3);
- TIMSK3 = (1<<ICIE3) | (1<<TOIE3);
- }
- static inline void capture_start(void)
- {
- TCCR3B = (1<<ICNC3) | (1<<ICES3) | (1<<CS30);
- }
- static inline uint16_t capture_read(void)
- {
- return ICR3;
- }
- static inline uint8_t capture_overflow(void)
- {
- return TIFR3 & (1<<TOV3);
- }
- static inline void capture_overflow_reset(void)
- {
- TIFR3 = (1<<TOV3);
- }
- static inline void capture_shutdown(void)
- {
- TCCR3B = 0;
- TIMSK3 = 0;
- TCCR3A = saveTCCR3A;
- TCCR3B = saveTCCR3B;
- }
-
- #define TIMER_OVERFLOW_VECTOR TIMER3_OVF_vect
- #define TIMER_CAPTURE_VECTOR TIMER3_CAPT_vect
-
-
-
- #elif defined(CAPTURE_USE_TIMER4)
-
- static uint8_t saveTCCR4A, saveTCCR4B;
-
- static inline void capture_init(void)
- {
- saveTCCR4A = TCCR4A;
- saveTCCR4B = TCCR4B;
- TCCR4B = 0;
- TCCR4A = 0;
- TCNT4 = 0;
- TIFR4 = (1<<ICF4) | (1<<TOV4);
- TIMSK4 = (1<<ICIE4) | (1<<TOIE4);
- }
- static inline void capture_start(void)
- {
- TCCR4B = (1<<ICNC4) | (1<<ICES4) | (1<<CS40);
- }
- static inline uint16_t capture_read(void)
- {
- return ICR4;
- }
- static inline uint8_t capture_overflow(void)
- {
- return TIFR4 & (1<<TOV4);
- }
- static inline void capture_overflow_reset(void)
- {
- TIFR4 = (1<<TOV4);
- }
- static inline void capture_shutdown(void)
- {
- TCCR4B = 0;
- TIMSK4 = 0;
- TCCR4A = saveTCCR4A;
- TCCR4B = saveTCCR4B;
- }
-
- #define TIMER_OVERFLOW_VECTOR TIMER4_OVF_vect
- #define TIMER_CAPTURE_VECTOR TIMER4_CAPT_vect
-
-
-
- #elif defined(CAPTURE_USE_TIMER5)
-
- static uint8_t saveTCCR5A, saveTCCR5B;
-
- static inline void capture_init(void)
- {
- saveTCCR5A = TCCR5A;
- saveTCCR5B = TCCR5B;
- TCCR5B = 0;
- TCCR5A = 0;
- TCNT5 = 0;
- TIFR5 = (1<<ICF5) | (1<<TOV5);
- TIMSK5 = (1<<ICIE5) | (1<<TOIE5);
- }
- static inline void capture_start(void)
- {
- TCCR5B = (1<<ICNC5) | (1<<ICES5) | (1<<CS50);
- }
- static inline uint16_t capture_read(void)
- {
- return ICR5;
- }
- static inline uint8_t capture_overflow(void)
- {
- return TIFR5 & (1<<TOV5);
- }
- static inline void capture_overflow_reset(void)
- {
- TIFR5 = (1<<TOV5);
- }
- static inline void capture_shutdown(void)
- {
- TCCR5B = 0;
- TIMSK5 = 0;
- TCCR5A = saveTCCR5A;
- TCCR5B = saveTCCR5B;
- }
-
- #define TIMER_OVERFLOW_VECTOR TIMER5_OVF_vect
- #define TIMER_CAPTURE_VECTOR TIMER5_CAPT_vect
-
-
-
-
- #endif // CAPTURE_USE_***
-
-
- #endif
|