FIX: Using EXTERNDEF w/ a label May Work Incorrectly

ID: Q85227


The information in this article applies to:
  • Microsoft Macro Assembler for MS-DOS and OS/2, versions 6.0, 6.0a, 6.0b


SYMPTOMS

In the Microsoft Macro Assembler (MASM) initializing a data structure with the offset of a label declared with EXTERNDEF or PROTO can cause incorrect results.


RESOLUTION

Use EXTERN to perform the same task as the EXTERNDEF; this method will work properly. Also, instead of using OFFSET to initialize a WORD field in the structure, use the label to initialize a NEAR PTR field.


STATUS

Microsoft has confirmed this to be a problem in MASM versions 6.0, 6.0a, and 6.0b. This problem was corrected in MASM for MS-DOS version 6.1.


MORE INFORMATION

EXTERNDEF was introduced as a convenient way to declare shared data structures, variables, symbols, and labels inside a header file. The same functionality can be obtained by using EXTERN and PUBLIC. To replace "EXTERNDEF <name>":

  • If <name> is used in the current module but is not defined, use "EXTERN <name>:<qualified type>".


  • If <name> is defined in the current module, use "PUBLIC <name>".


Using this method, each EXTERN and PUBLIC will be specific to certain source files, which prevents the use of one global include file.

Sample Code


; Assemble options needed:  /c /Zi
; Link options needed: /CO
; If SOURCE1.ASM and SOURCE2.ASM are assembled and linked together,
; The structure fields an_st.func2 and an_st.func3 will be improperly
; initialized with the offset 0x0000.

;===========================<source1.asm>=============================
.MODEL small

st_st STRUCT 1b
   func1 WORD ?
   func2 WORD ?
   func3 WORD ?
   func4 WORD ?
st_st ENDS

; Uncomment the line below to have fn_2a properly marked for external
; linkage. Note that if the EXTERNDEF statement is not commented out,
; the EXTERN statement must come first for this to work properly.
;EXTERN fn_2a:NEAR

EXTERN fn_1a:NEAR
EXTERNDEF fn_2a:NEAR
fn_3a PROTO NEAR

.DATA
an_st st_st { \ 
   offset fn_1a,
   offset fn_2a, ; This doesn't work.
   offset fn_3a, ; This doesn't work either.
   offset fn_4a}

.CODE
   .startup
   .exit 0
fn_4a:
   ret
END

;===========================<source2.asm>=============================
.MODEL small
EXTERNDEF fn_1a:NEAR
EXTERNDEF fn_2a:NEAR
EXTERNDEF fn_3a:NEAR

.CODE
fn_1a:
   ret
fn_2a:
   ret
fn_3a:
   ret
END 

Additional query words: 6.00 6.00a 6.00b buglist6.00 buglist6.00a buglist6.00b fixlist6.10

Keywords :
Version : MS-DOS:6.0,6.0a,6.0b
Platform : MS-DOS
Issue type :


Last Reviewed: January 4, 2000
© 2000 Microsoft Corporation. All rights reserved. Terms of Use.