Loading...
--- xnu/xnu-517.7.21/libkern/c++/OSRuntime.cpp
+++ xnu/xnu-201.42.3/libkern/c++/OSRuntime.cpp
@@ -44,6 +44,13 @@
extern int debug_iomalloc_size;
#endif
+#define MDECL(reqlen) \
+typedef union { \
+ struct _mhead hdr; \
+ char _m[(reqlen) + sizeof (struct _mhead)]; \
+} hdr_t; \
+hdr_t
+
struct _mhead {
size_t mlen;
char dat[0];
@@ -52,13 +59,13 @@
void *kern_os_malloc(
size_t size)
{
- struct _mhead *mem;
- size_t memsize = sizeof (*mem) + size ;
+ MDECL(size) *mem;
+ size_t memsize = sizeof (*mem);
if (size == 0)
return (0);
- mem = (struct _mhead *)kalloc(memsize);
+ mem = (hdr_t *)kalloc(memsize);
if (!mem)
return (0);
@@ -66,10 +73,10 @@
debug_iomalloc_size += memsize;
#endif
- mem->mlen = memsize;
- (void) memset(mem->dat, 0, size);
-
- return (mem->dat);
+ mem->hdr.mlen = memsize;
+ (void) memset(mem->hdr.dat, 0, size);
+
+ return (mem->hdr.dat);
}
void kern_os_free(
@@ -98,7 +105,7 @@
size_t nsize)
{
struct _mhead *ohdr;
- struct _mhead *nmem;
+ MDECL(nsize) *nmem;
size_t nmemsize, osize;
if (!addr)
@@ -114,8 +121,8 @@
return (0);
}
- nmemsize = sizeof (*nmem) + nsize ;
- nmem = (struct _mhead *) kalloc(nmemsize);
+ nmemsize = sizeof (*nmem);
+ nmem = (hdr_t *) kalloc(nmemsize);
if (!nmem){
kern_os_free(addr);
return (0);
@@ -125,14 +132,14 @@
debug_iomalloc_size += (nmemsize - ohdr->mlen);
#endif
- nmem->mlen = nmemsize;
+ nmem->hdr.mlen = nmemsize;
if (nsize > osize)
- (void) memset(&nmem->dat[osize], 0, nsize - osize);
- (void) memcpy(nmem->dat, ohdr->dat,
+ (void) memset(&nmem->hdr.dat[osize], 0, nsize - osize);
+ (void) memcpy(nmem->hdr.dat, ohdr->dat,
(nsize > osize) ? osize : nsize);
kfree((vm_offset_t)ohdr, ohdr->mlen);
- return (nmem->dat);
+ return (nmem->hdr.dat);
}
size_t kern_os_malloc_size(
@@ -147,11 +154,7 @@
return( hdr->mlen - sizeof (struct _mhead));
}
-#if __GNUC__ >= 3
-void __cxa_pure_virtual( void ) { panic(__FUNCTION__); }
-#else
void __pure_virtual( void ) { panic(__FUNCTION__); }
-#endif
typedef void (*structor_t)(void);