xref: /aosp_15_r20/system/core/debuggerd/protocol.h (revision 00c7fec1bb09f3284aad6a6f96d2f63dfc3650ad)
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