Der Header
Der folgende Header stellt eine der Headerstile dar, die von der aktuellen Version von MIDL generiert werden können. Der Einfachheit halber finden Sie hier die vollständige Liste der Kopfzeilenfelder.
(–Oif-Header )
handle_type<1>
Oi_flags<1>
[rpc_flags<4>]
proc_num<2>
stack_size<2>
[explicit_handle_description<>]
constant_client_buffer_size<2>
constant_server_buffer_size<2>
INTERPRETER_OPT_FLAGS<1>
number_of_params<1>
Erweiterungen ab Windows 2000: <8> für 32-Bit, <12> für 64-Bit)
extension_version<1>
INTERPRETER_OPT_FLAGS2<1>
ClientCorrHint<2>
ServerCorrHint<2>
NotifyIndex<2>
[ FloatDoubleMask<2> ]
Der extension_version<1> gibt die Größe des Erweiterungsabschnitts in Bytes an. Dies ermöglicht es der aktuellen NDR-Engine, den Erweiterungsabschnitt ordnungsgemäß zu durchlaufen, selbst wenn der Abschnitt aus einer späteren Compilerversion mit mehr Feldern stammt, als die aktuelle Engine versteht.
Die INTERPRETER_OPT_FLAGS2 werden wie folgt definiert:
typedef struct
{
unsigned char HasNewCorrDesc : 1; // 0x01
unsigned char ClientCorrCheck : 1; // 0x02
unsigned char ServerCorrCheck : 1; // 0x04
unsigned char HasNotify : 1; // 0x08
unsigned char HasNotify2 : 1; // 0x10
unsigned char Unused : 3;
} INTERPRETER_OPT_FLAGS2, *PINTERPRETER_OPT_FLAGS2;
Das HasNewCorrDesc-Element gibt an, ob neue Korrelationsdeskriptoren in den vom Compiler generierten Formatzeichenfolgen verwendet werden. Der neue Korrelationsdeskriptor bezieht sich auf die Denial-of-Attack-Funktionalität. Die Member ClientCorrCheck und ServerCorrCheck werden festgelegt, wenn die Routine die Korrelationsprüfung auf der angegebenen Seite benötigt.
Die Flags HasNotify und HasNotify2 geben an, dass die Routine das Benachrichtigungsfeature verwendet, wie durch die Attribute [notify] bzw. [notify_flag] definiert.
Der ClientCorrHint-Member ist ein Hinweis auf die Cachegröße auf der Clientseite, und ServerCorrHint ist ein Hinweis auf der Serverseite. Wenn die Größe 0 (null) lautet, sollte eine Standardgröße verwendet werden.
Das NotifyIndex-Element ist ein Index für eine Benachrichtigungsroutine, sofern verwendet.
Das FloatDoubleMask-Element behandelt das Problem eines Gleitkommaarguments für 64-Bit-Windows. Dieses Feld wird nur für 64-Bit-Stubs generiert. Die Maske wird für die Assemblyroutinen benötigt, die Register vom/in den virtuellen Stapel herunterladen/hochladen, um Gleitkommaargumente und Registrierungen ordnungsgemäß zu verarbeiten. Die Maske besteht aus 2 Bits pro Argument bzw. pro Gleitkommaregister. Die Codierung sieht wie folgt aus: Die am wenigsten signifikanten Bits entsprechen dem ersten FP-Register, die nächsten 2 Bits entsprechen dem zweiten Register usw.
Hinweis
Bei Objektroutinen endet das erste Argument im zweiten Register, da dieser Zeiger zuerst ist. Für jedes Register ist die Bedeutung von Bits wie in der folgenden Tabelle dargestellt.
Bits | Bedeutung |
---|---|
01 | Ein Gleitkommawert sollte in das Register geladen werden. |
10 | Ein double-Wert sollte in das Register geladen werden. |
00 und 11 sind ungültige Werte für die Bits.
Derzeit gibt es acht FP-Register in einem Intel Architecture 64-Bit-Prozessor, daher kann die Maske nur 16b niedrigste Bits festlegen. Die Maskengröße wurde auf insgesamt 16 Bit festgelegt, basierend auf der unveränderten C-Compilermaske.
Optimieren von Headern für die Leistung
Um Code zu vereinfachen und die Leistung zu verbessern, versucht der Compiler, nach Möglichkeit einen Header mit fester Größe zu generieren. Insbesondere wird der folgende Header für asynchrones DCOM verwendet:
typedef struct _NDR_DCOM_OI2_PROC_HEADER
{
unsigned char HandleType; // The Oi header
INTERPRETER_FLAGS OldOiFlags; //
unsigned short RpcFlagsLow; //
unsigned short RpcFlagsHi; //
unsigned short ProcNum; //
unsigned short StackSize; //
// expl handle descr is never generated //
unsigned short ClientBufferSize; // The Oi2 header
unsigned short ServerBufferSize; //
INTERPRETER_OPT_FLAGS Oi2Flags; //
unsigned char NumberParams; //
} NDR_DCOM_OI2_PROC_HEADER, *PNDR_DCOM_OI2_PROC_HEADER;