mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2024-11-14 21:37:52 -07:00
MMU: Get rid of type punning in FP read/write functions
The previous code is actually considered undefined behavior.
This commit is contained in:
parent
74290e873a
commit
e8b5e38d98
@ -2,6 +2,8 @@
|
||||
// Licensed under GPLv2+
|
||||
// Refer to the license.txt file included.
|
||||
|
||||
#include <cstring>
|
||||
|
||||
#include "Common/Atomic.h"
|
||||
#include "Common/BitSet.h"
|
||||
#include "Common/CommonTypes.h"
|
||||
@ -470,24 +472,22 @@ u64 Read_U64(const u32 address)
|
||||
|
||||
double Read_F64(const u32 address)
|
||||
{
|
||||
union {
|
||||
u64 i;
|
||||
double d;
|
||||
} cvt;
|
||||
const u64 integral = Read_U64(address);
|
||||
|
||||
cvt.i = Read_U64(address);
|
||||
return cvt.d;
|
||||
double real;
|
||||
std::memcpy(&real, &integral, sizeof(double));
|
||||
|
||||
return real;
|
||||
}
|
||||
|
||||
float Read_F32(const u32 address)
|
||||
{
|
||||
union {
|
||||
u32 i;
|
||||
float d;
|
||||
} cvt;
|
||||
const u32 integral = Read_U32(address);
|
||||
|
||||
cvt.i = Read_U32(address);
|
||||
return cvt.d;
|
||||
float real;
|
||||
std::memcpy(&real, &integral, sizeof(float));
|
||||
|
||||
return real;
|
||||
}
|
||||
|
||||
u32 Read_U8_ZX(const u32 address)
|
||||
@ -541,12 +541,10 @@ void Write_U64_Swap(const u64 var, const u32 address)
|
||||
|
||||
void Write_F64(const double var, const u32 address)
|
||||
{
|
||||
union {
|
||||
u64 i;
|
||||
double d;
|
||||
} cvt;
|
||||
cvt.d = var;
|
||||
Write_U64(cvt.i, address);
|
||||
u64 integral;
|
||||
std::memcpy(&integral, &var, sizeof(u64));
|
||||
|
||||
Write_U64(integral, address);
|
||||
}
|
||||
|
||||
u8 HostRead_U8(const u32 address)
|
||||
|
Loading…
Reference in New Issue
Block a user