[lsan] Allow the ignored TLS range to be empty.

git-svn-id: https://llvm.org/svn/llvm-project/compiler-rt/trunk@182657 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/lsan/lsan_common.cc b/lib/lsan/lsan_common.cc
index 815e78b..53a9009 100644
--- a/lib/lsan/lsan_common.cc
+++ b/lib/lsan/lsan_common.cc
@@ -155,15 +155,19 @@
 
     if (flags()->use_tls()) {
       if (flags()->log_threads) Report("TLS at %p-%p.\n", tls_begin, tls_end);
-      // Because LSan should not be loaded with dlopen(), we can assume
-      // that allocator cache will be part of static TLS image.
-      CHECK_LE(tls_begin, cache_begin);
-      CHECK_GE(tls_end, cache_end);
-      if (tls_begin < cache_begin)
-        ScanRangeForPointers(tls_begin, cache_begin, frontier, "TLS",
-                             kReachable);
-      if (tls_end > cache_end)
-        ScanRangeForPointers(cache_end, tls_end, frontier, "TLS", kReachable);
+      if (cache_begin == cache_end) {
+        ScanRangeForPointers(tls_begin, tls_end, frontier, "TLS", kReachable);
+      } else {
+        // Because LSan should not be loaded with dlopen(), we can assume
+        // that allocator cache will be part of static TLS image.
+        CHECK_LE(tls_begin, cache_begin);
+        CHECK_GE(tls_end, cache_end);
+        if (tls_begin < cache_begin)
+          ScanRangeForPointers(tls_begin, cache_begin, frontier, "TLS",
+                               kReachable);
+        if (tls_end > cache_end)
+          ScanRangeForPointers(cache_end, tls_end, frontier, "TLS", kReachable);
+      }
     }
   }
 }