From 9ed1a118e62d151f89ec81bddc80a46f4f5be946 Mon Sep 17 00:00:00 2001 From: joevt Date: Wed, 20 Mar 2024 01:38:28 -0700 Subject: [PATCH] ppcmmu: Check sizeof(T) explicitly. I don't know if the compiler is smart enough to figure out that ((guest_va & 0xFFF) + sizeof(T)) > 0x1000) is always false when sizeof(T) == 1 so we'll add a check for sizeof(T) > 1. --- cpu/ppc/ppcmmu.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/cpu/ppc/ppcmmu.cpp b/cpu/ppc/ppcmmu.cpp index f25a756..a7a5aff 100644 --- a/cpu/ppc/ppcmmu.cpp +++ b/cpu/ppc/ppcmmu.cpp @@ -1206,7 +1206,7 @@ static T read_unaligned(uint32_t guest_va, uint8_t *host_va) T result = 0; // is it a misaligned cross-page read? - if (((guest_va & 0xFFF) + sizeof(T)) > 0x1000) { + if ((sizeof(T) > 1) && ((guest_va & 0xFFF) + sizeof(T)) > 0x1000) { #ifdef MMU_PROFILING unaligned_crossp_r++; #endif @@ -1249,7 +1249,7 @@ static void write_unaligned(uint32_t guest_va, uint8_t *host_va, T value) } // is it a misaligned cross-page write? - if (((guest_va & 0xFFF) + sizeof(T)) > 0x1000) { + if ((sizeof(T) > 1) && ((guest_va & 0xFFF) + sizeof(T)) > 0x1000) { #ifdef MMU_PROFILING unaligned_crossp_w++; #endif