From af83cd60e1c1bac89eba08936611bb425a73a386 Mon Sep 17 00:00:00 2001 From: Alexey Lapshin Date: Thu, 19 Jan 2023 00:04:06 +0700 Subject: [PATCH 1/2] Revert "sdio_slave: workaround the sdio_slave crash issue with release config + GCC11" This reverts commit 19add3fb052922edcdeacf56a8c6845cfe8aa00f. --- components/hal/sdio_slave_hal.c | 9 ++------- 1 file changed, 2 insertions(+), 7 deletions(-) diff --git a/components/hal/sdio_slave_hal.c b/components/hal/sdio_slave_hal.c index f7a9206a867b..166e0361ee4f 100644 --- a/components/hal/sdio_slave_hal.c +++ b/components/hal/sdio_slave_hal.c @@ -40,7 +40,7 @@ typedef enum { } sdio_ringbuf_pointer_t; static esp_err_t sdio_ringbuf_send(sdio_ringbuf_t *buf, esp_err_t (*copy_callback)(uint8_t *, void *), void *arg); -esp_err_t sdio_ringbuf_recv(sdio_ringbuf_t *buf, uint8_t **start, uint8_t **end, ringbuf_get_all_t get_all); +static inline esp_err_t sdio_ringbuf_recv(sdio_ringbuf_t *buf, uint8_t **start, uint8_t **end, ringbuf_get_all_t get_all); static inline int sdio_ringbuf_return(sdio_ringbuf_t* buf, uint8_t *ptr); #define _SEND_DESC_NEXT(x) STAILQ_NEXT(&((sdio_slave_hal_send_desc_t*)x)->dma_desc, qe) @@ -95,12 +95,7 @@ static esp_err_t sdio_ringbuf_send(sdio_ringbuf_t *buf, esp_err_t (*copy_callbac // this ringbuf is a return-before-recv-again strategy // since this is designed to be called in the ISR, no parallel logic -/* - * Workaround for gcc 11. GCC-277. Break the inferring of callers. - * This function used to be static inline. - */ -__attribute__((weak)) -esp_err_t sdio_ringbuf_recv(sdio_ringbuf_t *buf, uint8_t **start, uint8_t **end, ringbuf_get_all_t get_all) +static inline esp_err_t sdio_ringbuf_recv(sdio_ringbuf_t *buf, uint8_t **start, uint8_t **end, ringbuf_get_all_t get_all) { HAL_ASSERT(buf->free_ptr == buf->read_ptr); //must return before recv again if (start == NULL && end == NULL) return ESP_ERR_INVALID_ARG; // must have a output From 0f97a2489234c3b62ea081997008e68099035425 Mon Sep 17 00:00:00 2001 From: Alexey Lapshin Date: Thu, 19 Jan 2023 00:24:40 +0700 Subject: [PATCH 2/2] sdio_slave: fix strict aliasing violation for sdio_ringbuf_recv() This happened because of passing sdio_slave_hal_send_desc_t** to function sdio_ringbuf_recv() which is declared to have char** as input parameter --- components/hal/sdio_slave_hal.c | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/components/hal/sdio_slave_hal.c b/components/hal/sdio_slave_hal.c index 166e0361ee4f..34c08d31bc32 100644 --- a/components/hal/sdio_slave_hal.c +++ b/components/hal/sdio_slave_hal.c @@ -40,7 +40,7 @@ typedef enum { } sdio_ringbuf_pointer_t; static esp_err_t sdio_ringbuf_send(sdio_ringbuf_t *buf, esp_err_t (*copy_callback)(uint8_t *, void *), void *arg); -static inline esp_err_t sdio_ringbuf_recv(sdio_ringbuf_t *buf, uint8_t **start, uint8_t **end, ringbuf_get_all_t get_all); +static inline esp_err_t sdio_ringbuf_recv(sdio_ringbuf_t *buf, sdio_slave_hal_send_desc_t **start, sdio_slave_hal_send_desc_t **end, ringbuf_get_all_t get_all); static inline int sdio_ringbuf_return(sdio_ringbuf_t* buf, uint8_t *ptr); #define _SEND_DESC_NEXT(x) STAILQ_NEXT(&((sdio_slave_hal_send_desc_t*)x)->dma_desc, qe) @@ -95,7 +95,7 @@ static esp_err_t sdio_ringbuf_send(sdio_ringbuf_t *buf, esp_err_t (*copy_callbac // this ringbuf is a return-before-recv-again strategy // since this is designed to be called in the ISR, no parallel logic -static inline esp_err_t sdio_ringbuf_recv(sdio_ringbuf_t *buf, uint8_t **start, uint8_t **end, ringbuf_get_all_t get_all) +static inline esp_err_t sdio_ringbuf_recv(sdio_ringbuf_t *buf, sdio_slave_hal_send_desc_t **start, sdio_slave_hal_send_desc_t **end, ringbuf_get_all_t get_all) { HAL_ASSERT(buf->free_ptr == buf->read_ptr); //must return before recv again if (start == NULL && end == NULL) return ESP_ERR_INVALID_ARG; // must have a output @@ -110,10 +110,10 @@ static inline esp_err_t sdio_ringbuf_recv(sdio_ringbuf_t *buf, uint8_t **start, } if (start != NULL) { - *start = get_start; + *start = (sdio_slave_hal_send_desc_t *) get_start; } if (end != NULL) { - *end = buf->read_ptr; + *end = (sdio_slave_hal_send_desc_t *) buf->read_ptr; } return ESP_OK; } @@ -188,7 +188,7 @@ static esp_err_t init_send_queue(sdio_slave_context_t *hal) //loop in the ringbuf to link all the desc one after another as a ring for (int i = 0; i < hal->send_queue_size + 1; i++) { - rcv_res = sdio_ringbuf_recv(buf, (uint8_t **) &last, NULL, RINGBUF_GET_ONE); + rcv_res = sdio_ringbuf_recv(buf, &last, NULL, RINGBUF_GET_ONE); assert (rcv_res == ESP_OK); ret = sdio_ringbuf_send(buf, link_desc_to_last, last); @@ -200,7 +200,7 @@ static esp_err_t init_send_queue(sdio_slave_context_t *hal) first = NULL; last = NULL; //clear the queue - rcv_res = sdio_ringbuf_recv(buf, (uint8_t **) &first, (uint8_t **) &last, RINGBUF_GET_ALL); + rcv_res = sdio_ringbuf_recv(buf, &first, &last, RINGBUF_GET_ALL); assert (rcv_res == ESP_OK); HAL_ASSERT(first == last); //there should be only one desc remain sdio_ringbuf_return(buf, (uint8_t *) first); @@ -331,9 +331,9 @@ static esp_err_t send_check_new_packet(sdio_slave_context_t *hal) sdio_slave_hal_send_desc_t *start = NULL; sdio_slave_hal_send_desc_t *end = NULL; if (hal->sending_mode == SDIO_SLAVE_SEND_PACKET) { - ret = sdio_ringbuf_recv(&(hal->send_desc_queue), (uint8_t **) &start, (uint8_t **) &end, RINGBUF_GET_ONE); + ret = sdio_ringbuf_recv(&(hal->send_desc_queue), &start, &end, RINGBUF_GET_ONE); } else { //stream mode - ret = sdio_ringbuf_recv(&(hal->send_desc_queue), (uint8_t **) &start, (uint8_t **) &end, RINGBUF_GET_ALL); + ret = sdio_ringbuf_recv(&(hal->send_desc_queue), &start, &end, RINGBUF_GET_ALL); } if (ret == ESP_OK) { hal->in_flight_head = start; @@ -424,7 +424,7 @@ static esp_err_t send_get_unsent_desc(sdio_slave_context_t *hal, void **out_arg, esp_err_t ret; sdio_slave_hal_send_desc_t *head = NULL; sdio_slave_hal_send_desc_t *tail = NULL; - ret = sdio_ringbuf_recv(&(hal->send_desc_queue), (uint8_t **) &head, (uint8_t **) &tail, RINGBUF_GET_ONE); + ret = sdio_ringbuf_recv(&(hal->send_desc_queue), &head, &tail, RINGBUF_GET_ONE); if (ret == ESP_OK) { //currently each packet takes only one desc.