aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authormrfaptastic <12006953+mrfaptastic@users.noreply.github.com>2023-01-01 15:00:44 +0000
committermrfaptastic <12006953+mrfaptastic@users.noreply.github.com>2023-01-01 15:00:44 +0000
commitce2b6264dd77c15f0f533fe6587b84dd403f8013 (patch)
tree3838b49667d3d0a4f46ec1f92c1f05ee7da8d56d /src
parent81ee41e15a8a2223cd811319ef93d95b237df275 (diff)
Fix compilation issues with Arduino IDE
* Fix various compile errors / warnings when using Arduino 2.0 IDE (it compiles to a strict standard and errors out with unused variables etc.) * Fix issue with compiling for ESP32-S2 using Arduino IDE
Diffstat (limited to 'src')
-rw-r--r--src/ESP32-HUB75-MatrixPanel-I2S-DMA.cpp8
-rw-r--r--src/platforms/esp32/esp32_i2s_parallel_dma.c.txt444
-rw-r--r--src/platforms/esp32/esp32_i2s_parallel_dma.cpp71
-rw-r--r--src/platforms/esp32/esp32_i2s_parallel_dma.h.txt106
-rw-r--r--src/platforms/esp32/esp32_i2s_parallel_dma.hpp4
-rw-r--r--src/platforms/esp32s3/gdma_lcd_parallel16.cpp15
-rw-r--r--src/platforms/esp32s3/gdma_lcd_parallel16.hpp2
-rw-r--r--src/platforms/platform_detect.hpp4
8 files changed, 54 insertions, 600 deletions
diff --git a/src/ESP32-HUB75-MatrixPanel-I2S-DMA.cpp b/src/ESP32-HUB75-MatrixPanel-I2S-DMA.cpp
index fd0ab2d..8096cf7 100644
--- a/src/ESP32-HUB75-MatrixPanel-I2S-DMA.cpp
+++ b/src/ESP32-HUB75-MatrixPanel-I2S-DMA.cpp
@@ -6,7 +6,11 @@
#include "rom/cache.h"
#endif
-static const char* TAG = "MatrixPanel";
+extern Bus_Parallel16 dma_bus;
+
+#if CORE_DEBUG_LEVEL > 0
+ static const char* TAG = "MatrixPanel";
+#endif
/* This replicates same function in rowBitStruct, but due to induced inlining it might be MUCH faster
* when used in tight loops while method from struct could be flushed out of instruction cache between
@@ -256,7 +260,7 @@ void MatrixPanel_I2S_DMA::configureDMA(const HUB75_I2S_CFG& _cfg)
bus_cfg.pin_d15 = -1;
#if defined(SPIRAM_DMA_BUFFER)
- bus_cfg.psram_clk_hack = true;
+ bus_cfg.psram_clk_override = true;
#endif
dma_bus.config(bus_cfg);
diff --git a/src/platforms/esp32/esp32_i2s_parallel_dma.c.txt b/src/platforms/esp32/esp32_i2s_parallel_dma.c.txt
deleted file mode 100644
index 82eebe6..0000000
--- a/src/platforms/esp32/esp32_i2s_parallel_dma.c.txt
+++ /dev/null
@@ -1,444 +0,0 @@
-/*
- * ESP32_I2S_PARALLEL_DMA (Version 3)
- *
- * Author: Mrfaptastic @ https://github.com/mrfaptastic/
- *
- * Description: Multi-ESP32 product DMA setup functions for WROOM & S2, S3 mcu's.
- *
- * Credits:
- * 1) https://www.esp32.com/viewtopic.php?f=17&t=3188 for original ref. implementation
- * 2) https://github.com/TobleMiner/esp_i2s_parallel for a cleaner implementation
- *
- */
-
-// Header
-#include "esp32_i2s_parallel_dma.h"
-#include "esp32_i2s_parallel_mcu_def.h"
-
-#include <stdbool.h>
-#include <stdint.h>
-#include <stdlib.h>
-#include <string.h>
-
-#include <driver/gpio.h>
-#include <driver/periph_ctrl.h>
-#include <soc/gpio_sig_map.h>
-
-// For I2S state management.
-static i2s_parallel_state_t *i2s_state = NULL;
-
-// ESP32-S2,S3,C3 only has IS20
-// Original ESP32 has two I2S's, but we'll stick with the lowest common denominator.
-
-#ifdef ESP32_ORIG
-static i2s_dev_t* I2S[I2S_NUM_MAX] = {&I2S0, &I2S1};
-#else
-static i2s_dev_t* I2S[I2S_NUM_MAX] = {&I2S0};
-#endif
-
-callback shiftCompleteCallback;
-void setShiftCompleteCallback(callback f) {
- shiftCompleteCallback = f;
-}
-
-volatile int previousBufferOutputLoopCount = 0;
-volatile bool previousBufferFree = true;
-
-static void IRAM_ATTR irq_hndlr(void* arg) { // if we use I2S1 (default)
-
-//i2s_port_t port = *((i2s_port_t*) arg);
-
-/* Saves a few cycles, no need to cast void ptr to i2s_port_t and then check 120 times second... */
- SET_PERI_REG_BITS(I2S_INT_CLR_REG(ESP32_I2S_DEVICE), I2S_OUT_EOF_INT_CLR_V, 1, I2S_OUT_EOF_INT_CLR_S);
-
- previousBufferFree = true;
-
-/*
- if(shiftCompleteCallback) { // we've defined a callback function ?
- shiftCompleteCallback();
- }
-*/
-
-} // end irq_hndlr
-
-
-// For peripheral setup and configuration
-static inline int get_bus_width(i2s_parallel_cfg_bits_t width) {
- switch(width) {
- case I2S_PARALLEL_WIDTH_8:
- return 8;
- case I2S_PARALLEL_WIDTH_16:
- return 16;
- case I2S_PARALLEL_WIDTH_24:
- return 24;
- default:
- return -ESP_ERR_INVALID_ARG;
- }
-}
-
-static void iomux_set_signal(int gpio, int signal) {
- if(gpio < 0) {
- return;
- }
- PIN_FUNC_SELECT(GPIO_PIN_MUX_REG[gpio], PIN_FUNC_GPIO);
- gpio_set_direction(gpio, GPIO_MODE_DEF_OUTPUT);
- gpio_matrix_out(gpio, signal, false, false);
-
- // More mA the better...
- gpio_set_drive_capability((gpio_num_t)gpio, (gpio_drive_cap_t)3);
-
-}
-
-static void dma_reset(i2s_dev_t* dev) {
- dev->lc_conf.in_rst = 1;
- dev->lc_conf.in_rst = 0;
- dev->lc_conf.out_rst = 1;
- dev->lc_conf.out_rst = 0;
-
- dev->lc_conf.ahbm_rst = 1;
- dev->lc_conf.ahbm_rst = 0;
-
-
-}
-
-static void fifo_reset(i2s_dev_t* dev) {
- dev->conf.rx_fifo_reset = 1;
-
-#ifdef ESP32_SXXX
- while(dev->conf.rx_fifo_reset_st); // esp32-s2 only
-#endif
- dev->conf.rx_fifo_reset = 0;
-
- dev->conf.tx_fifo_reset = 1;
-#ifdef ESP32_SXXX
- while(dev->conf.tx_fifo_reset_st); // esp32-s2 only
-#endif
-
- dev->conf.tx_fifo_reset = 0;
-}
-
-static void dev_reset(i2s_dev_t* dev) {
- fifo_reset(dev);
- dma_reset(dev);
- dev->conf.rx_reset=1;
- dev->conf.tx_reset=1;
- dev->conf.rx_reset=0;
- dev->conf.tx_reset=0;
-}
-
-// DMA Linked List
-// Size must be less than DMA_MAX - need to handle breaking long transfer into two descriptors before call
-// DMA_MAX by the way is the maximum data packet size you can hold in one chunk
-void link_dma_desc(volatile lldesc_t *dmadesc, volatile lldesc_t *prevdmadesc, void *memory, size_t size)
-{
- if(size > DMA_MAX) size = DMA_MAX;
-
- dmadesc->size = size;
- dmadesc->length = size;
- dmadesc->buf = memory;
- dmadesc->eof = 0;
- dmadesc->sosf = 0;
- dmadesc->owner = 1;
- dmadesc->qe.stqe_next = 0; // will need to set this elsewhere
- dmadesc->offset = 0;
-
- // link previous to current
- if(prevdmadesc)
- prevdmadesc->qe.stqe_next = (lldesc_t*)dmadesc;
-}
-
-
-
-esp_err_t i2s_parallel_driver_install(i2s_port_t port, i2s_parallel_config_t* conf) {
-
- //port = I2S_NUM_0; /// override.
-
- if(port < I2S_NUM_0 || port >= I2S_NUM_MAX) {
- return ESP_ERR_INVALID_ARG;
- }
- if(conf->sample_width < I2S_PARALLEL_WIDTH_8 || conf->sample_width >= I2S_PARALLEL_WIDTH_MAX) {
- return ESP_ERR_INVALID_ARG;
- }
- if(conf->sample_rate > I2S_PARALLEL_CLOCK_HZ || conf->sample_rate < 1) {
- return ESP_ERR_INVALID_ARG;
- }
- uint32_t clk_div_main = I2S_PARALLEL_CLOCK_HZ / conf->sample_rate / i2s_parallel_get_memory_width(port, conf->sample_width);
- if(clk_div_main < 2 || clk_div_main > 0xFF) {
- return ESP_ERR_INVALID_ARG;
- }
-
- volatile int iomux_signal_base;
- volatile int iomux_clock;
- int irq_source;
-
- // Initialize I2S0 peripheral
- if (port == I2S_NUM_0) {
- periph_module_reset(PERIPH_I2S0_MODULE);
- periph_module_enable(PERIPH_I2S0_MODULE);
- iomux_clock = I2S0O_WS_OUT_IDX;
- irq_source = ETS_I2S0_INTR_SOURCE;
-
- switch(conf->sample_width) {
- case I2S_PARALLEL_WIDTH_8:
- case I2S_PARALLEL_WIDTH_16:
- iomux_signal_base = I2S0O_DATA_OUT8_IDX;
- break;
- case I2S_PARALLEL_WIDTH_24:
- iomux_signal_base = I2S0O_DATA_OUT0_IDX;
- break;
- case I2S_PARALLEL_WIDTH_MAX:
- return ESP_ERR_INVALID_ARG;
- }
- }
-#ifdef ESP32_ORIG
- // Can't compile if I2S1 if it doesn't exist with that hardware's IDF....
- else {
-// I2S = &I2S1;
-
- periph_module_reset(PERIPH_I2S1_MODULE);
- periph_module_enable(PERIPH_I2S1_MODULE);
- iomux_clock = I2S1O_WS_OUT_IDX;
- irq_source = ETS_I2S1_INTR_SOURCE;
-
- switch(conf->sample_width) {
- case I2S_PARALLEL_WIDTH_16:
- iomux_signal_base = I2S1O_DATA_OUT8_IDX;
- break;
- case I2S_PARALLEL_WIDTH_8:
- case I2S_PARALLEL_WIDTH_24:
- iomux_signal_base = I2S1O_DATA_OUT0_IDX;
- break;
- case I2S_PARALLEL_WIDTH_MAX:
- return ESP_ERR_INVALID_ARG;
- }
- }
-#endif
-
- // Setup GPIOs
- int bus_width = get_bus_width(conf->sample_width);
-
- // Setup I2S peripheral
- i2s_dev_t* dev = I2S[port];
- //dev_reset(dev);
-
-
- // Setup GPIO's
- for(int i = 0; i < bus_width; i++) {
- iomux_set_signal(conf->gpio_bus[i], iomux_signal_base + i);
- }
- iomux_set_signal(conf->gpio_clk, iomux_clock);
-
- // invert clock phase if required
- if (conf->clkphase)
- GPIO.func_out_sel_cfg[conf->gpio_clk].inv_sel = 1;
-
- // Setup i2s clock
- dev->sample_rate_conf.val = 0;
-
- // Third stage config, width of data to be written to IO (I think this should always be the actual data width?)
- dev->sample_rate_conf.rx_bits_mod = bus_width;
- dev->sample_rate_conf.tx_bits_mod = bus_width;
-
- dev->sample_rate_conf.rx_bck_div_num = 2;
- dev->sample_rate_conf.tx_bck_div_num = 2;
-
- // Clock configuration
- dev->clkm_conf.val=0; // Clear the clkm_conf struct
-
-#ifdef ESP32_SXXX
- dev->clkm_conf.clk_sel = 2; // esp32-s2 only
- dev->clkm_conf.clk_en = 1;
-#endif
-
-#ifdef ESP32_ORIG
- dev->clkm_conf.clka_en=0; // Use the 160mhz system clock (PLL_D2_CLK) when '0'
-#endif
-
- dev->clkm_conf.clkm_div_b=0; // Clock numerator
- dev->clkm_conf.clkm_div_a=1; // Clock denominator
-
-
- // Note: clkm_div_num must only be set here AFTER clkm_div_b, clkm_div_a, etc. Or weird things happen!
- // On original ESP32, max I2S DMA parallel speed is 20Mhz.
- dev->clkm_conf.clkm_div_num = clk_div_main;
-
-
- // I2S conf2 reg
- dev->conf2.val = 0;
- dev->conf2.lcd_en = 1;
- dev->conf2.lcd_tx_wrx2_en=0;
- dev->conf2.lcd_tx_sdx2_en=0;
-
- // I2S conf reg
- dev->conf.val = 0;
-
-#ifdef ESP32_SXXX
- dev->conf.tx_dma_equal=1; // esp32-s2 only
- dev->conf.pre_req_en=1; // esp32-s2 only - enable I2S to prepare data earlier? wtf?
-#endif
-
- // Now start setting up DMA FIFO
- dev->fifo_conf.val = 0;
- dev->fifo_conf.rx_data_num = 32; // Thresholds.
- dev->fifo_conf.tx_data_num = 32;
- dev->fifo_conf.dscr_en = 1;
-
-#ifdef ESP32_ORIG
-
- // Enable "One datum will be written twice in LCD mode" - for some reason,
- // if we don't do this in 8-bit mode, data is updated on half-clocks not clocks
- if(conf->sample_width == I2S_PARALLEL_WIDTH_8)
- dev->conf2.lcd_tx_wrx2_en=1;
-
- // Not really described for non-pcm modes, although datasheet states it should be set correctly even for LCD mode
- // First stage config. Configures how data is loaded into fifo
- if(conf->sample_width == I2S_PARALLEL_WIDTH_24) {
- // Mode 0, single 32-bit channel, linear 32 bit load to fifo
- dev->fifo_conf.tx_fifo_mod = 3;
- } else {
- // Mode 1, single 16-bit channel, load 16 bit sample(*) into fifo and pad to 32 bit with zeros
- // *Actually a 32 bit read where two samples are read at once. Length of fifo must thus still be word-aligned
- dev->fifo_conf.tx_fifo_mod = 1;
- }
-
- // Dictated by ESP32 datasheet
- dev->fifo_conf.rx_fifo_mod_force_en = 1;
- dev->fifo_conf.tx_fifo_mod_force_en = 1;
-
- // Second stage config
- dev->conf_chan.val = 0;
-
- // 16-bit single channel data
- dev->conf_chan.tx_chan_mod = 1;
- dev->conf_chan.rx_chan_mod = 1;
-
-#endif
-
-
- // Device Reset
- dev_reset(dev);
- dev->conf1.val = 0;
- dev->conf1.tx_stop_en = 0;
-
- // Allocate I2S status structure for buffer swapping stuff
- i2s_state = (i2s_parallel_state_t*) malloc(sizeof(i2s_parallel_state_t));
- assert(i2s_state != NULL);
- i2s_parallel_state_t *state = i2s_state;
-
- state->desccount_a = conf->desccount_a;
- state->desccount_b = conf->desccount_b;
- state->dmadesc_a = conf->lldesc_a;
- state->dmadesc_b = conf->lldesc_b;
- state->i2s_interrupt_port_arg = port; // need to keep this somewhere in static memory for the ISR
-
- dev->timing.val = 0;
-
- // We using the double buffering switch logic?
- if (conf->int_ena_out_eof)
- {
- // Get ISR setup
- esp_err_t err = esp_intr_alloc(irq_source,
- (int)(ESP_INTR_FLAG_IRAM | ESP_INTR_FLAG_LEVEL1),
- irq_hndlr,
- &state->i2s_interrupt_port_arg, NULL);
-
- if(err) {
- return err;
- }
-
-
- // Setup interrupt handler which is focussed only on the (page 322 of Tech. Ref. Manual)
- // "I2S_OUT_EOF_INT: Triggered when rxlink has finished sending a packet"
- // ... whatever the hell that is supposed to mean... One massive linked list? So all pixels in the chain?
- dev->int_ena.out_eof = 1;
- }
-
- return ESP_OK;
-}
-
- esp_err_t i2s_parallel_stop_dma(i2s_port_t port) {
- if(port < I2S_NUM_0 || port >= I2S_NUM_MAX) {
- return ESP_ERR_INVALID_ARG;
- }
-
- i2s_dev_t* dev = I2S[port];
-
- // Stop all ongoing DMA operations
- dev->out_link.stop = 1;
- dev->out_link.start = 0;
- dev->conf.tx_start = 0;
-
- return ESP_OK;
-}
-
-
- esp_err_t i2s_parallel_send_dma(i2s_port_t port, lldesc_t* dma_descriptor) {
- if(port < I2S_NUM_0 || port >= I2S_NUM_MAX) {
- return ESP_ERR_INVALID_ARG;
- }
-
- i2s_dev_t* dev = I2S[port];
-
-
- // Configure DMA burst mode
- dev->lc_conf.val = I2S_OUT_DATA_BURST_EN | I2S_OUTDSCR_BURST_EN;
-
- // Set address of DMA descriptor
- dev->out_link.addr = (uint32_t) dma_descriptor;
-
- // Start DMA operation
- dev->out_link.stop = 0;
- dev->out_link.start = 1;
-
- dev->conf.tx_start = 1;
-
- return ESP_OK;
-}
-/*
-i2s_dev_t* i2s_parallel_get_dev(i2s_port_t port) {
- if(port < I2S_NUM_0 || port >= I2S_NUM_MAX) {
- return NULL;
- }
-
-#ifdef ESP32_ORIG
-if (port == I2S_NUM_1)
- return &I2S1;
-#endif
-
- return I2S0; // HARCODE THIS TO RETURN &I2S0
-}
-*/
-// Double buffering flipping
-// Flip to a buffer: 0 for bufa, 1 for bufb
-// dmadesc_a and dmadesc_b point to the same memory if double buffering isn't enabled.
-void i2s_parallel_flip_to_buffer(i2s_port_t port, int buffer_id) {
-
- if (i2s_state == NULL) {
- return; // :-()
- }
-
- lldesc_t *active_dma_chain;
- if (buffer_id == 0) {
- active_dma_chain=(lldesc_t*)&i2s_state->dmadesc_a[0];
- } else {
- active_dma_chain=(lldesc_t*)&i2s_state->dmadesc_b[0];
- }
-
- // setup linked list to refresh from new buffer (continuously) when the end of the current list has been reached
- i2s_state->dmadesc_a[i2s_state->desccount_a-1].qe.stqe_next = active_dma_chain;
- i2s_state->dmadesc_b[i2s_state->desccount_b-1].qe.stqe_next = active_dma_chain;
-
- // we're still shifting out the buffer, so it shouldn't be written to yet.
- //previousBufferFree = false;
- i2s_parallel_set_previous_buffer_not_free();
-}
-
-bool i2s_parallel_is_previous_buffer_free() {
- return previousBufferFree;
-}
-
-
-void i2s_parallel_set_previous_buffer_not_free() {
- previousBufferFree = false;
- previousBufferOutputLoopCount = 0;
-}
diff --git a/src/platforms/esp32/esp32_i2s_parallel_dma.cpp b/src/platforms/esp32/esp32_i2s_parallel_dma.cpp
index b7e8401..f9f3c55 100644
--- a/src/platforms/esp32/esp32_i2s_parallel_dma.cpp
+++ b/src/platforms/esp32/esp32_i2s_parallel_dma.cpp
@@ -19,11 +19,12 @@ Modified heavily for the ESP32 HUB75 DMA library by:
[mrfaptastic](https://github.com/mrfaptastic)
/----------------------------------------------------------------------------*/
-
-static const char* TAG = "esp32_i2s_parallel_dma";
-
#include <sdkconfig.h>
-#if defined (CONFIG_IDF_TARGET_ESP32)
+#if defined (CONFIG_IDF_TARGET_ESP32) || defined (CONFIG_IDF_TARGET_ESP32S2)
+
+#if CORE_DEBUG_LEVEL > 0
+ static const char* TAG = "esp32_i2s_parallel_dma";
+#endif
#include "esp32_i2s_parallel_dma.hpp"
@@ -58,7 +59,7 @@ static void IRAM_ATTR irq_hndlr(void* arg) { // if we use I2S1 (default)
volatile int active_dma_buffer_output_count = 0;
- static void IRAM_ATTR irq_hndlr(void* arg) {
+ void IRAM_ATTR irq_hndlr(void* arg) {
// Clear flag so we can get retriggered
SET_PERI_REG_BITS(I2S_INT_CLR_REG(ESP32_I2S_DEVICE), I2S_OUT_EOF_INT_CLR_V, 1, I2S_OUT_EOF_INT_CLR_S);
@@ -78,7 +79,7 @@ static void IRAM_ATTR irq_hndlr(void* arg) { // if we use I2S1 (default)
} // end irq_hndlr
// Static
- static i2s_dev_t* getDev()
+ i2s_dev_t* getDev()
{
#if defined (CONFIG_IDF_TARGET_ESP32S2)
return &I2S0;
@@ -89,7 +90,7 @@ static void IRAM_ATTR irq_hndlr(void* arg) { // if we use I2S1 (default)
}
// Static
- static void _gpio_pin_init(int pin)
+ void _gpio_pin_init(int pin)
{
if (pin >= 0)
{
@@ -104,7 +105,6 @@ static void IRAM_ATTR irq_hndlr(void* arg) { // if we use I2S1 (default)
{
ESP_LOGI(TAG, "Performing config for ESP32 or ESP32-S2");
_cfg = cfg;
- auto port = ESP32_I2S_DEVICE; //cfg.port;
_dev = getDev();
}
@@ -191,42 +191,43 @@ static void IRAM_ATTR irq_hndlr(void* arg) { // if we use I2S1 (default)
////////////////////////////// Clock configuration //////////////////////////////
- //auto freq = (_cfg.freq_write, 50000000u); // ?
auto freq = (_cfg.bus_freq);
-
- uint32_t _clkdiv_write = 0;
size_t _div_num = 10;
// Calculate clock divider for ESP32-S2
#if defined (CONFIG_IDF_TARGET_ESP32S2)
- static constexpr uint32_t pll_160M_clock_d2 = 160 * 1000 * 1000 >> 1;
-
- // I2S_CLKM_DIV_NUM 2=40MHz / 3=27MHz / 4=20MHz / 5=16MHz / 8=10MHz / 10=8MHz
- _div_num = std::min(255u, 1 + ((pll_160M_clock_d2) / (1 + _cfg.freq_write)));
-/*
- _clkdiv_write = I2S_CLK_160M_PLL << I2S_CLK_SEL_S
- | I2S_CLK_EN
- | 1 << I2S_CLKM_DIV_A_S
- | 0 << I2S_CLKM_DIV_B_S
- | _div_num << I2S_CLKM_DIV_NUM_S
- ;
-*/
+ static constexpr uint32_t pll_160M_clock_d2 = 160 * 1000 * 1000 >> 1;
+
+ // I2S_CLKM_DIV_NUM 2=40MHz / 3=27MHz / 4=20MHz / 5=16MHz / 8=10MHz / 10=8MHz
+ _div_num = std::min(255u, 1 + ((pll_160M_clock_d2) / (1 + freq)));
+
+ /*
+ _clkdiv_write = I2S_CLK_160M_PLL << I2S_CLK_SEL_S
+ | I2S_CLK_EN
+ | 1 << I2S_CLKM_DIV_A_S
+ | 0 << I2S_CLKM_DIV_B_S
+ | _div_num << I2S_CLKM_DIV_NUM_S
+ ;
+ */
+
#else
- // clock = 80MHz(PLL_D2_CLK)
- static constexpr uint32_t pll_d2_clock = 80 * 1000 * 1000;
-
- // I2S_CLKM_DIV_NUM 4=20MHz / 5=16MHz / 8=10MHz / 10=8MHz
- _div_num = std::min(255u, std::max(3u, 1 + (pll_d2_clock / (1 + freq))));
-/*
- _clkdiv_write = I2S_CLK_EN
- | 1 << I2S_CLKM_DIV_A_S
- | 0 << I2S_CLKM_DIV_B_S
- | _div_num << I2S_CLKM_DIV_NUM_S
- ;
-*/
+ // clock = 80MHz(PLL_D2_CLK)
+ static constexpr uint32_t pll_d2_clock = 80 * 1000 * 1000;
+
+ // I2S_CLKM_DIV_NUM 4=20MHz / 5=16MHz / 8=10MHz / 10=8MHz
+ _div_num = std::min(255u, std::max(3u, 1 + (pll_d2_clock / (1 + freq))));
+
+ /*
+ _clkdiv_write = I2S_CLK_EN
+ | 1 << I2S_CLKM_DIV_A_S
+ | 0 << I2S_CLKM_DIV_B_S
+ | _div_num << I2S_CLKM_DIV_NUM_S
+ ;
+ */
+
#endif
if(_div_num < 2 || _div_num > 16) {
diff --git a/src/platforms/esp32/esp32_i2s_parallel_dma.h.txt b/src/platforms/esp32/esp32_i2s_parallel_dma.h.txt
deleted file mode 100644
index d7678bc..0000000
--- a/src/platforms/esp32/esp32_i2s_parallel_dma.h.txt
+++ /dev/null
@@ -1,106 +0,0 @@
-#pragma once
-/*
- * ESP32_I2S_PARALLEL_DMA
- */
-
-#pragma once
-
-#if defined(ESP32) || defined(IDF_VER)
-
-#include <stdint.h>
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#include <stdbool.h>
-#include <sys/types.h>
-
-#include <freertos/FreeRTOS.h>
-#include <driver/i2s.h>
-#include <esp_err.h>
-//#include <esp32/rom/lldesc.h>
-//#include <esp32/rom/gpio.h>
-#include <rom/lldesc.h>
-#include <rom/gpio.h>
-
-
-// Get MCU Type and Max CLK Hz for MCU
-#include <esp32_i2s_parallel_mcu_def.h>
-
-typedef enum {
- I2S_PARALLEL_WIDTH_8,
- I2S_PARALLEL_WIDTH_16,
- I2S_PARALLEL_WIDTH_24,
- I2S_PARALLEL_WIDTH_MAX
-} i2s_parallel_cfg_bits_t;
-
-typedef struct {
- int gpio_bus[24]; // The parallel GPIOs to use, set gpio to -1 to disable
- int gpio_clk;
- int sample_rate; // 'clockspeed'
- int sample_width;
- int desccount_a;
- lldesc_t * lldesc_a;
- int desccount_b; // only used with double buffering
- lldesc_t * lldesc_b; // only used with double buffering
- bool clkphase; // Clock signal phase
- bool int_ena_out_eof; // Do we raise an interrupt every time the DMA output loops? Don't do this unless we're doing double buffering!
-} i2s_parallel_config_t;
-
-static inline int i2s_parallel_get_memory_width(i2s_port_t port, i2s_parallel_cfg_bits_t width) {
- switch(width) {
- case I2S_PARALLEL_WIDTH_8:
-
-#ifdef ESP32_ORIG
- // Only I2S1 on the legacy ESP32 WROOM MCU supports space saving single byte 8 bit parallel access
- if(port == I2S_NUM_1) {
- return 1;
- } else {
- return 2;
- }
-#else
- return 1;
-#endif
-
- case I2S_PARALLEL_WIDTH_16:
- return 2;
- case I2S_PARALLEL_WIDTH_24:
- return 4;
- default:
- return -ESP_ERR_INVALID_ARG;
- }
-}
-
-// DMA Linked List Creation
-void link_dma_desc(volatile lldesc_t *dmadesc, volatile lldesc_t *prevdmadesc, void *memory, size_t size);
-
-// I2S DMA Peripheral Setup Functions
-esp_err_t i2s_parallel_driver_install(i2s_port_t port, i2s_parallel_config_t* conf);
-esp_err_t i2s_parallel_send_dma(i2s_port_t port, lldesc_t* dma_descriptor);
-esp_err_t i2s_parallel_stop_dma(i2s_port_t port);
-//i2s_dev_t* i2s_parallel_get_dev(i2s_port_t port);
-
-// For frame buffer flipping / double buffering
-typedef struct {
- volatile lldesc_t *dmadesc_a, *dmadesc_b;
- int desccount_a, desccount_b;
- i2s_port_t i2s_interrupt_port_arg;
-} i2s_parallel_state_t;
-
-void i2s_parallel_flip_to_buffer(i2s_port_t port, int bufid);
-bool i2s_parallel_is_previous_buffer_free();
-void i2s_parallel_set_previous_buffer_not_free();
-
-// Callback function for when whole length of DMA chain has been sent out.
-typedef void (*callback)(void);
-void setShiftCompleteCallback(callback f);
-
-
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif
-
diff --git a/src/platforms/esp32/esp32_i2s_parallel_dma.hpp b/src/platforms/esp32/esp32_i2s_parallel_dma.hpp
index 151558b..0fb68d2 100644
--- a/src/platforms/esp32/esp32_i2s_parallel_dma.hpp
+++ b/src/platforms/esp32/esp32_i2s_parallel_dma.hpp
@@ -56,8 +56,8 @@ Contributors:
//----------------------------------------------------------------------------
-static void IRAM_ATTR irq_hndlr(void* arg);
-static i2s_dev_t* getDev();
+void IRAM_ATTR irq_hndlr(void* arg);
+i2s_dev_t* getDev();
//----------------------------------------------------------------------------
diff --git a/src/platforms/esp32s3/gdma_lcd_parallel16.cpp b/src/platforms/esp32s3/gdma_lcd_parallel16.cpp
index edea630..d72d975 100644
--- a/src/platforms/esp32s3/gdma_lcd_parallel16.cpp
+++ b/src/platforms/esp32s3/gdma_lcd_parallel16.cpp
@@ -22,10 +22,13 @@
#ifdef ARDUINO_ARCH_ESP32
#include <Arduino.h>
#endif
+
#include "gdma_lcd_parallel16.hpp"
#include "esp_attr.h"
+#if CORE_DEBUG_LEVEL > 0
static const char* TAG = "gdma_lcd_parallel16";
+#endif
static int _dmadesc_a_idx = 0;
static int _dmadesc_b_idx = 0;
@@ -37,7 +40,7 @@
uint16_t* dmabuff2;
*/
// End-of-DMA-transfer callback
- static IRAM_ATTR bool dma_callback(gdma_channel_handle_t dma_chan,
+ IRAM_ATTR bool dma_callback(gdma_channel_handle_t dma_chan,
gdma_event_data_t *event_data, void *user_data) {
// This DMA callback seems to trigger a moment before the last data has
// issued (buffering between DMA & LCD peripheral?), so pause a moment
@@ -54,7 +57,7 @@
return true;
}
- static lcd_cam_dev_t* getDev()
+ lcd_cam_dev_t* getDev()
{
return &LCD_CAM;
}
@@ -83,11 +86,7 @@
esp_rom_delay_us(100);
// uint32_t lcd_clkm_div_num = ((160000000 + 1) / _cfg.bus_freq);
- ESP_LOGI(TAG, "Cpu frequecny is %" PRIu16 "", CONFIG_ESP_DEFAULT_CPU_FREQ_MHZ);
-
- uint32_t lcd_clkm_div_num = ( ((CONFIG_ESP_DEFAULT_CPU_FREQ_MHZ*1000000)+1) / _cfg.bus_freq ) / 4;
-
- //ESP_LOGI(TAG, "Clock divider is %d", lcd_clkm_div_num);
+// ESP_LOGI(TAG, "Clock divider is %d", lcd_clkm_div_num);
// Configure LCD clock. Since this program generates human-perceptible
// output and not data for LED matrices or NeoPixels, use almost the
@@ -105,7 +104,7 @@
LCD_CAM.lcd_clock.lcd_clk_equ_sysclk = 0; // PCLK = CLK / (CLKCNT_N+1)
- if (_cfg.psram_clk_hack) // fastest speed I can get PSRAM to work before nothing shows
+ if (_cfg.psram_clk_override) // fastest speed I can get PSRAM to work before nothing shows
{
LCD_CAM.lcd_clock.lcd_clkm_div_num = 4;
}
diff --git a/src/platforms/esp32s3/gdma_lcd_parallel16.hpp b/src/platforms/esp32s3/gdma_lcd_parallel16.hpp
index b5ef76b..3cb94e8 100644
--- a/src/platforms/esp32s3/gdma_lcd_parallel16.hpp
+++ b/src/platforms/esp32s3/gdma_lcd_parallel16.hpp
@@ -106,7 +106,7 @@
int8_t pin_rd = -1;
int8_t pin_rs = -1; // D/C
bool invert_pclk = false;
- bool psram_clk_hack = false;
+ bool psram_clk_override = false;
union
{
int8_t pin_data[16];
diff --git a/src/platforms/platform_detect.hpp b/src/platforms/platform_detect.hpp
index 3ae7f86..8a0982a 100644
--- a/src/platforms/platform_detect.hpp
+++ b/src/platforms/platform_detect.hpp
@@ -29,7 +29,7 @@ Modified heavily for the ESP32 HUB75 DMA library by:
#elif defined (CONFIG_IDF_TARGET_ESP32S2)
#pragma message "Compiling for ESP32-S2"
- #include "esp32/esp32_i2s_parallel_dma.hpp"
+ #include "esp32/esp32_i2s_parallel_dma.hpp"
#include "esp32s2/esp32s2-default-pins.hpp"
@@ -55,7 +55,7 @@ Modified heavily for the ESP32 HUB75 DMA library by:
// Assume an ESP32 (the original 2015 version)
// Same include as ESP32S3
- #pragma message "Compiling for original ESP32 (2015 release)"
+ #pragma message "Compiling for original ESP32 (released 2016)"
#define ESP32_THE_ORIG 1
//#include "esp32/esp32_i2s_parallel_dma.hpp"
//#include "esp32/esp32_i2s_parallel_dma.h"