C ++ и структура контекста - PullRequest
       12

C ++ и структура контекста

0 голосов
/ 15 декабря 2010

Кто-нибудь знает, где можно найти информацию о полях структуры CONTEXT в C ++?

Ответы [ 3 ]

4 голосов
/ 15 декабря 2010

Как утверждает @bcsanches, это Windows API.Это будет полностью зависеть от процессора.Посмотрите структуру в ваших собственных заголовках.

На моих заголовках она отображается как:

//
// Context Frame
//
//  This frame has a several purposes: 1) it is used as an argument to
//  NtContinue, 2) is is used to constuct a call frame for APC delivery,
//  and 3) it is used in the user level thread creation routines.
//
//
// The flags field within this record controls the contents of a CONTEXT
// record.
//
// If the context record is used as an input parameter, then for each
// portion of the context record controlled by a flag whose value is
// set, it is assumed that that portion of the context record contains
// valid context. If the context record is being used to modify a threads
// context, then only that portion of the threads context is modified.
//
// If the context record is used as an output parameter to capture the
// context of a thread, then only those portions of the thread's context
// corresponding to set flags will be returned.
//
// CONTEXT_CONTROL specifies SegSs, Rsp, SegCs, Rip, and EFlags.
//
// CONTEXT_INTEGER specifies Rax, Rcx, Rdx, Rbx, Rbp, Rsi, Rdi, and R8-R15.
//
// CONTEXT_SEGMENTS specifies SegDs, SegEs, SegFs, and SegGs.
//
// CONTEXT_DEBUG_REGISTERS specifies Dr0-Dr3 and Dr6-Dr7.
//
// CONTEXT_MMX_REGISTERS specifies the floating point and extended registers
//     Mm0/St0-Mm7/St7 and Xmm0-Xmm15).
//

typedef struct DECLSPEC_ALIGN(16) _CONTEXT {

    //
    // Register parameter home addresses.
    //
    // N.B. These fields are for convience - they could be used to extend the
    //      context record in the future.
    //

    DWORD64 P1Home;
    DWORD64 P2Home;
    DWORD64 P3Home;
    DWORD64 P4Home;
    DWORD64 P5Home;
    DWORD64 P6Home;

    //
    // Control flags.
    //

    DWORD ContextFlags;
    DWORD MxCsr;

    //
    // Segment Registers and processor flags.
    //

    WORD   SegCs;
    WORD   SegDs;
    WORD   SegEs;
    WORD   SegFs;
    WORD   SegGs;
    WORD   SegSs;
    DWORD EFlags;

    //
    // Debug registers
    //

    DWORD64 Dr0;
    DWORD64 Dr1;
    DWORD64 Dr2;
    DWORD64 Dr3;
    DWORD64 Dr6;
    DWORD64 Dr7;

    //
    // Integer registers.
    //

    DWORD64 Rax;
    DWORD64 Rcx;
    DWORD64 Rdx;
    DWORD64 Rbx;
    DWORD64 Rsp;
    DWORD64 Rbp;
    DWORD64 Rsi;
    DWORD64 Rdi;
    DWORD64 R8;
    DWORD64 R9;
    DWORD64 R10;
    DWORD64 R11;
    DWORD64 R12;
    DWORD64 R13;
    DWORD64 R14;
    DWORD64 R15;

    //
    // Program counter.
    //

    DWORD64 Rip;

    //
    // Floating point state.
    //

    union {
        XMM_SAVE_AREA32 FltSave;
        struct {
            M128A Header[2];
            M128A Legacy[8];
            M128A Xmm0;
            M128A Xmm1;
            M128A Xmm2;
            M128A Xmm3;
            M128A Xmm4;
            M128A Xmm5;
            M128A Xmm6;
            M128A Xmm7;
            M128A Xmm8;
            M128A Xmm9;
            M128A Xmm10;
            M128A Xmm11;
            M128A Xmm12;
            M128A Xmm13;
            M128A Xmm14;
            M128A Xmm15;
        };
    };

    //
    // Vector registers.
    //

    M128A VectorRegister[26];
    DWORD64 VectorControl;

    //
    // Special debug control registers.
    //

    DWORD64 DebugControl;
    DWORD64 LastBranchToRip;
    DWORD64 LastBranchFromRip;
    DWORD64 LastExceptionToRip;
    DWORD64 LastExceptionFromRip;
} CONTEXT, *PCONTEXT;

, но она может отличаться для вашей платформы.Обратите внимание, что если вы пишете код, который зависит от какой-либо конкретной версии структуры CONTEXT, ваш код не будет компилироваться, когда вы ориентируетесь на другую платформу, например, пытаетесь собрать для x86 из кода x64 или наоборот.действительно следует рассматривать эту структуру как непрозрачный объект, если у вас нет действительно хороших (примечание: большинство причин не являются действительно хорошими ) причинами делать иначе.Этот материал должен содержаться в недрах hal.dll, ntoskrnl.exe и ntdll.dll, а не в вашем коде.

3 голосов
/ 15 декабря 2010

Правильно сказано в документации:

Содержит данные регистра для конкретного процессора.Система использует структуры CONTEXT для выполнения различных внутренних операций. Обратитесь к заголовочному файлу WinNT.h для определения этой структуры для каждой архитектуры процессора .

Так что вам нужно проверить свою платформу.Найдите определение в WinNT.h.

0 голосов
/ 10 мая 2016

Если вы не пишете код на языке ассемблера, а затем хотите написать обработчик исключений на языке ассемблера, у вас не должно быть никакой необходимости или информации о CONTEXT содержимом структуры.

Если вы хотитеписать логику в ассемблерном коде и хотеть вызывать ее из C ++, и вы хотите использовать обработку исключений (например, перехватывать деления на ноль или исключения SSE, которые, вероятно, следует предотвратить с помощью таких схем, как проверка данных в любом случае), тогда вы, вероятно,лучше оставить обработку исключений для кода C ++, который вызывает вашу процедуру на языке ассемблера.

Это будет намного менее беспорядочным, потому что тогда вам не придется суетиться с тем, что код C ++ делает со своей стороны относительноОбработка исключений.Гораздо проще и проще заставить логику вашего кода сборки работать так, чтобы она не создавала исключения.Кроме того, это должно сделать ваш код значительно более эффективным и изящным в том, как он обрабатывает проблемы.

Помните, что механизмы обработки исключений были изобретены для того, чтобы служить защитной сеткой и крайней мерой для спасения программного обеспечения отпросто грохотать и гореть экстравагантно, когда происходит что-то странное и неожиданное.Выдающие исключения должны быть скорее исключением, чем правилом, поэтому их называют «исключениями».

...