Article: Q49398
Product(s): See article
Version(s): 4.00 4.00b 4.50
Operating System(s): MS-DOS
Keyword(s): ENDUSER | B_BasicCom H_MASM S_QuickASM | mspl13_basic
Last Modified: 13-AUG-1990
The two programs shown below demonstrate how a Microsoft BASIC program
can pass a two-dimensional integer array to assembly language.
This information about interlanguage calling applies to QuickBASIC
versions 4.00, 4.00b, and 4.50 for MS-DOS, to Microsoft BASIC Compiler
versions 6.00 and 6.00b for MS-DOS and MS OS/2 and to Microsoft BASIC
Professional Development System (PDS) versions 7.00 and 7.10 for
MS-DOS and MS OS/2.
For more information about passing other types of parameters between
BASIC and MASM, search in the Software/Data Library for the following
word:
BAS2MASM
Code Example
------------
The following BASIC program is BTWODIMI.BAS, which passes an
uninitialized two-dimensional integer array to an assembly routine
that initializes the array:
DECLARE SUB TwoInt(BYVAL ASeg AS INTEGER, BYVAL AOff AS INTEGER)
DIM IntArray(1 TO 2, 1 TO 3) AS INTEGER
CALL TwoInt(VARSEG(IntArray(1, 1)), VARPTR(IntArray(1, 1)))
FOR row% = 1 TO 2
FOR col% = 1 TO 3
PRINT IntArray(row%, col%)
NEXT
NEXT
END
The following program is ATWODIMI.ASM, which initializes a
two-dimensional integer array passed from BASIC:
; The following handy .MODEL MEDIUM,BASIC directive is found in MASM
; 5.10 but not in earlier versions:
.MODEL MEDIUM, BASIC
.DATA
i11 DW 11
i21 DW 21
i12 DW 12
i22 DW 22
i13 DW 13
i23 DW 23
.CODE
PUBLIC TwoInt
TwoInt PROC
push bp
mov bp, sp ; set stack frame
push es
push si
push di
mov es, [bp+8] ; segment of array
mov di, [bp+6] ; offset of array
mov si, OFFSET i11
mov cx, 6 ; number of items to copy
rep movsw ; copy data to array
pop di
pop si
pop es
pop bp
ret 4
TwoInt ENDP
END
To demonstrate these programs from an .EXE program, compile and link
as follows:
BC BTWODIMI.BAS;
MASM ATWODIMI.ASM;
LINK BTWODIMI ATWODIMI;
BTWODIMI.EXE produces the following output:
11
12
13
21
22
23