Browse Source

some fixes, display does not work but no boot loops any more

pull/1626/head
lumapu 9 months ago
parent
commit
c3f2c8bbe8
  1. 78
      src/plugins/Display/epdHal.h

78
src/plugins/Display/epdHal.h

@ -106,15 +106,16 @@ class epdHal: public GxEPD2_HalInterface, public SpiPatcherHandle {
data[0] = buf; data[0] = buf;
request_spi(); request_spi();
size_t spiLen = static_cast<size_t>(1u) << 3;
spi_transaction_t t = { spi_transaction_t t = {
.flags = 0, .flags = 0,
.cmd = 0, .cmd = 0,
.addr = 0, .addr = 0,
.length = static_cast<size_t>(1u) << 3, .length = spiLen,
.rxlength = 0, .rxlength = spiLen,
.user = NULL, .user = NULL,
.tx_buffer = data, .tx_buffer = data,
.rx_buffer = NULL .rx_buffer = data
}; };
ESP_ERROR_CHECK(spi_device_polling_transmit(spi, &t)); ESP_ERROR_CHECK(spi_device_polling_transmit(spi, &t));
@ -127,15 +128,16 @@ class epdHal: public GxEPD2_HalInterface, public SpiPatcherHandle {
request_spi(); request_spi();
size_t spiLen = static_cast<size_t>(n) << 3;
spi_transaction_t t = { spi_transaction_t t = {
.flags = 0, .flags = 0,
.cmd = 0, .cmd = 0,
.addr = 0, .addr = 0,
.length = static_cast<size_t>(n) << 3, .length = spiLen,
.rxlength = 0, .rxlength = spiLen,
.user = NULL, .user = NULL,
.tx_buffer = data, .tx_buffer = data,
.rx_buffer = NULL .rx_buffer = data
}; };
ESP_ERROR_CHECK(spi_device_polling_transmit(spi, &t)); ESP_ERROR_CHECK(spi_device_polling_transmit(spi, &t));
@ -151,17 +153,52 @@ class epdHal: public GxEPD2_HalInterface, public SpiPatcherHandle {
request_spi(); request_spi();
size_t spiLen = static_cast<size_t>(n + fill_with_zeroes) << 3;
spi_transaction_t t = {
.flags = SPI_TRANS_CS_KEEP_ACTIVE,
.cmd = 0,
.addr = 0,
.length = spiLen,
.rxlength = spiLen,
.user = NULL,
.tx_buffer = data,
.rx_buffer = data
};
size_t offs = 0;
spi_device_acquire_bus(spi, portMAX_DELAY);
while(offs < (n + fill_with_zeroes)) {
t.length = (64u << 3);
t.rxlength = t.length;
t.tx_buffer = &data[offs];
offs += 64;
ESP_ERROR_CHECK(spi_device_polling_transmit(spi, &t));
}
spi_device_release_bus(spi);
release_spi();
}
void writeCmd(const uint8_t val) override {
uint8_t data[1];
data[0] = val;
request_spi();
gpio_set_level(mPinDc, LOW);
size_t spiLen = static_cast<size_t>(1u) << 3;
spi_transaction_t t = { spi_transaction_t t = {
.flags = 0, .flags = 0,
.cmd = 0, .cmd = 0,
.addr = 0, .addr = 0,
.length = static_cast<size_t>(n + fill_with_zeroes) << 3, .length = spiLen,
.rxlength = 0, .rxlength = spiLen,
.user = NULL, .user = NULL,
.tx_buffer = data, .tx_buffer = data,
.rx_buffer = NULL .rx_buffer = data
}; };
ESP_ERROR_CHECK(spi_device_polling_transmit(spi, &t)); ESP_ERROR_CHECK(spi_device_polling_transmit(spi, &t));
gpio_set_level(mPinDc, HIGH);
release_spi(); release_spi();
} }
@ -173,15 +210,16 @@ class epdHal: public GxEPD2_HalInterface, public SpiPatcherHandle {
request_spi(); request_spi();
gpio_set_level(mPinDc, LOW); gpio_set_level(mPinDc, LOW);
size_t spiLen = static_cast<size_t>(1u) << 3;
spi_transaction_t t = { spi_transaction_t t = {
.flags = 0, .flags = 0,
.cmd = 0, .cmd = 0,
.addr = 0, .addr = 0,
.length = static_cast<size_t>(1u) << 3, .length = spiLen,
.rxlength = 0, .rxlength = spiLen,
.user = NULL, .user = NULL,
.tx_buffer = data, .tx_buffer = data,
.rx_buffer = NULL .rx_buffer = data
}; };
ESP_ERROR_CHECK(spi_device_polling_transmit(spi, &t)); ESP_ERROR_CHECK(spi_device_polling_transmit(spi, &t));
gpio_set_level(mPinDc, HIGH); gpio_set_level(mPinDc, HIGH);
@ -193,15 +231,16 @@ class epdHal: public GxEPD2_HalInterface, public SpiPatcherHandle {
} else } else
std::copy(&buf[1], &buf[n], &data[0]); std::copy(&buf[1], &buf[n], &data[0]);
spiLen = static_cast<size_t>(n) << 3;
spi_transaction_t t1 = { spi_transaction_t t1 = {
.flags = 0, .flags = 0,
.cmd = 0, .cmd = 0,
.addr = 0, .addr = 0,
.length = static_cast<size_t>(n) << 3, .length = spiLen,
.rxlength = 0, .rxlength = spiLen,
.user = NULL, .user = NULL,
.tx_buffer = data, .tx_buffer = data,
.rx_buffer = NULL .rx_buffer = data
}; };
ESP_ERROR_CHECK(spi_device_polling_transmit(spi, &t1)); ESP_ERROR_CHECK(spi_device_polling_transmit(spi, &t1));
@ -210,11 +249,9 @@ class epdHal: public GxEPD2_HalInterface, public SpiPatcherHandle {
void startTransfer(void) override { void startTransfer(void) override {
request_spi(); request_spi();
gpio_set_level(mPinDc, LOW);
} }
void endTransfer(void) override { void endTransfer(void) override {
gpio_set_level(mPinDc, HIGH);
release_spi(); release_spi();
} }
@ -222,15 +259,16 @@ class epdHal: public GxEPD2_HalInterface, public SpiPatcherHandle {
uint8_t data[1]; uint8_t data[1];
data[0] = val; data[0] = val;
size_t spiLen = static_cast<size_t>(1u) << 3;
spi_transaction_t t = { spi_transaction_t t = {
.flags = 0, .flags = 0,
.cmd = 0, .cmd = 0,
.addr = 0, .addr = 0,
.length = static_cast<size_t>(1u) << 3, .length = spiLen,
.rxlength = 0, .rxlength = spiLen,
.user = NULL, .user = NULL,
.tx_buffer = data, .tx_buffer = data,
.rx_buffer = NULL .rx_buffer = data
}; };
ESP_ERROR_CHECK(spi_device_polling_transmit(spi, &t)); ESP_ERROR_CHECK(spi_device_polling_transmit(spi, &t));
} }

Loading…
Cancel
Save