summaryrefslogtreecommitdiff
path: root/compiler
diff options
context:
space:
mode:
Diffstat (limited to 'compiler')
-rw-r--r--compiler/i8086/cgcpu.pas51
1 files changed, 51 insertions, 0 deletions
diff --git a/compiler/i8086/cgcpu.pas b/compiler/i8086/cgcpu.pas
index d6921e7f2f..5aa82447f0 100644
--- a/compiler/i8086/cgcpu.pas
+++ b/compiler/i8086/cgcpu.pas
@@ -43,6 +43,11 @@ unit cgcpu;
function getintregister(list:TAsmList;size:Tcgsize):Tregister;override;
+ procedure a_call_name(list : TAsmList;const s : string; weak: boolean);override;
+ procedure a_call_name_far(list : TAsmList;const s : string; weak: boolean);
+ procedure a_call_name_static(list : TAsmList;const s : string);override;
+ procedure a_call_name_static_far(list : TAsmList;const s : string);
+
procedure a_op_const_reg(list : TAsmList; Op: TOpCG; size: TCGSize; a: tcgint; reg: TRegister); override;
procedure a_op_const_ref(list : TAsmList; Op: TOpCG; size: TCGSize; a: tcgint; const ref: TReference); override;
procedure a_op_reg_reg(list : TAsmList; Op: TOpCG; size: TCGSize; src, dst: TRegister); override;
@@ -157,6 +162,52 @@ unit cgcpu;
end;
+ procedure tcg8086.a_call_name(list: TAsmList; const s: string; weak: boolean);
+ begin
+ if current_settings.x86memorymodel in x86_far_code_models then
+ a_call_name_far(list,s,weak)
+ else
+ a_call_name_near(list,s,weak);
+ end;
+
+
+ procedure tcg8086.a_call_name_far(list: TAsmList; const s: string;
+ weak: boolean);
+ var
+ sym : tasmsymbol;
+ r : treference;
+ begin
+ if not(weak) then
+ sym:=current_asmdata.RefAsmSymbol(s)
+ else
+ sym:=current_asmdata.WeakRefAsmSymbol(s);
+ reference_reset_symbol(r,sym,0,sizeof(pint));
+ r.refaddr:=addr_far;
+ list.concat(taicpu.op_ref(A_CALL,S_NO,r));
+ end;
+
+
+ procedure tcg8086.a_call_name_static(list: TAsmList; const s: string);
+ begin
+ if current_settings.x86memorymodel in x86_far_code_models then
+ a_call_name_static_far(list,s)
+ else
+ a_call_name_static_near(list,s);
+ end;
+
+
+ procedure tcg8086.a_call_name_static_far(list: TAsmList; const s: string);
+ var
+ sym : tasmsymbol;
+ r : treference;
+ begin
+ sym:=current_asmdata.RefAsmSymbol(s);
+ reference_reset_symbol(r,sym,0,sizeof(pint));
+ r.refaddr:=addr_far;
+ list.concat(taicpu.op_ref(A_CALL,S_NO,r));
+ end;
+
+
procedure tcg8086.a_op_const_reg(list: TAsmList; Op: TOpCG; size: TCGSize;
a: tcgint; reg: TRegister);
var