diff options
| author | Chris Lattner <sabre@nondot.org> | 2007-10-12 17:49:52 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2007-10-12 17:49:52 +0000 |
| commit | 4c461477bde048320b1cd1ac695af3dada09cc6b (patch) | |
| tree | 4a33cb414eb39120a4c955ffed628a007f39ff93 | |
| parent | 431ef632cbac174076d4c07fef6162eac5eacc14 (diff) | |
| download | bcm5719-llvm-4c461477bde048320b1cd1ac695af3dada09cc6b.tar.gz bcm5719-llvm-4c461477bde048320b1cd1ac695af3dada09cc6b.zip | |
Make this compute the correct offset, handling alignment of the element
pointer correctly.
llvm-svn: 42918
| -rw-r--r-- | llvm/include/llvm/ADT/StringMap.h | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/llvm/include/llvm/ADT/StringMap.h b/llvm/include/llvm/ADT/StringMap.h index fecd61ead1b..7f8657e5609 100644 --- a/llvm/include/llvm/ADT/StringMap.h +++ b/llvm/include/llvm/ADT/StringMap.h @@ -171,8 +171,9 @@ public: /// GetStringMapEntryFromValue - Given a value that is known to be embedded /// into a StringMapEntry, return the StringMapEntry itself. static StringMapEntry &GetStringMapEntryFromValue(ValueTy &V) { - return *reinterpret_cast<StringMapEntry*>(reinterpret_cast<char*>(&V) - - sizeof(StringMapEntryBase)); + StringMapEntry *EPtr = 0; + char *Ptr = reinterpret_cast<char*>(&V) - (intptr_t)&EPtr->Val; + return *reinterpret_cast<StringMapEntry*>(Ptr); } static const StringMapEntry &GetStringMapEntryFromValue(const ValueTy &V) { return GetStringMapEntryFromValue(const_cast<ValueTy&>(V)); |

