--- ./src/OSspecific/POSIX/signals/sigFpe.C.orig	2021-12-01 03:15:50.000000000 +0100
+++ ./src/OSspecific/POSIX/signals/sigFpe.C	2021-12-01 03:15:50.000000000 +0100
@@ -36,7 +36,7 @@
 
 #include <limits>
 
-#if defined(__linux__) && defined(__GNUC__)
+#if (defined(__linux__) && defined(__GNUC__)) || defined(__ANDROID__)
     #ifndef __USE_GNU
         #define __USE_GNU      // To use feenableexcept()
     #endif
@@ -82,8 +82,11 @@
 #ifdef __linux__
 extern "C"
 {
-    extern void* __libc_malloc(size_t size);
+    extern void* malloc(size_t size);
 
+    // The override below gives segmentation fault in malloc on arm so skip
+    // on android for now.
+    #ifndef __ANDROID__
     // Override the GLIBC malloc to support mallocNan
     void* malloc(size_t size)
     {
@@ -93,16 +96,17 @@
         }
         else
         {
-            return __libc_malloc(size);
+            return malloc(size);
         }
     }
+    #endif
 }
 
 
 void* Foam::sigFpe::mallocNan(size_t size)
 {
     // Call the low-level GLIBC malloc function
-    void* result = __libc_malloc(size);
+    void* result = malloc(size);
 
     // Initialize to signalling NaN
     UList<scalar> list(reinterpret_cast<scalar*>(result), size/sizeof(scalar));
@@ -117,7 +121,7 @@
 
 void Foam::sigFpe::sigHandler(int)
 {
-    #if (defined(__linux__) && defined(__GNUC__)) || defined(__APPLE__)
+    #if (defined(__linux__) && defined(__GNUC__)) || defined(__APPLE__) || defined(__ANDROID__)
 
     resetHandler("SIGFPE", SIGFPE);
 
@@ -125,7 +129,7 @@
     error::printStack(Perr);
     ::raise(SIGFPE);            // Throw signal (to old handler)
 
-    #endif  // (__linux__ && __GNUC__) || __APPLE__
+    #endif  // (__linux__ && __GNUC__) || __APPLE__ || __ANDROID__
 }