INFO: Passing a long from C to MASM by Value & Returning a long (104645)



The information in this article applies to:

  • Microsoft C for MS-DOS
  • Microsoft C for OS/2
  • Microsoft Visual C++ 1.0
  • Microsoft Visual C++ 1.5
  • Microsoft Visual C++ 2.0
  • Microsoft Visual C++ 4.0
  • Microsoft Visual C++, 32-bit Enterprise Edition 5.0
  • Microsoft Visual C++, 32-bit Enterprise Edition 6.0
  • Microsoft Visual C++, 32-bit Professional Edition 5.0
  • Microsoft Visual C++, 32-bit Professional Edition 6.0
  • Microsoft Visual C++, 32-bit Learning Edition 6.0

This article was previously published under Q104645

SUMMARY

The sample code below demonstrates how to pass a long from a program written in Microsoft C to a procedure written with the Microsoft Macro Assembler (MASM). The MASM function also returns a long to the C program.

Registers are used to return values of simple data types. For 16-bit code, such as an MS-DOS program, use the following conventions for returning data to a C program:
char                   AL
short, int, near *     AX
long, far *            DX:  High order portion (segment)
                       AX:  Low order portion (offset)
				
For 32-bit code, such as a Windows NT program, use the following conventions for returning data to a C program:
char                   AL
short                  AX
long, int, *           EAX
				

MORE INFORMATION

The samples below include one C file and two different assembly files. The two assembly files demonstrate how to pass a variable in small model for MS- DOS and in flat model for Windows NT. Link only the appropriate assembly module to the C module.

Note that MASM 6.1 or later and the C/C++ 32-bit compiler that ships with Visual C++, 32-bit Edition, are required to build the flat model Windows NT version.

Sample Code

// Filename: CMAIN.C
// Compile options needed: /c

#include <stdio.h>

#ifdef __cplusplus
extern "C" {
#endif

long MasmSub (long, long);

#ifdef __cplusplus
}
#endif

main ()
   {
   long var1 = 98304, var2 = 147456;
   printf ("%ld + %ld = %ld", var1, var2, MasmSub (var1, var2));
   }
				

Sample Code for MS-DOS Small Model Version

; Filename: MASMSUB.ASM
; Assemble options needed for MASM: /MX
; Assemble options needed for ML: /c /Cx

.MODEL small, C
.286
.CODE

MasmSub PROC, \ 
   lVar1:DWORD, \ 
   lVar2:DWORD

   mov ax, WORD PTR lVar1       ; Load the first long into DX:AX.
   mov dx, WORD PTR lVar1+2
   add ax, WORD PTR lVar2       ; Add the second long to DX:AX
   adc dx, WORD PTR lVar2+2
   ret              ; Because the function returns a long (a 4-byte
MasmSub ENDP        ; value), C will get the return value from DX:AX.
END
				

Sample Code for Windows NT Flat Model Version

; Filename: MASMSUB.ASM
; Assemble options needed for ML: /c /Cx /coff

.386
.MODEL flat, C
.CODE

MasmSub PROC, \ 
   lVar1:DWORD, \ 
   lVar2:DWORD

   mov eax, lVar1   ; Load the first long into EAX.
   add eax, lVar2   ; Add the second long to EAX.
   ret              ; Because the function returns a long (a 4-byte
MasmSub ENDP        ; value), C will get the return value from EAX.
END
				
The following is the output of the program:
   98304 + 147456 = 245760
				

Modification Type:MinorLast Reviewed:7/5/2005
Keywords:kbinfo kbLangC KB104645