aboutsummaryrefslogtreecommitdiff
path: root/gdb/darwin-nat.h
diff options
context:
space:
mode:
Diffstat (limited to 'gdb/darwin-nat.h')
-rw-r--r--gdb/darwin-nat.h38
1 files changed, 20 insertions, 18 deletions
diff --git a/gdb/darwin-nat.h b/gdb/darwin-nat.h
index 77feb0e..db72698 100644
--- a/gdb/darwin-nat.h
+++ b/gdb/darwin-nat.h
@@ -26,21 +26,20 @@
struct darwin_exception_info
{
/* Exceptions handled by the port. */
- exception_mask_t masks[EXC_TYPES_COUNT];
+ exception_mask_t masks[EXC_TYPES_COUNT] {};
/* Ports receiving exception messages. */
- mach_port_t ports[EXC_TYPES_COUNT];
+ mach_port_t ports[EXC_TYPES_COUNT] {};
/* Type of messages sent. */
- exception_behavior_t behaviors[EXC_TYPES_COUNT];
+ exception_behavior_t behaviors[EXC_TYPES_COUNT] {};
/* Type of state to be sent. */
- thread_state_flavor_t flavors[EXC_TYPES_COUNT];
+ thread_state_flavor_t flavors[EXC_TYPES_COUNT] {};
/* Number of elements set. */
- mach_msg_type_number_t count;
+ mach_msg_type_number_t count = 0;
};
-typedef struct darwin_exception_info darwin_exception_info;
struct darwin_exception_msg
{
@@ -95,36 +94,39 @@ struct private_thread_info
};
typedef struct private_thread_info darwin_thread_t;
-/* Define the threads vector type. */
-DEF_VEC_O (darwin_thread_t);
-
-
/* Describe an inferior. */
-struct private_inferior
+struct darwin_inferior : public private_inferior
{
/* Corresponding task port. */
- task_t task;
+ task_t task = 0;
/* Port which will receive the dead-name notification for the task port.
This is used to detect the death of the task. */
- mach_port_t notify_port;
+ mach_port_t notify_port = 0;
/* Initial exception handling. */
darwin_exception_info exception_info;
/* Number of messages that have been received but not yet replied. */
- unsigned int pending_messages;
+ unsigned int pending_messages = 0;
/* Set if inferior is not controlled by ptrace(2) but through Mach. */
- unsigned char no_ptrace;
+ bool no_ptrace = false;
/* True if this task is suspended. */
- unsigned char suspended;
+ bool suspended = false;
/* Sorted vector of known threads. */
- VEC(darwin_thread_t) *threads;
+ std::vector<darwin_thread_t *> threads;
};
-typedef struct private_inferior darwin_inferior;
+
+/* Return the darwin_inferior attached to INF. */
+
+static inline darwin_inferior *
+get_darwin_inferior (inferior *inf)
+{
+ return static_cast<darwin_inferior *> (inf->priv.get ());
+}
/* Exception port. */
extern mach_port_t darwin_ex_port;