From da69849328e982c2702ced82718ad65c58f93ee4 Mon Sep 17 00:00:00 2001 From: Taylor Braun-Jones Date: Wed, 5 Jun 2024 00:29:03 -0400 Subject: [PATCH] Fix broken reset logic if reset pin exceeds 127 due to int8 overflow --- Adafruit_GrayOLED.cpp | 12 ++++++------ Adafruit_GrayOLED.h | 10 +++++----- 2 files changed, 11 insertions(+), 11 deletions(-) diff --git a/Adafruit_GrayOLED.cpp b/Adafruit_GrayOLED.cpp index f487861b..9a680f26 100644 --- a/Adafruit_GrayOLED.cpp +++ b/Adafruit_GrayOLED.cpp @@ -61,7 +61,7 @@ allocation is performed there! */ Adafruit_GrayOLED::Adafruit_GrayOLED(uint8_t bpp, uint16_t w, uint16_t h, - TwoWire *twi, int8_t rst_pin, + TwoWire *twi, uint32_t rst_pin, uint32_t clkDuring, uint32_t clkAfter) : Adafruit_GFX(w, h), i2c_preclk(clkDuring), i2c_postclk(clkAfter), buffer(NULL), dcPin(-1), csPin(-1), rstPin(rst_pin), _bpp(bpp) { @@ -97,9 +97,9 @@ Adafruit_GrayOLED::Adafruit_GrayOLED(uint8_t bpp, uint16_t w, uint16_t h, allocation is performed there! */ Adafruit_GrayOLED::Adafruit_GrayOLED(uint8_t bpp, uint16_t w, uint16_t h, - int8_t mosi_pin, int8_t sclk_pin, - int8_t dc_pin, int8_t rst_pin, - int8_t cs_pin) + uint32_t mosi_pin, uint32_t sclk_pin, + uint32_t dc_pin, uint32_t rst_pin, + uint32_t cs_pin) : Adafruit_GFX(w, h), dcPin(dc_pin), csPin(cs_pin), rstPin(rst_pin), _bpp(bpp) { @@ -133,8 +133,8 @@ Adafruit_GrayOLED::Adafruit_GrayOLED(uint8_t bpp, uint16_t w, uint16_t h, allocation is performed there! */ Adafruit_GrayOLED::Adafruit_GrayOLED(uint8_t bpp, uint16_t w, uint16_t h, - SPIClass *spi, int8_t dc_pin, - int8_t rst_pin, int8_t cs_pin, + SPIClass *spi, uint32_t dc_pin, + uint32_t rst_pin, uint32_t cs_pin, uint32_t bitrate) : Adafruit_GFX(w, h), dcPin(dc_pin), csPin(cs_pin), rstPin(rst_pin), _bpp(bpp) { diff --git a/Adafruit_GrayOLED.h b/Adafruit_GrayOLED.h index 8ec7b23d..527aebd4 100644 --- a/Adafruit_GrayOLED.h +++ b/Adafruit_GrayOLED.h @@ -47,13 +47,13 @@ class Adafruit_GrayOLED : public Adafruit_GFX { public: Adafruit_GrayOLED(uint8_t bpp, uint16_t w, uint16_t h, TwoWire *twi = &Wire, - int8_t rst_pin = -1, uint32_t preclk = 400000, + uint32_t rst_pin = -1, uint32_t preclk = 400000, uint32_t postclk = 100000); - Adafruit_GrayOLED(uint8_t bpp, uint16_t w, uint16_t h, int8_t mosi_pin, - int8_t sclk_pin, int8_t dc_pin, int8_t rst_pin, - int8_t cs_pin); + Adafruit_GrayOLED(uint8_t bpp, uint16_t w, uint16_t h, uint32_t mosi_pin, + uint32_t sclk_pin, uint32_t dc_pin, uint32_t rst_pin, + uint32_t cs_pin); Adafruit_GrayOLED(uint8_t bpp, uint16_t w, uint16_t h, SPIClass *spi, - int8_t dc_pin, int8_t rst_pin, int8_t cs_pin, + uint32_t dc_pin, uint32_t rst_pin, uint32_t cs_pin, uint32_t bitrate = 8000000UL); ~Adafruit_GrayOLED(void);