bellard | 6af0bf9 | 2005-07-02 14:58:51 +0000 | [diff] [blame] | 1 | #if !defined (__QEMU_MIPS_DEFS_H__) |
| 2 | #define __QEMU_MIPS_DEFS_H__ |
| 3 | |
bellard | 6af0bf9 | 2005-07-02 14:58:51 +0000 | [diff] [blame] | 4 | /* If we want to use host float regs... */ |
| 5 | //#define USE_HOST_FLOAT_REGS |
| 6 | |
ths | e9c71dd | 2007-12-25 20:46:56 +0000 | [diff] [blame] | 7 | /* Real pages are variable size... */ |
bellard | 6af0bf9 | 2005-07-02 14:58:51 +0000 | [diff] [blame] | 8 | #define TARGET_PAGE_BITS 12 |
ths | 814b9a4 | 2006-12-06 17:42:40 +0000 | [diff] [blame] | 9 | #define MIPS_TLB_MAX 128 |
bellard | 6af0bf9 | 2005-07-02 14:58:51 +0000 | [diff] [blame] | 10 | |
ths | d26bc21 | 2007-11-08 18:05:37 +0000 | [diff] [blame] | 11 | #if defined(TARGET_MIPS64) |
ths | c570fd1 | 2006-12-21 01:19:56 +0000 | [diff] [blame] | 12 | #define TARGET_LONG_BITS 64 |
Leon Alrae | e117f52 | 2015-04-14 10:09:38 +0100 | [diff] [blame] | 13 | #define TARGET_PHYS_ADDR_SPACE_BITS 48 |
Yongbok Kim | 4dc89b7 | 2015-06-29 10:11:23 +0100 | [diff] [blame] | 14 | #define TARGET_VIRT_ADDR_SPACE_BITS 48 |
ths | c570fd1 | 2006-12-21 01:19:56 +0000 | [diff] [blame] | 15 | #else |
| 16 | #define TARGET_LONG_BITS 32 |
Leon Alrae | e117f52 | 2015-04-14 10:09:38 +0100 | [diff] [blame] | 17 | #define TARGET_PHYS_ADDR_SPACE_BITS 40 |
Aurelien Jarno | 30724e7 | 2010-03-13 01:39:17 +0100 | [diff] [blame] | 18 | #define TARGET_VIRT_ADDR_SPACE_BITS 32 |
ths | c570fd1 | 2006-12-21 01:19:56 +0000 | [diff] [blame] | 19 | #endif |
| 20 | |
ths | e189e74 | 2007-09-24 12:48:00 +0000 | [diff] [blame] | 21 | /* Masks used to mark instructions to indicate which ISA level they |
| 22 | were introduced in. */ |
| 23 | #define ISA_MIPS1 0x00000001 |
| 24 | #define ISA_MIPS2 0x00000002 |
| 25 | #define ISA_MIPS3 0x00000004 |
| 26 | #define ISA_MIPS4 0x00000008 |
| 27 | #define ISA_MIPS5 0x00000010 |
| 28 | #define ISA_MIPS32 0x00000020 |
| 29 | #define ISA_MIPS32R2 0x00000040 |
| 30 | #define ISA_MIPS64 0x00000080 |
| 31 | #define ISA_MIPS64R2 0x00000100 |
Petar Jovanovic | e527526 | 2014-01-15 17:01:46 +0100 | [diff] [blame] | 32 | #define ISA_MIPS32R3 0x00000200 |
Leon Alrae | fa0d2f6 | 2014-06-27 08:49:00 +0100 | [diff] [blame] | 33 | #define ISA_MIPS64R3 0x00000400 |
| 34 | #define ISA_MIPS32R5 0x00000800 |
| 35 | #define ISA_MIPS64R5 0x00001000 |
| 36 | #define ISA_MIPS32R6 0x00002000 |
| 37 | #define ISA_MIPS64R6 0x00004000 |
ths | e189e74 | 2007-09-24 12:48:00 +0000 | [diff] [blame] | 38 | |
ths | e9c71dd | 2007-12-25 20:46:56 +0000 | [diff] [blame] | 39 | /* MIPS ASEs. */ |
Leon Alrae | fa0d2f6 | 2014-06-27 08:49:00 +0100 | [diff] [blame] | 40 | #define ASE_MIPS16 0x00010000 |
| 41 | #define ASE_MIPS3D 0x00020000 |
| 42 | #define ASE_MDMX 0x00040000 |
| 43 | #define ASE_DSP 0x00080000 |
| 44 | #define ASE_DSPR2 0x00100000 |
| 45 | #define ASE_MT 0x00200000 |
| 46 | #define ASE_SMARTMIPS 0x00400000 |
| 47 | #define ASE_MICROMIPS 0x00800000 |
Yongbok Kim | e97a391 | 2014-11-01 05:28:35 +0000 | [diff] [blame] | 48 | #define ASE_MSA 0x01000000 |
ths | e189e74 | 2007-09-24 12:48:00 +0000 | [diff] [blame] | 49 | |
ths | e9c71dd | 2007-12-25 20:46:56 +0000 | [diff] [blame] | 50 | /* Chip specific instructions. */ |
Huacai Chen | 5bc6fba | 2010-06-29 10:50:27 +0800 | [diff] [blame] | 51 | #define INSN_LOONGSON2E 0x20000000 |
| 52 | #define INSN_LOONGSON2F 0x40000000 |
ths | e9c71dd | 2007-12-25 20:46:56 +0000 | [diff] [blame] | 53 | #define INSN_VR54XX 0x80000000 |
ths | e189e74 | 2007-09-24 12:48:00 +0000 | [diff] [blame] | 54 | |
ths | e9c71dd | 2007-12-25 20:46:56 +0000 | [diff] [blame] | 55 | /* MIPS CPU defines. */ |
ths | e189e74 | 2007-09-24 12:48:00 +0000 | [diff] [blame] | 56 | #define CPU_MIPS1 (ISA_MIPS1) |
| 57 | #define CPU_MIPS2 (CPU_MIPS1 | ISA_MIPS2) |
| 58 | #define CPU_MIPS3 (CPU_MIPS2 | ISA_MIPS3) |
| 59 | #define CPU_MIPS4 (CPU_MIPS3 | ISA_MIPS4) |
ths | e9c71dd | 2007-12-25 20:46:56 +0000 | [diff] [blame] | 60 | #define CPU_VR54XX (CPU_MIPS4 | INSN_VR54XX) |
Huacai Chen | 5bc6fba | 2010-06-29 10:50:27 +0800 | [diff] [blame] | 61 | #define CPU_LOONGSON2E (CPU_MIPS3 | INSN_LOONGSON2E) |
| 62 | #define CPU_LOONGSON2F (CPU_MIPS3 | INSN_LOONGSON2F) |
ths | e9c71dd | 2007-12-25 20:46:56 +0000 | [diff] [blame] | 63 | |
ths | e189e74 | 2007-09-24 12:48:00 +0000 | [diff] [blame] | 64 | #define CPU_MIPS5 (CPU_MIPS4 | ISA_MIPS5) |
| 65 | |
ths | e9c71dd | 2007-12-25 20:46:56 +0000 | [diff] [blame] | 66 | /* MIPS Technologies "Release 1" */ |
ths | e189e74 | 2007-09-24 12:48:00 +0000 | [diff] [blame] | 67 | #define CPU_MIPS32 (CPU_MIPS2 | ISA_MIPS32) |
| 68 | #define CPU_MIPS64 (CPU_MIPS5 | CPU_MIPS32 | ISA_MIPS64) |
| 69 | |
ths | e9c71dd | 2007-12-25 20:46:56 +0000 | [diff] [blame] | 70 | /* MIPS Technologies "Release 2" */ |
ths | e189e74 | 2007-09-24 12:48:00 +0000 | [diff] [blame] | 71 | #define CPU_MIPS32R2 (CPU_MIPS32 | ISA_MIPS32R2) |
| 72 | #define CPU_MIPS64R2 (CPU_MIPS64 | CPU_MIPS32R2 | ISA_MIPS64R2) |
| 73 | |
Petar Jovanovic | e527526 | 2014-01-15 17:01:46 +0100 | [diff] [blame] | 74 | /* MIPS Technologies "Release 3" */ |
| 75 | #define CPU_MIPS32R3 (CPU_MIPS32R2 | ISA_MIPS32R3) |
Leon Alrae | fa0d2f6 | 2014-06-27 08:49:00 +0100 | [diff] [blame] | 76 | #define CPU_MIPS64R3 (CPU_MIPS64R2 | CPU_MIPS32R3 | ISA_MIPS64R3) |
Petar Jovanovic | e527526 | 2014-01-15 17:01:46 +0100 | [diff] [blame] | 77 | |
| 78 | /* MIPS Technologies "Release 5" */ |
| 79 | #define CPU_MIPS32R5 (CPU_MIPS32R3 | ISA_MIPS32R5) |
Leon Alrae | fa0d2f6 | 2014-06-27 08:49:00 +0100 | [diff] [blame] | 80 | #define CPU_MIPS64R5 (CPU_MIPS64R3 | CPU_MIPS32R5 | ISA_MIPS64R5) |
| 81 | |
| 82 | /* MIPS Technologies "Release 6" */ |
| 83 | #define CPU_MIPS32R6 (CPU_MIPS32R5 | ISA_MIPS32R6) |
| 84 | #define CPU_MIPS64R6 (CPU_MIPS64R5 | CPU_MIPS32R6 | ISA_MIPS64R6) |
Petar Jovanovic | e527526 | 2014-01-15 17:01:46 +0100 | [diff] [blame] | 85 | |
ths | 19221bd | 2007-04-19 16:35:09 +0000 | [diff] [blame] | 86 | /* Strictly follow the architecture standard: |
| 87 | - Disallow "special" instruction handling for PMON/SPIM. |
| 88 | Note that we still maintain Count/Compare to match the host clock. */ |
ths | b48cfdf | 2007-04-11 02:24:14 +0000 | [diff] [blame] | 89 | //#define MIPS_STRICT_STANDARD 1 |
| 90 | |
bellard | 6af0bf9 | 2005-07-02 14:58:51 +0000 | [diff] [blame] | 91 | #endif /* !defined (__QEMU_MIPS_DEFS_H__) */ |