Skip to content

Commit

Permalink
android: implement fatal_error() via async_safe_fatal()
Browse files Browse the repository at this point in the history
async_safe_fatal() performs the following steps:
- logs the error message to stderr and logcat
- passes error message to debuggerd via android_set_abort_message(). debuggerd then saves the error
message in the crash report file ("tombstone")
- calls abort()
  • Loading branch information
muhomorr authored and thestinger committed Sep 28, 2023
1 parent 903cba5 commit 8d5c631
Showing 1 changed file with 6 additions and 3 deletions.
9 changes: 6 additions & 3 deletions util.c
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@

#include "util.h"

#ifndef __ANDROID__
static int write_full(int fd, const char *buf, size_t length) {
do {
ssize_t bytes_written = write(fd, buf, length);
Expand All @@ -25,14 +26,16 @@ static int write_full(int fd, const char *buf, size_t length) {

return 0;
}
#endif

COLD noreturn void fatal_error(const char *s) {
#ifdef __ANDROID__
async_safe_fatal("hardened_malloc: fatal allocator error: %s", s);
#else
const char *prefix = "fatal allocator error: ";
(void)(write_full(STDERR_FILENO, prefix, strlen(prefix)) != -1 &&
write_full(STDERR_FILENO, s, strlen(s)) != -1 &&
write_full(STDERR_FILENO, "\n", 1));
#ifdef __ANDROID__
async_safe_format_log(ANDROID_LOG_FATAL, "hardened_malloc", "fatal allocator error: %s", s);
#endif
abort();
#endif
}

0 comments on commit 8d5c631

Please sign in to comment.