1*00c7fec1SAndroid Build Coastguard Worker /* 2*00c7fec1SAndroid Build Coastguard Worker * Copyright 2016, The Android Open Source Project 3*00c7fec1SAndroid Build Coastguard Worker * 4*00c7fec1SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*00c7fec1SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*00c7fec1SAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*00c7fec1SAndroid Build Coastguard Worker * 8*00c7fec1SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*00c7fec1SAndroid Build Coastguard Worker * 10*00c7fec1SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*00c7fec1SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*00c7fec1SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*00c7fec1SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*00c7fec1SAndroid Build Coastguard Worker * limitations under the License. 15*00c7fec1SAndroid Build Coastguard Worker */ 16*00c7fec1SAndroid Build Coastguard Worker 17*00c7fec1SAndroid Build Coastguard Worker #pragma once 18*00c7fec1SAndroid Build Coastguard Worker 19*00c7fec1SAndroid Build Coastguard Worker #include <signal.h> 20*00c7fec1SAndroid Build Coastguard Worker #include <stdint.h> 21*00c7fec1SAndroid Build Coastguard Worker #include <sys/ucontext.h> 22*00c7fec1SAndroid Build Coastguard Worker #include <unistd.h> 23*00c7fec1SAndroid Build Coastguard Worker 24*00c7fec1SAndroid Build Coastguard Worker #include "dump_type.h" 25*00c7fec1SAndroid Build Coastguard Worker 26*00c7fec1SAndroid Build Coastguard Worker // Sockets in the ANDROID_SOCKET_NAMESPACE_RESERVED namespace. 27*00c7fec1SAndroid Build Coastguard Worker // Both sockets are SOCK_SEQPACKET sockets, so no explicit length field is needed. 28*00c7fec1SAndroid Build Coastguard Worker constexpr char kTombstonedCrashSocketName[] = "tombstoned_crash"; 29*00c7fec1SAndroid Build Coastguard Worker constexpr char kTombstonedJavaTraceSocketName[] = "tombstoned_java_trace"; 30*00c7fec1SAndroid Build Coastguard Worker constexpr char kTombstonedInterceptSocketName[] = "tombstoned_intercept"; 31*00c7fec1SAndroid Build Coastguard Worker 32*00c7fec1SAndroid Build Coastguard Worker enum class CrashPacketType : uint8_t { 33*00c7fec1SAndroid Build Coastguard Worker // Initial request from crash_dump. 34*00c7fec1SAndroid Build Coastguard Worker kDumpRequest = 0, 35*00c7fec1SAndroid Build Coastguard Worker 36*00c7fec1SAndroid Build Coastguard Worker // Notification of a completed crash dump. 37*00c7fec1SAndroid Build Coastguard Worker // Sent after a dump is completed and the process has been untraced, but 38*00c7fec1SAndroid Build Coastguard Worker // before it has been resumed with SIGCONT. 39*00c7fec1SAndroid Build Coastguard Worker kCompletedDump, 40*00c7fec1SAndroid Build Coastguard Worker 41*00c7fec1SAndroid Build Coastguard Worker // Responses to kRequest. 42*00c7fec1SAndroid Build Coastguard Worker // kPerformDump sends along an output fd via cmsg(3). 43*00c7fec1SAndroid Build Coastguard Worker kPerformDump = 128, 44*00c7fec1SAndroid Build Coastguard Worker kAbortDump, 45*00c7fec1SAndroid Build Coastguard Worker }; 46*00c7fec1SAndroid Build Coastguard Worker 47*00c7fec1SAndroid Build Coastguard Worker struct DumpRequest { 48*00c7fec1SAndroid Build Coastguard Worker DebuggerdDumpType dump_type; 49*00c7fec1SAndroid Build Coastguard Worker int32_t pid; 50*00c7fec1SAndroid Build Coastguard Worker }; 51*00c7fec1SAndroid Build Coastguard Worker 52*00c7fec1SAndroid Build Coastguard Worker // The full packet must always be written, regardless of whether the union is used. 53*00c7fec1SAndroid Build Coastguard Worker struct TombstonedCrashPacket { 54*00c7fec1SAndroid Build Coastguard Worker CrashPacketType packet_type; 55*00c7fec1SAndroid Build Coastguard Worker union { 56*00c7fec1SAndroid Build Coastguard Worker DumpRequest dump_request; 57*00c7fec1SAndroid Build Coastguard Worker } packet; 58*00c7fec1SAndroid Build Coastguard Worker }; 59*00c7fec1SAndroid Build Coastguard Worker 60*00c7fec1SAndroid Build Coastguard Worker // Comes with a file descriptor via SCM_RIGHTS. 61*00c7fec1SAndroid Build Coastguard Worker // This packet should be sent before an actual dump happens. 62*00c7fec1SAndroid Build Coastguard Worker struct InterceptRequest { 63*00c7fec1SAndroid Build Coastguard Worker DebuggerdDumpType dump_type; 64*00c7fec1SAndroid Build Coastguard Worker int32_t pid; 65*00c7fec1SAndroid Build Coastguard Worker }; 66*00c7fec1SAndroid Build Coastguard Worker 67*00c7fec1SAndroid Build Coastguard Worker enum class InterceptStatus : uint8_t { 68*00c7fec1SAndroid Build Coastguard Worker // Returned when an intercept of the same type has already been 69*00c7fec1SAndroid Build Coastguard Worker // registered (and is active) for a given PID. 70*00c7fec1SAndroid Build Coastguard Worker kFailedAlreadyRegistered, 71*00c7fec1SAndroid Build Coastguard Worker // Returned in all other failure cases. 72*00c7fec1SAndroid Build Coastguard Worker kFailed, 73*00c7fec1SAndroid Build Coastguard Worker kStarted, 74*00c7fec1SAndroid Build Coastguard Worker kRegistered, 75*00c7fec1SAndroid Build Coastguard Worker }; 76*00c7fec1SAndroid Build Coastguard Worker 77*00c7fec1SAndroid Build Coastguard Worker // Sent either immediately upon failure, or when the intercept has been used. 78*00c7fec1SAndroid Build Coastguard Worker struct InterceptResponse { 79*00c7fec1SAndroid Build Coastguard Worker InterceptStatus status; 80*00c7fec1SAndroid Build Coastguard Worker char error_message[127]; // always null-terminated 81*00c7fec1SAndroid Build Coastguard Worker }; 82*00c7fec1SAndroid Build Coastguard Worker 83*00c7fec1SAndroid Build Coastguard Worker // Sent from handler to crash_dump via pipe. 84*00c7fec1SAndroid Build Coastguard Worker struct __attribute__((__packed__)) CrashInfoHeader { 85*00c7fec1SAndroid Build Coastguard Worker uint32_t version; 86*00c7fec1SAndroid Build Coastguard Worker }; 87*00c7fec1SAndroid Build Coastguard Worker 88*00c7fec1SAndroid Build Coastguard Worker struct __attribute__((__packed__)) CrashInfoDataStatic { 89*00c7fec1SAndroid Build Coastguard Worker siginfo_t siginfo; 90*00c7fec1SAndroid Build Coastguard Worker ucontext_t ucontext; 91*00c7fec1SAndroid Build Coastguard Worker uintptr_t abort_msg_address; 92*00c7fec1SAndroid Build Coastguard Worker }; 93*00c7fec1SAndroid Build Coastguard Worker 94*00c7fec1SAndroid Build Coastguard Worker struct __attribute__((__packed__)) CrashInfoDataDynamic : public CrashInfoDataStatic { 95*00c7fec1SAndroid Build Coastguard Worker uintptr_t fdsan_table_address; 96*00c7fec1SAndroid Build Coastguard Worker uintptr_t gwp_asan_state; 97*00c7fec1SAndroid Build Coastguard Worker uintptr_t gwp_asan_metadata; 98*00c7fec1SAndroid Build Coastguard Worker uintptr_t scudo_stack_depot; 99*00c7fec1SAndroid Build Coastguard Worker uintptr_t scudo_region_info; 100*00c7fec1SAndroid Build Coastguard Worker uintptr_t scudo_ring_buffer; 101*00c7fec1SAndroid Build Coastguard Worker size_t scudo_ring_buffer_size; 102*00c7fec1SAndroid Build Coastguard Worker size_t scudo_stack_depot_size; 103*00c7fec1SAndroid Build Coastguard Worker bool recoverable_crash; 104*00c7fec1SAndroid Build Coastguard Worker uintptr_t crash_detail_page; 105*00c7fec1SAndroid Build Coastguard Worker }; 106*00c7fec1SAndroid Build Coastguard Worker 107*00c7fec1SAndroid Build Coastguard Worker struct __attribute__((__packed__)) CrashInfo { 108*00c7fec1SAndroid Build Coastguard Worker CrashInfoHeader header; 109*00c7fec1SAndroid Build Coastguard Worker union { 110*00c7fec1SAndroid Build Coastguard Worker CrashInfoDataStatic s; 111*00c7fec1SAndroid Build Coastguard Worker CrashInfoDataDynamic d; 112*00c7fec1SAndroid Build Coastguard Worker } data; 113*00c7fec1SAndroid Build Coastguard Worker }; 114