summaryrefslogtreecommitdiff
path: root/m68k_core_x86.c
diff options
context:
space:
mode:
authorMichael Pavone <pavone@retrodev.com>2019-04-07 00:06:29 -0700
committerMichael Pavone <pavone@retrodev.com>2019-04-07 00:06:29 -0700
commit376bef93cfadf5d0f778ac887500ee8d5d70fbcc (patch)
treecf003a31f4362bf3484e6bee1608a7ceae0f507b /m68k_core_x86.c
parentd8e444e15c16fc80e513c43e99dbb33c30f72a51 (diff)
Get 64-bit builds working for Windows target
Diffstat (limited to 'm68k_core_x86.c')
-rw-r--r--m68k_core_x86.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/m68k_core_x86.c b/m68k_core_x86.c
index a0a6f06..6455e70 100644
--- a/m68k_core_x86.c
+++ b/m68k_core_x86.c
@@ -2658,8 +2658,11 @@ void init_m68k_opts(m68k_options * opts, memmap_chunk * memmap, uint32_t num_chu
opts->start_context = (start_fun)code->cur;
save_callee_save_regs(code);
#ifdef X86_64
- if (opts->gen.scratch2 != RDI) {
- mov_rr(code, RDI, opts->gen.scratch2, SZ_PTR);
+ if (opts->gen.scratch2 != FIRST_ARG_REG) {
+ mov_rr(code, FIRST_ARG_REG, opts->gen.scratch2, SZ_PTR);
+ }
+ if (opts->gen.context_reg != SECOND_ARG_REG) {
+ mov_rr(code, SECOND_ARG_REG, opts->gen.context_reg, SZ_PTR);
}
#else
mov_rdispr(code, RSP, 20, opts->gen.scratch2, SZ_D);