From 827ad327a59c483d29e7de99376eaabceccbc143 Mon Sep 17 00:00:00 2001 From: Scott Shawcroft Date: Wed, 22 Dec 2021 18:21:18 -0800 Subject: [PATCH] Only ignore warnings if in gcc >= 11 --- ports/raspberrypi/common-hal/nvm/ByteArray.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/ports/raspberrypi/common-hal/nvm/ByteArray.c b/ports/raspberrypi/common-hal/nvm/ByteArray.c index 86eb82683bde..cc52c88f3828 100644 --- a/ports/raspberrypi/common-hal/nvm/ByteArray.c +++ b/ports/raspberrypi/common-hal/nvm/ByteArray.c @@ -65,11 +65,13 @@ static void erase_and_write_sector(uint32_t address, uint32_t len, uint8_t *byte // Write a whole sector to flash, buffering it first and then erasing and rewriting it // since we can only erase a whole sector at a time. uint8_t buffer[FLASH_SECTOR_SIZE]; + #pragma GCC diagnostic push + #if __GNUC__ >= 11 // TODO: Update this to a better workaround for GCC 11 when one is provided. // See: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=99578#c20 - #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Warray-bounds" #pragma GCC diagnostic ignored "-Wstringop-overread" + #endif memcpy(buffer, (uint8_t *)CIRCUITPY_INTERNAL_NVM_START_ADDR, FLASH_SECTOR_SIZE); #pragma GCC diagnostic pop memcpy(buffer + address, bytes, len);