mirror of
https://github.com/byteworksinc/ORCA-C.git
synced 2025-01-05 08:30:59 +00:00
Implement 64-bit addition and subtraction.
This commit is contained in:
parent
2426794194
commit
807a143e51
@ -90,10 +90,12 @@
|
|||||||
{ }
|
{ }
|
||||||
{ pc_adi - integer addition }
|
{ pc_adi - integer addition }
|
||||||
{ pc_adl - long addition }
|
{ pc_adl - long addition }
|
||||||
|
{ pc_adq - long long addition }
|
||||||
{ pc_adr - real addition }
|
{ pc_adr - real addition }
|
||||||
{ }
|
{ }
|
||||||
{ Gen0(pc_adi) cgByte,cgUByte,cgWord,cgUWord }
|
{ Gen0(pc_adi) cgByte,cgUByte,cgWord,cgUWord }
|
||||||
{ Gen0(pc_adl) cgLong,cgULong }
|
{ Gen0(pc_adl) cgLong,cgULong }
|
||||||
|
{ Gen0(pc_adq) cgQuad,cgUQuad }
|
||||||
{ Gen0(pc_adr) cgReal,cgDouble,cgComp,cgExtended }
|
{ Gen0(pc_adr) cgReal,cgDouble,cgComp,cgExtended }
|
||||||
{ }
|
{ }
|
||||||
{ The two values on the top of the evaluation stack are }
|
{ The two values on the top of the evaluation stack are }
|
||||||
@ -547,10 +549,12 @@
|
|||||||
{ }
|
{ }
|
||||||
{ pc_sbi - integer subtraction }
|
{ pc_sbi - integer subtraction }
|
||||||
{ pc_sbl - long subtraction }
|
{ pc_sbl - long subtraction }
|
||||||
|
{ pc_sbq - long long subtraction }
|
||||||
{ pc_sbr - real subtraction }
|
{ pc_sbr - real subtraction }
|
||||||
{ }
|
{ }
|
||||||
{ Gen0(pc_sbi) cgByte,cgUByte,cgWord,cgUWord }
|
{ Gen0(pc_sbi) cgByte,cgUByte,cgWord,cgUWord }
|
||||||
{ Gen0(pc_sbl) cgLong,cgULong }
|
{ Gen0(pc_sbl) cgLong,cgULong }
|
||||||
|
{ Gen0(pc_sbq) cgQuad,cgUQuad }
|
||||||
{ Gen0(pc_sbr) cgReal,cgDouble,cgComp,cgExtended }
|
{ Gen0(pc_sbr) cgReal,cgDouble,cgComp,cgExtended }
|
||||||
{ }
|
{ }
|
||||||
{ The two values on the top of the evaluation stack are }
|
{ The two values on the top of the evaluation stack are }
|
||||||
|
2
CGI.pas
2
CGI.pas
@ -229,7 +229,7 @@ type
|
|||||||
dc_sym,pc_lnd,pc_lor,pc_vsr,pc_uml,pc_udl,pc_ulm,pc_pop,pc_gil,
|
dc_sym,pc_lnd,pc_lor,pc_vsr,pc_uml,pc_udl,pc_ulm,pc_pop,pc_gil,
|
||||||
pc_gli,pc_gdl,pc_gld,pc_cpi,pc_tri,pc_lbu,pc_lbf,pc_sbf,pc_cbf,dc_cns,
|
pc_gli,pc_gdl,pc_gld,pc_cpi,pc_tri,pc_lbu,pc_lbf,pc_sbf,pc_cbf,dc_cns,
|
||||||
dc_prm,pc_nat,pc_bno,pc_nop,pc_psh,pc_ili,pc_iil,pc_ild,pc_idl,
|
dc_prm,pc_nat,pc_bno,pc_nop,pc_psh,pc_ili,pc_iil,pc_ild,pc_idl,
|
||||||
pc_bqr,pc_bqx,pc_baq,pc_bnq,pc_ngq);
|
pc_bqr,pc_bqx,pc_baq,pc_bnq,pc_ngq,pc_adq,pc_sbq);
|
||||||
|
|
||||||
{intermediate code}
|
{intermediate code}
|
||||||
{-----------------}
|
{-----------------}
|
||||||
|
9
DAG.pas
9
DAG.pas
@ -110,7 +110,7 @@ function CodesMatch (op1, op2: icptr; exact: boolean): boolean;
|
|||||||
|
|
||||||
pc_adi, pc_adl, pc_adr, pc_and, pc_lnd, pc_bnd, pc_bal, pc_bor,
|
pc_adi, pc_adl, pc_adr, pc_and, pc_lnd, pc_bnd, pc_bal, pc_bor,
|
||||||
pc_blr, pc_bxr, pc_blx, pc_equ, pc_neq, pc_ior, pc_lor, pc_mpi,
|
pc_blr, pc_bxr, pc_blx, pc_equ, pc_neq, pc_ior, pc_lor, pc_mpi,
|
||||||
pc_umi, pc_mpl, pc_uml, pc_mpr, pc_bqr, pc_bqx, pc_baq: begin
|
pc_umi, pc_mpl, pc_uml, pc_mpr, pc_bqr, pc_bqx, pc_baq, pc_adq: begin
|
||||||
if op1^.left = op2^.left then
|
if op1^.left = op2^.left then
|
||||||
if op1^.right = op2^.right then
|
if op1^.right = op2^.right then
|
||||||
result := true;
|
result := true;
|
||||||
@ -2266,7 +2266,7 @@ case op^.opcode of
|
|||||||
pc_udl, pc_ulm, pc_uml, pc_vsr:
|
pc_udl, pc_ulm, pc_uml, pc_vsr:
|
||||||
TypeOf := cgULong;
|
TypeOf := cgULong;
|
||||||
|
|
||||||
pc_bnq, pc_ngq, pc_bqr, pc_bqx, pc_baq:
|
pc_bnq, pc_ngq, pc_bqr, pc_bqx, pc_baq, pc_adq, pc_sbq:
|
||||||
TypeOf := cgQuad;
|
TypeOf := cgQuad;
|
||||||
|
|
||||||
pc_ngr, pc_adr, pc_dvr, pc_mpr, pc_sbr:
|
pc_ngr, pc_adr, pc_dvr, pc_mpr, pc_sbr:
|
||||||
@ -4062,7 +4062,7 @@ var
|
|||||||
pc_mdl,pc_ulm,pc_mpi,pc_umi,pc_mpl,pc_uml,pc_mpr,pc_ngi,
|
pc_mdl,pc_ulm,pc_mpi,pc_umi,pc_mpl,pc_uml,pc_mpr,pc_ngi,
|
||||||
pc_ngl,pc_ngr,pc_not,pc_pop,pc_sbi,pc_sbl,pc_sbr,
|
pc_ngl,pc_ngr,pc_not,pc_pop,pc_sbi,pc_sbl,pc_sbr,
|
||||||
pc_shl,pc_sll,pc_shr,pc_usr,pc_slr,pc_vsr,pc_tri,
|
pc_shl,pc_sll,pc_shr,pc_usr,pc_slr,pc_vsr,pc_tri,
|
||||||
pc_bqr,pc_bqx,pc_baq,pc_bnq,pc_ngq]
|
pc_bqr,pc_bqx,pc_baq,pc_bnq,pc_ngq,pc_adq,pc_sbq]
|
||||||
then begin
|
then begin
|
||||||
op^.parents := icount;
|
op^.parents := icount;
|
||||||
icount := icount+1;
|
icount := icount+1;
|
||||||
@ -4942,7 +4942,8 @@ case code^.opcode of
|
|||||||
pc_les, pc_neq, pc_ior, pc_lor, pc_ixa, pc_mod, pc_uim, pc_mdl,
|
pc_les, pc_neq, pc_ior, pc_lor, pc_ixa, pc_mod, pc_uim, pc_mdl,
|
||||||
pc_ulm, pc_mpi, pc_umi, pc_mpl, pc_uml, pc_mpr, pc_psh, pc_sbi,
|
pc_ulm, pc_mpi, pc_umi, pc_mpl, pc_uml, pc_mpr, pc_psh, pc_sbi,
|
||||||
pc_sbl, pc_sbr, pc_shl, pc_sll, pc_shr, pc_usr, pc_slr, pc_vsr,
|
pc_sbl, pc_sbr, pc_shl, pc_sll, pc_shr, pc_usr, pc_slr, pc_vsr,
|
||||||
pc_tri, pc_sbf, pc_sto, pc_cui, pc_bqr, pc_bqx, pc_baq:
|
pc_tri, pc_sbf, pc_sto, pc_cui, pc_bqr, pc_bqx, pc_baq, pc_adq,
|
||||||
|
pc_sbq:
|
||||||
begin
|
begin
|
||||||
code^.right := Pop;
|
code^.right := Pop;
|
||||||
code^.left := Pop;
|
code^.left := Pop;
|
||||||
|
@ -3063,6 +3063,8 @@ case tree^.token.kind of
|
|||||||
Gen0(pc_adi)
|
Gen0(pc_adi)
|
||||||
else if et in [cgLong,cgULong] then
|
else if et in [cgLong,cgULong] then
|
||||||
Gen0(pc_adl)
|
Gen0(pc_adl)
|
||||||
|
else if et in [cgQuad,cgUQuad] then
|
||||||
|
Gen0(pc_adq)
|
||||||
else if et = cgExtended then
|
else if et = cgExtended then
|
||||||
Gen0(pc_adr)
|
Gen0(pc_adr)
|
||||||
else
|
else
|
||||||
@ -3077,6 +3079,8 @@ case tree^.token.kind of
|
|||||||
Gen0(pc_sbi)
|
Gen0(pc_sbi)
|
||||||
else if et in [cgLong,cgULong] then
|
else if et in [cgLong,cgULong] then
|
||||||
Gen0(pc_sbl)
|
Gen0(pc_sbl)
|
||||||
|
else if et in [cgQuad,cgUQuad] then
|
||||||
|
Gen0(pc_sbq)
|
||||||
else if et = cgExtended then
|
else if et = cgExtended then
|
||||||
Gen0(pc_sbr)
|
Gen0(pc_sbr)
|
||||||
else
|
else
|
||||||
@ -3422,6 +3426,8 @@ case tree^.token.kind of
|
|||||||
Gen0(pc_adi);
|
Gen0(pc_adi);
|
||||||
cgLong,cgULong:
|
cgLong,cgULong:
|
||||||
Gen0(pc_adl);
|
Gen0(pc_adl);
|
||||||
|
cgQuad,cgUQuad:
|
||||||
|
Gen0(pc_adq);
|
||||||
cgExtended:
|
cgExtended:
|
||||||
Gen0(pc_adr);
|
Gen0(pc_adr);
|
||||||
otherwise:
|
otherwise:
|
||||||
@ -3478,6 +3484,8 @@ case tree^.token.kind of
|
|||||||
Gen0(pc_sbi);
|
Gen0(pc_sbi);
|
||||||
cgLong,cgULong:
|
cgLong,cgULong:
|
||||||
Gen0(pc_sbl);
|
Gen0(pc_sbl);
|
||||||
|
cgQuad,cgUQuad:
|
||||||
|
Gen0(pc_sbq);
|
||||||
cgExtended:
|
cgExtended:
|
||||||
Gen0(pc_sbr);
|
Gen0(pc_sbr);
|
||||||
otherwise:
|
otherwise:
|
||||||
|
44
Gen.pas
44
Gen.pas
@ -679,6 +679,49 @@ else begin
|
|||||||
end; {GenAdlSbl}
|
end; {GenAdlSbl}
|
||||||
|
|
||||||
|
|
||||||
|
procedure GenAdqSbq (op: icptr);
|
||||||
|
|
||||||
|
{ generate code for pc_adq, pc_sbq }
|
||||||
|
{ }
|
||||||
|
{ parameters: }
|
||||||
|
{ op - pc_adq or pc_sbq operation }
|
||||||
|
|
||||||
|
begin {GenAdqSbq}
|
||||||
|
GenTree(op^.right);
|
||||||
|
GenTree(op^.left);
|
||||||
|
if op^.opcode = pc_adq then begin
|
||||||
|
GenImplied(m_clc);
|
||||||
|
GenImplied(m_pla);
|
||||||
|
GenNative(m_adc_s, direct, 7, nil, 0);
|
||||||
|
GenNative(m_sta_s, direct, 7, nil, 0);
|
||||||
|
GenImplied(m_pla);
|
||||||
|
GenNative(m_adc_s, direct, 7, nil, 0);
|
||||||
|
GenNative(m_sta_s, direct, 7, nil, 0);
|
||||||
|
GenImplied(m_pla);
|
||||||
|
GenNative(m_adc_s, direct, 7, nil, 0);
|
||||||
|
GenNative(m_sta_s, direct, 7, nil, 0);
|
||||||
|
GenImplied(m_pla);
|
||||||
|
GenNative(m_adc_s, direct, 7, nil, 0);
|
||||||
|
GenNative(m_sta_s, direct, 7, nil, 0);
|
||||||
|
end {else}
|
||||||
|
else {if op^.opcode = pc_sbq then} begin
|
||||||
|
GenImplied(m_sec);
|
||||||
|
GenImplied(m_pla);
|
||||||
|
GenNative(m_sbc_s, direct, 7, nil, 0);
|
||||||
|
GenNative(m_sta_s, direct, 7, nil, 0);
|
||||||
|
GenImplied(m_pla);
|
||||||
|
GenNative(m_sbc_s, direct, 7, nil, 0);
|
||||||
|
GenNative(m_sta_s, direct, 7, nil, 0);
|
||||||
|
GenImplied(m_pla);
|
||||||
|
GenNative(m_sbc_s, direct, 7, nil, 0);
|
||||||
|
GenNative(m_sta_s, direct, 7, nil, 0);
|
||||||
|
GenImplied(m_pla);
|
||||||
|
GenNative(m_sbc_s, direct, 7, nil, 0);
|
||||||
|
GenNative(m_sta_s, direct, 7, nil, 0);
|
||||||
|
end; {else}
|
||||||
|
end; {GenAdqSbq}
|
||||||
|
|
||||||
|
|
||||||
procedure GenCmp (op: icptr; rOpcode: pcodes; lb: integer);
|
procedure GenCmp (op: icptr; rOpcode: pcodes; lb: integer);
|
||||||
|
|
||||||
{ generate code for pc_les, pc_leq, pc_grt or pc_geq }
|
{ generate code for pc_les, pc_leq, pc_grt or pc_geq }
|
||||||
@ -5755,6 +5798,7 @@ case op^.opcode of
|
|||||||
pc_add: GenNative(d_add, genaddress, op^.q, nil, 0);
|
pc_add: GenNative(d_add, genaddress, op^.q, nil, 0);
|
||||||
pc_adi: GenAdi(op);
|
pc_adi: GenAdi(op);
|
||||||
pc_adl,pc_sbl: GenAdlSbl(op, nil);
|
pc_adl,pc_sbl: GenAdlSbl(op, nil);
|
||||||
|
pc_adq,pc_sbq: GenAdqSbq(op);
|
||||||
pc_adr,pc_dvr,pc_mpr,pc_sbr: GenRealBinOp(op);
|
pc_adr,pc_dvr,pc_mpr,pc_sbr: GenRealBinOp(op);
|
||||||
pc_and,pc_bnd,pc_bor,pc_bxr,pc_ior: GenLogic(op);
|
pc_and,pc_bnd,pc_bor,pc_bxr,pc_ior: GenLogic(op);
|
||||||
pc_blr,pc_blx,pc_bal,pc_dvl,pc_mdl,pc_mpl,pc_sll,pc_slr,pc_udl,pc_ulm,
|
pc_blr,pc_blx,pc_bal,pc_dvl,pc_mdl,pc_mpl,pc_sll,pc_slr,pc_udl,pc_ulm,
|
||||||
|
Loading…
Reference in New Issue
Block a user