//----------------------------------------------------------------------------- // // Copyright (c) Microsoft. All rights reserved. // This code is licensed under the Microsoft Public License. // THIS CODE IS PROVIDED *AS IS* WITHOUT WARRANTY OF // ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING ANY // IMPLIED WARRANTIES OF FITNESS FOR A PARTICULAR // PURPOSE, MERCHANTABILITY, OR NON-INFRINGEMENT. // //----------------------------------------------------------------------------- // // File: CvInfo.cs // // Generic CodeView information definitions // // Structures, constants, etc. for accessing and interpreting // CodeView information. // // The master copy of this file resides in the langapi project (in C++). // All Microsoft projects are required to use the master copy without // modification. Modification of the master version or a copy // without consultation with all parties concerned is extremely // risky. // // When this file is modified, the corresponding documentation file // omfdeb.doc in the langapi project must be updated. // // This is a read-only copy of the C++ file converted to C#. // using System; namespace Microsoft.Cci.Pdb { internal struct FLOAT10 { internal byte Data_0; internal byte Data_1; internal byte Data_2; internal byte Data_3; internal byte Data_4; internal byte Data_5; internal byte Data_6; internal byte Data_7; internal byte Data_8; internal byte Data_9; }; internal enum CV_SIGNATURE { C6=0, // Actual signature is >64K C7=1, // First explicit signature C11=2, // C11 (vc5.x) 32-bit types C13=4, // C13 (vc7.x) zero terminated names RESERVERD=5, // All signatures from 5 to 64K are reserved }; // CodeView Symbol and Type OMF type information is broken up into two // ranges. Type indices less than 0x1000 describe type information // that is frequently used. Type indices above 0x1000 are used to // describe more complex features such as functions, arrays and // structures. // // Primitive types have predefined meaning that is encoded in the // values of the various bit fields in the value. // // A CodeView primitive type is defined as: // // 1 1 // 1 089 7654 3 210 // r mode type r sub // // Where // mode is the pointer mode // type is a type indicator // sub is a subtype enumeration // r is a reserved field // // See Microsoft Symbol and Type OMF (Version 4.0) for more // information. // // pointer mode enumeration values internal enum CV_prmode { CV_TM_DIRECT=0, // mode is not a pointer CV_TM_NPTR32=4, // mode is a 32 bit near pointer CV_TM_NPTR64=6, // mode is a 64 bit near pointer CV_TM_NPTR128=7, // mode is a 128 bit near pointer }; // type enumeration values internal enum CV_type { CV_SPECIAL=0x00, // special type size values CV_SIGNED=0x01, // signed integral size values CV_UNSIGNED=0x02, // unsigned integral size values CV_BOOLEAN=0x03, // Boolean size values CV_REAL=0x04, // real number size values CV_COMPLEX=0x05, // complex number size values CV_SPECIAL2=0x06, // second set of special types CV_INT=0x07, // integral (int) values CV_CVRESERVED=0x0f, }; // subtype enumeration values for CV_SPECIAL internal enum CV_special { CV_SP_NOTYPE=0x00, CV_SP_ABS=0x01, CV_SP_SEGMENT=0x02, CV_SP_VOID=0x03, CV_SP_CURRENCY=0x04, CV_SP_NBASICSTR=0x05, CV_SP_FBASICSTR=0x06, CV_SP_NOTTRANS=0x07, CV_SP_HRESULT=0x08, }; // subtype enumeration values for CV_SPECIAL2 internal enum CV_special2 { CV_S2_BIT=0x00, CV_S2_PASCHAR=0x01, // Pascal CHAR }; // subtype enumeration values for CV_SIGNED, CV_UNSIGNED and CV_BOOLEAN internal enum CV_integral { CV_IN_1BYTE=0x00, CV_IN_2BYTE=0x01, CV_IN_4BYTE=0x02, CV_IN_8BYTE=0x03, CV_IN_16BYTE=0x04, }; // subtype enumeration values for CV_REAL and CV_COMPLEX internal enum CV_real { CV_RC_REAL32=0x00, CV_RC_REAL64=0x01, CV_RC_REAL80=0x02, CV_RC_REAL128=0x03, }; // subtype enumeration values for CV_INT (really int) internal enum CV_int { CV_RI_CHAR=0x00, CV_RI_INT1=0x00, CV_RI_WCHAR=0x01, CV_RI_UINT1=0x01, CV_RI_INT2=0x02, CV_RI_UINT2=0x03, CV_RI_INT4=0x04, CV_RI_UINT4=0x05, CV_RI_INT8=0x06, CV_RI_UINT8=0x07, CV_RI_INT16=0x08, CV_RI_UINT16=0x09, }; internal struct CV_PRIMITIVE_TYPE { const uint CV_MMASK = 0x700; // mode mask const uint CV_TMASK = 0x0f0; // type mask const uint CV_SMASK = 0x00f; // subtype mask const int CV_MSHIFT = 8; // primitive mode right shift count const int CV_TSHIFT = 4; // primitive type right shift count const int CV_SSHIFT = 0; // primitive subtype right shift count // function to extract primitive mode, type and size //internal static CV_prmode CV_MODE(TYPE_ENUM typ) { // return (CV_prmode)((((uint)typ) & CV_MMASK) >> CV_MSHIFT); //} //internal static CV_type CV_TYPE(TYPE_ENUM typ) { // return (CV_type)((((uint)typ) & CV_TMASK) >> CV_TSHIFT); //} //internal static uint CV_SUBT(TYPE_ENUM typ) { // return ((((uint)typ) & CV_SMASK) >> CV_SSHIFT); //} // functions to check the type of a primitive //internal static bool CV_TYP_IS_DIRECT(TYPE_ENUM typ) { // return (CV_MODE(typ) == CV_prmode.CV_TM_DIRECT); //} //internal static bool CV_TYP_IS_PTR(TYPE_ENUM typ) { // return (CV_MODE(typ) != CV_prmode.CV_TM_DIRECT); //} //internal static bool CV_TYP_IS_SIGNED(TYPE_ENUM typ) { // return // (((CV_TYPE(typ) == CV_type.CV_SIGNED) && CV_TYP_IS_DIRECT(typ)) || // (typ == TYPE_ENUM.T_INT1) || // (typ == TYPE_ENUM.T_INT2) || // (typ == TYPE_ENUM.T_INT4) || // (typ == TYPE_ENUM.T_INT8) || // (typ == TYPE_ENUM.T_INT16) || // (typ == TYPE_ENUM.T_RCHAR)); //} //internal static bool CV_TYP_IS_UNSIGNED(TYPE_ENUM typ) { // return (((CV_TYPE(typ) == CV_type.CV_UNSIGNED) && CV_TYP_IS_DIRECT(typ)) || // (typ == TYPE_ENUM.T_UINT1) || // (typ == TYPE_ENUM.T_UINT2) || // (typ == TYPE_ENUM.T_UINT4) || // (typ == TYPE_ENUM.T_UINT8) || // (typ == TYPE_ENUM.T_UINT16)); //} //internal static bool CV_TYP_IS_REAL(TYPE_ENUM typ) { // return ((CV_TYPE(typ) == CV_type.CV_REAL) && CV_TYP_IS_DIRECT(typ)); //} const uint CV_FIRST_NONPRIM = 0x1000; //internal static bool CV_IS_PRIMITIVE(TYPE_ENUM typ) { // return ((uint)(typ) < CV_FIRST_NONPRIM); //} //internal static bool CV_TYP_IS_COMPLEX(TYPE_ENUM typ) { // return ((CV_TYPE(typ) == CV_type.CV_COMPLEX) && CV_TYP_IS_DIRECT(typ)); //} //internal static bool CV_IS_INTERNAL_PTR(TYPE_ENUM typ) { // return (CV_IS_PRIMITIVE(typ) && // CV_TYPE(typ) == CV_type.CV_CVRESERVED && // CV_TYP_IS_PTR(typ)); //} } // selected values for type_index - for a more complete definition, see // Microsoft Symbol and Type OMF document // Special Types internal enum TYPE_ENUM { // Special Types T_NOTYPE=0x0000, // uncharacterized type (no type) T_ABS=0x0001, // absolute symbol T_SEGMENT=0x0002, // segment type T_VOID=0x0003, // void T_HRESULT=0x0008, // OLE/COM HRESULT T_32PHRESULT=0x0408, // OLE/COM HRESULT __ptr32// T_64PHRESULT=0x0608, // OLE/COM HRESULT __ptr64// T_PVOID=0x0103, // near pointer to void T_PFVOID=0x0203, // far pointer to void T_PHVOID=0x0303, // huge pointer to void T_32PVOID=0x0403, // 32 bit pointer to void T_64PVOID=0x0603, // 64 bit pointer to void T_CURRENCY=0x0004, // BASIC 8 byte currency value T_NOTTRANS=0x0007, // type not translated by cvpack T_BIT=0x0060, // bit T_PASCHAR=0x0061, // Pascal CHAR // Character types T_CHAR=0x0010, // 8 bit signed T_32PCHAR=0x0410, // 32 bit pointer to 8 bit signed T_64PCHAR=0x0610, // 64 bit pointer to 8 bit signed T_UCHAR=0x0020, // 8 bit unsigned T_32PUCHAR=0x0420, // 32 bit pointer to 8 bit unsigned T_64PUCHAR=0x0620, // 64 bit pointer to 8 bit unsigned // really a character types T_RCHAR=0x0070, // really a char T_32PRCHAR=0x0470, // 32 bit pointer to a real char T_64PRCHAR=0x0670, // 64 bit pointer to a real char // really a wide character types T_WCHAR=0x0071, // wide char T_32PWCHAR=0x0471, // 32 bit pointer to a wide char T_64PWCHAR=0x0671, // 64 bit pointer to a wide char // 8 bit int types T_INT1=0x0068, // 8 bit signed int T_32PINT1=0x0468, // 32 bit pointer to 8 bit signed int T_64PINT1=0x0668, // 64 bit pointer to 8 bit signed int T_UINT1=0x0069, // 8 bit unsigned int T_32PUINT1=0x0469, // 32 bit pointer to 8 bit unsigned int T_64PUINT1=0x0669, // 64 bit pointer to 8 bit unsigned int // 16 bit short types T_SHORT=0x0011, // 16 bit signed T_32PSHORT=0x0411, // 32 bit pointer to 16 bit signed T_64PSHORT=0x0611, // 64 bit pointer to 16 bit signed T_USHORT=0x0021, // 16 bit unsigned T_32PUSHORT=0x0421, // 32 bit pointer to 16 bit unsigned T_64PUSHORT=0x0621, // 64 bit pointer to 16 bit unsigned // 16 bit int types T_INT2=0x0072, // 16 bit signed int T_32PINT2=0x0472, // 32 bit pointer to 16 bit signed int T_64PINT2=0x0672, // 64 bit pointer to 16 bit signed int T_UINT2=0x0073, // 16 bit unsigned int T_32PUINT2=0x0473, // 32 bit pointer to 16 bit unsigned int T_64PUINT2=0x0673, // 64 bit pointer to 16 bit unsigned int // 32 bit long types T_LONG=0x0012, // 32 bit signed T_ULONG=0x0022, // 32 bit unsigned T_32PLONG=0x0412, // 32 bit pointer to 32 bit signed T_32PULONG=0x0422, // 32 bit pointer to 32 bit unsigned T_64PLONG=0x0612, // 64 bit pointer to 32 bit signed T_64PULONG=0x0622, // 64 bit pointer to 32 bit unsigned // 32 bit int types T_INT4=0x0074, // 32 bit signed int T_32PINT4=0x0474, // 32 bit pointer to 32 bit signed int T_64PINT4=0x0674, // 64 bit pointer to 32 bit signed int T_UINT4=0x0075, // 32 bit unsigned int T_32PUINT4=0x0475, // 32 bit pointer to 32 bit unsigned int T_64PUINT4=0x0675, // 64 bit pointer to 32 bit unsigned int // 64 bit quad types T_QUAD=0x0013, // 64 bit signed T_32PQUAD=0x0413, // 32 bit pointer to 64 bit signed T_64PQUAD=0x0613, // 64 bit pointer to 64 bit signed T_UQUAD=0x0023, // 64 bit unsigned T_32PUQUAD=0x0423, // 32 bit pointer to 64 bit unsigned T_64PUQUAD=0x0623, // 64 bit pointer to 64 bit unsigned // 64 bit int types T_INT8=0x0076, // 64 bit signed int T_32PINT8=0x0476, // 32 bit pointer to 64 bit signed int T_64PINT8=0x0676, // 64 bit pointer to 64 bit signed int T_UINT8=0x0077, // 64 bit unsigned int T_32PUINT8=0x0477, // 32 bit pointer to 64 bit unsigned int T_64PUINT8=0x0677, // 64 bit pointer to 64 bit unsigned int // 128 bit octet types T_OCT=0x0014, // 128 bit signed T_32POCT=0x0414, // 32 bit pointer to 128 bit signed T_64POCT=0x0614, // 64 bit pointer to 128 bit signed T_UOCT=0x0024, // 128 bit unsigned T_32PUOCT=0x0424, // 32 bit pointer to 128 bit unsigned T_64PUOCT=0x0624, // 64 bit pointer to 128 bit unsigned // 128 bit int types T_INT16=0x0078, // 128 bit signed int T_32PINT16=0x0478, // 32 bit pointer to 128 bit signed int T_64PINT16=0x0678, // 64 bit pointer to 128 bit signed int T_UINT16=0x0079, // 128 bit unsigned int T_32PUINT16=0x0479, // 32 bit pointer to 128 bit unsigned int T_64PUINT16=0x0679, // 64 bit pointer to 128 bit unsigned int // 32 bit real types T_REAL32=0x0040, // 32 bit real T_32PREAL32=0x0440, // 32 bit pointer to 32 bit real T_64PREAL32=0x0640, // 64 bit pointer to 32 bit real // 64 bit real types T_REAL64=0x0041, // 64 bit real T_32PREAL64=0x0441, // 32 bit pointer to 64 bit real T_64PREAL64=0x0641, // 64 bit pointer to 64 bit real // 80 bit real types T_REAL80=0x0042, // 80 bit real T_32PREAL80=0x0442, // 32 bit pointer to 80 bit real T_64PREAL80=0x0642, // 64 bit pointer to 80 bit real // 128 bit real types T_REAL128=0x0043, // 128 bit real T_32PREAL128=0x0443, // 32 bit pointer to 128 bit real T_64PREAL128=0x0643, // 64 bit pointer to 128 bit real // 32 bit complex types T_CPLX32=0x0050, // 32 bit complex T_32PCPLX32=0x0450, // 32 bit pointer to 32 bit complex T_64PCPLX32=0x0650, // 64 bit pointer to 32 bit complex // 64 bit complex types T_CPLX64=0x0051, // 64 bit complex T_32PCPLX64=0x0451, // 32 bit pointer to 64 bit complex T_64PCPLX64=0x0651, // 64 bit pointer to 64 bit complex // 80 bit complex types T_CPLX80=0x0052, // 80 bit complex T_32PCPLX80=0x0452, // 32 bit pointer to 80 bit complex T_64PCPLX80=0x0652, // 64 bit pointer to 80 bit complex // 128 bit complex types T_CPLX128=0x0053, // 128 bit complex T_32PCPLX128=0x0453, // 32 bit pointer to 128 bit complex T_64PCPLX128=0x0653, // 64 bit pointer to 128 bit complex // boolean types T_BOOL08=0x0030, // 8 bit boolean T_32PBOOL08=0x0430, // 32 bit pointer to 8 bit boolean T_64PBOOL08=0x0630, // 64 bit pointer to 8 bit boolean T_BOOL16=0x0031, // 16 bit boolean T_32PBOOL16=0x0431, // 32 bit pointer to 18 bit boolean T_64PBOOL16=0x0631, // 64 bit pointer to 18 bit boolean T_BOOL32=0x0032, // 32 bit boolean T_32PBOOL32=0x0432, // 32 bit pointer to 32 bit boolean T_64PBOOL32=0x0632, // 64 bit pointer to 32 bit boolean T_BOOL64=0x0033, // 64 bit boolean T_32PBOOL64=0x0433, // 32 bit pointer to 64 bit boolean T_64PBOOL64=0x0633, // 64 bit pointer to 64 bit boolean }; // No leaf index can have a value of 0x0000. The leaf indices are // separated into ranges depending upon the use of the type record. // The second range is for the type records that are directly referenced // in symbols. The first range is for type records that are not // referenced by symbols but instead are referenced by other type // records. All type records must have a starting leaf index in these // first two ranges. The third range of leaf indices are used to build // up complex lists such as the field list of a class type record. No // type record can begin with one of the leaf indices. The fourth ranges // of type indices are used to represent numeric data in a symbol or // type record. These leaf indices are greater than 0x8000. At the // point that type or symbol processor is expecting a numeric field, the // next two bytes in the type record are examined. If the value is less // than 0x8000, then the two bytes contain the numeric value. If the // value is greater than 0x8000, then the data follows the leaf index in // a format specified by the leaf index. The final range of leaf indices // are used to force alignment of subfields within a complex type record.. // internal enum LEAF { // leaf indices starting records but referenced from symbol records LF_VTSHAPE=0x000a, LF_COBOL1=0x000c, LF_LABEL=0x000e, LF_NULL=0x000f, LF_NOTTRAN=0x0010, LF_ENDPRECOMP=0x0014, // not referenced from symbol LF_TYPESERVER_ST=0x0016, // not referenced from symbol // leaf indices starting records but referenced only from type records LF_LIST=0x0203, LF_REFSYM=0x020c, LF_ENUMERATE_ST=0x0403, // 32-bit type index versions of leaves, all have the 0x1000 bit set // LF_TI16_MAX=0x1000, LF_MODIFIER=0x1001, LF_POINTER=0x1002, LF_ARRAY_ST=0x1003, LF_CLASS_ST=0x1004, LF_STRUCTURE_ST=0x1005, LF_UNION_ST=0x1006, LF_ENUM_ST=0x1007, LF_PROCEDURE=0x1008, LF_MFUNCTION=0x1009, LF_COBOL0=0x100a, LF_BARRAY=0x100b, LF_DIMARRAY_ST=0x100c, LF_VFTPATH=0x100d, LF_PRECOMP_ST=0x100e, // not referenced from symbol LF_OEM=0x100f, // oem definable type string LF_ALIAS_ST=0x1010, // alias (typedef) type LF_OEM2=0x1011, // oem definable type string // leaf indices starting records but referenced only from type records LF_SKIP=0x1200, LF_ARGLIST=0x1201, LF_DEFARG_ST=0x1202, LF_FIELDLIST=0x1203, LF_DERIVED=0x1204, LF_BITFIELD=0x1205, LF_METHODLIST=0x1206, LF_DIMCONU=0x1207, LF_DIMCONLU=0x1208, LF_DIMVARU=0x1209, LF_DIMVARLU=0x120a, LF_BCLASS=0x1400, LF_VBCLASS=0x1401, LF_IVBCLASS=0x1402, LF_FRIENDFCN_ST=0x1403, LF_INDEX=0x1404, LF_MEMBER_ST=0x1405, LF_STMEMBER_ST=0x1406, LF_METHOD_ST=0x1407, LF_NESTTYPE_ST=0x1408, LF_VFUNCTAB=0x1409, LF_FRIENDCLS=0x140a, LF_ONEMETHOD_ST=0x140b, LF_VFUNCOFF=0x140c, LF_NESTTYPEEX_ST=0x140d, LF_MEMBERMODIFY_ST=0x140e, LF_MANAGED_ST=0x140f, // Types w/ SZ names LF_ST_MAX=0x1500, LF_TYPESERVER=0x1501, // not referenced from symbol LF_ENUMERATE=0x1502, LF_ARRAY=0x1503, LF_CLASS=0x1504, LF_STRUCTURE=0x1505, LF_UNION=0x1506, LF_ENUM=0x1507, LF_DIMARRAY=0x1508, LF_PRECOMP=0x1509, // not referenced from symbol LF_ALIAS=0x150a, // alias (typedef) type LF_DEFARG=0x150b, LF_FRIENDFCN=0x150c, LF_MEMBER=0x150d, LF_STMEMBER=0x150e, LF_METHOD=0x150f, LF_NESTTYPE=0x1510, LF_ONEMETHOD=0x1511, LF_NESTTYPEEX=0x1512, LF_MEMBERMODIFY=0x1513, LF_MANAGED=0x1514, LF_TYPESERVER2=0x1515, LF_NUMERIC=0x8000, LF_CHAR=0x8000, LF_SHORT=0x8001, LF_USHORT=0x8002, LF_LONG=0x8003, LF_ULONG=0x8004, LF_REAL32=0x8005, LF_REAL64=0x8006, LF_REAL80=0x8007, LF_REAL128=0x8008, LF_QUADWORD=0x8009, LF_UQUADWORD=0x800a, LF_COMPLEX32=0x800c, LF_COMPLEX64=0x800d, LF_COMPLEX80=0x800e, LF_COMPLEX128=0x800f, LF_VARSTRING=0x8010, LF_OCTWORD=0x8017, LF_UOCTWORD=0x8018, LF_DECIMAL=0x8019, LF_DATE=0x801a, LF_UTF8STRING=0x801b, LF_PAD0=0xf0, LF_PAD1=0xf1, LF_PAD2=0xf2, LF_PAD3=0xf3, LF_PAD4=0xf4, LF_PAD5=0xf5, LF_PAD6=0xf6, LF_PAD7=0xf7, LF_PAD8=0xf8, LF_PAD9=0xf9, LF_PAD10=0xfa, LF_PAD11=0xfb, LF_PAD12=0xfc, LF_PAD13=0xfd, LF_PAD14=0xfe, LF_PAD15=0xff, }; // end of leaf indices // Type enum for pointer records // Pointers can be one of the following types internal enum CV_ptrtype { CV_PTR_BASE_SEG=0x03, // based on segment CV_PTR_BASE_VAL=0x04, // based on value of base CV_PTR_BASE_SEGVAL=0x05, // based on segment value of base CV_PTR_BASE_ADDR=0x06, // based on address of base CV_PTR_BASE_SEGADDR=0x07, // based on segment address of base CV_PTR_BASE_TYPE=0x08, // based on type CV_PTR_BASE_SELF=0x09, // based on self CV_PTR_NEAR32=0x0a, // 32 bit pointer CV_PTR_64=0x0c, // 64 bit pointer CV_PTR_UNUSEDPTR=0x0d // first unused pointer type }; // Mode enum for pointers // Pointers can have one of the following modes internal enum CV_ptrmode { CV_PTR_MODE_PTR=0x00, // "normal" pointer CV_PTR_MODE_REF=0x01, // reference CV_PTR_MODE_PMEM=0x02, // pointer to data member CV_PTR_MODE_PMFUNC=0x03, // pointer to member function CV_PTR_MODE_RESERVED=0x04 // first unused pointer mode }; // enumeration for pointer-to-member types internal enum CV_pmtype { CV_PMTYPE_Undef=0x00, // not specified (pre VC8) CV_PMTYPE_D_Single=0x01, // member data, single inheritance CV_PMTYPE_D_Multiple=0x02, // member data, multiple inheritance CV_PMTYPE_D_Virtual=0x03, // member data, virtual inheritance CV_PMTYPE_D_General=0x04, // member data, most general CV_PMTYPE_F_Single=0x05, // member function, single inheritance CV_PMTYPE_F_Multiple=0x06, // member function, multiple inheritance CV_PMTYPE_F_Virtual=0x07, // member function, virtual inheritance CV_PMTYPE_F_General=0x08, // member function, most general }; // enumeration for method properties internal enum CV_methodprop { CV_MTvanilla=0x00, CV_MTvirtual=0x01, CV_MTstatic=0x02, CV_MTfriend=0x03, CV_MTintro=0x04, CV_MTpurevirt=0x05, CV_MTpureintro=0x06 }; // enumeration for virtual shape table entries internal enum CV_VTS_desc { CV_VTS_near=0x00, CV_VTS_far=0x01, CV_VTS_thin=0x02, CV_VTS_outer=0x03, CV_VTS_meta=0x04, CV_VTS_near32=0x05, CV_VTS_far32=0x06, CV_VTS_unused=0x07 }; // enumeration for LF_LABEL address modes internal enum CV_LABEL_TYPE { CV_LABEL_NEAR=0, // near return CV_LABEL_FAR=4 // far return }; // enumeration for LF_MODIFIER values [Flags] internal enum CV_modifier : ushort { MOD_const=0x0001, MOD_volatile=0x0002, MOD_unaligned=0x0004, }; // bit field structure describing class/struct/union/enum properties [Flags] internal enum CV_prop : ushort { packed=0x0001, // true if structure is packed ctor=0x0002, // true if constructors or destructors present ovlops=0x0004, // true if overloaded operators present isnested=0x0008, // true if this is a nested class cnested=0x0010, // true if this class contains nested types opassign=0x0020, // true if overloaded assignment (=) opcast=0x0040, // true if casting methods fwdref=0x0080, // true if forward reference (incomplete defn) scoped=0x0100, // scoped definition } // class field attribute [Flags] internal enum CV_fldattr { access=0x0003, // access protection CV_access_t mprop=0x001c, // method properties CV_methodprop_t pseudo=0x0020, // compiler generated fcn and does not exist noinherit=0x0040, // true if class cannot be inherited noconstruct=0x0080, // true if class cannot be constructed compgenx=0x0100, // compiler generated fcn and does exist } // Structures to access to the type records internal struct TYPTYPE { internal ushort len; internal ushort leaf; // byte data[]; // char *NextType (char * pType) { // return (pType + ((TYPTYPE *)pType)->len + sizeof(ushort)); // } }; // general types record // memory representation of pointer to member. These representations are // indexed by the enumeration above in the LF_POINTER record // representation of a 32 bit pointer to data for a class with // or without virtual functions and no virtual bases internal struct CV_PDMR32_NVVFCN { internal int mdisp; // displacement to data (NULL = 0x80000000) }; // representation of a 32 bit pointer to data for a class // with virtual bases internal struct CV_PDMR32_VBASE { internal int mdisp; // displacement to data internal int pdisp; // this pointer displacement internal int vdisp; // vbase table displacement // NULL = (,,0xffffffff) }; // representation of a 32 bit pointer to member function for a // class with no virtual bases and a single address point internal struct CV_PMFR32_NVSA { internal uint off; // near address of function (NULL = 0L) }; // representation of a 32 bit pointer to member function for a // class with no virtual bases and multiple address points internal struct CV_PMFR32_NVMA { internal uint off; // near address of function (NULL = 0L,x) internal int disp; }; // representation of a 32 bit pointer to member function for a // class with virtual bases internal struct CV_PMFR32_VBASE { internal uint off; // near address of function (NULL = 0L,x,x,x) internal int mdisp; // displacement to data internal int pdisp; // this pointer displacement internal int vdisp; // vbase table displacement }; ////////////////////////////////////////////////////////////////////////////// // // The following type records are basically variant records of the // above structure. The "ushort leaf" of the above structure and // the "ushort leaf" of the following type definitions are the same // symbol. // // Notes on alignment // Alignment of the fields in most of the type records is done on the // basis of the TYPTYPE record base. That is why in most of the lf* // records that the type is located on what appears to // be a offset mod 4 == 2 boundary. The exception to this rule are those // records that are in a list (lfFieldList, lfMethodList), which are // aligned to their own bases since they don't have the length field // // Type record for LF_MODIFIER internal struct LeafModifier { // internal ushort leaf; // LF_MODIFIER [TYPTYPE] internal uint type; // (type index) modified type internal CV_modifier attr; // modifier attribute modifier_t }; // type record for LF_POINTER [Flags] internal enum LeafPointerAttr : uint { ptrtype=0x0000001f, // ordinal specifying pointer type (CV_ptrtype) ptrmode=0x000000e0, // ordinal specifying pointer mode (CV_ptrmode) isflat32=0x00000100, // true if 0:32 pointer isvolatile=0x00000200, // TRUE if volatile pointer isconst=0x00000400, // TRUE if const pointer isunaligned=0x00000800, // TRUE if unaligned pointer isrestrict=0x00001000, // TRUE if restricted pointer (allow agressive opts) }; internal struct LeafPointer { internal struct LeafPointerBody { // internal ushort leaf; // LF_POINTER [TYPTYPE] internal uint utype; // (type index) type index of the underlying type internal LeafPointerAttr attr; }; #if false union { internal struct { uint pmclass; // (type index) index of containing class for pointer to member ushort pmenum; // enumeration specifying pm format (CV_pmtype) }; ushort bseg; // base segment if PTR_BASE_SEG byte[] Sym; // copy of base symbol record (including length) internal struct { uint index; // (type index) type index if CV_PTR_BASE_TYPE string name; // name of base type } btype; } pbase; #endif } // type record for LF_ARRAY internal struct LeafArray { // internal ushort leaf; // LF_ARRAY [TYPTYPE] internal uint elemtype; // (type index) type index of element type internal uint idxtype; // (type index) type index of indexing type internal byte[] data; // variable length data specifying size in bytes internal string name; }; // type record for LF_CLASS, LF_STRUCTURE internal struct LeafClass { // internal ushort leaf; // LF_CLASS, LF_STRUCT [TYPTYPE] internal ushort count; // count of number of elements in class internal ushort property; // (CV_prop_t) property attribute field (prop_t) internal uint field; // (type index) type index of LF_FIELD descriptor list internal uint derived; // (type index) type index of derived from list if not zero internal uint vshape; // (type index) type index of vshape table for this class internal byte[] data; // data describing length of structure in bytes internal string name; }; // type record for LF_UNION internal struct LeafUnion { // internal ushort leaf; // LF_UNION [TYPTYPE] internal ushort count; // count of number of elements in class internal ushort property; // (CV_prop_t) property attribute field internal uint field; // (type index) type index of LF_FIELD descriptor list internal byte[] data; // variable length data describing length of internal string name; }; // type record for LF_ALIAS internal struct LeafAlias { // internal ushort leaf; // LF_ALIAS [TYPTYPE] internal uint utype; // (type index) underlying type internal string name; // alias name }; // type record for LF_MANAGED internal struct LeafManaged { // internal ushort leaf; // LF_MANAGED [TYPTYPE] internal string name; // utf8, zero terminated managed type name }; // type record for LF_ENUM internal struct LeafEnum { // internal ushort leaf; // LF_ENUM [TYPTYPE] internal ushort count; // count of number of elements in class internal ushort property; // (CV_propt_t) property attribute field internal uint utype; // (type index) underlying type of the enum internal uint field; // (type index) type index of LF_FIELD descriptor list internal string name; // length prefixed name of enum }; // Type record for LF_PROCEDURE internal struct LeafProc { // internal ushort leaf; // LF_PROCEDURE [TYPTYPE] internal uint rvtype; // (type index) type index of return value internal byte calltype; // calling convention (CV_call_t) internal byte reserved; // reserved for future use internal ushort parmcount; // number of parameters internal uint arglist; // (type index) type index of argument list }; // Type record for member function internal struct LeafMFunc { // internal ushort leaf; // LF_MFUNCTION [TYPTYPE] internal uint rvtype; // (type index) type index of return value internal uint classtype; // (type index) type index of containing class internal uint thistype; // (type index) type index of this pointer (model specific) internal byte calltype; // calling convention (call_t) internal byte reserved; // reserved for future use internal ushort parmcount; // number of parameters internal uint arglist; // (type index) type index of argument list internal int thisadjust; // this adjuster (long because pad required anyway) }; // type record for virtual function table shape internal struct LeafVTShape { // internal ushort leaf; // LF_VTSHAPE [TYPTYPE] internal ushort count; // number of entries in vfunctable internal byte[] desc; // 4 bit (CV_VTS_desc) descriptors }; // type record for cobol0 internal struct LeafCobol0 { // internal ushort leaf; // LF_COBOL0 [TYPTYPE] internal uint type; // (type index) parent type record index internal byte[] data; }; // type record for cobol1 internal struct LeafCobol1 { // internal ushort leaf; // LF_COBOL1 [TYPTYPE] internal byte[] data; }; // type record for basic array internal struct LeafBArray { // internal ushort leaf; // LF_BARRAY [TYPTYPE] internal uint utype; // (type index) type index of underlying type }; // type record for assembler labels internal struct LeafLabel { // internal ushort leaf; // LF_LABEL [TYPTYPE] internal ushort mode; // addressing mode of label }; // type record for dimensioned arrays internal struct LeafDimArray { // internal ushort leaf; // LF_DIMARRAY [TYPTYPE] internal uint utype; // (type index) underlying type of the array internal uint diminfo; // (type index) dimension information internal string name; // length prefixed name }; // type record describing path to virtual function table internal struct LeafVFTPath { // internal ushort leaf; // LF_VFTPATH [TYPTYPE] internal uint count; // count of number of bases in path internal uint[] bases; // (type index) bases from root to leaf }; // type record describing inclusion of precompiled types internal struct LeafPreComp { // internal ushort leaf; // LF_PRECOMP [TYPTYPE] internal uint start; // starting type index included internal uint count; // number of types in inclusion internal uint signature; // signature internal string name; // length prefixed name of included type file }; // type record describing end of precompiled types that can be // included by another file internal struct LeafEndPreComp { // internal ushort leaf; // LF_ENDPRECOMP [TYPTYPE] internal uint signature; // signature }; // type record for OEM definable type strings internal struct LeafOEM { // internal ushort leaf; // LF_OEM [TYPTYPE] internal ushort cvOEM; // MS assigned OEM identified internal ushort recOEM; // OEM assigned type identifier internal uint count; // count of type indices to follow internal uint[] index; // (type index) array of type indices followed // by OEM defined data }; internal enum OEM_ID { OEM_MS_FORTRAN90=0xF090, OEM_ODI=0x0010, OEM_THOMSON_SOFTWARE=0x5453, OEM_ODI_REC_BASELIST=0x0000, }; internal struct LeafOEM2 { // internal ushort leaf; // LF_OEM2 [TYPTYPE] internal Guid idOem; // an oem ID (Guid) internal uint count; // count of type indices to follow internal uint[] index; // (type index) array of type indices followed // by OEM defined data }; // type record describing using of a type server internal struct LeafTypeServer { // internal ushort leaf; // LF_TYPESERVER [TYPTYPE] internal uint signature; // signature internal uint age; // age of database used by this module internal string name; // length prefixed name of PDB }; // type record describing using of a type server with v7 (GUID) signatures internal struct LeafTypeServer2 { // internal ushort leaf; // LF_TYPESERVER2 [TYPTYPE] internal Guid sig70; // guid signature internal uint age; // age of database used by this module internal string name; // length prefixed name of PDB }; // description of type records that can be referenced from // type records referenced by symbols // type record for skip record internal struct LeafSkip { // internal ushort leaf; // LF_SKIP [TYPTYPE] internal uint type; // (type index) next valid index internal byte[] data; // pad data }; // argument list leaf internal struct LeafArgList { // internal ushort leaf; // LF_ARGLIST [TYPTYPE] internal uint count; // number of arguments internal uint[] arg; // (type index) number of arguments }; // derived class list leaf internal struct LeafDerived { // internal ushort leaf; // LF_DERIVED [TYPTYPE] internal uint count; // number of arguments internal uint[] drvdcls; // (type index) type indices of derived classes }; // leaf for default arguments internal struct LeafDefArg { // internal ushort leaf; // LF_DEFARG [TYPTYPE] internal uint type; // (type index) type of resulting expression internal byte[] expr; // length prefixed expression string }; // list leaf // This list should no longer be used because the utilities cannot // verify the contents of the list without knowing what type of list // it is. New specific leaf indices should be used instead. internal struct LeafList { // internal ushort leaf; // LF_LIST [TYPTYPE] internal byte[] data; // data format specified by indexing type }; // field list leaf // This is the header leaf for a complex list of class and structure // subfields. internal struct LeafFieldList { // internal ushort leaf; // LF_FIELDLIST [TYPTYPE] internal char[] data; // field list sub lists }; // type record for non-static methods and friends in overloaded method list internal struct mlMethod { internal ushort attr; // (CV_fldattr_t) method attribute internal ushort pad0; // internal padding, must be 0 internal uint index; // (type index) index to type record for procedure internal uint[] vbaseoff; // offset in vfunctable if intro virtual }; internal struct LeafMethodList { // internal ushort leaf; // LF_METHODLIST [TYPTYPE] internal byte[] mList; // really a mlMethod type }; // type record for LF_BITFIELD internal struct LeafBitfield { // internal ushort leaf; // LF_BITFIELD [TYPTYPE] internal uint type; // (type index) type of bitfield internal byte length; internal byte position; }; // type record for dimensioned array with constant bounds internal struct LeafDimCon { // internal ushort leaf; // LF_DIMCONU or LF_DIMCONLU [TYPTYPE] internal uint typ; // (type index) type of index internal ushort rank; // number of dimensions internal byte[] dim; // array of dimension information with // either upper bounds or lower/upper bound }; // type record for dimensioned array with variable bounds internal struct LeafDimVar { // internal ushort leaf; // LF_DIMVARU or LF_DIMVARLU [TYPTYPE] internal uint rank; // number of dimensions internal uint typ; // (type index) type of index internal uint[] dim; // (type index) array of type indices for either // variable upper bound or variable // lower/upper bound. The count of type // indices is rank or rank*2 depending on // whether it is LFDIMVARU or LF_DIMVARLU. // The referenced types must be // LF_REFSYM or T_VOID }; // type record for referenced symbol internal struct LeafRefSym { // internal ushort leaf; // LF_REFSYM [TYPTYPE] internal byte[] Sym; // copy of referenced symbol record // (including length) }; // the following are numeric leaves. They are used to indicate the // size of the following variable length data. When the numeric // data is a single byte less than 0x8000, then the data is output // directly. If the data is more the 0x8000 or is a negative value, // then the data is preceeded by the proper index. // // signed character leaf internal struct LeafChar { // internal ushort leaf; // LF_CHAR [TYPTYPE] internal sbyte val; // signed 8-bit value }; // signed short leaf internal struct LeafShort { // internal ushort leaf; // LF_SHORT [TYPTYPE] internal short val; // signed 16-bit value }; // ushort leaf internal struct LeafUShort { // internal ushort leaf; // LF_ushort [TYPTYPE] internal ushort val; // unsigned 16-bit value }; // signed (32-bit) long leaf internal struct LeafLong { // internal ushort leaf; // LF_LONG [TYPTYPE] internal int val; // signed 32-bit value }; // uint leaf internal struct LeafULong { // internal ushort leaf; // LF_ULONG [TYPTYPE] internal uint val; // unsigned 32-bit value }; // signed quad leaf internal struct LeafQuad { // internal ushort leaf; // LF_QUAD [TYPTYPE] internal long val; // signed 64-bit value }; // unsigned quad leaf internal struct LeafUQuad { // internal ushort leaf; // LF_UQUAD [TYPTYPE] internal ulong val; // unsigned 64-bit value }; // signed int128 leaf internal struct LeafOct { // internal ushort leaf; // LF_OCT [TYPTYPE] internal ulong val0; internal ulong val1; // signed 128-bit value }; // unsigned int128 leaf internal struct LeafUOct { // internal ushort leaf; // LF_UOCT [TYPTYPE] internal ulong val0; internal ulong val1; // unsigned 128-bit value }; // real 32-bit leaf internal struct LeafReal32 { // internal ushort leaf; // LF_REAL32 [TYPTYPE] internal float val; // 32-bit real value }; // real 64-bit leaf internal struct LeafReal64 { // internal ushort leaf; // LF_REAL64 [TYPTYPE] internal double val; // 64-bit real value }; // real 80-bit leaf internal struct LeafReal80 { // internal ushort leaf; // LF_REAL80 [TYPTYPE] internal FLOAT10 val; // real 80-bit value }; // real 128-bit leaf internal struct LeafReal128 { // internal ushort leaf; // LF_REAL128 [TYPTYPE] internal ulong val0; internal ulong val1; // real 128-bit value }; // complex 32-bit leaf internal struct LeafCmplx32 { // internal ushort leaf; // LF_COMPLEX32 [TYPTYPE] internal float val_real; // real component internal float val_imag; // imaginary component }; // complex 64-bit leaf internal struct LeafCmplx64 { // internal ushort leaf; // LF_COMPLEX64 [TYPTYPE] internal double val_real; // real component internal double val_imag; // imaginary component }; // complex 80-bit leaf internal struct LeafCmplx80 { // internal ushort leaf; // LF_COMPLEX80 [TYPTYPE] internal FLOAT10 val_real; // real component internal FLOAT10 val_imag; // imaginary component }; // complex 128-bit leaf internal struct LeafCmplx128 { // internal ushort leaf; // LF_COMPLEX128 [TYPTYPE] internal ulong val0_real; internal ulong val1_real; // real component internal ulong val0_imag; internal ulong val1_imag; // imaginary component }; // variable length numeric field internal struct LeafVarString { // internal ushort leaf; // LF_VARSTRING [TYPTYPE] internal ushort len; // length of value in bytes internal byte[] value; // value }; // index leaf - contains type index of another leaf // a major use of this leaf is to allow the compilers to emit a // long complex list (LF_FIELD) in smaller pieces. internal struct LeafIndex { // internal ushort leaf; // LF_INDEX [TYPTYPE] internal ushort pad0; // internal padding, must be 0 internal uint index; // (type index) type index of referenced leaf }; // subfield record for base class field internal struct LeafBClass { // internal ushort leaf; // LF_BCLASS [TYPTYPE] internal ushort attr; // (CV_fldattr_t) attribute internal uint index; // (type index) type index of base class internal byte[] offset; // variable length offset of base within class }; // subfield record for direct and indirect virtual base class field internal struct LeafVBClass { // internal ushort leaf; // LF_VBCLASS | LV_IVBCLASS [TYPTYPE] internal ushort attr; // (CV_fldattr_t) attribute internal uint index; // (type index) type index of direct virtual base class internal uint vbptr; // (type index) type index of virtual base pointer internal byte[] vbpoff; // virtual base pointer offset from address point // followed by virtual base offset from vbtable }; // subfield record for friend class internal struct LeafFriendCls { // internal ushort leaf; // LF_FRIENDCLS [TYPTYPE] internal ushort pad0; // internal padding, must be 0 internal uint index; // (type index) index to type record of friend class }; // subfield record for friend function internal struct LeafFriendFcn { // internal ushort leaf; // LF_FRIENDFCN [TYPTYPE] internal ushort pad0; // internal padding, must be 0 internal uint index; // (type index) index to type record of friend function internal string name; // name of friend function }; // subfield record for non-static data members internal struct LeafMember { // internal ushort leaf; // LF_MEMBER [TYPTYPE] internal ushort attr; // (CV_fldattr_t)attribute mask internal uint index; // (type index) index of type record for field internal byte[] offset; // variable length offset of field internal string name; // length prefixed name of field }; // type record for static data members internal struct LeafSTMember { // internal ushort leaf; // LF_STMEMBER [TYPTYPE] internal ushort attr; // (CV_fldattr_t) attribute mask internal uint index; // (type index) index of type record for field internal string name; // length prefixed name of field }; // subfield record for virtual function table pointer internal struct LeafVFuncTab { // internal ushort leaf; // LF_VFUNCTAB [TYPTYPE] internal ushort pad0; // internal padding, must be 0 internal uint type; // (type index) type index of pointer }; // subfield record for virtual function table pointer with offset internal struct LeafVFuncOff { // internal ushort leaf; // LF_VFUNCOFF [TYPTYPE] internal ushort pad0; // internal padding, must be 0. internal uint type; // (type index) type index of pointer internal int offset; // offset of virtual function table pointer }; // subfield record for overloaded method list internal struct LeafMethod { // internal ushort leaf; // LF_METHOD [TYPTYPE] internal ushort count; // number of occurrences of function internal uint mList; // (type index) index to LF_METHODLIST record internal string name; // length prefixed name of method }; // subfield record for nonoverloaded method internal struct LeafOneMethod { // internal ushort leaf; // LF_ONEMETHOD [TYPTYPE] internal ushort attr; // (CV_fldattr_t) method attribute internal uint index; // (type index) index to type record for procedure internal uint[] vbaseoff; // offset in vfunctable if intro virtual internal string name; }; // subfield record for enumerate internal struct LeafEnumerate { // internal ushort leaf; // LF_ENUMERATE [TYPTYPE] internal ushort attr; // (CV_fldattr_t) access internal byte[] value; // variable length value field internal string name; }; // type record for nested (scoped) type definition internal struct LeafNestType { // internal ushort leaf; // LF_NESTTYPE [TYPTYPE] internal ushort pad0; // internal padding, must be 0 internal uint index; // (type index) index of nested type definition internal string name; // length prefixed type name }; // type record for nested (scoped) type definition, with attributes // new records for vC v5.0, no need to have 16-bit ti versions. internal struct LeafNestTypeEx { // internal ushort leaf; // LF_NESTTYPEEX [TYPTYPE] internal ushort attr; // (CV_fldattr_t) member access internal uint index; // (type index) index of nested type definition internal string name; // length prefixed type name }; // type record for modifications to members internal struct LeafMemberModify { // internal ushort leaf; // LF_MEMBERMODIFY [TYPTYPE] internal ushort attr; // (CV_fldattr_t) the new attributes internal uint index; // (type index) index of base class type definition internal string name; // length prefixed member name }; // type record for pad leaf internal struct LeafPad { internal byte leaf; }; // Symbol definitions internal enum SYM { S_END=0x0006, // Block, procedure, "with" or thunk end S_OEM=0x0404, // OEM defined symbol S_REGISTER_ST=0x1001, // Register variable S_CONSTANT_ST=0x1002, // constant symbol S_UDT_ST=0x1003, // User defined type S_COBOLUDT_ST=0x1004, // special UDT for cobol that does not symbol pack S_MANYREG_ST=0x1005, // multiple register variable S_BPREL32_ST=0x1006, // BP-relative S_LDATA32_ST=0x1007, // Module-local symbol S_GDATA32_ST=0x1008, // Global data symbol S_PUB32_ST=0x1009, // a internal symbol (CV internal reserved) S_LPROC32_ST=0x100a, // Local procedure start S_GPROC32_ST=0x100b, // Global procedure start S_VFTABLE32=0x100c, // address of virtual function table S_REGREL32_ST=0x100d, // register relative address S_LTHREAD32_ST=0x100e, // local thread storage S_GTHREAD32_ST=0x100f, // global thread storage S_LPROCMIPS_ST=0x1010, // Local procedure start S_GPROCMIPS_ST=0x1011, // Global procedure start // new symbol records for edit and continue information S_FRAMEPROC=0x1012, // extra frame and proc information S_COMPILE2_ST=0x1013, // extended compile flags and info // new symbols necessary for 16-bit enumerates of IA64 registers // and IA64 specific symbols S_MANYREG2_ST=0x1014, // multiple register variable S_LPROCIA64_ST=0x1015, // Local procedure start (IA64) S_GPROCIA64_ST=0x1016, // Global procedure start (IA64) // Local symbols for IL S_LOCALSLOT_ST=0x1017, // local IL sym with field for local slot index S_PARAMSLOT_ST=0x1018, // local IL sym with field for parameter slot index S_ANNOTATION=0x1019, // Annotation string literals // symbols to support managed code debugging S_GMANPROC_ST=0x101a, // Global proc S_LMANPROC_ST=0x101b, // Local proc S_RESERVED1=0x101c, // reserved S_RESERVED2=0x101d, // reserved S_RESERVED3=0x101e, // reserved S_RESERVED4=0x101f, // reserved S_LMANDATA_ST=0x1020, S_GMANDATA_ST=0x1021, S_MANFRAMEREL_ST=0x1022, S_MANREGISTER_ST=0x1023, S_MANSLOT_ST=0x1024, S_MANMANYREG_ST=0x1025, S_MANREGREL_ST=0x1026, S_MANMANYREG2_ST=0x1027, S_MANTYPREF=0x1028, // Index for type referenced by name from metadata S_UNAMESPACE_ST=0x1029, // Using namespace // Symbols w/ SZ name fields. All name fields contain utf8 encoded strings. S_ST_MAX=0x1100, // starting point for SZ name symbols S_OBJNAME=0x1101, // path to object file name S_THUNK32=0x1102, // Thunk Start S_BLOCK32=0x1103, // block start S_WITH32=0x1104, // with start S_LABEL32=0x1105, // code label S_REGISTER=0x1106, // Register variable S_CONSTANT=0x1107, // constant symbol S_UDT=0x1108, // User defined type S_COBOLUDT=0x1109, // special UDT for cobol that does not symbol pack S_MANYREG=0x110a, // multiple register variable S_BPREL32=0x110b, // BP-relative S_LDATA32=0x110c, // Module-local symbol S_GDATA32=0x110d, // Global data symbol S_PUB32=0x110e, // a internal symbol (CV internal reserved) S_LPROC32=0x110f, // Local procedure start S_GPROC32=0x1110, // Global procedure start S_REGREL32=0x1111, // register relative address S_LTHREAD32=0x1112, // local thread storage S_GTHREAD32=0x1113, // global thread storage S_LPROCMIPS=0x1114, // Local procedure start S_GPROCMIPS=0x1115, // Global procedure start S_COMPILE2=0x1116, // extended compile flags and info S_MANYREG2=0x1117, // multiple register variable S_LPROCIA64=0x1118, // Local procedure start (IA64) S_GPROCIA64=0x1119, // Global procedure start (IA64) S_LOCALSLOT=0x111a, // local IL sym with field for local slot index S_SLOT=S_LOCALSLOT, // alias for LOCALSLOT S_PARAMSLOT=0x111b, // local IL sym with field for parameter slot index // symbols to support managed code debugging S_LMANDATA=0x111c, S_GMANDATA=0x111d, S_MANFRAMEREL=0x111e, S_MANREGISTER=0x111f, S_MANSLOT=0x1120, S_MANMANYREG=0x1121, S_MANREGREL=0x1122, S_MANMANYREG2=0x1123, S_UNAMESPACE=0x1124, // Using namespace // ref symbols with name fields S_PROCREF=0x1125, // Reference to a procedure S_DATAREF=0x1126, // Reference to data S_LPROCREF=0x1127, // Local Reference to a procedure S_ANNOTATIONREF=0x1128, // Reference to an S_ANNOTATION symbol S_TOKENREF=0x1129, // Reference to one of the many MANPROCSYM's // continuation of managed symbols S_GMANPROC=0x112a, // Global proc S_LMANPROC=0x112b, // Local proc // short, light-weight thunks S_TRAMPOLINE=0x112c, // trampoline thunks S_MANCONSTANT=0x112d, // constants with metadata type info // native attributed local/parms S_ATTR_FRAMEREL=0x112e, // relative to virtual frame ptr S_ATTR_REGISTER=0x112f, // stored in a register S_ATTR_REGREL=0x1130, // relative to register (alternate frame ptr) S_ATTR_MANYREG=0x1131, // stored in >1 register // Separated code (from the compiler) support S_SEPCODE=0x1132, S_LOCAL=0x1133, // defines a local symbol in optimized code S_DEFRANGE=0x1134, // defines a single range of addresses in which symbol can be evaluated S_DEFRANGE2=0x1135, // defines ranges of addresses in which symbol can be evaluated S_SECTION=0x1136, // A COFF section in a PE executable S_COFFGROUP=0x1137, // A COFF group S_EXPORT=0x1138, // A export S_CALLSITEINFO=0x1139, // Indirect call site information S_FRAMECOOKIE=0x113a, // Security cookie information S_DISCARDED=0x113b, // Discarded by LINK /OPT:REF (experimental, see richards) S_RECTYPE_MAX, // one greater than last S_RECTYPE_LAST=S_RECTYPE_MAX - 1, }; // enum describing compile flag ambient data model internal enum CV_CFL_DATA { CV_CFL_DNEAR=0x00, CV_CFL_DFAR=0x01, CV_CFL_DHUGE=0x02 }; // enum describing compile flag ambiant code model internal enum CV_CFL_CODE { CV_CFL_CNEAR=0x00, CV_CFL_CFAR=0x01, CV_CFL_CHUGE=0x02 }; // enum describing compile flag target floating point package internal enum CV_CFL_FPKG { CV_CFL_NDP=0x00, CV_CFL_EMU=0x01, CV_CFL_ALT=0x02 }; // enum describing function return method [Flags] internal enum CV_PROCFLAGS : byte { CV_PFLAG_NOFPO=0x01, // frame pointer present CV_PFLAG_INT=0x02, // interrupt return CV_PFLAG_FAR=0x04, // far return CV_PFLAG_NEVER=0x08, // function does not return CV_PFLAG_NOTREACHED=0x10, // label isn't fallen into CV_PFLAG_CUST_CALL=0x20, // custom calling convention CV_PFLAG_NOINLINE=0x40, // function marked as noinline CV_PFLAG_OPTDBGINFO=0x80, // function has debug information for optimized code }; // Extended proc flags // internal struct CV_EXPROCFLAGS { internal byte flags; // (CV_PROCFLAGS) internal byte reserved; // must be zero }; // local variable flags [Flags] internal enum CV_LVARFLAGS : ushort { fIsParam=0x0001, // variable is a parameter fAddrTaken=0x0002, // address is taken fCompGenx=0x0004, // variable is compiler generated fIsAggregate=0x0008, // the symbol is splitted in temporaries, // which are treated by compiler as // independent entities fIsAggregated=0x0010, // Counterpart of fIsAggregate - tells // that it is a part of a fIsAggregate symbol fIsAliased=0x0020, // variable has multiple simultaneous lifetimes fIsAlias=0x0040, // represents one of the multiple simultaneous lifetimes }; // represents an address range, used for optimized code debug info internal struct CV_lvar_addr_range { // defines a range of addresses internal uint offStart; internal ushort isectStart; internal uint cbRange; }; // enum describing function data return method internal enum CV_GENERIC_STYLE { CV_GENERIC_VOID=0x00, // void return type CV_GENERIC_REG=0x01, // return data is in registers CV_GENERIC_ICAN=0x02, // indirect caller allocated near CV_GENERIC_ICAF=0x03, // indirect caller allocated far CV_GENERIC_IRAN=0x04, // indirect returnee allocated near CV_GENERIC_IRAF=0x05, // indirect returnee allocated far CV_GENERIC_UNUSED=0x06 // first unused }; [Flags] internal enum CV_GENERIC_FLAG : ushort { cstyle=0x0001, // true push varargs right to left rsclean=0x0002, // true if returnee stack cleanup }; // flag bitfields for separated code attributes [Flags] internal enum CV_SEPCODEFLAGS : uint { fIsLexicalScope=0x00000001, // S_SEPCODE doubles as lexical scope fReturnsToParent=0x00000002, // code frag returns to parent }; // Generic layout for symbol records internal struct SYMTYPE { internal ushort reclen; // Record length internal ushort rectyp; // Record type // byte data[CV_ZEROLEN]; // SYMTYPE *NextSym (SYMTYPE * pSym) { // return (SYMTYPE *) ((char *)pSym + pSym->reclen + sizeof(ushort)); // } }; // non-model specific symbol types internal struct RegSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_REGISTER internal uint typind; // (type index) Type index or Metadata token internal ushort reg; // register enumerate internal string name; // Length-prefixed name }; internal struct AttrRegSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_MANREGISTER | S_ATTR_REGISTER internal uint typind; // (type index) Type index or Metadata token internal uint offCod; // first code address where var is live internal ushort segCod; internal ushort flags; // (CV_LVARFLAGS)local var flags internal ushort reg; // register enumerate internal string name; // Length-prefixed name }; internal struct ManyRegSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_MANYREG internal uint typind; // (type index) Type index or metadata token internal byte count; // count of number of registers internal byte[] reg; // count register enumerates, most-sig first internal string name; // length-prefixed name. }; internal struct ManyRegSym2 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_MANYREG2 internal uint typind; // (type index) Type index or metadata token internal ushort count; // count of number of registers, internal ushort[] reg; // count register enumerates, most-sig first internal string name; // length-prefixed name. }; internal struct AttrManyRegSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_MANMANYREG internal uint typind; // (type index) Type index or metadata token internal uint offCod; // first code address where var is live internal ushort segCod; internal ushort flags; // (CV_LVARFLAGS)local var flags internal byte count; // count of number of registers internal byte[] reg; // count register enumerates, most-sig first internal string name; // utf-8 encoded zero terminate name }; internal struct AttrManyRegSym2 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_MANMANYREG2 | S_ATTR_MANYREG internal uint typind; // (type index) Type index or metadata token internal uint offCod; // first code address where var is live internal ushort segCod; internal ushort flags; // (CV_LVARFLAGS)local var flags internal ushort count; // count of number of registers internal ushort[] reg; // count register enumerates, most-sig first internal string name; // utf-8 encoded zero terminate name }; internal struct ConstSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_CONSTANT or S_MANCONSTANT internal uint typind; // (type index) Type index (containing enum if enumerate) or metadata token internal ushort value; // numeric leaf containing value internal string name; // Length-prefixed name }; internal struct UdtSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_UDT | S_COBOLUDT internal uint typind; // (type index) Type index internal string name; // Length-prefixed name }; internal struct ManyTypRef { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_MANTYPREF internal uint typind; // (type index) Type index }; internal struct SearchSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_SSEARCH internal uint startsym; // offset of the procedure internal ushort seg; // segment of symbol }; [Flags] internal enum CFLAGSYM_FLAGS : ushort { pcode=0x0001, // true if pcode present floatprec=0x0006, // floating precision floatpkg=0x0018, // float package ambdata=0x00e0, // ambient data model ambcode=0x0700, // ambient code model mode32=0x0800, // true if compiled 32 bit mode }; internal struct CFlagSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_COMPILE internal byte machine; // target processor internal byte language; // language index internal ushort flags; // (CFLAGSYM_FLAGS) internal string ver; // Length-prefixed compiler version string }; [Flags] internal enum COMPILESYM_FLAGS : uint { iLanguage=0x000000ff, // language index fEC=0x00000100, // compiled for E/C fNoDbgInfo=0x00000200, // not compiled with debug info fLTCG=0x00000400, // compiled with LTCG fNoDataAlign=0x00000800, // compiled with -Bzalign fManagedPresent=0x00001000, // managed code/data present fSecurityChecks=0x00002000, // compiled with /GS fHotPatch=0x00004000, // compiled with /hotpatch fCVTCIL=0x00008000, // converted with CVTCIL fMSILModule=0x00010000, // MSIL netmodule }; internal struct CompileSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_COMPILE2 internal uint flags; // (COMPILESYM_FLAGS) internal ushort machine; // target processor internal ushort verFEMajor; // front end major version # internal ushort verFEMinor; // front end minor version # internal ushort verFEBuild; // front end build version # internal ushort verMajor; // back end major version # internal ushort verMinor; // back end minor version # internal ushort verBuild; // back end build version # internal string verSt; // Length-prefixed compiler version string, followed internal string[] verArgs; // block of zero terminated strings, ended by double-zero. }; internal struct ObjNameSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_OBJNAME internal uint signature; // signature internal string name; // Length-prefixed name }; internal struct EndArgSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_ENDARG }; internal struct ReturnSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_RETURN internal CV_GENERIC_FLAG flags; // flags internal byte style; // CV_GENERIC_STYLE return style // followed by return method data }; internal struct EntryThisSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_ENTRYTHIS internal byte thissym; // symbol describing this pointer on entry }; internal struct BpRelSym32 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_BPREL32 internal int off; // BP-relative offset internal uint typind; // (type index) Type index or Metadata token internal string name; // Length-prefixed name }; internal struct FrameRelSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_MANFRAMEREL | S_ATTR_FRAMEREL internal int off; // Frame relative offset internal uint typind; // (type index) Type index or Metadata token internal uint offCod; // first code address where var is live internal ushort segCod; internal ushort flags; // (CV_LVARFLAGS)local var flags internal string name; // Length-prefixed name }; internal struct SlotSym32 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_LOCALSLOT or S_PARAMSLOT internal uint index; // slot index internal uint typind; // (type index) Type index or Metadata token internal string name; // Length-prefixed name }; internal struct AttrSlotSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_MANSLOT internal uint index; // slot index internal uint typind; // (type index) Type index or Metadata token internal uint offCod; // first code address where var is live internal ushort segCod; internal ushort flags; // (CV_LVARFLAGS)local var flags internal string name; // Length-prefixed name }; internal struct AnnotationSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_ANNOTATION internal uint off; internal ushort seg; internal ushort csz; // Count of zero terminated annotation strings internal string[] rgsz; // Sequence of zero terminated annotation strings }; internal struct DatasSym32 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_LDATA32, S_GDATA32 or S_PUB32, S_LMANDATA, S_GMANDATA internal uint typind; // (type index) Type index, or Metadata token if a managed symbol internal uint off; internal ushort seg; internal string name; // Length-prefixed name }; [Flags] internal enum CV_PUBSYMFLAGS : uint { fNone=0, fCode=0x00000001, // set if internal symbol refers to a code address fFunction=0x00000002, // set if internal symbol is a function fManaged=0x00000004, // set if managed code (native or IL) fMSIL=0x00000008, // set if managed IL code }; internal struct PubSym32 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_PUB32 internal uint flags; // (CV_PUBSYMFLAGS) internal uint off; internal ushort seg; internal string name; // Length-prefixed name }; internal struct ProcSym32 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_GPROC32 or S_LPROC32 internal uint parent; // pointer to the parent internal uint end; // pointer to this blocks end internal uint next; // pointer to next symbol internal uint len; // Proc length internal uint dbgStart; // Debug start offset internal uint dbgEnd; // Debug end offset internal uint typind; // (type index) Type index internal uint off; internal ushort seg; internal byte flags; // (CV_PROCFLAGS) Proc flags internal string name; // Length-prefixed name }; internal struct ManProcSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_GMANPROC, S_LMANPROC, S_GMANPROCIA64 or S_LMANPROCIA64 internal uint parent; // pointer to the parent internal uint end; // pointer to this blocks end internal uint next; // pointer to next symbol internal uint len; // Proc length internal uint dbgStart; // Debug start offset internal uint dbgEnd; // Debug end offset internal uint token; // COM+ metadata token for method internal uint off; internal ushort seg; internal byte flags; // (CV_PROCFLAGS) Proc flags internal ushort retReg; // Register return value is in (may not be used for all archs) internal string name; // optional name field }; internal struct ManProcSymMips { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_GMANPROCMIPS or S_LMANPROCMIPS internal uint parent; // pointer to the parent internal uint end; // pointer to this blocks end internal uint next; // pointer to next symbol internal uint len; // Proc length internal uint dbgStart; // Debug start offset internal uint dbgEnd; // Debug end offset internal uint regSave; // int register save mask internal uint fpSave; // fp register save mask internal uint intOff; // int register save offset internal uint fpOff; // fp register save offset internal uint token; // COM+ token type internal uint off; internal ushort seg; internal byte retReg; // Register return value is in internal byte frameReg; // Frame pointer register internal string name; // optional name field }; internal struct ThunkSym32 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_THUNK32 internal uint parent; // pointer to the parent internal uint end; // pointer to this blocks end internal uint next; // pointer to next symbol internal uint off; internal ushort seg; internal ushort len; // length of thunk internal byte ord; // THUNK_ORDINAL specifying type of thunk internal string name; // Length-prefixed name internal byte[] variant; // variant portion of thunk }; internal enum TRAMP { // Trampoline subtype trampIncremental, // incremental thunks trampBranchIsland, // Branch island thunks }; internal struct TrampolineSym { // Trampoline thunk symbol // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_TRAMPOLINE internal ushort trampType; // trampoline sym subtype internal ushort cbThunk; // size of the thunk internal uint offThunk; // offset of the thunk internal uint offTarget; // offset of the target of the thunk internal ushort sectThunk; // section index of the thunk internal ushort sectTarget; // section index of the target of the thunk }; internal struct LabelSym32 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_LABEL32 internal uint off; internal ushort seg; internal byte flags; // (CV_PROCFLAGS) flags internal string name; // Length-prefixed name }; internal struct BlockSym32 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_BLOCK32 internal uint parent; // pointer to the parent internal uint end; // pointer to this blocks end internal uint len; // Block length internal uint off; // Offset in code segment internal ushort seg; // segment of label internal string name; // Length-prefixed name }; internal struct WithSym32 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_WITH32 internal uint parent; // pointer to the parent internal uint end; // pointer to this blocks end internal uint len; // Block length internal uint off; // Offset in code segment internal ushort seg; // segment of label internal string expr; // Length-prefixed expression string }; internal struct VpathSym32 { // internal ushort reclen; // record length // internal ushort rectyp; // S_VFTABLE32 internal uint root; // (type index) type index of the root of path internal uint path; // (type index) type index of the path record internal uint off; // offset of virtual function table internal ushort seg; // segment of virtual function table }; internal struct RegRel32 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_REGREL32 internal uint off; // offset of symbol internal uint typind; // (type index) Type index or metadata token internal ushort reg; // register index for symbol internal string name; // Length-prefixed name }; internal struct AttrRegRel { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_MANREGREL | S_ATTR_REGREL internal uint off; // offset of symbol internal uint typind; // (type index) Type index or metadata token internal ushort reg; // register index for symbol internal uint offCod; // first code address where var is live internal ushort segCod; internal ushort flags; // (CV_LVARFLAGS)local var flags internal string name; // Length-prefixed name }; internal struct ThreadSym32 { // internal ushort reclen; // record length // internal ushort rectyp; // S_LTHREAD32 | S_GTHREAD32 internal uint typind; // (type index) type index internal uint off; // offset into thread storage internal ushort seg; // segment of thread storage internal string name; // length prefixed name }; internal struct Slink32 { // internal ushort reclen; // record length // internal ushort rectyp; // S_SLINK32 internal uint framesize; // frame size of parent procedure internal int off; // signed offset where the static link was saved relative to the value of reg internal ushort reg; }; internal struct ProcSymMips { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_GPROCMIPS or S_LPROCMIPS internal uint parent; // pointer to the parent internal uint end; // pointer to this blocks end internal uint next; // pointer to next symbol internal uint len; // Proc length internal uint dbgStart; // Debug start offset internal uint dbgEnd; // Debug end offset internal uint regSave; // int register save mask internal uint fpSave; // fp register save mask internal uint intOff; // int register save offset internal uint fpOff; // fp register save offset internal uint typind; // (type index) Type index internal uint off; // Symbol offset internal ushort seg; // Symbol segment internal byte retReg; // Register return value is in internal byte frameReg; // Frame pointer register internal string name; // Length-prefixed name }; internal struct ProcSymIa64 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_GPROCIA64 or S_LPROCIA64 internal uint parent; // pointer to the parent internal uint end; // pointer to this blocks end internal uint next; // pointer to next symbol internal uint len; // Proc length internal uint dbgStart; // Debug start offset internal uint dbgEnd; // Debug end offset internal uint typind; // (type index) Type index internal uint off; // Symbol offset internal ushort seg; // Symbol segment internal ushort retReg; // Register return value is in internal byte flags; // (CV_PROCFLAGS) Proc flags internal string name; // Length-prefixed name }; internal struct RefSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_PROCREF_ST, S_DATAREF_ST, or S_LPROCREF_ST internal uint sumName; // SUC of the name internal uint ibSym; // Offset of actual symbol in $$Symbols internal ushort imod; // Module containing the actual symbol internal ushort usFill; // align this record }; internal struct RefSym2 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_PROCREF, S_DATAREF, or S_LPROCREF internal uint sumName; // SUC of the name internal uint ibSym; // Offset of actual symbol in $$Symbols internal ushort imod; // Module containing the actual symbol internal string name; // hidden name made a first class member }; internal struct AlignSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_ALIGN }; internal struct OemSymbol { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_OEM internal Guid idOem; // an oem ID (GUID) internal uint typind; // (type index) Type index internal byte[] rgl; // user data, force 4-byte alignment }; [Flags] internal enum FRAMEPROCSYM_FLAGS : uint { fHasAlloca=0x00000001, // function uses _alloca() fHasSetJmp=0x00000002, // function uses setjmp() fHasLongJmp=0x00000004, // function uses longjmp() fHasInlAsm=0x00000008, // function uses inline asm fHasEH=0x00000010, // function has EH states fInlSpec=0x00000020, // function was speced as inline fHasSEH=0x00000040, // function has SEH fNaked=0x00000080, // function is __declspec(naked) fSecurityChecks=0x00000100, // function has buffer security check introduced by /GS. fAsyncEH=0x00000200, // function compiled with /EHa fGSNoStackOrdering=0x00000400, // function has /GS buffer checks, but stack ordering couldn't be done fWasInlined=0x00000800, // function was inlined within another function }; internal struct FrameProcSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_FRAMEPROC internal uint cbFrame; // count of bytes of total frame of procedure internal uint cbPad; // count of bytes of padding in the frame internal uint offPad; // offset (rel to frame) to where padding starts internal uint cbSaveRegs; // count of bytes of callee save registers internal uint offExHdlr; // offset of exception handler internal ushort secExHdlr; // section id of exception handler internal uint flags; // (FRAMEPROCSYM_FLAGS) } internal struct UnamespaceSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_UNAMESPACE internal string name; // name }; internal struct SepCodSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_SEPCODE internal uint parent; // pointer to the parent internal uint end; // pointer to this block's end internal uint length; // count of bytes of this block internal uint scf; // (CV_SEPCODEFLAGS) flags internal uint off; // sec:off of the separated code internal uint offParent; // secParent:offParent of the enclosing scope internal ushort sec; // (proc, block, or sepcode) internal ushort secParent; }; internal struct LocalSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_LOCAL internal uint id; // id of the local internal uint typind; // (type index) type index internal ushort flags; // (CV_LVARFLAGS) local var flags internal uint idParent; // This is is parent variable - fIsAggregated or fIsAlias internal uint offParent; // Offset in parent variable - fIsAggregated internal uint expr; // NI of expression that this temp holds internal uint pad0; // pad, must be zero internal uint pad1; // pad, must be zero internal string name; // Name of this symbol. } internal struct DefRangeSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_DEFRANGE internal uint id; // ID of the local symbol for which this formula holds internal uint program; // program to evaluate the value of the symbol internal CV_lvar_addr_range range; // Range of addresses where this program is valid }; internal struct DefRangeSym2 { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_DEFRANGE2 internal uint id; // ID of the local symbol for which this formula holds internal uint program; // program to evaluate the value of the symbol internal ushort count; // count of CV_lvar_addr_range records following internal CV_lvar_addr_range[] range;// Range of addresses where this program is valid }; internal struct SectionSym { // internal ushort reclen // Record length // internal ushort rectyp; // S_SECTION internal ushort isec; // Section number internal byte align; // Alignment of this section (power of 2) internal byte bReserved; // Reserved. Must be zero. internal uint rva; internal uint cb; internal uint characteristics; internal string name; // name }; internal struct CoffGroupSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_COFFGROUP internal uint cb; internal uint characteristics; internal uint off; // Symbol offset internal ushort seg; // Symbol segment internal string name; // name }; [Flags] internal enum EXPORTSYM_FLAGS : ushort { fConstant=0x0001, // CONSTANT fData=0x0002, // DATA fPrivate=0x0004, // PRIVATE fNoName=0x0008, // NONAME fOrdinal=0x0010, // Ordinal was explicitly assigned fForwarder=0x0020, // This is a forwarder } internal struct ExportSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_EXPORT internal ushort ordinal; internal ushort flags; // (EXPORTSYM_FLAGS) internal string name; // name of }; // // Symbol for describing indirect calls when they are using // a function pointer cast on some other type or temporary. // Typical content will be an LF_POINTER to an LF_PROCEDURE // type record that should mimic an actual variable with the // function pointer type in question. // // Since the compiler can sometimes tail-merge a function call // through a function pointer, there may be more than one // S_CALLSITEINFO record at an address. This is similar to what // you could do in your own code by: // // if (expr) // pfn = &function1; // else // pfn = &function2; // // (*pfn)(arg list); // internal struct CallsiteInfo { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_CALLSITEINFO internal int off; // offset of call site internal ushort ect; // section index of call site internal ushort pad0; // alignment padding field, must be zero internal uint typind; // (type index) type index describing function signature }; // Frame cookie information internal enum CV_cookietype { CV_COOKIETYPE_COPY=0, CV_COOKIETYPE_XOR_SP, CV_COOKIETYPE_XOR_BP, CV_COOKIETYPE_XOR_R13, }; // Symbol for describing security cookie's position and type // (raw, xor'd with esp, xor'd with ebp). internal struct FrameCookie { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_FRAMECOOKIE internal int off; // Frame relative offset internal ushort reg; // Register index internal int cookietype; // (CV_cookietype) Type of the cookie internal byte flags; // Flags describing this cookie }; internal enum CV_DISCARDED : uint { CV_DISCARDED_UNKNOWN=0, CV_DISCARDED_NOT_SELECTED=1, CV_DISCARDED_NOT_REFERENCED=2, }; internal struct DiscardedSym { // internal ushort reclen; // Record length [SYMTYPE] // internal ushort rectyp; // S_DISCARDED internal CV_DISCARDED iscarded; internal uint fileid; // First FILEID if line number info present internal uint linenum; // First line number internal byte[] data; // Original record(s) with invalid indices }; // // V7 line number data types // internal enum DEBUG_S_SUBSECTION_TYPE : uint { DEBUG_S_IGNORE=0x80000000, // if this bit is set in a subsection type then ignore the subsection contents DEBUG_S_SYMBOLS=0xf1, DEBUG_S_LINES=0xf2, DEBUG_S_STRINGTABLE=0xf3, DEBUG_S_FILECHKSMS=0xf4, DEBUG_S_FRAMEDATA=0xf5, }; // // Line flags (data present) // internal enum CV_LINE_SUBSECTION_FLAGS : ushort { CV_LINES_HAVE_COLUMNS=0x0001, } internal struct CV_LineSection { internal uint off; internal ushort sec; internal ushort flags; internal uint cod; } internal struct CV_SourceFile { internal uint index; // Index to file in checksum section. internal uint count; // Number of CV_Line records. internal uint linsiz; // Size of CV_Line recods. } [Flags] internal enum CV_Line_Flags : uint { linenumStart=0x00ffffff, // line where statement/expression starts deltaLineEnd=0x7f000000, // delta to line where statement ends (optional) fStatement=0x80000000, // true if a statement linenumber, else an expression line num }; internal struct CV_Line { internal uint offset; // Offset to start of code bytes for line number internal uint flags; // (CV_Line_Flags) }; internal struct CV_Column { internal ushort offColumnStart; internal ushort offColumnEnd; }; // File information internal enum CV_FILE_CHECKSUM_TYPE : byte { None=0, MD5=1, }; internal struct CV_FileCheckSum { internal uint name; // Index of name in name table. internal byte len; // Hash length internal byte type; // Hash type } [Flags] internal enum FRAMEDATA_FLAGS : uint { fHasSEH=0x00000001, fHasEH=0x00000002, fIsFunctionStart=0x00000004, }; internal struct FrameData { internal uint ulRvaStart; internal uint cbBlock; internal uint cbLocals; internal uint cbParams; internal uint cbStkMax; internal uint frameFunc; internal ushort cbProlog; internal ushort cbSavedRegs; internal uint flags; // (FRAMEDATA_FLAGS) }; internal struct XFixupData { internal ushort wType; internal ushort wExtra; internal uint rva; internal uint rvaTarget; }; internal enum DEBUG_S_SUBSECTION { SYMBOLS=0xF1, LINES=0xF2, STRINGTABLE=0xF3, FILECHKSMS=0xF4, FRAMEDATA=0xF5, } }