ViewVC Help
View File | Revision Log | Show Annotations | Revision Graph | Root Listing
root/cebix/BasiliskII/src/uae_cpu/compiler/compemu.h
(Generate patch)

Comparing BasiliskII/src/uae_cpu/compiler/compemu.h (file contents):
Revision 1.5 by gbeauche, 2002-10-03T16:13:46Z vs.
Revision 1.13 by gbeauche, 2006-01-16T21:31:08Z

# Line 3 | Line 3
3   *
4   *  Original 68040 JIT compiler for UAE, copyright 2000-2002 Bernd Meyer
5   *
6 < *  Adaptation for Basilisk II and improvements, copyright 2000-2002
6 > *  Adaptation for Basilisk II and improvements, copyright 2000-2005
7   *    Gwenole Beauchesne
8   *
9 < *  Basilisk II (C) 1997-2002 Christian Bauer
9 > *  Basilisk II (C) 1997-2005 Christian Bauer
10   *  
11   *  This program is free software; you can redistribute it and/or modify
12   *  it under the terms of the GNU General Public License as published by
# Line 41 | Line 41 | extern void compiler_dumpstate(void);
41   #define TAGMASK 0x0000ffff
42   #define TAGSIZE (TAGMASK+1)
43   #define MAXRUN 1024
44 < #define cacheline(x) (((uae_u32)x)&TAGMASK)
44 > #define cacheline(x) (((uintptr)x)&TAGMASK)
45  
46   extern uae_u8* start_pc_p;
47   extern uae_u32 start_pc;
# Line 57 | Line 57 | union cacheline {
57          blockinfo_t * bi;
58   };
59  
60 + /* Use new spill/reload strategy when calling external functions */
61 + #define USE_OPTIMIZED_CALLS 0
62 + #if USE_OPTIMIZED_CALLS
63 + #error implementation in progress
64 + #endif
65 +
66   /* (gb) When on, this option can save save up to 30% compilation time
67   *  when many lazy flushes occur (e.g. apps in MacOS 8.x).
68   */
# Line 74 | Line 80 | union cacheline {
80   #define USE_CHECKSUM_INFO 1
81   #endif
82  
83 + /* Does flush_icache_range() only check for blocks falling in the requested range? */
84 + #define LAZY_FLUSH_ICACHE_RANGE 0
85 +
86   #define USE_F_ALIAS 1
87   #define USE_OFFSET 1
88   #define COMP_DEBUG 1
# Line 115 | Line 124 | union cacheline {
124  
125   #define KILLTHERAT 1  /* Set to 1 to avoid some partial_rat_stalls */
126  
127 < /* Whether to preserve registers across calls to JIT compiled routines */
128 < #ifdef X86_ASSEMBLY
120 < #define USE_PUSH_POP 0
127 > #if defined(__x86_64__)
128 > #define N_REGS 16 /* really only 15, but they are numbered 0-3,5-15 */
129   #else
122 #define USE_PUSH_POP 1
123 #endif
124
130   #define N_REGS 8  /* really only 7, but they are numbered 0,1,2,3,5,6,7 */
131 + #endif
132   #define N_FREGS 6 /* That leaves us two positions on the stack to play with */
133  
134   /* Functions exposed to newcpu, or to what was moved from newcpu.c to
# Line 502 | Line 508 | extern void writelong_clobber(int addres
508   extern void get_n_addr(int address, int dest, int tmp);
509   extern void get_n_addr_jmp(int address, int dest, int tmp);
510   extern void calc_disp_ea_020(int base, uae_u32 dp, int target, int tmp);
511 + /* Set native Z flag only if register is zero */
512 + extern void set_zero(int r, int tmp);
513   extern int kill_rodent(int r);
514   extern void sync_m68k_pc(void);
515   extern uae_u32 get_const(int r);
# Line 515 | Line 523 | extern void register_branch(uae_u32 not_
523   struct blockinfo_t;
524  
525   typedef struct dep_t {
526 <  uintptr*            jmp_off;
526 >  uae_u32*            jmp_off;
527    struct blockinfo_t* target;
528    struct blockinfo_t* source;
529    struct dep_t**      prev_p;

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines