mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-04-13 10:39:26 +02:00

recordtype or recordtype.variable, but explicit 'byte ptr' or 'word ptr' type override git-svn-id: trunk@38228 -
200 lines
8.4 KiB
ObjectPascal
200 lines
8.4 KiB
ObjectPascal
{ %CPU=i8086 }
|
|
program tasm18;
|
|
|
|
{$ifndef FPC}
|
|
type
|
|
CodePointer = Pointer;
|
|
{$endif FPC}
|
|
|
|
const
|
|
cval = 1;
|
|
|
|
type
|
|
foo = record
|
|
b1: byte;
|
|
w: word;
|
|
b2: byte;
|
|
end;
|
|
foo2 = record
|
|
bb1, bb2: byte;
|
|
end;
|
|
foo32 = record
|
|
b1, b2, b3, b4: byte;
|
|
end;
|
|
foo32_2 = record
|
|
b1: byte;
|
|
l: longint;
|
|
end;
|
|
|
|
const
|
|
expect1: array [0..$B9] of byte = (
|
|
$F7,$05,$01,$00, { TEST WORD PTR [DI],0001 }
|
|
$F6,$05,$01, { TEST BYTE PTR [DI],01 }
|
|
$F7,$45,$01,$01,$00, { TEST WORD PTR [DI+01],0001 }
|
|
$F6,$45,$03,$01, { TEST BYTE PTR [DI+03],01 }
|
|
$F7,$45,$FF,$01,$00, { TEST WORD PTR [DI-01],0001 }
|
|
$F6,$45,$FD,$01, { TEST BYTE PTR [DI-03],01 }
|
|
$F7,$45,$04,$01,$00, { TEST WORD PTR [DI+04],0001 }
|
|
$F6,$45,$04,$01, { TEST BYTE PTR [DI+04],01 }
|
|
|
|
$F7,$05,$01,$00, { TEST WORD PTR [DI],0001 }
|
|
$F6,$05,$01, { TEST BYTE PTR [DI],01 }
|
|
$F7,$45,$01,$01,$00, { TEST WORD PTR [DI+01],0001 }
|
|
$F6,$45,$03,$01, { TEST BYTE PTR [DI+03],01 }
|
|
$F7,$45,$FF,$01,$00, { TEST WORD PTR [DI-01],0001 }
|
|
$F6,$45,$FD,$01, { TEST BYTE PTR [DI-03],01 }
|
|
$F7,$45,$04,$01,$00, { TEST WORD PTR [DI+04],0001 }
|
|
$F6,$45,$04,$01, { TEST BYTE PTR [DI+04],01 }
|
|
|
|
$F7,$05,$01,$00, { TEST WORD PTR [DI],0001 }
|
|
$F6,$05,$01, { TEST BYTE PTR [DI],01 }
|
|
$F7,$45,$05,$01,$00, { TEST WORD PTR [DI+05],0001 }
|
|
$F6,$45,$0F,$01, { TEST BYTE PTR [DI+0F],01 }
|
|
$F7,$45,$FB,$01,$00, { TEST WORD PTR [DI-05],0001 }
|
|
$F6,$45,$F1,$01, { TEST BYTE PTR [DI-0F],01 }
|
|
$F7,$45,$12,$01,$00, { TEST WORD PTR [DI+12],0001 }
|
|
$F6,$45,$0E,$01, { TEST BYTE PTR [DI+0E],01 }
|
|
|
|
$F6,$05,$01, { TEST BYTE PTR [DI],01 }
|
|
$F6,$05,$01, { TEST BYTE PTR [DI],01 }
|
|
$F6,$45,$01,$01, { TEST BYTE PTR [DI+01],01 }
|
|
$F6,$45,$03,$01, { TEST BYTE PTR [DI+03],01 }
|
|
$F6,$45,$FF,$01, { TEST BYTE PTR [DI-01],01 }
|
|
$F6,$45,$FD,$01, { TEST BYTE PTR [DI-03],01 }
|
|
$F6,$45,$04,$01, { TEST BYTE PTR [DI+04],01 }
|
|
$F6,$45,$04,$01, { TEST BYTE PTR [DI+04],01 }
|
|
$F6,$05,$01, { TEST BYTE PTR [DI],01 }
|
|
$F6,$45,$01,$01, { TEST BYTE PTR [DI+01],01 }
|
|
|
|
$F7,$05,$01,$00, { TEST WORD PTR [DI],0001 }
|
|
$F7,$05,$01,$00, { TEST WORD PTR [DI],0001 }
|
|
$F7,$45,$01,$01,$00, { TEST WORD PTR [DI+01],0001 }
|
|
$F7,$45,$03,$01,$00, { TEST WORD PTR [DI+03],0001 }
|
|
$F7,$45,$FF,$01,$00, { TEST WORD PTR [DI-01],0001 }
|
|
$F7,$45,$FD,$01,$00, { TEST WORD PTR [DI-03],0001 }
|
|
$F7,$45,$04,$01,$00, { TEST WORD PTR [DI+04],0001 }
|
|
$F7,$45,$04,$01,$00, { TEST WORD PTR [DI+04],0001 }
|
|
$F7,$05,$01,$00, { TEST WORD PTR [DI],0001 }
|
|
$F7,$45,$01,$01,$00 { TEST WORD PTR [DI+01],0001 }
|
|
);
|
|
{$ifdef FPC}
|
|
expect2: array [0..$4C] of byte = (
|
|
$66,$F7,$05,$01,$00,$00,$00, { TEST DWORD PTR [DI],00000001 }
|
|
$66,$F7,$45,$01,$01,$00,$00,$00, { TEST DWORD PTR [DI+01],00000001 }
|
|
|
|
$66,$F7,$05,$01,$00,$00,$00, { TEST DWORD PTR [DI],00000001 }
|
|
$66,$F7,$05,$01,$00,$00,$00, { TEST DWORD PTR [DI],00000001 }
|
|
$66,$F7,$45,$01,$01,$00,$00,$00, { TEST DWORD PTR [DI+01],00000001 }
|
|
$66,$F7,$45,$03,$01,$00,$00,$00, { TEST DWORD PTR [DI+03],00000001 }
|
|
$66,$F7,$45,$FF,$01,$00,$00,$00, { TEST DWORD PTR [DI-01],00000001 }
|
|
$66,$F7,$45,$FD,$01,$00,$00,$00, { TEST DWORD PTR [DI-03],00000001 }
|
|
$66,$F7,$45,$04,$01,$00,$00,$00, { TEST DWORD PTR [DI+04],00000001 }
|
|
$66,$F7,$45,$04,$01,$00,$00,$00 { TEST DWORD PTR [DI+04],00000001 }
|
|
);
|
|
{$endif FPC}
|
|
|
|
|
|
procedure test1; assembler; {$IFDEF FPC_MM_HUGE}nostackframe;{$ENDIF}
|
|
asm
|
|
test [di+foo2], cval { test word ptr [di], 1 }
|
|
test byte ptr [di+foo], cval { test byte ptr [di], 1 }
|
|
test [di+foo.w], cval { test word ptr [di+1], 1 }
|
|
test [di+foo.b2], cval { test byte ptr [di+3], 1 }
|
|
test [di-foo.w], cval { test word ptr [di-1], 1 }
|
|
test [di-foo.b2], cval { test byte ptr [di-3], 1 }
|
|
test [di+foo.b2+foo.w], cval { test word ptr [di+4], 1 }
|
|
test [di+foo.w+foo.b2], cval { test byte ptr [di+4], 1 }
|
|
|
|
test [di+foo2*1], cval { test word ptr [di], 1 }
|
|
test byte ptr [di+foo*1], cval { test byte ptr [di], 1 }
|
|
test [di+foo.w*1], cval { test word ptr [di+1], 1 }
|
|
test [di+foo.b2*1], cval { test byte ptr [di+3], 1 }
|
|
test [di-foo.w*1], cval { test word ptr [di-1], 1 }
|
|
test [di-foo.b2*1], cval { test byte ptr [di-3], 1 }
|
|
test [di+foo.b2*1+foo.w*1], cval { test word ptr [di+4], 1 }
|
|
test [di+foo.w*1+foo.b2*1], cval { test byte ptr [di+4], 1 }
|
|
|
|
test [di+foo2*5], cval { test word ptr [di], 1 }
|
|
test byte ptr [di+foo*5], cval { test byte ptr [di], 1 }
|
|
test [di+foo.w*5], cval { test word ptr [di+5], 1 }
|
|
test [di+foo.b2*5], cval { test byte ptr [di+15], 1 }
|
|
test [di-foo.w*5], cval { test word ptr [di-5], 1 }
|
|
test [di-foo.b2*5], cval { test byte ptr [di-15], 1 }
|
|
test [di+foo.b2*5+foo.w*3], cval { test word ptr [di+18], 1 }
|
|
test [di+foo.w*5+foo.b2*3], cval { test byte ptr [di+14], 1 }
|
|
|
|
test byte ptr [di+foo2], cval { test byte ptr [di], 1 }
|
|
test byte ptr [di+foo], cval { test byte ptr [di], 1 }
|
|
test byte ptr [di+foo.w], cval { test byte ptr [di+1], 1 }
|
|
test byte ptr [di+foo.b2], cval { test byte ptr [di+3], 1 }
|
|
test byte ptr [di-foo.w], cval { test byte ptr [di-1], 1 }
|
|
test byte ptr [di-foo.b2], cval { test byte ptr [di-3], 1 }
|
|
test byte ptr [di+foo.b2+foo.w], cval { test byte ptr [di+4], 1 }
|
|
test byte ptr [di+foo.w+foo.b2], cval { test byte ptr [di+4], 1 }
|
|
test byte ptr [di+foo32], cval { test byte ptr [di], 1 }
|
|
test byte ptr [di+foo32_2.l], cval { test byte ptr [di+1], 1 }
|
|
|
|
test word ptr [di+foo2], cval { test word ptr [di], 1 }
|
|
test word ptr [di+foo], cval { test word ptr [di], 1 }
|
|
test word ptr [di+foo.w], cval { test word ptr [di+1], 1 }
|
|
test word ptr [di+foo.b2], cval { test word ptr [di+3], 1 }
|
|
test word ptr [di-foo.w], cval { test word ptr [di-1], 1 }
|
|
test word ptr [di-foo.b2], cval { test word ptr [di-3], 1 }
|
|
test word ptr [di+foo.b2+foo.w], cval { test word ptr [di+4], 1 }
|
|
test word ptr [di+foo.w+foo.b2], cval { test word ptr [di+4], 1 }
|
|
test word ptr [di+foo32], cval { test word ptr [di], 1 }
|
|
test word ptr [di+foo32_2.l], cval { test word ptr [di+1], 1 }
|
|
end;
|
|
|
|
{$ifdef FPC}
|
|
{ 32-bit test }
|
|
{ FPC only, since TP7 doesn't support 32-bit }
|
|
{$asmcpu 80386}
|
|
procedure test2; assembler; {$IFDEF FPC_MM_HUGE}nostackframe;{$ENDIF}
|
|
asm
|
|
test [di+foo32], cval { test dword ptr [di], 1 }
|
|
test [di+foo32_2.l], cval { test dword ptr [di+1], 1 }
|
|
|
|
test dword ptr [di+foo2], cval { test dword ptr [di], 1 }
|
|
test dword ptr [di+foo], cval { test dword ptr [di], 1 }
|
|
test dword ptr [di+foo.w], cval { test dword ptr [di+1], 1 }
|
|
test dword ptr [di+foo.b2], cval { test dword ptr [di+3], 1 }
|
|
test dword ptr [di-foo.w], cval { test dword ptr [di-1], 1 }
|
|
test dword ptr [di-foo.b2], cval { test dword ptr [di-3], 1 }
|
|
test dword ptr [di+foo.b2+foo.w], cval { test dword ptr [di+4], 1 }
|
|
test dword ptr [di+foo.w+foo.b2], cval { test dword ptr [di+4], 1 }
|
|
end;
|
|
{$endif FPC}
|
|
|
|
procedure Error;
|
|
begin
|
|
Writeln('Error!');
|
|
Halt(1);
|
|
end;
|
|
|
|
{ This version works in all i8086 memory models }
|
|
function CompareCode(cp: CodePointer; dp: Pointer; sz: Integer): Boolean;
|
|
var
|
|
I: Integer;
|
|
begin
|
|
for I := 0 to sz - 1 do
|
|
if Mem[Seg(cp^):Ofs(cp^) + I] <> Mem[Seg(dp^):Ofs(dp^) + I] then
|
|
begin
|
|
Writeln(I, ' ', Mem[Seg(cp^):Ofs(cp^) + I], ' ', Mem[Seg(dp^):Ofs(dp^) + I]);
|
|
CompareCode := False;
|
|
exit;
|
|
end;
|
|
CompareCode := True;
|
|
end;
|
|
|
|
begin
|
|
if not CompareCode(CodePointer(@test1), @expect1, SizeOf(expect1)) then
|
|
Error;
|
|
{$ifdef FPC}
|
|
if not CompareCode(CodePointer(@test2), @expect2, SizeOf(expect2)) then
|
|
Error;
|
|
{$endif FPC}
|
|
|
|
Writeln('Ok!');
|
|
end.
|