forked from KolibriOS/kolibrios
oberon07 compiler: bug fix
git-svn-id: svn://kolibrios.org@7667 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
b6b8407c4f
commit
920044111f
Binary file not shown.
@ -666,6 +666,7 @@ VAR
|
|||||||
reg: INTEGER;
|
reg: INTEGER;
|
||||||
max: INTEGER;
|
max: INTEGER;
|
||||||
loop: INTEGER;
|
loop: INTEGER;
|
||||||
|
param2: INTEGER;
|
||||||
|
|
||||||
BEGIN
|
BEGIN
|
||||||
loop := 1;
|
loop := 1;
|
||||||
@ -730,9 +731,36 @@ BEGIN
|
|||||||
|
|
||||||
|CODE.opCALL, CODE.opCALLP, CODE.opCALLI,
|
|CODE.opCALL, CODE.opCALLP, CODE.opCALLI,
|
||||||
CODE.opWIN64CALL, CODE.opWIN64CALLP, CODE.opWIN64CALLI,
|
CODE.opWIN64CALL, CODE.opWIN64CALLP, CODE.opWIN64CALLI,
|
||||||
CODE.opSYSVCALL, CODE.opSYSVCALLP, CODE.opSYSVCALLI:
|
CODE.opSYSVCALL, CODE.opSYSVCALLP, CODE.opSYSVCALLI,
|
||||||
|
|
||||||
|
CODE.opSAVES, CODE.opRSET, CODE.opRSETR,
|
||||||
|
CODE.opRSETL, CODE.opRSET1,
|
||||||
|
CODE.opEQS .. CODE.opGES,
|
||||||
|
CODE.opEQS2 .. CODE.opGES2,
|
||||||
|
CODE.opEQSW .. CODE.opGESW,
|
||||||
|
CODE.opEQSW2 .. CODE.opGESW2,
|
||||||
|
CODE.opCOPY, CODE.opMOVE, CODE.opCOPYA,
|
||||||
|
CODE.opCOPYS, CODE.opCOPYS2, CODE.opROT,
|
||||||
|
CODE.opNEW, CODE.opDISP, CODE.opISREC,
|
||||||
|
CODE.opIS, CODE.opTYPEGR, CODE.opTYPEGP,
|
||||||
|
CODE.opCASET, CODE.opDIV,
|
||||||
|
CODE.opDIVL, CODE.opMOD,
|
||||||
|
CODE.opMODL, CODE.opLENGTH, CODE.opLENGTHW:
|
||||||
leaf := FALSE
|
leaf := FALSE
|
||||||
|
|
||||||
|
|CODE.opDIVR, CODE.opMODR:
|
||||||
|
param2 := cur.param2;
|
||||||
|
IF param2 >= 1 THEN
|
||||||
|
param2 := X86.log2(param2)
|
||||||
|
ELSIF param2 <= -1 THEN
|
||||||
|
param2 := X86.log2(-param2)
|
||||||
|
ELSE
|
||||||
|
param2 := -1
|
||||||
|
END;
|
||||||
|
IF param2 < 0 THEN
|
||||||
|
leaf := FALSE
|
||||||
|
END
|
||||||
|
|
||||||
ELSE
|
ELSE
|
||||||
|
|
||||||
END;
|
END;
|
||||||
@ -1425,6 +1453,14 @@ BEGIN
|
|||||||
ELSE
|
ELSE
|
||||||
ASSERT(R.top + 1 <= n);
|
ASSERT(R.top + 1 <= n);
|
||||||
PushAll(n)
|
PushAll(n)
|
||||||
|
END
|
||||||
|
|
||||||
|
|CODE.opACC:
|
||||||
|
IF (R.top # 0) OR (R.stk[0] # rax) THEN
|
||||||
|
PushAll(0);
|
||||||
|
GetRegA;
|
||||||
|
pop(rax);
|
||||||
|
DEC(R.pushed)
|
||||||
END
|
END
|
||||||
|
|
||||||
|CODE.opJNZ:
|
|CODE.opJNZ:
|
||||||
|
@ -89,6 +89,8 @@ CONST
|
|||||||
opALIGN16* = 236; opPOPSP* = 237;
|
opALIGN16* = 236; opPOPSP* = 237;
|
||||||
opWIN64CALL* = 238; opWIN64CALLI* = 239; opWIN64CALLP* = 240; opLOOP* = 241; opENDLOOP* = 242;
|
opWIN64CALL* = 238; opWIN64CALLI* = 239; opWIN64CALLP* = 240; opLOOP* = 241; opENDLOOP* = 242;
|
||||||
opSYSVCALL* = 243; opSYSVCALLI* = 244; opSYSVCALLP* = 245; opSYSVALIGN16* = 246; opWIN64ALIGN16* = 247;
|
opSYSVCALL* = 243; opSYSVCALLI* = 244; opSYSVCALLP* = 245; opSYSVALIGN16* = 246; opWIN64ALIGN16* = 247;
|
||||||
|
|
||||||
|
opACC* = 248;
|
||||||
|
|
||||||
|
|
||||||
opSADR_PARAM* = 1000; opLOAD64_PARAM* = 1001; opLLOAD64_PARAM* = 1002; opGLOAD64_PARAM* = 1003;
|
opSADR_PARAM* = 1000; opLOAD64_PARAM* = 1001; opLLOAD64_PARAM* = 1002; opGLOAD64_PARAM* = 1003;
|
||||||
|
@ -1860,7 +1860,8 @@ VAR
|
|||||||
|
|
||||||
IF e.obj = eCONST THEN
|
IF e.obj = eCONST THEN
|
||||||
CODE.AddCmd(CODE.opCONST, ORD(ARITH.getBool(e.value)))
|
CODE.AddCmd(CODE.opCONST, ORD(ARITH.getBool(e.value)))
|
||||||
END;
|
END;
|
||||||
|
CODE.AddCmd0(CODE.opACC);
|
||||||
CODE.AddJmpCmd(CODE.opJZ, label);
|
CODE.AddJmpCmd(CODE.opJZ, label);
|
||||||
CODE.drop
|
CODE.drop
|
||||||
END
|
END
|
||||||
@ -1983,7 +1984,8 @@ VAR
|
|||||||
e.obj := eEXPR;
|
e.obj := eEXPR;
|
||||||
IF e1.obj = eCONST THEN
|
IF e1.obj = eCONST THEN
|
||||||
CODE.AddCmd(CODE.opCONST, ORD(ARITH.getBool(e1.value)))
|
CODE.AddCmd(CODE.opCONST, ORD(ARITH.getBool(e1.value)))
|
||||||
END
|
END;
|
||||||
|
CODE.AddCmd0(CODE.opACC)
|
||||||
END
|
END
|
||||||
|
|
||||||
END
|
END
|
||||||
@ -2055,7 +2057,8 @@ VAR
|
|||||||
|
|
||||||
IF e.obj = eCONST THEN
|
IF e.obj = eCONST THEN
|
||||||
CODE.AddCmd(CODE.opCONST, ORD(ARITH.getBool(e.value)))
|
CODE.AddCmd(CODE.opCONST, ORD(ARITH.getBool(e.value)))
|
||||||
END;
|
END;
|
||||||
|
CODE.AddCmd0(CODE.opACC);
|
||||||
CODE.AddJmpCmd(CODE.opJNZ, label);
|
CODE.AddJmpCmd(CODE.opJNZ, label);
|
||||||
CODE.drop
|
CODE.drop
|
||||||
END
|
END
|
||||||
@ -2122,7 +2125,8 @@ VAR
|
|||||||
e.obj := eEXPR;
|
e.obj := eEXPR;
|
||||||
IF e1.obj = eCONST THEN
|
IF e1.obj = eCONST THEN
|
||||||
CODE.AddCmd(CODE.opCONST, ORD(ARITH.getBool(e1.value)))
|
CODE.AddCmd(CODE.opCONST, ORD(ARITH.getBool(e1.value)))
|
||||||
END
|
END;
|
||||||
|
CODE.AddCmd0(CODE.opACC)
|
||||||
END
|
END
|
||||||
|
|
||||||
END
|
END
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
(*
|
(*
|
||||||
BSD 2-Clause License
|
BSD 2-Clause License
|
||||||
|
|
||||||
Copyright (c) 2018, Anton Krotov
|
Copyright (c) 2018, 2019, Anton Krotov
|
||||||
All rights reserved.
|
All rights reserved.
|
||||||
*)
|
*)
|
||||||
|
|
||||||
@ -255,19 +255,19 @@ BEGIN
|
|||||||
|0C1X..0DFX:
|
|0C1X..0DFX:
|
||||||
u := LSL(ORD(c) - 0C0H, 6);
|
u := LSL(ORD(c) - 0C0H, 6);
|
||||||
IF i + 1 < srclen THEN
|
IF i + 1 < srclen THEN
|
||||||
u := u + ROR(LSL(ORD(src[i + 1]), 26), 26);
|
INC(i);
|
||||||
INC(i)
|
INC(u, ORD(BITS(ORD(src[i])) * {0..5}))
|
||||||
END
|
END
|
||||||
|
|
||||||
|0E1X..0EFX:
|
|0E1X..0EFX:
|
||||||
u := LSL(ORD(c) - 0E0H, 12);
|
u := LSL(ORD(c) - 0E0H, 12);
|
||||||
IF i + 1 < srclen THEN
|
IF i + 1 < srclen THEN
|
||||||
u := u + ROR(LSL(ORD(src[i + 1]), 26), 20);
|
INC(i);
|
||||||
INC(i)
|
INC(u, ORD(BITS(ORD(src[i])) * {0..5}) * 64)
|
||||||
END;
|
END;
|
||||||
IF i + 1 < srclen THEN
|
IF i + 1 < srclen THEN
|
||||||
u := u + ROR(LSL(ORD(src[i + 1]), 26), 26);
|
INC(i);
|
||||||
INC(i)
|
INC(u, ORD(BITS(ORD(src[i])) * {0..5}))
|
||||||
END
|
END
|
||||||
(*
|
(*
|
||||||
|0F1X..0F7X:
|
|0F1X..0F7X:
|
||||||
|
@ -308,6 +308,12 @@ BEGIN
|
|||||||
END setcc;
|
END setcc;
|
||||||
|
|
||||||
|
|
||||||
|
PROCEDURE xor (reg1, reg2: INTEGER);
|
||||||
|
BEGIN
|
||||||
|
OutByte2(31H, 0C0H + reg2 * 8 + reg1) // xor reg1, reg2
|
||||||
|
END xor;
|
||||||
|
|
||||||
|
|
||||||
PROCEDURE drop;
|
PROCEDURE drop;
|
||||||
BEGIN
|
BEGIN
|
||||||
REG.Drop(R)
|
REG.Drop(R)
|
||||||
@ -937,7 +943,7 @@ BEGIN
|
|||||||
ELSIF a = -1 THEN
|
ELSIF a = -1 THEN
|
||||||
neg(reg1)
|
neg(reg1)
|
||||||
ELSIF a = 0 THEN
|
ELSIF a = 0 THEN
|
||||||
OutByte2(31H, 0C0H + reg1 * 9) // xor reg1, reg1
|
xor(reg1, reg1)
|
||||||
ELSE
|
ELSE
|
||||||
IF n > 0 THEN
|
IF n > 0 THEN
|
||||||
IF a < 0 THEN
|
IF a < 0 THEN
|
||||||
@ -1080,7 +1086,7 @@ BEGIN
|
|||||||
reg1 := REG.GetAnyReg(R);
|
reg1 := REG.GetAnyReg(R);
|
||||||
setcc(cc + 16, reg1);
|
setcc(cc + 16, reg1);
|
||||||
andrc(reg1, 1)
|
andrc(reg1, 1)
|
||||||
END;
|
END
|
||||||
|
|
||||||
|CODE.opGT, CODE.opGE, CODE.opLT,
|
|CODE.opGT, CODE.opGE, CODE.opLT,
|
||||||
CODE.opLE, CODE.opEQ, CODE.opNE:
|
CODE.opLE, CODE.opEQ, CODE.opNE:
|
||||||
@ -1128,6 +1134,14 @@ BEGIN
|
|||||||
setcc(setne, reg1)
|
setcc(setne, reg1)
|
||||||
END;
|
END;
|
||||||
andrc(reg1, 1)
|
andrc(reg1, 1)
|
||||||
|
|
||||||
|
|CODE.opACC:
|
||||||
|
IF (R.top # 0) OR (R.stk[0] # eax) THEN
|
||||||
|
PushAll(0);
|
||||||
|
GetRegA;
|
||||||
|
pop(eax);
|
||||||
|
DEC(R.pushed)
|
||||||
|
END
|
||||||
|
|
||||||
|CODE.opDROP:
|
|CODE.opDROP:
|
||||||
UnOp(reg1);
|
UnOp(reg1);
|
||||||
@ -1344,7 +1358,7 @@ BEGIN
|
|||||||
|
|
||||||
|CODE.opDIVS:
|
|CODE.opDIVS:
|
||||||
BinOp(reg1, reg2);
|
BinOp(reg1, reg2);
|
||||||
OutByte2(31H, 0C0H + reg2 * 8 + reg1); // xor reg1, reg2
|
xor(reg1, reg2);
|
||||||
drop
|
drop
|
||||||
|
|
||||||
|CODE.opDIVSC:
|
|CODE.opDIVSC:
|
||||||
@ -1478,7 +1492,7 @@ BEGIN
|
|||||||
BinOp(reg1, reg2);
|
BinOp(reg1, reg2);
|
||||||
cmprc(reg1, 32);
|
cmprc(reg1, 32);
|
||||||
OutByte2(72H, 4); // jb L
|
OutByte2(72H, 4); // jb L
|
||||||
OutByte2(31H, 0C0H + reg1 * 9); // xor reg1, reg1
|
xor(reg1, reg1);
|
||||||
jmp(label);
|
jmp(label);
|
||||||
//L:
|
//L:
|
||||||
OutByte3(0FH, 0A3H, 0C0H + reg2 + 8 * reg1); // bt reg2, reg1
|
OutByte3(0FH, 0A3H, 0C0H + reg2 + 8 * reg1); // bt reg2, reg1
|
||||||
@ -1493,7 +1507,7 @@ BEGIN
|
|||||||
reg2 := REG.GetAnyReg(R);
|
reg2 := REG.GetAnyReg(R);
|
||||||
cmprc(reg1, 32);
|
cmprc(reg1, 32);
|
||||||
OutByte2(72H, 4); // jb L
|
OutByte2(72H, 4); // jb L
|
||||||
OutByte2(31H, 0C0H + reg1 * 9); // xor reg1, reg1
|
xor(reg1, reg1);
|
||||||
jmp(label);
|
jmp(label);
|
||||||
//L:
|
//L:
|
||||||
movrc(reg2, param2);
|
movrc(reg2, param2);
|
||||||
@ -1631,7 +1645,7 @@ BEGIN
|
|||||||
|
|
||||||
IF ABS(a) = 1 THEN
|
IF ABS(a) = 1 THEN
|
||||||
UnOp(reg1);
|
UnOp(reg1);
|
||||||
OutByte2(31H, 0C0H + reg1 * 9) // xor reg1, reg1
|
xor(reg1, reg1)
|
||||||
ELSE
|
ELSE
|
||||||
IF n > 0 THEN
|
IF n > 0 THEN
|
||||||
UnOp(reg1);
|
UnOp(reg1);
|
||||||
@ -2226,8 +2240,8 @@ BEGIN
|
|||||||
push(esp)
|
push(esp)
|
||||||
ELSE
|
ELSE
|
||||||
pushc(0)
|
pushc(0)
|
||||||
END;
|
END;
|
||||||
|
|
||||||
IF pic THEN
|
IF pic THEN
|
||||||
reg1 := REG.GetAnyReg(R);
|
reg1 := REG.GetAnyReg(R);
|
||||||
Pic(reg1, BIN.PICCODE, entry);
|
Pic(reg1, BIN.PICCODE, entry);
|
||||||
|
Loading…
Reference in New Issue
Block a user