X-Git-Url: https://git.saurik.com/apple/xnu.git/blobdiff_plain/8f6c56a50524aa785f7e596d52dddfb331e18961..04b8595b18b1b41ac7a206e4b3d51a635f8413d7:/iokit/IOKit/OSMessageNotification.h diff --git a/iokit/IOKit/OSMessageNotification.h b/iokit/IOKit/OSMessageNotification.h index 9f453fdee..bd6bc1cb1 100644 --- a/iokit/IOKit/OSMessageNotification.h +++ b/iokit/IOKit/OSMessageNotification.h @@ -40,6 +40,7 @@ extern "C" { #endif #include +#include #include enum { @@ -49,7 +50,12 @@ enum { kIOServiceTerminatedNotificationType = 102, kIOAsyncCompletionNotificationType = 150, kIOServiceMessageNotificationType = 160, - kLastIOKitNotificationType = 199 + kLastIOKitNotificationType = 199, + + // reserved bits + kIOKitNoticationTypeMask = 0x00000FFF, + kIOKitNoticationTypeSizeAdjShift = 30, + kIOKitNoticationMsgSizeMask = 3, }; enum { @@ -76,6 +82,37 @@ enum { kIOInterestCalloutCount }; + + +// -------------- +enum { + kOSAsyncRef64Count = 8, + kOSAsyncRef64Size = kOSAsyncRef64Count * ((int) sizeof(io_user_reference_t)) +}; +typedef io_user_reference_t OSAsyncReference64[kOSAsyncRef64Count]; + +struct OSNotificationHeader64 { + mach_msg_size_t size; /* content size */ + natural_t type; + OSAsyncReference64 reference; + +#if defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) + unsigned char content[]; +#else + unsigned char content[0]; +#endif +}; + +#pragma pack(4) +struct IOServiceInterestContent64 { + natural_t messageType; + io_user_reference_t messageArgument[1]; +}; +#pragma pack() +// -------------- + +#if !KERNEL_USER32 + enum { kOSAsyncRefCount = 8, kOSAsyncRefSize = 32 @@ -83,7 +120,7 @@ enum { typedef natural_t OSAsyncReference[kOSAsyncRefCount]; struct OSNotificationHeader { - vm_size_t size; /* content size */ + mach_msg_size_t size; /* content size */ natural_t type; OSAsyncReference reference; @@ -94,17 +131,21 @@ struct OSNotificationHeader { #endif }; +#pragma pack(4) struct IOServiceInterestContent { natural_t messageType; void * messageArgument[1]; }; +#pragma pack() + +#endif /* KERNEL_USER32 */ struct IOAsyncCompletionContent { IOReturn result; #if defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) - void * args[]; + void * args[] __attribute__ ((packed)); #else - void * args[0]; + void * args[0] __attribute__ ((packed)); #endif };