]> git.eshelyaron.com Git - emacs.git/commitdiff
Disable exec loader when Emacs is running under an existing instance
authorPo Lu <luangruo@yahoo.com>
Mon, 12 Feb 2024 03:16:47 +0000 (11:16 +0800)
committerEshel Yaron <me@eshelyaron.com>
Mon, 12 Feb 2024 07:03:10 +0000 (08:03 +0100)
* src/androidfns.c (syms_of_androidfns_for_pdumper): Check if
Emacs is running under process tracing, and if so, disable
android_use_exec_loader.

(cherry picked from commit bc6c55c5cf3fc5bd248232c6332ea7cca19ffe91)

src/androidfns.c

index 48c3f3046d640b209da19ca9fdabe90f3c141389..ea3d5f71c7c0c12818ead1b8ade0063ae8d16858 100644 (file)
@@ -3216,6 +3216,10 @@ syms_of_androidfns_for_pdumper (void)
   jstring string;
   Lisp_Object language, country, script, variant;
   const char *data;
+  FILE *fd;
+  char *line;
+  size_t size;
+  long pid;
 
   /* Find the Locale class.  */
 
@@ -3386,6 +3390,35 @@ syms_of_androidfns_for_pdumper (void)
 
   /* Set Vandroid_os_language.  */
   Vandroid_os_language = list4 (language, country, script, variant);
+
+  /* Detect whether Emacs is running under libloader.so or another
+     process tracing mechanism, and disable `android_use_exec_loader' if
+     so, leaving subprocesses started by Emacs to the care of that
+     loader instance.  */
+
+  if (android_get_current_api_level () >= 29) /* Q */
+    {
+      fd = fopen ("/proc/self/status", "r");
+      if (!fd)
+       return;
+
+      line = NULL;
+      while (getline (&line, &size, fd) != -1)
+       {
+         if (strncmp (line, "TracerPid:", sizeof "TracerPid:" - 1))
+           continue;
+
+         pid = atol (line + sizeof "TracerPid:" - 1);
+
+         if (pid)
+           android_use_exec_loader = false;
+
+         break;
+       }
+
+      free (line);
+      fclose (fd);
+    }
 }
 
 #endif /* ANDROID_STUBIFY */