windows-nt/Source/XPSP1/NT/base/published/ntxcapi.w
2020-09-26 16:20:57 +08:00

366 lines
7 KiB
OpenEdge ABL

/*++ BUILD Version: 0001 // Increment this if a change has global effects
Copyright (c) Microsoft Corporation. All rights reserved.
Module Name:
ntxcapi.h
Abstract:
This module contains procedure prototypes and data structures
that support structured exception handling.
Author:
Mark Lucovsky (markl) 29-Jun-1989
Revision History:
--*/
#ifndef _NTXCAPI_
#define _NTXCAPI_
#if _MSC_VER > 1000
#pragma once
#endif
#ifdef __cplusplus
extern "C" {
#endif
// begin_ntddk begin_wdm
//
// Exception flag definitions.
//
// begin_winnt
#define EXCEPTION_NONCONTINUABLE 0x1 // Noncontinuable exception
// end_winnt
// end_ntddk end_wdm
#define EXCEPTION_UNWINDING 0x2 // Unwind is in progress
#define EXCEPTION_EXIT_UNWIND 0x4 // Exit unwind is in progress
#define EXCEPTION_STACK_INVALID 0x8 // Stack out of limits or unaligned
#define EXCEPTION_NESTED_CALL 0x10 // Nested exception handler call
#define EXCEPTION_TARGET_UNWIND 0x20 // Target unwind in progress
#define EXCEPTION_COLLIDED_UNWIND 0x40 // Collided exception handler call
#define EXCEPTION_UNWIND (EXCEPTION_UNWINDING | EXCEPTION_EXIT_UNWIND | \
EXCEPTION_TARGET_UNWIND | EXCEPTION_COLLIDED_UNWIND)
#define IS_UNWINDING(Flag) ((Flag & EXCEPTION_UNWIND) != 0)
#define IS_DISPATCHING(Flag) ((Flag & EXCEPTION_UNWIND) == 0)
#define IS_TARGET_UNWIND(Flag) (Flag & EXCEPTION_TARGET_UNWIND)
// begin_ntddk begin_wdm begin_nthal
//
// Define maximum number of exception parameters.
//
// begin_winnt
#define EXCEPTION_MAXIMUM_PARAMETERS 15 // maximum number of exception parameters
//
// Exception record definition.
//
typedef struct _EXCEPTION_RECORD {
NTSTATUS ExceptionCode;
ULONG ExceptionFlags;
struct _EXCEPTION_RECORD *ExceptionRecord;
PVOID ExceptionAddress;
ULONG NumberParameters;
ULONG_PTR ExceptionInformation[EXCEPTION_MAXIMUM_PARAMETERS];
} EXCEPTION_RECORD;
typedef EXCEPTION_RECORD *PEXCEPTION_RECORD;
typedef struct _EXCEPTION_RECORD32 {
NTSTATUS ExceptionCode;
ULONG ExceptionFlags;
ULONG ExceptionRecord;
ULONG ExceptionAddress;
ULONG NumberParameters;
ULONG ExceptionInformation[EXCEPTION_MAXIMUM_PARAMETERS];
} EXCEPTION_RECORD32, *PEXCEPTION_RECORD32;
typedef struct _EXCEPTION_RECORD64 {
NTSTATUS ExceptionCode;
ULONG ExceptionFlags;
ULONG64 ExceptionRecord;
ULONG64 ExceptionAddress;
ULONG NumberParameters;
ULONG __unusedAlignment;
ULONG64 ExceptionInformation[EXCEPTION_MAXIMUM_PARAMETERS];
} EXCEPTION_RECORD64, *PEXCEPTION_RECORD64;
//
// Typedef for pointer returned by exception_info()
//
typedef struct _EXCEPTION_POINTERS {
PEXCEPTION_RECORD ExceptionRecord;
PCONTEXT ContextRecord;
} EXCEPTION_POINTERS, *PEXCEPTION_POINTERS;
// end_winnt
// end_ntddk end_wdm end_nthal
//
// Define IEEE exception information.
//
// Define 32-, 64-, 80-, and 128-bit IEEE floating operand structures.
//
typedef struct _FP_32 {
ULONG W[1];
} FP_32, *PFP_32;
typedef struct _FP_64 {
ULONG W[2];
} FP_64, *PFP_64;
typedef struct _FP_80 {
ULONG W[3];
} FP_80, *PFP_80;
typedef struct _FP_128 {
ULONG W[4];
} FP_128, *PFP_128;
//
// Define IEEE compare result values.
//
typedef enum _FP_IEEE_COMPARE_RESULT {
FpCompareEqual,
FpCompareGreater,
FpCompareLess,
FpCompareUnordered
} FP_IEEE_COMPARE_RESULT;
//
// Define IEEE format and result precision values.
//
typedef enum _FP__IEEE_FORMAT {
FpFormatFp32,
FpFormatFp64,
FpFormatFp80,
FpFormatFp128,
FpFormatI16,
FpFormatI32,
FpFormatI64,
FpFormatU16,
FpFormatU32,
FpFormatU64,
FpFormatCompare,
FpFormatString
} FP_IEEE_FORMAT;
//
// Define IEEE operation code values.
//
typedef enum _FP_IEEE_OPERATION_CODE {
FpCodeUnspecified,
FpCodeAdd,
FpCodeSubtract,
FpCodeMultiply,
FpCodeDivide,
FpCodeSquareRoot,
FpCodeRemainder,
FpCodeCompare,
FpCodeConvert,
FpCodeRound,
FpCodeTruncate,
FpCodeFloor,
FpCodeCeil,
FpCodeAcos,
FpCodeAsin,
FpCodeAtan,
FpCodeAtan2,
FpCodeCabs,
FpCodeCos,
FpCodeCosh,
FpCodeExp,
FpCodeFabs,
FpCodeFmod,
FpCodeFrexp,
FpCodeHypot,
FpCodeLdexp,
FpCodeLog,
FpCodeLog10,
FpCodeModf,
FpCodePow,
FpCodeSin,
FpCodeSinh,
FpCodeTan,
FpCodeTanh,
FpCodeY0,
FpCodeY1,
FpCodeYn
} FP_OPERATION_CODE;
//
// Define IEEE rounding modes.
//
typedef enum _FP__IEEE_ROUNDING_MODE {
FpRoundNearest,
FpRoundMinusInfinity,
FpRoundPlusInfinity,
FpRoundChopped
} FP_IEEE_ROUNDING_MODE;
//
// Define IEEE floating exception operand structure.
//
typedef struct _FP_IEEE_VALUE {
union {
SHORT I16Value;
USHORT U16Value;
LONG I32Value;
ULONG U32Value;
PVOID StringValue;
ULONG CompareValue;
FP_32 Fp32Value;
LARGE_INTEGER I64Value;
ULARGE_INTEGER U64Value;
FP_64 Fp64Value;
FP_80 Fp80Value;
FP_128 Fp128Value;
} Value;
struct {
ULONG RoundingMode : 2;
ULONG Inexact : 1;
ULONG Underflow : 1;
ULONG Overflow : 1;
ULONG ZeroDivide : 1;
ULONG InvalidOperation : 1;
ULONG OperandValid : 1;
ULONG Format : 4;
ULONG Precision : 4;
ULONG Operation : 12;
ULONG Spare : 3;
ULONG HardwareException : 1;
} Control;
} FP_IEEE_VALUE, *PFP_IEEE_VALUE;
//
// Define IEEE exception infomation structure.
//
#include "pshpack4.h"
typedef struct _FP_IEEE_RECORD {
FP_IEEE_VALUE Operand1;
FP_IEEE_VALUE Operand2;
FP_IEEE_VALUE Result;
} FP_IEEE_RECORD, *PFP_IEEE_RECORD;
#include "poppack.h"
//
// Exception dispatcher routine definition.
//
NTSYSAPI
BOOLEAN
NTAPI
RtlDispatchException (
IN PEXCEPTION_RECORD ExceptionRecord,
IN PCONTEXT ContextRecord
);
//
// Exception handling procedure prototypes.
//
NTSYSAPI
VOID
NTAPI
RtlRaiseStatus (
IN NTSTATUS Status
);
NTSYSAPI
VOID
NTAPI
RtlRaiseException (
IN PEXCEPTION_RECORD
);
NTSYSAPI
VOID
NTAPI
RtlUnwind (
IN PVOID TargetFrame OPTIONAL,
IN PVOID TargetIp OPTIONAL,
IN PEXCEPTION_RECORD ExceptionRecord OPTIONAL,
IN PVOID ReturnValue
);
#if defined(_AMD64_)
NTSYSAPI
VOID
NTAPI
RtlUnwindEx (
IN PVOID TargetFrame OPTIONAL,
IN PVOID TargetIp OPTIONAL,
IN PEXCEPTION_RECORD ExceptionRecord OPTIONAL,
IN PVOID ReturnValue,
IN PCONTEXT ContextRecord,
IN PUNWIND_HISTORY_TABLE HistoryTable OPTIONAL
);
#elif defined(_IA64_)
NTSYSAPI
VOID
NTAPI
RtlUnwind2 (
IN FRAME_POINTERS TargetFrame OPTIONAL,
IN PVOID TargetIp OPTIONAL,
IN PEXCEPTION_RECORD ExceptionRecord OPTIONAL,
IN PVOID ReturnValue,
IN PCONTEXT ContextRecord
);
#endif
//
// Continue execution.
//
NTSYSCALLAPI
NTSTATUS
NTAPI
NtContinue (
IN PCONTEXT ContextRecord,
IN BOOLEAN TestAlert
);
//
// Raise exception.
//
NTSYSCALLAPI
NTSTATUS
NTAPI
NtRaiseException (
IN PEXCEPTION_RECORD ExceptionRecord,
IN PCONTEXT ContextRecord,
IN BOOLEAN FirstChance
);
#ifdef __cplusplus
}
#endif
#endif //_NTXCAPI_