1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

cpu/esp*: Fix cast alignment issues

- Add `WORD_ALIGNED` attribute to potentially unaligned allocations
- Use intermediate cast to `uintptr_t` to silence false positives of
  `-Wcast-align`
This commit is contained in:
Marian Buschsieweke 2020-11-18 10:19:23 +01:00
parent 1f7fdbc97a
commit 921bc7f6e0
No known key found for this signature in database
GPG Key ID: 61F64C6599B1539F
3 changed files with 23 additions and 11 deletions

View File

@ -6,3 +6,6 @@ ifneq (, $(filter esp_gdbstub, $(USEMODULE)))
endif endif
include $(RIOTBASE)/Makefile.base include $(RIOTBASE)/Makefile.base
# vendor code contains casts that increase alignment requirements. Let's hope
# those are false positives.
CFLAGS += -Wno-cast-align

View File

@ -25,6 +25,7 @@
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
#include "architecture.h"
#include "board.h" #include "board.h"
#include "esp_common.h" #include "esp_common.h"
#include "irq_arch.h" #include "irq_arch.h"
@ -134,10 +135,12 @@ void spi_flash_drive_init (void)
/* read in partition table an determine the top of all partitions */ /* read in partition table an determine the top of all partitions */
uint32_t part_addr = ESP_PART_TABLE_ADDR; uint32_t part_addr = ESP_PART_TABLE_ADDR;
uint8_t part_buf[ESP_PART_ENTRY_SIZE]; uint8_t WORD_ALIGNED part_buf[ESP_PART_ENTRY_SIZE];
bool part_read = true; bool part_read = true;
uint32_t part_top = 0; uint32_t part_top = 0;
esp_partition_info_t* part = (esp_partition_info_t*)part_buf; /* Use intermediate cast to uintptr_t to silence false positive of
* -Wcast-align. We aligned part_buf to word size via attribute */
esp_partition_info_t* part = (esp_partition_info_t*)(uintptr_t)part_buf;
while (part_read && part_addr < ESP_PART_TABLE_ADDR + ESP_PART_TABLE_SIZE) { while (part_read && part_addr < ESP_PART_TABLE_ADDR + ESP_PART_TABLE_SIZE) {
spi_flash_read (part_addr, (void*)part_buf, ESP_PART_ENTRY_SIZE); spi_flash_read (part_addr, (void*)part_buf, ESP_PART_ENTRY_SIZE);
@ -436,10 +439,12 @@ const esp_partition_t* esp_partition_find_first(esp_partition_type_t type,
const char* label) const char* label)
{ {
uint32_t info_addr = ESP_PART_TABLE_ADDR; uint32_t info_addr = ESP_PART_TABLE_ADDR;
uint8_t info_buf[ESP_PART_ENTRY_SIZE]; uint8_t WORD_ALIGNED info_buf[ESP_PART_ENTRY_SIZE];
bool info_read = true; bool info_read = true;
esp_partition_info_t* info = (esp_partition_info_t*)info_buf; /* use intermediate cast to uintptr_t to silence false positive of
* -Wcast-align. We used an attribute to align info_buf to word boundary */
esp_partition_info_t* info = (esp_partition_info_t*)(uintptr_t)info_buf;
esp_partition_t* part; esp_partition_t* part;
while (info_read && info_addr < ESP_PART_TABLE_ADDR + ESP_PART_TABLE_SIZE) { while (info_read && info_addr < ESP_PART_TABLE_ADDR + ESP_PART_TABLE_SIZE) {

View File

@ -142,12 +142,12 @@ char* thread_stack_init(thread_task_func_t task_func, void *arg, void *stack_sta
uint8_t *top_of_stack; uint8_t *top_of_stack;
uint8_t *sp; uint8_t *sp;
top_of_stack = (uint8_t*)((uint32_t)stack_start + stack_size - 1); top_of_stack = (uint8_t*)((uintptr_t)stack_start + stack_size - 1);
/* BEGIN - code from FreeRTOS port for Xtensa from Cadence */ /* BEGIN - code from FreeRTOS port for Xtensa from Cadence */
/* Create interrupt stack frame aligned to 16 byte boundary */ /* Create interrupt stack frame aligned to 16 byte boundary */
sp = (uint8_t*)(((uint32_t)(top_of_stack + 1) - XT_STK_FRMSZ - XT_CP_SIZE) & ~0xf); sp = (uint8_t*)(((uintptr_t)(top_of_stack + 1) - XT_STK_FRMSZ - XT_CP_SIZE) & ~0xf);
/* Clear whole stack with a known value to assist debugging */ /* Clear whole stack with a known value to assist debugging */
#if !defined(DEVELHELP) && !defined(SCHED_TEST_STACK) #if !defined(DEVELHELP) && !defined(SCHED_TEST_STACK)
@ -160,7 +160,9 @@ char* thread_stack_init(thread_task_func_t task_func, void *arg, void *stack_sta
/* ensure that stack is big enough */ /* ensure that stack is big enough */
assert (sp > (uint8_t*)stack_start); assert (sp > (uint8_t*)stack_start);
XtExcFrame* exc_frame = (XtExcFrame*)sp; /* sp is aligned to 16 byte boundary, so cast is safe here. Use an
* intermediate cast to uintptr_t to silence -Wcast-align false positive */
XtExcFrame* exc_frame = (XtExcFrame*)(uintptr_t)sp;
/* Explicitly initialize certain saved registers for call0 ABI */ /* Explicitly initialize certain saved registers for call0 ABI */
exc_frame->pc = (uint32_t)task_func; /* task entry point */ exc_frame->pc = (uint32_t)task_func; /* task entry point */
@ -344,9 +346,11 @@ void thread_isr_stack_init(void)
register uint32_t *sp __asm__ ("a1"); register uint32_t *sp __asm__ ("a1");
#endif /* MCU_ESP32 */ #endif /* MCU_ESP32 */
/* assign each int of the stack the value of it's address */ /* assign each int of the stack the value of it's address. We can safely
uintptr_t *stackmax = (uintptr_t *)sp; * cast, as stack is aligned. Use an intermediate cast to uintptr_t to
uintptr_t *stackp = (uintptr_t *)&port_IntStack; * silence -Wcast-align false positive */
uintptr_t *stackmax = (uintptr_t *)(uintptr_t)sp;
uintptr_t *stackp = (uintptr_t *)(uintptr_t)&port_IntStack;
while (stackp < stackmax) { while (stackp < stackmax) {
*stackp = (uintptr_t) stackp; *stackp = (uintptr_t) stackp;