From c4186bd5f0ad967b3a1fed5455f985003f2270af Mon Sep 17 00:00:00 2001 From: Bananymous Date: Thu, 14 Dec 2023 23:40:08 +0200 Subject: [PATCH] LibC: Compile with -O2 optimizations I have no idea why libc had no optimizations enabled. Weird thing is that memcpy optimized to infinite loop if I kept the __restrict__ attributes in pointers. I don't think there was any ub. --- libc/CMakeLists.txt | 2 +- libc/string.cpp | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/libc/CMakeLists.txt b/libc/CMakeLists.txt index e50897e897..c7e3a21d5a 100644 --- a/libc/CMakeLists.txt +++ b/libc/CMakeLists.txt @@ -47,7 +47,7 @@ add_custom_target(crtx-install add_library(libc ${LIBC_SOURCES}) add_dependencies(libc headers crtx-install) -target_compile_options(libc PRIVATE -g -Wstack-usage=512) +target_compile_options(libc PRIVATE -O2 -g -Wstack-usage=512) target_compile_options(libc PUBLIC -Wall -Wextra -Werror -Wno-error=stack-usage=) add_custom_target(libc-install diff --git a/libc/string.cpp b/libc/string.cpp index f27fa29edd..49f60c1a46 100644 --- a/libc/string.cpp +++ b/libc/string.cpp @@ -17,7 +17,7 @@ int memcmp(const void* s1, const void* s2, size_t n) return 0; } -void* memcpy(void* __restrict__ dstp, const void* __restrict__ srcp, size_t n) +void* memcpy(void* dstp, const void* srcp, size_t n) { unsigned char* dst = static_cast(dstp); const unsigned char* src = static_cast(srcp);