/* Routine mach_exception_raise_state */ mig_external kern_return_t mach_exception_raise_state ( mach_port_t exception_port, exception_type_t exception, const mach_exception_data_t code, mach_msg_type_number_t codeCnt, int *flavor, const thread_state_t old_state, mach_msg_type_number_t old_stateCnt, thread_state_t new_state, mach_msg_type_number_t *new_stateCnt ) { #ifdef __MigPackStructs #pragma pack(4) #endif typedef struct { mach_msg_header_t Head; NDR_record_t NDR; exception_type_t exception; mach_msg_type_number_t codeCnt; int64_t code[2]; int flavor; mach_msg_type_number_t old_stateCnt; natural_t old_state[224]; } Request; #ifdef __MigPackStructs #pragma pack() #endif #ifdef __MigPackStructs #pragma pack(4) #endif typedef struct { mach_msg_header_t Head; NDR_record_t NDR; kern_return_t RetCode; int flavor; mach_msg_type_number_t new_stateCnt; natural_t new_state[224]; mach_msg_trailer_t trailer; } Reply; #ifdef __MigPackStructs #pragma pack() #endif #ifdef __MigPackStructs #pragma pack(4) #endif typedef struct { mach_msg_header_t Head; NDR_record_t NDR; kern_return_t RetCode; int flavor; mach_msg_type_number_t new_stateCnt; natural_t new_state[224]; } __Reply; #ifdef __MigPackStructs #pragma pack() #endif /* * typedef struct { * mach_msg_header_t Head; * NDR_record_t NDR; * kern_return_t RetCode; * } mig_reply_error_t; */ union { Request In; Reply Out; } Mess; Request *InP = &Mess.In; Reply *Out0P = &Mess.Out; mach_msg_return_t msg_result; unsigned int msgh_size; unsigned int msgh_size_delta; #ifdef __MIG_check__Reply__mach_exception_raise_state_t__defined kern_return_t check_result; #endif /* __MIG_check__Reply__mach_exception_raise_state_t__defined */ __DeclareSendRpc(2406, "mach_exception_raise_state") InP->NDR = NDR_record; InP->exception = exception; if (codeCnt > 2) { { return MIG_ARRAY_TOO_LARGE; } } (void)memcpy((char *) InP->code, (const char *) code, 8 * codeCnt); InP->codeCnt = codeCnt; msgh_size_delta = (8 * codeCnt); msgh_size = (mach_msg_size_t)(sizeof(Request) - 912) + msgh_size_delta; InP = (Request *) ((pointer_t) InP + msgh_size_delta - 16); InP->flavor = *flavor; if (old_stateCnt > 224) { { return MIG_ARRAY_TOO_LARGE; } } (void)memcpy((char *) InP->old_state, (const char *) old_state, 4 * old_stateCnt); InP->old_stateCnt = old_stateCnt; msgh_size += (4 * old_stateCnt); InP = &Mess.In; InP->Head.msgh_bits = MACH_MSGH_BITS(19, MACH_MSG_TYPE_MAKE_SEND_ONCE); /* msgh_size passed as argument */ InP->Head.msgh_request_port = exception_port; InP->Head.msgh_reply_port = mig_get_reply_port(); InP->Head.msgh_id = 2406; /* BEGIN VOUCHER CODE */ #ifdef USING_VOUCHERS if (voucher_mach_msg_set != NULL) { voucher_mach_msg_set(&InP->Head); } #endif // USING_VOUCHERS /* END VOUCHER CODE */ __BeforeSendRpc(2406, "mach_exception_raise_state") msg_result = mach_msg(&InP->Head, MACH_SEND_MSG|MACH_RCV_MSG|MACH_MSG_OPTION_NONE, msgh_size, (mach_msg_size_t)sizeof(Reply), InP->Head.msgh_reply_port, MACH_MSG_TIMEOUT_NONE, MACH_PORT_NULL); __AfterSendRpc(2406, "mach_exception_raise_state") if (msg_result != MACH_MSG_SUCCESS) { __MachMsgErrorWithoutTimeout(msg_result); { return msg_result; } } #if defined(__MIG_check__Reply__mach_exception_raise_state_t__defined) check_result = __MIG_check__Reply__mach_exception_raise_state_t((__Reply__mach_exception_raise_state_t *)Out0P); if (check_result != MACH_MSG_SUCCESS) { return check_result; } #endif /* defined(__MIG_check__Reply__mach_exception_raise_state_t__defined) */ *flavor = Out0P->flavor; if (Out0P->new_stateCnt > 224) { (void)memcpy((char *) new_state, (const char *) Out0P->new_state, 4 * 224); *new_stateCnt = Out0P->new_stateCnt; { return MIG_ARRAY_TOO_LARGE; } } (void)memcpy((char *) new_state, (const char *) Out0P->new_state, 4 * Out0P->new_stateCnt); *new_stateCnt = Out0P->new_stateCnt; return KERN_SUCCESS; }
/* Routine mach_exception_raise_state_identity */ mig_external kern_return_t mach_exception_raise_state_identity ( mach_port_t exception_port, mach_port_t thread, mach_port_t task, exception_type_t exception, mach_exception_data_t code, mach_msg_type_number_t codeCnt, int *flavor, thread_state_t old_state, mach_msg_type_number_t old_stateCnt, thread_state_t new_state, mach_msg_type_number_t *new_stateCnt ) { #ifdef __MigPackStructs #pragma pack(4) #endif typedef struct { mach_msg_header_t Head; /* start of the kernel processed data */ mach_msg_body_t msgh_body; mach_msg_port_descriptor_t thread; mach_msg_port_descriptor_t task; /* end of the kernel processed data */ NDR_record_t NDR; exception_type_t exception; mach_msg_type_number_t codeCnt; int64_t code[2]; int flavor; mach_msg_type_number_t old_stateCnt; natural_t old_state[224]; } Request; #ifdef __MigPackStructs #pragma pack() #endif #ifdef __MigPackStructs #pragma pack(4) #endif typedef struct { mach_msg_header_t Head; NDR_record_t NDR; kern_return_t RetCode; int flavor; mach_msg_type_number_t new_stateCnt; natural_t new_state[224]; mach_msg_trailer_t trailer; } Reply; #ifdef __MigPackStructs #pragma pack() #endif #ifdef __MigPackStructs #pragma pack(4) #endif typedef struct { mach_msg_header_t Head; NDR_record_t NDR; kern_return_t RetCode; int flavor; mach_msg_type_number_t new_stateCnt; natural_t new_state[224]; } __Reply; #ifdef __MigPackStructs #pragma pack() #endif /* * typedef struct { * mach_msg_header_t Head; * NDR_record_t NDR; * kern_return_t RetCode; * } mig_reply_error_t; */ union { Request In; Reply Out; } Mess; Request *InP = &Mess.In; Reply *Out0P = &Mess.Out; mach_msg_return_t msg_result; unsigned int msgh_size; unsigned int msgh_size_delta; #ifdef __MIG_check__Reply__mach_exception_raise_state_identity_t__defined kern_return_t check_result; #endif /* __MIG_check__Reply__mach_exception_raise_state_identity_t__defined */ __DeclareSendRpc(2407, "mach_exception_raise_state_identity") #if UseStaticTemplates const static mach_msg_port_descriptor_t threadTemplate = { /* name = */ MACH_PORT_NULL, /* pad1 = */ 0, /* pad2 = */ 0, /* disp = */ 19, /* type = */ MACH_MSG_PORT_DESCRIPTOR, }; #endif /* UseStaticTemplates */ #if UseStaticTemplates const static mach_msg_port_descriptor_t taskTemplate = { /* name = */ MACH_PORT_NULL, /* pad1 = */ 0, /* pad2 = */ 0, /* disp = */ 19, /* type = */ MACH_MSG_PORT_DESCRIPTOR, }; #endif /* UseStaticTemplates */ InP->msgh_body.msgh_descriptor_count = 2; #if UseStaticTemplates InP->thread = threadTemplate; InP->thread.name = thread; #else /* UseStaticTemplates */ InP->thread.name = thread; InP->thread.disposition = 19; InP->thread.type = MACH_MSG_PORT_DESCRIPTOR; #endif /* UseStaticTemplates */ #if UseStaticTemplates InP->task = taskTemplate; InP->task.name = task; #else /* UseStaticTemplates */ InP->task.name = task; InP->task.disposition = 19; InP->task.type = MACH_MSG_PORT_DESCRIPTOR; #endif /* UseStaticTemplates */ InP->NDR = NDR_record; InP->exception = exception; if (codeCnt > 2) { { return MIG_ARRAY_TOO_LARGE; } } (void)memcpy((char *) InP->code, (const char *) code, 8 * codeCnt); InP->codeCnt = codeCnt; msgh_size_delta = (8 * codeCnt); msgh_size = (mach_msg_size_t)(sizeof(Request) - 912) + msgh_size_delta; InP = (Request *) ((pointer_t) InP + msgh_size_delta - 16); InP->flavor = *flavor; if (old_stateCnt > 224) { { return MIG_ARRAY_TOO_LARGE; } } (void)memcpy((char *) InP->old_state, (const char *) old_state, 4 * old_stateCnt); InP->old_stateCnt = old_stateCnt; msgh_size += (4 * old_stateCnt); InP = &Mess.In; InP->Head.msgh_bits = MACH_MSGH_BITS_COMPLEX| MACH_MSGH_BITS(19, MACH_MSG_TYPE_MAKE_SEND_ONCE); /* msgh_size passed as argument */ InP->Head.msgh_request_port = exception_port; InP->Head.msgh_reply_port = mig_get_reply_port(); InP->Head.msgh_id = 2407; /* BEGIN VOUCHER CODE */ #ifdef USING_VOUCHERS if (voucher_mach_msg_set != NULL) { voucher_mach_msg_set(&InP->Head); } #endif // USING_VOUCHERS /* END VOUCHER CODE */ __BeforeSendRpc(2407, "mach_exception_raise_state_identity") msg_result = mach_msg(&InP->Head, MACH_SEND_MSG|MACH_RCV_MSG|MACH_MSG_OPTION_NONE, msgh_size, (mach_msg_size_t)sizeof(Reply), InP->Head.msgh_reply_port, MACH_MSG_TIMEOUT_NONE, MACH_PORT_NULL); __AfterSendRpc(2407, "mach_exception_raise_state_identity") if (msg_result != MACH_MSG_SUCCESS) { __MachMsgErrorWithoutTimeout(msg_result); { return msg_result; } } #if defined(__MIG_check__Reply__mach_exception_raise_state_identity_t__defined) check_result = __MIG_check__Reply__mach_exception_raise_state_identity_t((__Reply__mach_exception_raise_state_identity_t *)Out0P); if (check_result != MACH_MSG_SUCCESS) { return check_result; } #endif /* defined(__MIG_check__Reply__mach_exception_raise_state_identity_t__defined) */ *flavor = Out0P->flavor; if (Out0P->new_stateCnt > 224) { (void)memcpy((char *) new_state, (const char *) Out0P->new_state, 4 * 224); *new_stateCnt = Out0P->new_stateCnt; { return MIG_ARRAY_TOO_LARGE; } } (void)memcpy((char *) new_state, (const char *) Out0P->new_state, 4 * Out0P->new_stateCnt); *new_stateCnt = Out0P->new_stateCnt; return KERN_SUCCESS; }
/* Routine substrated_mark */ mig_external kern_return_t substrated_mark ( mach_port_t server, vm_map_t task, mach_vm_address_t source_address, mach_vm_size_t source_size, mach_vm_address_t *target_address ) { #ifdef __MigPackStructs #pragma pack(4) #endif typedef struct { mach_msg_header_t Head; /* start of the kernel processed data */ mach_msg_body_t msgh_body; mach_msg_port_descriptor_t task; /* end of the kernel processed data */ NDR_record_t NDR; mach_vm_address_t source_address; mach_vm_size_t source_size; mach_vm_address_t target_address; } Request __attribute__((unused)); #ifdef __MigPackStructs #pragma pack() #endif #ifdef __MigPackStructs #pragma pack(4) #endif typedef struct { mach_msg_header_t Head; NDR_record_t NDR; kern_return_t RetCode; mach_vm_address_t target_address; mach_msg_trailer_t trailer; } Reply __attribute__((unused)); #ifdef __MigPackStructs #pragma pack() #endif #ifdef __MigPackStructs #pragma pack(4) #endif typedef struct { mach_msg_header_t Head; NDR_record_t NDR; kern_return_t RetCode; mach_vm_address_t target_address; } __Reply __attribute__((unused)); #ifdef __MigPackStructs #pragma pack() #endif /* * typedef struct { * mach_msg_header_t Head; * NDR_record_t NDR; * kern_return_t RetCode; * } mig_reply_error_t; */ union { Request In; Reply Out; } Mess; Request *InP = &Mess.In; Reply *Out0P = &Mess.Out; mach_msg_return_t msg_result; #ifdef __MIG_check__Reply__substrated_mark_t__defined kern_return_t check_result; #endif /* __MIG_check__Reply__substrated_mark_t__defined */ __DeclareSendRpc(9000, "substrated_mark") #if UseStaticTemplates const static mach_msg_port_descriptor_t taskTemplate = { /* name = */ MACH_PORT_NULL, /* pad1 = */ 0, /* pad2 = */ 0, /* disp = */ 19, /* type = */ MACH_MSG_PORT_DESCRIPTOR, }; #endif /* UseStaticTemplates */ InP->msgh_body.msgh_descriptor_count = 1; #if UseStaticTemplates InP->task = taskTemplate; InP->task.name = task; #else /* UseStaticTemplates */ InP->task.name = task; InP->task.disposition = 19; InP->task.type = MACH_MSG_PORT_DESCRIPTOR; #endif /* UseStaticTemplates */ InP->NDR = NDR_record; InP->source_address = source_address; InP->source_size = source_size; InP->target_address = *target_address; InP->Head.msgh_bits = MACH_MSGH_BITS_COMPLEX| MACH_MSGH_BITS(19, MACH_MSG_TYPE_MAKE_SEND_ONCE); /* msgh_size passed as argument */ InP->Head.msgh_request_port = server; InP->Head.msgh_reply_port = mig_get_reply_port(); InP->Head.msgh_id = 9000; InP->Head.msgh_reserved = 0; /* BEGIN VOUCHER CODE */ #ifdef USING_VOUCHERS if (voucher_mach_msg_set != NULL) { voucher_mach_msg_set(&InP->Head); } #endif // USING_VOUCHERS /* END VOUCHER CODE */ __BeforeSendRpc(9000, "substrated_mark") msg_result = mach_msg(&InP->Head, MACH_SEND_MSG|MACH_RCV_MSG|MACH_MSG_OPTION_NONE, (mach_msg_size_t)sizeof(Request), (mach_msg_size_t)sizeof(Reply), InP->Head.msgh_reply_port, MACH_MSG_TIMEOUT_NONE, MACH_PORT_NULL); __AfterSendRpc(9000, "substrated_mark") if (msg_result != MACH_MSG_SUCCESS) { __MachMsgErrorWithoutTimeout(msg_result); { return msg_result; } } #if defined(__MIG_check__Reply__substrated_mark_t__defined) check_result = __MIG_check__Reply__substrated_mark_t((__Reply__substrated_mark_t *)Out0P); if (check_result != MACH_MSG_SUCCESS) { return check_result; } #endif /* defined(__MIG_check__Reply__substrated_mark_t__defined) */ *target_address = Out0P->target_address; return KERN_SUCCESS; }