summaryrefslogtreecommitdiffstats
path: root/src/VBox/ExtPacks/VBoxDTrace/include
diff options
context:
space:
mode:
Diffstat (limited to 'src/VBox/ExtPacks/VBoxDTrace/include')
-rw-r--r--src/VBox/ExtPacks/VBoxDTrace/include/VBoxDTraceLibCWrappers.h101
-rw-r--r--src/VBox/ExtPacks/VBoxDTrace/include/VBoxDTraceTypes.h472
2 files changed, 573 insertions, 0 deletions
diff --git a/src/VBox/ExtPacks/VBoxDTrace/include/VBoxDTraceLibCWrappers.h b/src/VBox/ExtPacks/VBoxDTrace/include/VBoxDTraceLibCWrappers.h
new file mode 100644
index 00000000..443f37d6
--- /dev/null
+++ b/src/VBox/ExtPacks/VBoxDTrace/include/VBoxDTraceLibCWrappers.h
@@ -0,0 +1,101 @@
+/* $Id: VBoxDTraceLibCWrappers.h $ */
+/** @file
+ * VBoxDTraceTLibCWrappers.h - IPRT wrappers/fake for lib C stuff.
+ *
+ * Contributed by: bird
+ */
+
+/*
+ * Copyright (C) 2012-2022 Oracle and/or its affiliates.
+ *
+ * This file is part of VirtualBox base platform packages, as
+ * available from http://www.virtualbox.org.
+ *
+ * The contents of this file are subject to the terms of the Common
+ * Development and Distribution License Version 1.0 (CDDL) only, as it
+ * comes in the "COPYING.CDDL" file of the VirtualBox distribution.
+ *
+ * SPDX-License-Identifier: CDDL-1.0
+ */
+
+#ifndef VBOX_INCLUDED_SRC_VBoxDTrace_include_VBoxDTraceLibCWrappers_h
+#define VBOX_INCLUDED_SRC_VBoxDTrace_include_VBoxDTraceLibCWrappers_h
+#ifndef RT_WITHOUT_PRAGMA_ONCE
+# pragma once
+#endif
+
+#include <assert.h>
+#include <stdlib.h>
+#include <string.h>
+#ifdef RT_OS_WINDOWS
+# include <process.h>
+#else
+# include <sys/types.h>
+# include <limits.h> /* Workaround for syslimit.h bug in gcc 4.8.3 on gentoo. */
+# ifdef RT_OS_DARWIN
+# include <sys/syslimits.h> /* PATH_MAX */
+# elif !defined(RT_OS_SOLARIS) && !defined(RT_OS_FREEBSD)
+# include <syslimits.h> /* PATH_MAX */
+# endif
+# include <libgen.h> /* basename */
+# include <unistd.h>
+# include <strings.h> /* bzero & bcopy.*/
+#endif
+
+#include <iprt/mem.h>
+#include <iprt/process.h>
+#include <iprt/param.h>
+#include <iprt/alloca.h>
+#include <iprt/assert.h>
+#include <iprt/mem.h>
+#include <iprt/string.h>
+#include <iprt/time.h>
+
+
+#undef gethrtime
+#define gethrtime() RTTimeNanoTS()
+#undef strcasecmp
+#define strcasecmp(a_psz1, a_psz2) RTStrICmp(a_psz1, a_psz2)
+#undef strncasecmp
+#define strncasecmp(a_psz1, a_psz2, a_cch) RTStrNICmp(a_psz1, a_psz2, a_cch)
+#undef strlcpy
+#define strlcpy(a_pszDst, a_pszSrc, a_cbDst) ((void)RTStrCopy(a_pszDst, a_cbDst, a_pszSrc))
+
+#undef assert
+#define assert(expr) Assert(expr)
+
+#undef PATH_MAX
+#define PATH_MAX RTPATH_MAX
+
+#undef getpid
+#define getpid RTProcSelf
+
+#undef basename
+#define basename(a_pszPath) RTPathFilename(a_pszPath)
+
+#undef malloc
+#define malloc(a_cb) RTMemAlloc(a_cb)
+#undef calloc
+#define calloc(a_cItems, a_cb) RTMemAllocZ((size_t)(a_cb) * (a_cItems))
+#undef realloc
+#define realloc(a_pvOld, a_cbNew) RTMemRealloc(a_pvOld, a_cbNew)
+#undef free
+#define free(a_pv) RTMemFree(a_pv)
+
+/* Not using RTStrDup and RTStrNDup here because the allocation won't be freed
+ by RTStrFree and thus may cause trouble when using the efence. */
+#undef strdup
+#define strdup(a_psz) ((char *)RTMemDup(a_psz, strlen(a_psz) + 1))
+#undef strndup
+#define strndup(a_psz, a_cchMax) ((char *)RTMemDupEx(a_psz, RTStrNLen(a_psz, a_cchMax), 1))
+
+/* For various stupid reasons, these are duplicated in VBoxDTraceTypes.h. */
+#undef bcopy
+#define bcopy(a_pSrc, a_pDst, a_cb) ((void)memmove(a_pDst, a_pSrc, a_cb))
+#undef bzero
+#define bzero(a_pDst, a_cb) ((void)memset(a_pDst, 0, a_cb))
+#undef bcmp
+#define bcmp(a_p1, a_p2, a_cb) (memcmp(a_p1, a_p2, a_cb))
+
+#endif /* !VBOX_INCLUDED_SRC_VBoxDTrace_include_VBoxDTraceLibCWrappers_h */
+
diff --git a/src/VBox/ExtPacks/VBoxDTrace/include/VBoxDTraceTypes.h b/src/VBox/ExtPacks/VBoxDTrace/include/VBoxDTraceTypes.h
new file mode 100644
index 00000000..3f4301fe
--- /dev/null
+++ b/src/VBox/ExtPacks/VBoxDTrace/include/VBoxDTraceTypes.h
@@ -0,0 +1,472 @@
+
+/* $Id: VBoxDTraceTypes.h $ */
+/** @file
+ * VBoxDTraceTypes.h - Fake a bunch of Solaris types.
+ *
+ * Contributed by: bird
+ */
+
+/*
+ * Copyright (C) 2012-2022 Oracle and/or its affiliates.
+ *
+ * This file is part of VirtualBox base platform packages, as
+ * available from http://www.virtualbox.org.
+ *
+ * The contents of this file are subject to the terms of the Common
+ * Development and Distribution License Version 1.0 (CDDL) only, as it
+ * comes in the "COPYING.CDDL" file of the VirtualBox distribution.
+ *
+ * SPDX-License-Identifier: CDDL-1.0
+ */
+
+#ifndef VBOX_INCLUDED_SRC_VBoxDTrace_include_VBoxDTraceTypes_h
+#define VBOX_INCLUDED_SRC_VBoxDTrace_include_VBoxDTraceTypes_h
+#ifndef RT_WITHOUT_PRAGMA_ONCE
+# pragma once
+#endif
+
+#include <iprt/types.h>
+#include <iprt/stdarg.h>
+#include <iprt/assert.h>
+#include <iprt/param.h>
+#include <iprt/errno.h>
+#ifdef IN_RING0
+# include <iprt/list.h>
+#endif
+#ifdef IN_RING3
+# include <sys/types.h>
+# include <limits.h>
+# ifdef RT_OS_LINUX
+# include <sys/ucontext.h> /* avoid greg_t trouble */
+# endif
+# if defined(_MSC_VER)
+# include <stdio.h>
+# endif
+#endif
+
+RT_C_DECLS_BEGIN
+
+struct modctl;
+
+typedef unsigned char uchar_t;
+typedef unsigned short ushort_t;
+typedef unsigned int uint_t;
+typedef uintptr_t ulong_t;
+#ifndef RT_OS_SOLARIS
+typedef int64_t longlong_t;
+typedef uint64_t u_longlong_t;
+typedef uint64_t hrtime_t;
+# ifndef RT_OS_FREEBSD
+typedef uint32_t id_t;
+# endif
+typedef uint32_t zoneid_t;
+#endif
+#if (!defined(__NGREG) && !defined(NGREG)) || !defined(RT_OS_LINUX)
+typedef RTCCINTREG greg_t;
+#else
+AssertCompileSize(greg_t, sizeof(RTCCINTREG));
+#endif
+typedef uintptr_t pc_t;
+typedef unsigned int model_t;
+typedef RTCPUID processorid_t;
+#if defined(_MSC_VER) || defined(IN_RING0)
+typedef RTUID uid_t;
+typedef RTPROCESS pid_t;
+#endif
+#if defined(_MSC_VER) || defined(IN_RING0) || defined(RT_OS_LINUX)
+typedef char *caddr_t;
+#endif
+
+#if !defined(NANOSEC) || !defined(RT_OS_SOLARIS)
+# define NANOSEC RT_NS_1SEC
+#endif
+#if !defined(MICROSEC) || !defined(RT_OS_SOLARIS)
+# define MICROSEC RT_US_1SEC
+#endif
+#if !defined(MILLISEC) || !defined(RT_OS_SOLARIS)
+# define MILLISEC RT_MS_1SEC
+#endif
+#if !defined(SEC) || !defined(RT_OS_SOLARIS)
+# define SEC (1)
+#endif
+#define MAXPATHLEN RTPATH_MAX
+#undef PATH_MAX
+#define PATH_MAX RTPATH_MAX
+#undef NBBY
+#define NBBY (8)
+#define NCPU RTCPUSET_MAX_CPUS
+#define B_FALSE (0)
+#define B_TRUE (1)
+#define MIN(a1, a2) RT_MIN(a1, a2)
+#define MAX(a1, a2) RT_MAX(a1, a2)
+#define ABS(a_iValue) RT_ABS(a_iValue)
+#define IS_P2ALIGNED(uWhat, uAlign) ( !((uWhat) & ((uAlign) - 1)) )
+#define P2ROUNDUP(uWhat, uAlign) ( ((uWhat) + (uAlign) - 1) & ~(uAlign - 1) )
+#define roundup(uWhat, uUnit) ( ( (uWhat) + ((uUnit) - 1)) / (uUnit) * (uUnit) )
+
+#if defined(RT_ARCH_X86)
+# ifndef __i386
+# define __i386 1
+# endif
+# ifndef __x86
+# define __x86 1
+# endif
+# ifndef _IPL32
+# define _IPL32 1
+# endif
+# if !defined(_LITTLE_ENDIAN) || (!defined(RT_OS_SOLARIS) && !defined(RT_OS_FREEBSD))
+# define _LITTLE_ENDIAN 1
+# endif
+
+#elif defined(RT_ARCH_AMD64)
+# ifndef __x86_64
+# define __x86_64 1
+# endif
+# ifndef __x86
+# define __x86 1
+# endif
+# ifndef _LP64
+# define _LP64 1
+# endif
+# if !defined(_LITTLE_ENDIAN) || (!defined(RT_OS_SOLARIS) && !defined(RT_OS_FREEBSD))
+# define _LITTLE_ENDIAN 1
+# endif
+
+#else
+# error "unsupported arch!"
+#endif
+
+/** Mark a cast added when porting the code to VBox.
+ * Avoids lots of \#ifdef VBOX otherwise needed to mark up the changes. */
+#define VBDTCAST(a_Type) (a_Type)
+/** Mark a type change made when porting the code to VBox.
+ * This is usually signed -> unsigned type changes that avoids a whole lot of
+ * comparsion warnings. */
+#define VBDTTYPE(a_VBox, a_Org) a_VBox
+/** Mark missing void in a parameter list. */
+#define VBDTVOID void
+/** Mark missing static in a function definition. */
+#define VBDTSTATIC static
+#define VBDTUNASS(a_Value) = a_Value
+#define VBDTGCC(a_Value) = a_Value
+#define VBDTMSC(a_Value) = a_Value
+
+/*
+ * string
+ */
+#ifdef IN_RING0
+# undef bcopy
+# define bcopy(a_pSrc, a_pDst, a_cb) ((void)memmove(a_pDst, a_pSrc, a_cb))
+# undef bzero
+# define bzero(a_pDst, a_cb) ((void)memset(a_pDst, 0, a_cb))
+# undef bcmp
+# define bcmp(a_p1, a_p2, a_cb) (memcmp(a_p1, a_p2, a_cb))
+#endif
+#if defined(_MSC_VER) || defined(IN_RING0)
+# define snprintf (int)RTStrPrintf /** @todo wrong return value */
+# define vsnprintf (int)RTStrPrintfV /** @todo wrong return value */
+#endif
+
+/*
+ * Bitmap stuff.
+ */
+#define BT_SIZEOFMAP(a_cBits) ( (a_cBits + 63) / 8 )
+#define BT_SET(a_aulBitmap, iBit) ASMBitSet(a_aulBitmap, iBit)
+#define BT_CLEAR(a_aulBitmap, iBit) ASMBitClear(a_aulBitmap, iBit)
+#define BT_TEST(a_aulBitmap, iBit) ASMBitTest(a_aulBitmap, iBit)
+#if ARCH_BITS == 32
+# define BT_NBIPUL 32
+# define BT_ULSHIFT 5 /* log2(32) = 5 */
+# define BT_ULMASK 0x1f
+# define BT_BITOUL(a_cBits) ( ((a_cBits) + 31) / 32 )
+#elif ARCH_BITS == 64
+# define BT_NBIPUL 64
+# define BT_ULSHIFT 6 /* log2(32) = 6 */
+# define BT_ULMASK 0x3f
+# define BT_BITOUL(a_cBits) ( ((a_cBits) + 63) / 64 )
+#else
+# error Bad ARCH_BITS...
+#endif
+
+
+#ifdef IN_RING0
+
+/*
+ * Kernel stuff...
+ */
+#define CPU_ON_INTR(a_pCpu) (false)
+
+#define KERNELBASE VBoxDtGetKernelBase()
+uintptr_t VBoxDtGetKernelBase(void);
+
+
+typedef struct VBoxDtCred
+{
+ int32_t cr_refs;
+ RTUID cr_uid;
+ RTUID cr_ruid;
+ RTUID cr_suid;
+ RTGID cr_gid;
+ RTGID cr_rgid;
+ RTGID cr_sgid;
+ zoneid_t cr_zone;
+} cred_t;
+#define PRIV_POLICY_ONLY(a_pCred, a_uPriv, a_fAll) (true)
+#define priv_isequalset(a, b) (true)
+#define crgetuid(a_pCred) ((a_pCred)->cr_uid)
+#define crgetzoneid(a_pCred) ((a_pCred)->cr_zone)
+#define crhold VBoxDtCredHold
+#define crfree VBoxDtCredFree
+void VBoxDtCredHold(struct VBoxDtCred *pCred);
+void VBoxDtCredFree(struct VBoxDtCred *pCred);
+
+
+typedef struct RTTIMER *cyclic_id_t;
+#define CYCLIC_NONE ((struct RTTIMER *)NULL)
+#define cyclic_remove(a_hTimer) RTTimerDestroy(a_hTimer)
+
+typedef struct VBoxDtThread
+{
+ /** The next thread with the same hash table entry.
+ * Or the next free thread. */
+ struct VBoxDtThread *pNext;
+ /** Age list node. */
+ RTLISTNODE AgeEntry;
+ /** The native thread handle. */
+ RTNATIVETHREAD hNative;
+ /** The process ID. */
+ RTPROCESS uPid;
+
+ uint32_t t_predcache;
+ uintptr_t t_dtrace_scrpc;
+ uintptr_t t_dtrace_astpc;
+ hrtime_t t_dtrace_vtime;
+ hrtime_t t_dtrace_start;
+ uint8_t t_dtrace_stop;
+} kthread_t;
+struct VBoxDtThread *VBoxDtGetCurrentThread(void);
+#define curthread (VBoxDtGetCurrentThread())
+
+
+typedef struct VBoxDtProcess proc_t;
+# if 0 /* not needed ? */
+struct VBoxDtProcess proc_t;
+{
+/* uint32_t p_flag; - don't bother with this */
+ RTPROCESS p_pid;
+ struct dtrace_helpers *p_dtrace_helpers;
+}
+proc_t *VBoxDtGetCurrentProc(void);
+# define curproc (VBoxDtGetCurrentProc())
+/*# define SNOCD RT_BIT(0) - don't bother with this */
+# endif
+
+typedef struct VBoxDtTaskQueue taskq_t;
+
+typedef struct VBoxDtMutex
+{
+ RTSEMMUTEX hMtx;
+ RTNATIVETHREAD volatile hOwner;
+} kmutex_t;
+#define mutex_enter VBoxDtMutexEnter
+#define mutex_exit VBoxDtMutexExit
+#define MUTEX_HELD(a_pMtx) VBoxDtMutexIsOwner(a_pMtx)
+#define MUTEX_NOT_HELD(a_pMtx) (!VBoxDtMutexIsOwner(a_pMtx))
+#define mod_lock g_DummyMtx
+#define cpu_lock g_DummyMtx
+int VBoxDtMutexInit(struct VBoxDtMutex *pMtx);
+void VBoxDtMutexDelete(struct VBoxDtMutex *pMtx);
+void VBoxDtMutexEnter(struct VBoxDtMutex *pMtx);
+void VBoxDtMutexExit(struct VBoxDtMutex *pMtx);
+bool VBoxDtMutexIsOwner(struct VBoxDtMutex *pMtx);
+extern struct VBoxDtMutex g_DummyMtx;
+
+
+typedef struct VBoxDtCpuCore
+{
+ RTCPUID cpu_id;
+ uintptr_t cpuc_dtrace_illval;
+ uint16_t volatile cpuc_dtrace_flags;
+
+} cpucore_t;
+
+#define CPU_DTRACE_BADADDR RT_BIT(0)
+#define CPU_DTRACE_BADALIGN RT_BIT(1)
+#define CPU_DTRACE_BADSTACK RT_BIT(2)
+#define CPU_DTRACE_KPRIV RT_BIT(3)
+#define CPU_DTRACE_DIVZERO RT_BIT(4)
+#define CPU_DTRACE_ILLOP RT_BIT(5)
+#define CPU_DTRACE_NOSCRATCH RT_BIT(6)
+#define CPU_DTRACE_UPRIV RT_BIT(7)
+#define CPU_DTRACE_TUPOFLOW RT_BIT(8)
+#define CPU_DTRACE_ENTRY RT_BIT(9)
+#define CPU_DTRACE_FAULT UINT16_C(0x03ff)
+#define CPU_DTRACE_DROP RT_BIT(12)
+#define CPU_DTRACE_ERROR UINT16_C(0x13ff)
+#define CPU_DTRACE_NOFAULT RT_BIT(15)
+
+extern cpucore_t g_aVBoxDtCpuCores[RTCPUSET_MAX_CPUS];
+#define cpu_core (g_aVBoxDtCpuCores)
+
+struct VBoxDtCred *VBoxDtGetCurrentCreds(void);
+#define CRED() VBoxDtGetCurrentCreds()
+
+proc_t *VBoxDtThreadToProc(kthread_t *);
+
+
+#define ASSERT(a_Expr) Assert(a_Expr)
+#define panic VBoxDtPanic
+void VBoxDtPanic(const char *pszFormat, ...);
+#define cmn_err VBoxDtCmnErr
+void VBoxDtCmnErr(int iLevel, const char *pszFormat, ...);
+#define CE_WARN 10
+#define CE_NOTE 11
+#define uprintf VBoxDtUPrintf
+#define vuprintf VBoxDtUPrintfV
+void VBoxDtUPrintf(const char *pszFormat, ...);
+void VBoxDtUPrintfV(const char *pszFormat, va_list va);
+
+/*
+ * Memory allocation wrappers.
+ */
+#define KM_SLEEP RT_BIT(0)
+#define KM_NOSLEEP RT_BIT(1)
+#define kmem_alloc VBoxDtKMemAlloc
+#define kmem_zalloc VBoxDtKMemAllocZ
+#define kmem_free VBoxDtKMemFree
+void *VBoxDtKMemAlloc(size_t cbMem, uint32_t fFlags);
+void *VBoxDtKMemAllocZ(size_t cbMem, uint32_t fFlags);
+void VBoxDtKMemFree(void *pvMem, size_t cbMem);
+
+
+typedef struct VBoxDtMemCache kmem_cache_t;
+#define kmem_cache_create VBoxDtKMemCacheCreate
+#define kmem_cache_destroy VBoxDtKMemCacheDestroy
+#define kmem_cache_alloc VBoxDtKMemCacheAlloc
+#define kmem_cache_free VBoxDtKMemCacheFree
+struct VBoxDtMemCache *VBoxDtKMemCacheCreate(const char *pszName, size_t cbBuf, size_t cbAlign,
+ PFNRT pfnCtor, PFNRT pfnDtor, PFNRT pfnReclaim,
+ void *pvUser, void *pvVM, uint32_t fFlags);
+void VBoxDtKMemCacheDestroy(struct VBoxDtMemCache *pCache);
+void *VBoxDtKMemCacheAlloc(struct VBoxDtMemCache *pCache, uint32_t fFlags);
+void VBoxDtKMemCacheFree(struct VBoxDtMemCache *pCache, void *pvMem);
+
+
+typedef struct VBoxDtVMem vmem_t;
+#define VM_SLEEP RT_BIT(0)
+#define VM_BESTFIT RT_BIT(1)
+#define VMC_IDENTIFIER RT_BIT(16)
+#define vmem_create VBoxDtVMemCreate
+#define vmem_destroy VBoxDtVMemDestroy
+#define vmem_alloc VBoxDtVMemAlloc
+#define vmem_free VBoxDtVMemFree
+struct VBoxDtVMem *VBoxDtVMemCreate(const char *pszName, void *pvBase, size_t cb, size_t cbUnit,
+ PFNRT pfnAlloc, PFNRT pfnFree, struct VBoxDtVMem *pSrc,
+ size_t cbQCacheMax, uint32_t fFlags);
+void VBoxDtVMemDestroy(struct VBoxDtVMem *pVMemArena);
+void *VBoxDtVMemAlloc(struct VBoxDtVMem *pVMemArena, size_t cbMem, uint32_t fFlags);
+void VBoxDtVMemFree(struct VBoxDtVMem *pVMemArena, void *pvMem, size_t cbMem);
+
+/*
+ * Copy In/Out
+ */
+#define copyin VBoxDtCopyIn
+#define copyout VBoxDtCopyOut
+int VBoxDtCopyIn(void const *pvUser, void *pvDst, size_t cb);
+int VBoxDtCopyOut(void const *pvSrc, void *pvUser, size_t cb);
+
+/*
+ * Device numbers.
+ */
+typedef uint64_t dev_t;
+typedef uint32_t major_t;
+typedef uint32_t minor_t;
+#define makedevice(a_Maj, a_Min) RT_MAKE_U64(a_Min, a_Maj)
+#define getemajor(a_Dev) RT_HIDWORD(a_Dev)
+#define geteminor(a_Dev) RT_LODWORD(a_Dev)
+#define getminor(a_Dev) RT_LODWORD(a_Dev)
+
+/*
+ * DDI
+ */
+# define DDI_SUCCESS (0)
+# define DDI_FAILURE (-1)
+# if 0 /* not needed */
+# define ddi_soft_state_init VBoxDtDdiSoftStateInit
+# define ddi_soft_state_fini VBoxDtDdiSoftStateTerm
+# define ddi_soft_state_zalloc VBoxDtDdiSoftStateAllocZ
+# define ddi_get_soft_state VBoxDtDdiSoftStateGet
+# define ddi_soft_state_free VBoxDtDdiSoftStateFree
+int VBoxDtDdiSoftStateInit(void **ppvSoftStates, size_t cbSoftState, uint32_t cMaxItems);
+int VBoxDtDdiSoftStateTerm(void **ppvSoftStates);
+int VBoxDtDdiSoftStateAllocZ(void *pvSoftStates, RTDEV uMinor);
+int VBoxDtDdiSoftStateFree(void *pvSoftStates, RTDEV uMinor);
+void *VBoxDtDdiSoftStateGet(void *pvSoftStates, RTDEV uMinor);
+
+typedef enum { DDI_ATT_CMD_DUMMY } ddi_attach_cmd_t;
+typedef enum { DDI_DETACH, DDI_SUSPEND } ddi_detach_cmd_t;
+typedef struct VBoxDtDevInfo dev_info_t;
+# define ddi_driver_major VBoxDtDdiDriverMajor
+# define ddi_report_dev VBoxDtDdiReportDev
+major_t VBoxDtDdiDriverMajor(struct VBoxDtDevInfo *pDevInfo);
+void VBoxDtDdiReportDev(struct VBoxDtDevInfo *pDevInfo);
+# endif
+
+/*
+ * DTrace bits we've made external.
+ */
+extern int dtrace_attach(void);
+extern int dtrace_detach(void);
+struct dtrace_state;
+extern int dtrace_open(struct dtrace_state **ppState, struct VBoxDtCred *cred_p);
+extern int dtrace_ioctl(struct dtrace_state *state, int cmd, intptr_t arg, int32_t *rv);
+extern int dtrace_close(struct dtrace_state *state);
+
+#endif /* IN_RING0 */
+
+
+#ifdef IN_RING3
+/*
+ * Make life a little easier in ring-3.
+ */
+
+/* Replacement for strndup(), requires editing the code unfortunately. */
+# define MY_STRDUPA(a_pszRes, a_pszSrc) \
+ do { \
+ size_t cb = strlen(a_pszSrc) + 1; \
+ (a_pszRes) = (char *)alloca(cb); \
+ memcpy(a_pszRes, a_pszSrc, cb); \
+ } while (0)
+
+/*
+ * gelf
+ */
+# include <iprt/formats/elf64.h>
+typedef Elf64_Half GElf_Half;
+typedef Elf64_Xword GElf_Xword;
+typedef Elf64_Shdr GElf_Shdr;
+typedef Elf64_Ehdr GElf_Ehdr;
+typedef Elf64_Sym GElf_Sym;
+typedef Elf64_Addr GElf_Addr;
+#define GELF_ST_INFO ELF64_ST_INFO
+#define GELF_ST_TYPE ELF64_ST_TYPE
+#define GELF_ST_BIND ELF64_ST_BIND
+
+/*
+ * MSC stuff.
+ */
+# ifdef _MSC_VER
+# ifndef SIZE_MAX
+# if ARCH_BITS == 32
+# define SIZE_MAX UINT32_MAX
+# else
+# define SIZE_MAX UINT64_MAX
+# endif
+# endif
+# endif /* _MSC_VER */
+
+#endif /* IN_RING3 */
+
+RT_C_DECLS_END
+#endif /* !VBOX_INCLUDED_SRC_VBoxDTrace_include_VBoxDTraceTypes_h */
+