Author: mark9064 <30447455+mark9064@users.noreply.github.com>
Batch display command arguments
src/drivers/St7789.cpp | 58 ++++++++++++++++++++----------------------- src/drivers/St7789.h | 9 +++---
diff --git a/src/drivers/St7789.cpp b/src/drivers/St7789.cpp index 12e95a4133f4395f3f4570fed3efe89459fccf8c..c22f2199c379d90d2a35dbc723c678d5fc444c27 100644 --- a/src/drivers/St7789.cpp +++ b/src/drivers/St7789.cpp @@ -1,3 +1,4 @@ +#include <cstring> #include "drivers/St7789.h" #include <hal/nrf_gpio.h> #include <nrfx_log.h> @@ -16,10 +17,9 @@ nrf_gpio_pin_set(pinReset); HardwareReset(); SoftwareReset(); SleepOut(); - ColMod(); + PixelFormat(); MemoryDataAccessControl(); - ColumnAddressSet(); - RowAddressSet(); + SetAddrWindow(0, 0, Width, Height); // P8B Mirrored version does not need display inversion. #ifndef DRIVER_DISPLAY_MIRROR DisplayInversionOn(); @@ -97,8 +97,9 @@ vTaskDelay(pdMS_TO_TICKS(6)); sleepIn = true; } -void St7789::ColMod() { - WriteCommand(static_cast<uint8_t>(Commands::ColMod)); +void St7789::PixelFormat() { + WriteCommand(static_cast<uint8_t>(Commands::PixelFormat)); + // 65K colours, 16-bit per pixel WriteData(0x55); } @@ -118,22 +119,6 @@ WriteData(0x00); #endif } -void St7789::ColumnAddressSet() { - WriteCommand(static_cast<uint8_t>(Commands::ColumnAddressSet)); - WriteData(0x00); - WriteData(0x00); - WriteData(Width >> 8u); - WriteData(Width & 0xffu); -} - -void St7789::RowAddressSet() { - WriteCommand(static_cast<uint8_t>(Commands::RowAddressSet)); - WriteData(0x00); - WriteData(0x00); - WriteData(320u >> 8u); - WriteData(320u & 0xffu); -} - void St7789::DisplayInversionOn() { WriteCommand(static_cast<uint8_t>(Commands::DisplayInversionOn)); } @@ -148,16 +133,23 @@ } void St7789::SetAddrWindow(uint16_t x0, uint16_t y0, uint16_t x1, uint16_t y1) { WriteCommand(static_cast<uint8_t>(Commands::ColumnAddressSet)); - WriteData(x0 >> 8); - WriteData(x0 & 0xff); - WriteData(x1 >> 8); - WriteData(x1 & 0xff); + uint8_t colArgs[] = { + static_cast<uint8_t>(x0 >> 8), // x start MSB + static_cast<uint8_t>(x0), // x start LSB + static_cast<uint8_t>(x1 >> 8), // x end MSB + static_cast<uint8_t>(x1) // x end LSB + }; + WriteData(colArgs, sizeof(colArgs)); WriteCommand(static_cast<uint8_t>(Commands::RowAddressSet)); - WriteData(y0 >> 8); - WriteData(y0 & 0xff); - WriteData(y1 >> 8); - WriteData(y1 & 0xff); + uint8_t rowArgs[] = { + static_cast<uint8_t>(y0 >> 8), // y start MSB + static_cast<uint8_t>(y0), // y start LSB + static_cast<uint8_t>(y1 >> 8), // y end MSB + static_cast<uint8_t>(y1) // y end LSB + }; + memcpy(addrWindowArgs, rowArgs, sizeof(rowArgs)); + WriteData(addrWindowArgs, sizeof(addrWindowArgs)); } void St7789::WriteToRam(const uint8_t* data, size_t size) { @@ -179,8 +171,12 @@ void St7789::VerticalScrollStartAddress(uint16_t line) { verticalScrollingStartAddress = line; WriteCommand(static_cast<uint8_t>(Commands::VerticalScrollStartAddress)); - WriteData(line >> 8u); - WriteData(line & 0x00ffu); + uint8_t args[] = { + static_cast<uint8_t>(line >> 8), // Frame memory line pointer MSB + static_cast<uint8_t>(line) // Frame memory line pointer LSB + }; + memcpy(verticalScrollArgs, args, sizeof(args)); + WriteData(verticalScrollArgs, sizeof(verticalScrollArgs)); } void St7789::Uninit() { diff --git a/src/drivers/St7789.h b/src/drivers/St7789.h index 45d4b56dc850b79ed1e6aa4935a234444d715dff..844e0180fd3347a7225d188455383a481cfd75f2 100644 --- a/src/drivers/St7789.h +++ b/src/drivers/St7789.h @@ -40,7 +40,7 @@ void SoftwareReset(); void SleepOut(); void EnsureSleepOutPostDelay(); void SleepIn(); - void ColMod(); + void PixelFormat(); void MemoryDataAccessControl(); void DisplayInversionOn(); void NormalModeOn(); @@ -68,16 +68,17 @@ WriteToRam = 0x2c, MemoryDataAccessControl = 0x36, VerticalScrollDefinition = 0x33, VerticalScrollStartAddress = 0x37, - ColMod = 0x3a, + PixelFormat = 0x3a, VdvSet = 0xc4, }; void WriteData(uint8_t data); void WriteData(const uint8_t* data, size_t size); - void ColumnAddressSet(); static constexpr uint16_t Width = 240; static constexpr uint16_t Height = 320; - void RowAddressSet(); + + uint8_t addrWindowArgs[4]; + uint8_t verticalScrollArgs[2]; }; } }