Microsoft KB Archive/104617

From BetaArchive Wiki
< Microsoft KB Archive
Revision as of 17:42, 20 July 2020 by X010 (talk | contribs) (Text replacement - ">" to ">")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Article ID: 104617

Article Last Modified on 6/1/2005



APPLIES TO

  • Microsoft Visual C++ 1.0 Professional Edition
  • Microsoft Visual C++ 1.5 Professional Edition
  • Microsoft Visual C++ 2.0 Professional Edition
  • Microsoft Visual C++ 4.0 Standard Edition
  • Microsoft Visual C++ 5.0 Enterprise Edition
  • Microsoft Visual C++ 6.0 Enterprise Edition
  • Microsoft Visual C++ 5.0 Professional Edition
  • Microsoft Visual C++ 6.0 Professional Edition
  • Microsoft Visual C++ 6.0 Standard Edition



This article was previously published under Q104617


SUMMARY

The sample code below demonstrates how to pass a short from a program that is written in Microsoft C to a procedure that is written with the Microsoft Macro Assembler (MASM). The MASM function also returns a short 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
                

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

short MasmSub(short);

#ifdef __cplusplus
}
#endif

main ()
{
   short var = 1;
   printf ("%d\n", var);
   printf ("%d", MasmSub(var));
}
                

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, \ 
   sVar:WORD

   mov ax, sVar     ; Load the short into AX.
   add ax, 32766    ; Because the function returns a short (a 2-byte
   ret              ; value), C will get the return value from AX.
MasmSub ENDP
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, \ 
   sVar:WORD

   mov ax, sVar     ; Load the short into AX.
   add ax, 32766    ; Because the function returns a short (a 2-byte
   ret              ; value), C will get the return value from AX.
MasmSub ENDP
END
                


The following is the output of the program:

  1
  32767
                


Additional query words: mixed language

Keywords: kbhowtomaster kblangc kbcode KB104617