From acb7bee5302bc940b735637b46addb3c3ee9f358 Mon Sep 17 00:00:00 2001 From: Julian Uziemblo Date: Tue, 5 Nov 2024 16:10:46 +0100 Subject: [PATCH] hal/imxrt117x: fix IOpad - properly set ranges of registers configured differently - add a way of setting ODE field in non-LPSR/SNVS GPIO registers - set proper ranges for setting ODE field in LPSR, SNVS, and remaining GPIO registers JIRA: RTOS-963 --- hal/armv7m/imxrt/117x/imxrt.c | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/hal/armv7m/imxrt/117x/imxrt.c b/hal/armv7m/imxrt/117x/imxrt.c index 8d514d02..690ce058 100644 --- a/hal/armv7m/imxrt/117x/imxrt.c +++ b/hal/armv7m/imxrt/117x/imxrt.c @@ -158,8 +158,7 @@ __attribute__((section(".noxip"))) int _imxrt_setIOpad(int pad, char sre, char d return -1; } - if (((pad >= pctl_pad_gpio_emc_b1_00) && (pad <= pctl_pad_gpio_emc_b2_20)) || - ((pad >= pctl_pad_gpio_sd_b1_00) && (pad <= pctl_pad_gpio_disp_b2_15))) { + if ((pad <= pctl_pad_gpio_emc_b2_20) || ((pad >= pctl_pad_gpio_sd_b1_00) && (pad <= pctl_pad_gpio_disp_b1_11))) { /* Fields have slightly diffrent meaning... */ if (pue == 0) { pull = 3; @@ -178,14 +177,22 @@ __attribute__((section(".noxip"))) int _imxrt_setIOpad(int pad, char sre, char d t = *reg & ~0x1f; t |= (!!sre) | (!!dse << 1) | (!!pue << 2) | (!!pus << 3); - if ((pad >= pctl_pad_test_mode) && (pad <= pctl_pad_gpio_snvs_09)) { + if (pad <= pctl_pad_gpio_disp_b2_15) { + t &= ~(1 << 4); + t |= !!ode << 4; + } + else if ((pad >= pctl_pad_wakeup) && (pad <= pctl_pad_gpio_snvs_09)) { t &= ~(1 << 6); t |= !!ode << 6; } - else { + else if (pad >= pctl_pad_gpio_lpsr_00) { t &= ~(1 << 5); t |= !!ode << 5; } + else { + /* MISRA */ + /* pctl_pad_test_mode, pctl_pad_por_b, pctl_pad_onoff - no ode field */ + } } /* APC field is not documented. Leave it alone for now. */