here is small sketch to test GPT with external clock (pin 14) and and capture with pin 15
Code:
// GPT2 external clock (GPS 8 mhz) into pin 14, PPS captured to pin 15
//https://forum.pjrc.com/threads/54265-Teensy-4-testing-mbed-NXP-MXRT1050-EVKB-(600-Mhz-M7)?p=193217&viewfull=1#post193217
// CLKSRC 1 24mhz or 150mhz 3 external 4 32khz
// 1062 capture pin 15 Serial3 Rx test with GPS pps or pwm on pin 14
// GPT2 capture 1 GPIO_AD_B1_03 Alt 8
// external pin is 14 GPIO_AD_B1_02 ALT8 (Frontside - A0) Serial3 Tx
void setup() {
Serial.begin(9600);
while (!Serial);
delay(2000);
Serial.println("ok");
pinMode(13, OUTPUT);
// analogWriteFrequency(14, 100); // test with PWM
// analogWrite(14, 128); // jumper pwm 14 to pin 15 Serial3 on T4B2 breakout
// Connect GPS 1PPS signal to pin 15 (GPIO_AD_B1_03)
IOMUXC_GPT2_IPP_IND_CAPIN1_SELECT_INPUT = 1; // remap GPT2 capture 1
IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_03 = 8; // GPT2 Capture1
IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_03 = 0x13000; //Pulldown & Hyst
// external clock pin 14
IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_02 = 8;
IOMUXC_GPT2_IPP_IND_CLKIN_SELECT_INPUT = 1;
// uncomment following for 150mhz, required if external > 8mhz
CCM_CSCMR1 &= ~CCM_CSCMR1_PERCLK_CLK_SEL; // turn off 24mhz mode
CCM_CCGR0 |= CCM_CCGR0_GPT2_BUS(CCM_CCGR_ON) |
CCM_CCGR0_GPT2_SERIAL(CCM_CCGR_ON); // enable clock
GPT2_CR = 0;
GPT2_PR = 0;
GPT2_SR = 0x3F; // clear all prior status
GPT2_IR = GPT_IR_IF1IE;
GPT2_CR = GPT_CR_EN | GPT_CR_CLKSRC(3) | // SRC 1 24 or 150mhz 3 external clock
GPT_CR_FRR | GPT_CR_IM1(1);
attachInterruptVector(IRQ_GPT2, capture);
NVIC_ENABLE_IRQ(IRQ_GPT2);
}
volatile uint32_t delta, captured;
void capture() {
static uint32_t prior = 0;
uint32_t ticks = GPT2_ICR1;
GPT2_SR = GPT_SR_IF1;
delta = ticks - prior;
prior = ticks;
asm("dsb");
captured = 1;
}
void loop() {
if (captured) {
Serial.println(delta);
captured = 0;
}
}
I tested with a signal generator at 10mhz to Teensy pin 14 and GPS PPS as trigger on pin 15 so I could measure accuracy of generator.