mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-16 14:31:59 +00:00
Fix Alias Bug
Use memcpy to do type punning instead of a cast. A cast or similar operation through a union breaks strict aliasing rules. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@172081 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c560bf638b
commit
5e1b31bf55
@ -783,10 +783,18 @@ namespace yaml {
|
|||||||
static void mapping(IO &io, KindAndFlags& kf) {
|
static void mapping(IO &io, KindAndFlags& kf) {
|
||||||
io.mapRequired("kind", kf.kind);
|
io.mapRequired("kind", kf.kind);
|
||||||
// type of flags field varies depending on kind field
|
// type of flags field varies depending on kind field
|
||||||
if ( kf.kind == kindA )
|
|
||||||
io.mapRequired("flags", *((AFlags*)&kf.flags));
|
// Use memcpy here to avoid breaking strict aliasing rules.
|
||||||
else
|
if ( kf.kind == kindA ) {
|
||||||
io.mapRequired("flags", *((BFlags*)&kf.flags));
|
AFlags aflags;
|
||||||
|
memcpy(&aflags, &kf.flags, sizeof(aflags));
|
||||||
|
io.mapRequired("flags", aflags);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
BFlags bflags;
|
||||||
|
memcpy(&bflags, &kf.flags, sizeof(bflags));
|
||||||
|
io.mapRequired("flags", bflags);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user