diff options
author | Elliott Hughes <enh@google.com> | 2014-07-15 11:38:47 -0700 |
---|---|---|
committer | Elliott Hughes <enh@google.com> | 2014-07-15 11:38:47 -0700 |
commit | 3ecc42106ea4cf825a57859cfd58442442685d24 (patch) | |
tree | e6674af84639ce745006f4db2a9740bb8fba65fd /debuggerd | |
parent | c8a37913422503e166dbe8b4ff4d2efd20a1fbe6 (diff) | |
download | core-3ecc42106ea4cf825a57859cfd58442442685d24.tar.gz core-3ecc42106ea4cf825a57859cfd58442442685d24.tar.bz2 core-3ecc42106ea4cf825a57859cfd58442442685d24.zip |
Add SIGFPE to crasher.
Bug: 3399996
Change-Id: I115caf846a47f57984c1b1844104e37d29e6f24e
Diffstat (limited to 'debuggerd')
-rw-r--r-- | debuggerd/crasher.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/debuggerd/crasher.c b/debuggerd/crasher.c index 9df3c6464..d315ee53f 100644 --- a/debuggerd/crasher.c +++ b/debuggerd/crasher.c @@ -141,11 +141,14 @@ static int do_action(const char* arg) } else if (!strcmp(arg, "assert")) { __assert("some_file.c", 123, "false"); } else if (!strcmp(arg, "assert2")) { - __assert2("some_file.c", 123, "some_function", "false"); + __assert2("some_file.c", 123, "some_function", "false"); } else if (!strcmp(arg, "LOG_ALWAYS_FATAL")) { LOG_ALWAYS_FATAL("hello %s", "world"); } else if (!strcmp(arg, "LOG_ALWAYS_FATAL_IF")) { LOG_ALWAYS_FATAL_IF(true, "hello %s", "world"); + } else if (!strcmp(arg, "SIGFPE")) { + raise(SIGFPE); + return EXIT_SUCCESS; } else if (!strcmp(arg, "SIGPIPE")) { int pipe_fds[2]; pipe(pipe_fds); @@ -177,6 +180,7 @@ static int do_action(const char* arg) fprintf(stderr, " assert2 call assert() with a function\n"); fprintf(stderr, " LOG_ALWAYS_FATAL call LOG_ALWAYS_FATAL\n"); fprintf(stderr, " LOG_ALWAYS_FATAL_IF call LOG_ALWAYS_FATAL\n"); + fprintf(stderr, " SIGFPE cause a SIGFPE\n"); fprintf(stderr, " SIGPIPE cause a SIGPIPE\n"); fprintf(stderr, " SIGSEGV cause a SIGSEGV at address 0x0 (synonym: crash)\n"); fprintf(stderr, " SIGSEGV-non-null cause a SIGSEGV at a non-zero address\n"); |