Article: Q28613
Product(s): See article
Version(s): 5.00 5.10
Operating System(s): MS-DOS
Keyword(s): ENDUSER | | mspl13_c
Last Modified: 17-NOV-1988
The following are Microsoft extensions to the Intel object module
format that were incorporated in Versions 5.00 and 5.10 of the C
compiler. For a complete description of the object module format, you
can contact Microsoft System Languages Technical Support at (206)
454-2030 and request the Object Module Format Application Note.
Microsoft OMF Extensions
Local Symbols (C 5.00) -- B4h, B6h, B7h, B8h
There will be three new record types to handle local symbols:
1. LEXTDEF = 0xb4 (180)
Format is identical to EXTDEF.
2. LPUBDEF = 0xb6 (182) or 0xb7 (183)
Format is identical to PUBDEF.
3. LCOMDEF = 0xb8 (184)
Format is identical to COMDEF.
LEXTDEF, LPUBDEF, and LCOMDEF are to be used exactly as EXTDEF,
PUBDEF, and COMDEF, except that the symbols are not visible outside
the module where they are defined--for example, C statics.
New OMF Comment -- Class A1h
A comment record with class A1h indicates that the obsolete method of
communal representation through TYPDEF and EXTDEF pairs is not used,
and that COMDEF records can be interpreted. The meaning of this record
is undergoing revision.
IMPDEF (OS2, Windows) -- Comment Class A0h, Subtype 1
The IMPort DEFinition (IMPDEF) record takes the form of a COMENT
record with class 0xa0:
DB 88h ; COMENT
DW reclen ; record length
DB 00h ; for Intel compatibility
DB A0h ; class: OMF extension
DB 01h ; subtype: IMPDEF
DB fOrd ; nonzero value means import by ordinal
; Internal Name
DB n ; length of name
DB n dup(?) ; ASCII text of name
; Module Name
DB n ; length of name
DB n dup(?) ; ASCII text of name
IF import by name (fOrd == 0)
; Imported Name: if length byte is 0 then imported name is
; identical to internal name.
;
DB n ; length of name
DB n dup(?) ; ASCII text of name
ELSE
DW ordno ; ordinal number
ENDIF
DB checksum
EXPDEF (C 5.10) -- Comment Class A0h, Subtype 2
The EXPort DEFinition record takes the form of a COMENT record with
class 0xa0:
DB 88h ; COMENT
DW reclen ; record length
DB 00h ; for Intel compatibility
DB A0h ; class: OMF extension
DB 02h ; extension type: EXPDEF
DB flags
; 80h = set if ordinal number specified
; 40h = set if RESIDENTNAME
; 20h = set if NODATA
; 1Fh = # of parameter words
; Exported name:
DB n ; length of name
DB n dup(?) ; ASCII text of name
; IF internal name different from exported name:
DB n ; length of name
DB n dup(?) ; ASCII text of name
; ELSE internal name same as exported name:
DB 00h
; IF ordinal number specified
DW ordno ; ordinal number
DB checksum
LIBMOD Comment Record -- Class A3h (LIB 3.07 in MASM 5.00)
DB 88h ; COMENT
DW reclen ; record length
DB 00h ; for Intel compatibility
DB A3h ; class: LIBrary MODule name
DB N ; length of module name
DB N dup(?) ; ASCII text of module name
DB checksum
The LIBMOD comment record identifies the name of a library module.
This record allows LIB to preserve the source file name in the THEADR
record and still identify the module name. Since the module name is
the base name of the .OBJ file, the two names may be completely
different.
LIB adds a LIBMOD record when an .OBJ file is added to a library and
strips the LIBMOD record when an .OBJ file is removed from a library,
so this record usually only exists in .LIB files.