#ifndef _TASK_CORPSE_H_
#define _TASK_CORPSE_H_
#include <stdint.h>
#include <mach/mach_types.h>
#include <kern/kern_cdata.h>
#include <kern/kcdata.h>
typedef struct kcdata_item *task_crashinfo_item_t;
#define CRASHINFO_ITEM_TYPE(item) KCDATA_ITEM_TYPE(item)
#define CRASHINFO_ITEM_SIZE(item) KCDATA_ITEM_SIZE(item)
#define CRASHINFO_ITEM_DATA_PTR(item) KCDATA_ITEM_DATA_PTR(item)
#define CRASHINFO_ITEM_NEXT_HEADER(item) KCDATA_ITEM_NEXT_HEADER(item)
#define CRASHINFO_ITEM_FOREACH(head) KCDATA_ITEM_FOREACH(head)
#ifndef KERNEL
#define task_crashinfo_get_data_with_desc kcdata_get_data_with_desc
#endif
#ifdef XNU_KERNEL_PRIVATE
#define CORPSEINFO_ALLOCATION_SIZE (1024 * 16)
#define TOTAL_CORPSES_ALLOWED 5
extern kern_return_t task_mark_corpse(task_t task);
extern kern_return_t task_deliver_crash_notification(task_t task, thread_t thread, mach_exception_data_type_t subcode);
extern kcdata_descriptor_t task_get_corpseinfo(task_t task);
#define GET_CORPSE_REF TRUE
#define RELEASE_CORPSE_REF TRUE
extern kcdata_descriptor_t task_crashinfo_alloc_init(
mach_vm_address_t crash_data_p,
unsigned size,
int get_corpseref, unsigned flags);
extern kern_return_t task_crashinfo_destroy(kcdata_descriptor_t data, int release_corpseref);
extern void corpses_init(void);
extern boolean_t corpses_enabled(void);
extern kern_return_t task_generate_corpse_internal(
task_t task,
task_t *corpse_task,
thread_t *thread,
mach_exception_data_type_t code,
mach_exception_data_type_t subcode);
extern void task_clear_corpse(task_t task);
extern kern_return_t task_duplicate_map_and_threads(
task_t task,
void *p,
task_t new_task,
thread_t *thread,
int is64bit,
uint64_t **udata_buffer,
int *size,
int*num_udata);
extern void task_enqueue_exception_with_corpse(
task_t task,
mach_exception_data_t code,
mach_msg_type_number_t codeCnt);
extern void task_add_to_corpse_task_list(task_t corpse_task);
void task_remove_from_corpse_task_list(task_t corpse_task);
void task_purge_all_corpses(void);
#endif
#endif