diff options
| author | Chris Lattner <sabre@nondot.org> | 2011-08-12 04:31:38 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2011-08-12 04:31:38 +0000 |
| commit | 1ec8114eb82162e8dc25eb3ff020bf0f3bf8b88b (patch) | |
| tree | c1ed855d334bbb20af2c8505d8d767ad1c33cc5f | |
| parent | a2dee81dec16c63bd709411ec6aa695fb3be3e1b (diff) | |
| download | bcm5719-llvm-1ec8114eb82162e8dc25eb3ff020bf0f3bf8b88b.tar.gz bcm5719-llvm-1ec8114eb82162e8dc25eb3ff020bf0f3bf8b88b.zip | |
Fix an obscure bug in PointerUnion that would bite PointerUnion3/4. Basically,
when checking isNull(), we'd pick off the sentinel bit for the outer
PointerUnion, but would not recursively convert the inner pointerunion to bool,
so if *its* sentinel bit is set, isNull() would incorrectly return false.
No testcase, because someone hit this when they were trying to refactor code
to use PointerUnion3, but they since found a better solution.
llvm-svn: 137428
| -rw-r--r-- | llvm/include/llvm/ADT/PointerUnion.h | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/llvm/include/llvm/ADT/PointerUnion.h b/llvm/include/llvm/ADT/PointerUnion.h index 13b98cef07a..487096a1710 100644 --- a/llvm/include/llvm/ADT/PointerUnion.h +++ b/llvm/include/llvm/ADT/PointerUnion.h @@ -108,7 +108,11 @@ namespace llvm { /// isNull - Return true if the pointer held in the union is null, /// regardless of which type it is. - bool isNull() const { return Val.getPointer() == 0; } + bool isNull() const { + // Convert from the void* to one of the pointer types, to make sure that + // we recursively strip off low bits if we have a nested PointerUnion. + return !PointerLikeTypeTraits<PT1>::getFromVoidPointer(Val.getPointer()); + } operator bool() const { return !isNull(); } /// is<T>() return true if the Union currently holds the type matching T. |

