mirror of https://github.com/x64dbg/zydis
Added basic support for Windows kernel drivers
- Manual typedefs for fixed width int types - Custom `vsnprintf` function - Disable ZYDIS_ASSERT and ZYDIS_UNREACHABLE
This commit is contained in:
parent
5ac595eb72
commit
87394ef4da
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
Zyan Disassembler Library (Zydis)
|
Zyan Disassembler Library (Zydis)
|
||||||
|
|
||||||
Original Author : Florian Bernd
|
Original Author : Florian Bernd, Joel Höner
|
||||||
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
* of this software and associated documentation files (the "Software"), to deal
|
* of this software and associated documentation files (the "Software"), to deal
|
||||||
|
@ -32,18 +32,47 @@
|
||||||
#ifndef ZYDIS_COMMONTYPES_H
|
#ifndef ZYDIS_COMMONTYPES_H
|
||||||
#define ZYDIS_COMMONTYPES_H
|
#define ZYDIS_COMMONTYPES_H
|
||||||
|
|
||||||
|
#include <Zydis/Defines.h>
|
||||||
|
|
||||||
/* ============================================================================================== */
|
/* ============================================================================================== */
|
||||||
/* Integral types */
|
/* Integral types */
|
||||||
/* ============================================================================================== */
|
/* ============================================================================================== */
|
||||||
|
|
||||||
/**
|
// Fixed width integer types.
|
||||||
* uint8_t, uint16_t, uint32_t, uint64_t, int8_t, int16_t, int32_t, int64_t
|
#if defined(ZYDIS_WINKERNEL)
|
||||||
*/
|
# if !defined(ZYDIS_MSVC)
|
||||||
#include <stdint.h>
|
# error "Windows kernel drivers are only supported with MSVC"
|
||||||
|
# endif
|
||||||
|
typedef unsigned __int8 uint8_t;
|
||||||
|
typedef unsigned __int16 uint16_t;
|
||||||
|
typedef unsigned __int32 uint32_t;
|
||||||
|
typedef unsigned __int64 uint64_t;
|
||||||
|
typedef __int8 int8_t;
|
||||||
|
typedef __int16 int16_t;
|
||||||
|
typedef __int32 int32_t;
|
||||||
|
typedef __int64 int64_t;
|
||||||
|
# define UINT8_MAX (255)
|
||||||
|
# define UINT16_MAX (65535U)
|
||||||
|
# define UINT32_MAX (4294967295UL)
|
||||||
|
# define UINT64_MAX (18446744073709551615ULL)
|
||||||
|
# define INT8_MAX (127)
|
||||||
|
# define INT8_MIN (-128)
|
||||||
|
# define INT16_MAX (32767)
|
||||||
|
# define INT16_MIN (-32767-1)
|
||||||
|
# define INT32_MIN (-2147483647L-1)
|
||||||
|
# define INT32_MAX (2147483647L)
|
||||||
|
# define INT64_MIN (-9223372036854775807LL-1)
|
||||||
|
# define INT64_MAX (9223372036854775807LL)
|
||||||
|
# define PRIX8 "hhX"
|
||||||
|
# define PRIX16 "hX"
|
||||||
|
# define PRIX32 "X"
|
||||||
|
# define PRIX64 "llX"
|
||||||
|
#else
|
||||||
|
# include <stdint.h>
|
||||||
|
# include <inttypes.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
// size_t, ptrdiff_t
|
||||||
* size_t, ptrdiff_t
|
|
||||||
*/
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
|
|
@ -32,8 +32,6 @@
|
||||||
#ifndef ZYDIS_DEFINES_H
|
#ifndef ZYDIS_DEFINES_H
|
||||||
#define ZYDIS_DEFINES_H
|
#define ZYDIS_DEFINES_H
|
||||||
|
|
||||||
#include <assert.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <ZydisExportConfig.h>
|
#include <ZydisExportConfig.h>
|
||||||
|
|
||||||
/* ============================================================================================== */
|
/* ============================================================================================== */
|
||||||
|
@ -123,7 +121,12 @@
|
||||||
/* Debugging and optimization macros */
|
/* Debugging and optimization macros */
|
||||||
/* ============================================================================================== */
|
/* ============================================================================================== */
|
||||||
|
|
||||||
#define ZYDIS_ASSERT(condition) assert(condition)
|
#if defined(ZYDIS_WINKERNEL)
|
||||||
|
# define ZYDIS_ASSERT(condition)
|
||||||
|
#else
|
||||||
|
# include <assert.h>
|
||||||
|
# define ZYDIS_ASSERT(condition) assert(condition)
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(ZYDIS_RELEASE)
|
#if defined(ZYDIS_RELEASE)
|
||||||
# if defined(ZYDIS_GNUC)
|
# if defined(ZYDIS_GNUC)
|
||||||
|
@ -137,7 +140,10 @@
|
||||||
# else
|
# else
|
||||||
# define ZYDIS_UNREACHABLE
|
# define ZYDIS_UNREACHABLE
|
||||||
# endif
|
# endif
|
||||||
|
#elif defined(ZYDIS_WINKERNEL)
|
||||||
|
# define ZYDIS_UNREACHABLE
|
||||||
#else
|
#else
|
||||||
|
# include <stdlib.h>
|
||||||
# define ZYDIS_UNREACHABLE { assert(0); abort(); }
|
# define ZYDIS_UNREACHABLE { assert(0); abort(); }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -34,6 +34,8 @@
|
||||||
|
|
||||||
#include <Zydis/Defines.h>
|
#include <Zydis/Defines.h>
|
||||||
#include <Zydis/Status.h>
|
#include <Zydis/Status.h>
|
||||||
|
#include <Zydis/Register.h>
|
||||||
|
#include <Zydis/Mnemonic.h>
|
||||||
#include <Zydis/SharedTypes.h>
|
#include <Zydis/SharedTypes.h>
|
||||||
#ifdef ZYDIS_ENABLE_FEATURE_DECODER
|
#ifdef ZYDIS_ENABLE_FEATURE_DECODER
|
||||||
# include <Zydis/DecoderTypes.h>
|
# include <Zydis/DecoderTypes.h>
|
||||||
|
|
|
@ -32,7 +32,6 @@
|
||||||
#ifndef ZYDIS_UTILS_H
|
#ifndef ZYDIS_UTILS_H
|
||||||
#define ZYDIS_UTILS_H
|
#define ZYDIS_UTILS_H
|
||||||
|
|
||||||
#include <stdint.h>
|
|
||||||
#include <Zydis/Defines.h>
|
#include <Zydis/Defines.h>
|
||||||
#include <Zydis/Status.h>
|
#include <Zydis/Status.h>
|
||||||
#include <Zydis/DecoderTypes.h>
|
#include <Zydis/DecoderTypes.h>
|
||||||
|
|
|
@ -29,7 +29,6 @@
|
||||||
#include <EncoderData.h>
|
#include <EncoderData.h>
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdint.h>
|
|
||||||
|
|
||||||
/* ============================================================================================== */
|
/* ============================================================================================== */
|
||||||
/* Internal context and table types */
|
/* Internal context and table types */
|
||||||
|
|
|
@ -28,9 +28,14 @@
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <inttypes.h>
|
|
||||||
#include <Zydis/Formatter.h>
|
#include <Zydis/Formatter.h>
|
||||||
#include <Zydis/Utils.h>
|
#include <Zydis/Utils.h>
|
||||||
|
#include <Zydis/CommonTypes.h>
|
||||||
|
|
||||||
|
#if defined(ZYDIS_WINKERNEL)
|
||||||
|
# include <ntddk.h>
|
||||||
|
# include <Ntstrsafe.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
/* ============================================================================================== */
|
/* ============================================================================================== */
|
||||||
/* String formatting */
|
/* String formatting */
|
||||||
|
@ -68,6 +73,24 @@ enum ZydisStringBufferAppendModes
|
||||||
/* Internal functions */
|
/* Internal functions */
|
||||||
/* ---------------------------------------------------------------------------------------------- */
|
/* ---------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
#if defined(ZYDIS_WINKERNEL)
|
||||||
|
static int ZydisVSNPrintF(char* s, size_t n, const char* format, va_list arg)
|
||||||
|
{
|
||||||
|
size_t bytesRemaining;
|
||||||
|
NTSTATUS ret = RtlStringCchVPrintfExA(
|
||||||
|
s, n, NULL, &bytesRemaining, 0, format, arg
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!NT_SUCCESS(ret)) return -1;
|
||||||
|
return (int)(n - bytesRemaining);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
static int ZydisVSNPrintF(char* s, size_t n, const char* format, va_list arg)
|
||||||
|
{
|
||||||
|
return vsnprintf(s, n, format, arg);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Appends the @c text to the given @c buffer and increases the string-buffer pointer by
|
* @brief Appends the @c text to the given @c buffer and increases the string-buffer pointer by
|
||||||
* the number of chars written.
|
* the number of chars written.
|
||||||
|
@ -137,7 +160,7 @@ static ZydisStatus ZydisStringBufferAppendFormat(char** buffer, size_t bufferLen
|
||||||
|
|
||||||
va_list arglist;
|
va_list arglist;
|
||||||
va_start(arglist, format);
|
va_start(arglist, format);
|
||||||
int w = vsnprintf(*buffer, bufferLen, format, arglist);
|
int w = ZydisVSNPrintF(*buffer, bufferLen, format, arglist);
|
||||||
if ((w < 0) || ((size_t)w >= bufferLen))
|
if ((w < 0) || ((size_t)w >= bufferLen))
|
||||||
{
|
{
|
||||||
va_end(arglist);
|
va_end(arglist);
|
||||||
|
|
|
@ -24,7 +24,6 @@
|
||||||
|
|
||||||
***************************************************************************************************/
|
***************************************************************************************************/
|
||||||
|
|
||||||
#include <stdint.h>
|
|
||||||
#include <Zydis/Utils.h>
|
#include <Zydis/Utils.h>
|
||||||
|
|
||||||
/* ============================================================================================== */
|
/* ============================================================================================== */
|
||||||
|
|
|
@ -95,7 +95,7 @@ int main(int argc, char** argv)
|
||||||
|
|
||||||
// TODO: Remove
|
// TODO: Remove
|
||||||
// DEBUG CODE START
|
// DEBUG CODE START
|
||||||
#if 1
|
#if 0
|
||||||
for (size_t i = 0; i < instruction.length; ++i)
|
for (size_t i = 0; i < instruction.length; ++i)
|
||||||
{
|
{
|
||||||
printf("%02X ", *(readBuf + readOffs + i));
|
printf("%02X ", *(readBuf + readOffs + i));
|
||||||
|
|
Loading…
Reference in New Issue