From d9bca305e576a98192724c212c31413395d31cb4 Mon Sep 17 00:00:00 2001 From: Damien George Date: Tue, 15 Nov 2022 12:44:29 +1100 Subject: [PATCH] esp8266/machine_pin: Disable open drain when pin becomes input/output. Otherwise the pin stays in open drain mode. Signed-off-by: Damien George --- ports/esp8266/machine_pin.c | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/ports/esp8266/machine_pin.c b/ports/esp8266/machine_pin.c index f5e17c7e14..a76f554237 100644 --- a/ports/esp8266/machine_pin.c +++ b/ports/esp8266/machine_pin.c @@ -46,6 +46,16 @@ (GPIO_REG_READ(GPIO_PIN_ADDR(phys_port)) & ~GPIO_PIN_INT_TYPE_MASK) \ | GPIO_PIN_INT_TYPE_SET(trig))) \ +#define ENABLE_OPEN_DRAIN(phys_port) \ + (GPIO_REG_WRITE(GPIO_PIN_ADDR(GPIO_ID_PIN(phys_port)), \ + GPIO_REG_READ(GPIO_PIN_ADDR(GPIO_ID_PIN(phys_port))) \ + | GPIO_PIN_PAD_DRIVER_SET(GPIO_PAD_DRIVER_ENABLE))) + +#define DISABLE_OPEN_DRAIN(phys_port) \ + (GPIO_REG_WRITE(GPIO_PIN_ADDR(GPIO_ID_PIN(phys_port)), \ + GPIO_REG_READ(GPIO_PIN_ADDR(GPIO_ID_PIN(phys_port))) \ + & ~GPIO_PIN_PAD_DRIVER_SET(GPIO_PAD_DRIVER_ENABLE))) \ + typedef struct _pin_irq_obj_t { mp_obj_base_t base; uint16_t phys_port; @@ -165,9 +175,7 @@ void mp_hal_pin_open_drain(mp_hal_pin_obj_t pin_id) { ETS_GPIO_INTR_DISABLE(); PIN_FUNC_SELECT(pin->periph, pin->func); - GPIO_REG_WRITE(GPIO_PIN_ADDR(GPIO_ID_PIN(pin->phys_port)), - GPIO_REG_READ(GPIO_PIN_ADDR(GPIO_ID_PIN(pin->phys_port))) - | GPIO_PIN_PAD_DRIVER_SET(GPIO_PAD_DRIVER_ENABLE)); // open drain + ENABLE_OPEN_DRAIN(pin->phys_port); GPIO_REG_WRITE(GPIO_ENABLE_ADDRESS, GPIO_REG_READ(GPIO_ENABLE_ADDRESS) | (1 << pin->phys_port)); ETS_GPIO_INTR_ENABLE(); @@ -271,6 +279,7 @@ STATIC mp_obj_t pyb_pin_obj_init_helper(pyb_pin_obj_t *self, size_t n_args, cons mp_raise_ValueError(MP_ERROR_TEXT("Pin(16) doesn't support pull")); } } else { + DISABLE_OPEN_DRAIN(self->phys_port); PIN_FUNC_SELECT(self->periph, self->func); #if 0 // Removed in SDK 1.1.0