ARM64: Enable implicit suspend checks and madvise()...

... away the alternate signal stack in the entrypoint.

Also fix 706-checker-scheduler to check the correct LDR.
During development of implicit suspend checks, the LDR
was emitted in the loop header but the final version
emits it at the back edge.

Also make `GenerateSuspendCheck()` consistently emit
the branch to `successor` if not null.

Test: run-gtests.sh
Test: testrunner.py --target --64 --optimizing
Bug: 38383823
Bug: 209235730
Change-Id: Ie3e2513d1b22522219f0f8a4ab8bcfd8921e8cdf
diff --git a/runtime/thread_android.cc b/runtime/thread_android.cc
index f333400..fadfc09 100644
--- a/runtime/thread_android.cc
+++ b/runtime/thread_android.cc
@@ -14,6 +14,9 @@
  * limitations under the License.
  */
 
+#include <signal.h>
+#include <sys/mman.h>
+
 #include "thread.h"
 
 namespace art {
@@ -26,4 +29,12 @@
   // Bionic does this for us.
 }
 
+void Thread::MadviseAwayAlternateSignalStack() {
+  stack_t old_ss;
+  int result = sigaltstack(nullptr, &old_ss);
+  CHECK_EQ(result, 0);
+  result = madvise(old_ss.ss_sp, old_ss.ss_size, MADV_FREE);
+  CHECK_EQ(result, 0);
+}
+
 }  // namespace art