summaryrefslogtreecommitdiff
path: root/compiler/ncgutil.pas
diff options
context:
space:
mode:
authornickysn <nickysn@3ad0048d-3df7-0310-abae-a5850022a9f2>2014-03-23 18:11:50 +0000
committernickysn <nickysn@3ad0048d-3df7-0310-abae-a5850022a9f2>2014-03-23 18:11:50 +0000
commit8785bb9d82eb1b6aa3f34122cef6faa9498107dc (patch)
treeb0243b046a32b962babd084fa3a405d0e3e184b0 /compiler/ncgutil.pas
parenta4798ac8ecadc03f2f7225c3ffd8d60e59d447ad (diff)
downloadfpc-8785bb9d82eb1b6aa3f34122cef6faa9498107dc.tar.gz
* i8086 far data memory model fix in ncgutil.new_exception
git-svn-id: http://svn.freepascal.org/svn/fpc/trunk@27242 3ad0048d-3df7-0310-abae-a5850022a9f2
Diffstat (limited to 'compiler/ncgutil.pas')
-rw-r--r--compiler/ncgutil.pas15
1 files changed, 14 insertions, 1 deletions
diff --git a/compiler/ncgutil.pas b/compiler/ncgutil.pas
index 63b122c883..fbb54897b1 100644
--- a/compiler/ncgutil.pas
+++ b/compiler/ncgutil.pas
@@ -412,6 +412,9 @@ implementation
var
paraloc1,paraloc2,paraloc3 : tcgpara;
pd: tprocdef;
+{$ifdef i8086}
+ tmpreg: TRegister;
+{$endif i8086}
begin
pd:=search_system_proc('fpc_pushexceptaddr');
paraloc1.init;
@@ -443,7 +446,17 @@ implementation
pd:=search_system_proc('fpc_setjmp');
paramanager.getintparaloc(pd,1,paraloc1);
- cg.a_load_reg_cgpara(list,OS_ADDR,NR_FUNCTION_RESULT_REG,paraloc1);
+{$ifdef i8086}
+ if current_settings.x86memorymodel in x86_far_data_models then
+ begin
+ tmpreg:=cg.getintregister(list,OS_32);
+ cg.a_load_reg_reg(list,OS_16,OS_16,NR_FUNCTION_RESULT32_LOW_REG,tmpreg);
+ cg.a_load_reg_reg(list,OS_16,OS_16,NR_FUNCTION_RESULT32_HIGH_REG,GetNextReg(tmpreg));
+ cg.a_load_reg_cgpara(list,OS_32,tmpreg,paraloc1);
+ end
+ else
+{$endif i8086}
+ cg.a_load_reg_cgpara(list,OS_ADDR,NR_FUNCTION_RESULT_REG,paraloc1);
paramanager.freecgpara(list,paraloc1);
cg.allocallcpuregisters(list);
cg.a_call_name(list,'FPC_SETJMP',false);