2003-11-23 17:55:54 +03:00
|
|
|
/*
|
2005-07-03 00:59:34 +04:00
|
|
|
* PowerPC emulation cpu definitions for qemu.
|
2007-09-17 01:08:06 +04:00
|
|
|
*
|
2007-03-07 11:32:30 +03:00
|
|
|
* Copyright (c) 2003-2007 Jocelyn Mayer
|
2003-11-23 17:55:54 +03:00
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
2009-07-17 00:47:01 +04:00
|
|
|
* License along with this library; if not, see <http://www.gnu.org/licenses/>.
|
2003-11-23 17:55:54 +03:00
|
|
|
*/
|
2016-06-29 12:05:55 +03:00
|
|
|
|
|
|
|
#ifndef PPC_CPU_H
|
|
|
|
#define PPC_CPU_H
|
2003-11-23 17:55:54 +03:00
|
|
|
|
2016-11-28 10:56:42 +03:00
|
|
|
#include "qemu/int128.h"
|
2019-03-22 21:51:19 +03:00
|
|
|
#include "exec/cpu-defs.h"
|
|
|
|
#include "cpu-qom.h"
|
|
|
|
#include "exec/cpu-defs.h"
|
|
|
|
#include "cpu-qom.h"
|
2005-07-03 00:59:34 +04:00
|
|
|
|
2019-03-21 08:29:36 +03:00
|
|
|
/* #define PPC_EMULATE_32BITS_HYPV */
|
2007-11-18 00:14:09 +03:00
|
|
|
|
2017-04-27 08:18:23 +03:00
|
|
|
#define TCG_GUEST_DEFAULT_MO 0
|
|
|
|
|
2015-01-26 17:21:58 +03:00
|
|
|
#define TARGET_PAGE_BITS_64K 16
|
2011-04-01 08:15:08 +04:00
|
|
|
#define TARGET_PAGE_BITS_16M 24
|
|
|
|
|
2019-03-21 08:29:36 +03:00
|
|
|
#if defined(TARGET_PPC64)
|
2015-05-11 09:29:10 +03:00
|
|
|
#define PPC_ELF_MACHINE EM_PPC64
|
2007-03-07 11:32:30 +03:00
|
|
|
#else
|
2015-05-11 09:29:10 +03:00
|
|
|
#define PPC_ELF_MACHINE EM_PPC
|
2007-03-07 11:32:30 +03:00
|
|
|
#endif
|
2006-12-23 17:18:40 +03:00
|
|
|
|
2018-12-18 01:34:39 +03:00
|
|
|
#define PPC_BIT(bit) (0x8000000000000000ULL >> (bit))
|
|
|
|
#define PPC_BIT32(bit) (0x80000000 >> (bit))
|
|
|
|
#define PPC_BIT8(bit) (0x80 >> (bit))
|
2017-12-06 12:41:50 +03:00
|
|
|
#define PPC_BITMASK(bs, be) ((PPC_BIT(bs) - PPC_BIT(be)) | PPC_BIT(bs))
|
|
|
|
#define PPC_BITMASK32(bs, be) ((PPC_BIT32(bs) - PPC_BIT32(be)) | \
|
|
|
|
PPC_BIT32(bs))
|
2017-12-22 12:55:51 +03:00
|
|
|
#define PPC_BITMASK8(bs, be) ((PPC_BIT8(bs) - PPC_BIT8(be)) | PPC_BIT8(bs))
|
|
|
|
|
2007-09-29 17:06:16 +04:00
|
|
|
/*****************************************************************************/
|
|
|
|
/* Exception vectors definitions */
|
|
|
|
enum {
|
|
|
|
POWERPC_EXCP_NONE = -1,
|
|
|
|
/* The 64 first entries are used by the PowerPC embedded specification */
|
|
|
|
POWERPC_EXCP_CRITICAL = 0, /* Critical input */
|
|
|
|
POWERPC_EXCP_MCHECK = 1, /* Machine check exception */
|
|
|
|
POWERPC_EXCP_DSI = 2, /* Data storage exception */
|
|
|
|
POWERPC_EXCP_ISI = 3, /* Instruction storage exception */
|
|
|
|
POWERPC_EXCP_EXTERNAL = 4, /* External input */
|
|
|
|
POWERPC_EXCP_ALIGN = 5, /* Alignment exception */
|
|
|
|
POWERPC_EXCP_PROGRAM = 6, /* Program exception */
|
|
|
|
POWERPC_EXCP_FPU = 7, /* Floating-point unavailable exception */
|
|
|
|
POWERPC_EXCP_SYSCALL = 8, /* System call exception */
|
|
|
|
POWERPC_EXCP_APU = 9, /* Auxiliary processor unavailable */
|
|
|
|
POWERPC_EXCP_DECR = 10, /* Decrementer exception */
|
|
|
|
POWERPC_EXCP_FIT = 11, /* Fixed-interval timer interrupt */
|
|
|
|
POWERPC_EXCP_WDT = 12, /* Watchdog timer interrupt */
|
2007-11-18 01:42:36 +03:00
|
|
|
POWERPC_EXCP_DTLB = 13, /* Data TLB miss */
|
|
|
|
POWERPC_EXCP_ITLB = 14, /* Instruction TLB miss */
|
2007-09-29 17:06:16 +04:00
|
|
|
POWERPC_EXCP_DEBUG = 15, /* Debug interrupt */
|
|
|
|
/* Vectors 16 to 31 are reserved */
|
|
|
|
POWERPC_EXCP_SPEU = 32, /* SPE/embedded floating-point unavailable */
|
|
|
|
POWERPC_EXCP_EFPDI = 33, /* Embedded floating-point data interrupt */
|
|
|
|
POWERPC_EXCP_EFPRI = 34, /* Embedded floating-point round interrupt */
|
|
|
|
POWERPC_EXCP_EPERFM = 35, /* Embedded performance monitor interrupt */
|
|
|
|
POWERPC_EXCP_DOORI = 36, /* Embedded doorbell interrupt */
|
|
|
|
POWERPC_EXCP_DOORCI = 37, /* Embedded doorbell critical interrupt */
|
2012-01-31 06:09:58 +04:00
|
|
|
POWERPC_EXCP_GDOORI = 38, /* Embedded guest doorbell interrupt */
|
|
|
|
POWERPC_EXCP_GDOORCI = 39, /* Embedded guest doorbell critical interrupt*/
|
|
|
|
POWERPC_EXCP_HYPPRIV = 41, /* Embedded hypervisor priv instruction */
|
|
|
|
/* Vectors 42 to 63 are reserved */
|
2007-09-29 17:06:16 +04:00
|
|
|
/* Exceptions defined in the PowerPC server specification */
|
|
|
|
POWERPC_EXCP_RESET = 64, /* System reset exception */
|
|
|
|
POWERPC_EXCP_DSEG = 65, /* Data segment exception */
|
|
|
|
POWERPC_EXCP_ISEG = 66, /* Instruction segment exception */
|
|
|
|
POWERPC_EXCP_HDECR = 67, /* Hypervisor decrementer exception */
|
|
|
|
POWERPC_EXCP_TRACE = 68, /* Trace exception */
|
|
|
|
POWERPC_EXCP_HDSI = 69, /* Hypervisor data storage exception */
|
|
|
|
POWERPC_EXCP_HISI = 70, /* Hypervisor instruction storage exception */
|
|
|
|
POWERPC_EXCP_HDSEG = 71, /* Hypervisor data segment exception */
|
|
|
|
POWERPC_EXCP_HISEG = 72, /* Hypervisor instruction segment exception */
|
|
|
|
POWERPC_EXCP_VPU = 73, /* Vector unavailable exception */
|
|
|
|
/* 40x specific exceptions */
|
|
|
|
POWERPC_EXCP_PIT = 74, /* Programmable interval timer interrupt */
|
|
|
|
/* 601 specific exceptions */
|
|
|
|
POWERPC_EXCP_IO = 75, /* IO error exception */
|
|
|
|
POWERPC_EXCP_RUNM = 76, /* Run mode exception */
|
|
|
|
/* 602 specific exceptions */
|
|
|
|
POWERPC_EXCP_EMUL = 77, /* Emulation trap exception */
|
|
|
|
/* 602/603 specific exceptions */
|
2007-11-18 01:42:36 +03:00
|
|
|
POWERPC_EXCP_IFTLB = 78, /* Instruction fetch TLB miss */
|
2007-09-29 17:06:16 +04:00
|
|
|
POWERPC_EXCP_DLTLB = 79, /* Data load TLB miss */
|
|
|
|
POWERPC_EXCP_DSTLB = 80, /* Data store TLB miss */
|
|
|
|
/* Exceptions available on most PowerPC */
|
|
|
|
POWERPC_EXCP_FPA = 81, /* Floating-point assist exception */
|
2007-11-18 01:42:36 +03:00
|
|
|
POWERPC_EXCP_DABR = 82, /* Data address breakpoint */
|
|
|
|
POWERPC_EXCP_IABR = 83, /* Instruction address breakpoint */
|
|
|
|
POWERPC_EXCP_SMI = 84, /* System management interrupt */
|
|
|
|
POWERPC_EXCP_PERFM = 85, /* Embedded performance monitor interrupt */
|
2007-09-29 17:06:16 +04:00
|
|
|
/* 7xx/74xx specific exceptions */
|
2007-11-18 01:42:36 +03:00
|
|
|
POWERPC_EXCP_THERM = 86, /* Thermal interrupt */
|
2007-09-29 17:06:16 +04:00
|
|
|
/* 74xx specific exceptions */
|
2007-11-18 01:42:36 +03:00
|
|
|
POWERPC_EXCP_VPUA = 87, /* Vector assist exception */
|
2007-09-29 17:06:16 +04:00
|
|
|
/* 970FX specific exceptions */
|
2007-11-18 01:42:36 +03:00
|
|
|
POWERPC_EXCP_SOFTP = 88, /* Soft patch exception */
|
|
|
|
POWERPC_EXCP_MAINT = 89, /* Maintenance exception */
|
2011-04-28 19:20:30 +04:00
|
|
|
/* Freescale embedded cores specific exceptions */
|
2007-11-18 01:42:36 +03:00
|
|
|
POWERPC_EXCP_MEXTBR = 90, /* Maskable external breakpoint */
|
|
|
|
POWERPC_EXCP_NMEXTBR = 91, /* Non maskable external breakpoint */
|
|
|
|
POWERPC_EXCP_ITLBE = 92, /* Instruction TLB error */
|
|
|
|
POWERPC_EXCP_DTLBE = 93, /* Data TLB error */
|
2013-10-22 15:06:17 +04:00
|
|
|
/* VSX Unavailable (Power ISA 2.06 and later) */
|
|
|
|
POWERPC_EXCP_VSXU = 94, /* VSX Unavailable */
|
2014-06-04 16:50:56 +04:00
|
|
|
POWERPC_EXCP_FU = 95, /* Facility Unavailable */
|
2016-06-22 00:48:49 +03:00
|
|
|
/* Additional ISA 2.06 and later server exceptions */
|
|
|
|
POWERPC_EXCP_HV_EMU = 96, /* HV emulation assistance */
|
|
|
|
POWERPC_EXCP_HV_MAINT = 97, /* HMI */
|
|
|
|
POWERPC_EXCP_HV_FU = 98, /* Hypervisor Facility unavailable */
|
2018-01-16 10:41:55 +03:00
|
|
|
/* Server doorbell variants */
|
|
|
|
POWERPC_EXCP_SDOOR = 99,
|
|
|
|
POWERPC_EXCP_SDOOR_HV = 100,
|
2019-02-15 19:16:46 +03:00
|
|
|
/* ISA 3.00 additions */
|
|
|
|
POWERPC_EXCP_HVIRT = 101,
|
2007-09-29 17:06:16 +04:00
|
|
|
/* EOL */
|
2019-02-15 19:16:46 +03:00
|
|
|
POWERPC_EXCP_NB = 102,
|
2012-04-07 11:23:39 +04:00
|
|
|
/* QEMU exceptions: used internally during code translation */
|
2007-09-29 17:06:16 +04:00
|
|
|
POWERPC_EXCP_STOP = 0x200, /* stop translation */
|
|
|
|
POWERPC_EXCP_BRANCH = 0x201, /* branch instruction */
|
2012-04-07 11:23:39 +04:00
|
|
|
/* QEMU exceptions: special cases we want to stop translation */
|
2007-09-29 17:06:16 +04:00
|
|
|
POWERPC_EXCP_SYNC = 0x202, /* context synchronizing instruction */
|
|
|
|
POWERPC_EXCP_SYSCALL_USER = 0x203, /* System call in user mode only */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Exceptions error codes */
|
|
|
|
enum {
|
|
|
|
/* Exception subtypes for POWERPC_EXCP_ALIGN */
|
|
|
|
POWERPC_EXCP_ALIGN_FP = 0x01, /* FP alignment exception */
|
|
|
|
POWERPC_EXCP_ALIGN_LST = 0x02, /* Unaligned mult/extern load/store */
|
|
|
|
POWERPC_EXCP_ALIGN_LE = 0x03, /* Multiple little-endian access */
|
|
|
|
POWERPC_EXCP_ALIGN_PROT = 0x04, /* Access cross protection boundary */
|
|
|
|
POWERPC_EXCP_ALIGN_BAT = 0x05, /* Access cross a BAT/seg boundary */
|
|
|
|
POWERPC_EXCP_ALIGN_CACHE = 0x06, /* Impossible dcbz access */
|
|
|
|
/* Exception subtypes for POWERPC_EXCP_PROGRAM */
|
|
|
|
/* FP exceptions */
|
|
|
|
POWERPC_EXCP_FP = 0x10,
|
|
|
|
POWERPC_EXCP_FP_OX = 0x01, /* FP overflow */
|
|
|
|
POWERPC_EXCP_FP_UX = 0x02, /* FP underflow */
|
|
|
|
POWERPC_EXCP_FP_ZX = 0x03, /* FP divide by zero */
|
|
|
|
POWERPC_EXCP_FP_XX = 0x04, /* FP inexact */
|
2007-10-27 21:54:30 +04:00
|
|
|
POWERPC_EXCP_FP_VXSNAN = 0x05, /* FP invalid SNaN op */
|
2007-09-29 17:06:16 +04:00
|
|
|
POWERPC_EXCP_FP_VXISI = 0x06, /* FP invalid infinite subtraction */
|
|
|
|
POWERPC_EXCP_FP_VXIDI = 0x07, /* FP invalid infinite divide */
|
|
|
|
POWERPC_EXCP_FP_VXZDZ = 0x08, /* FP invalid zero divide */
|
|
|
|
POWERPC_EXCP_FP_VXIMZ = 0x09, /* FP invalid infinite * zero */
|
|
|
|
POWERPC_EXCP_FP_VXVC = 0x0A, /* FP invalid compare */
|
|
|
|
POWERPC_EXCP_FP_VXSOFT = 0x0B, /* FP invalid operation */
|
|
|
|
POWERPC_EXCP_FP_VXSQRT = 0x0C, /* FP invalid square root */
|
|
|
|
POWERPC_EXCP_FP_VXCVI = 0x0D, /* FP invalid integer conversion */
|
|
|
|
/* Invalid instruction */
|
|
|
|
POWERPC_EXCP_INVAL = 0x20,
|
|
|
|
POWERPC_EXCP_INVAL_INVAL = 0x01, /* Invalid instruction */
|
|
|
|
POWERPC_EXCP_INVAL_LSWX = 0x02, /* Invalid lswx instruction */
|
|
|
|
POWERPC_EXCP_INVAL_SPR = 0x03, /* Invalid SPR access */
|
|
|
|
POWERPC_EXCP_INVAL_FP = 0x04, /* Unimplemented mandatory fp instr */
|
|
|
|
/* Privileged instruction */
|
|
|
|
POWERPC_EXCP_PRIV = 0x30,
|
|
|
|
POWERPC_EXCP_PRIV_OPC = 0x01, /* Privileged operation exception */
|
|
|
|
POWERPC_EXCP_PRIV_REG = 0x02, /* Privileged register exception */
|
|
|
|
/* Trap */
|
|
|
|
POWERPC_EXCP_TRAP = 0x40,
|
|
|
|
};
|
|
|
|
|
Great rework and cleanups to ease PowerPC implementations definitions.
* cleanup cpu.h, removing definitions used only in translate.c/translate_init.c
* add new flags to define instructions sets more precisely
* various changes in MMU models definitions
* add definitions for PowerPC 440/460 support (insns and SPRs).
* add definitions for PowerPC 401/403 and 620 input pins model
* Fix definitions for most PowerPC 401, 403, 405, 440, 601, 602, 603 and 7x0
* Preliminary support for PowerPC 74xx (aka G4) without altivec.
* Code provision for other PowerPC support (7x5, 970, ...).
* New SPR and PVR defined, from PowerPC 2.04 specification and other sources
* Misc code bugs, error messages and styles fixes.
* Update status files for PowerPC cores support.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@3244 c046a42c-6fe2-441c-8c8c-71466251a162
2007-09-27 03:54:22 +04:00
|
|
|
#define PPC_INPUT(env) (env->bus_model)
|
2005-07-03 00:59:34 +04:00
|
|
|
|
2007-09-30 17:03:23 +04:00
|
|
|
/*****************************************************************************/
|
2009-10-02 01:12:16 +04:00
|
|
|
typedef struct opc_handler_t opc_handler_t;
|
2003-11-23 17:55:54 +03:00
|
|
|
|
2005-07-03 00:59:34 +04:00
|
|
|
/*****************************************************************************/
|
target/ppc: Cleanup HPTE accessors for 64-bit hash MMU
Accesses to the hashed page table (HPT) are complicated by the fact that
the HPT could be in one of three places:
1) Within guest memory - when we're emulating a full guest CPU at the
hardware level (e.g. powernv, mac99, g3beige)
2) Within qemu, but outside guest memory - when we're emulating user and
supervisor instructions within TCG, but instead of emulating
the CPU's hypervisor mode, we just emulate a hypervisor's behaviour
(pseries in TCG or KVM-PR)
3) Within the host kernel - a pseries machine using KVM-HV
acceleration. Mostly accesses to the HPT are handled by KVM,
but there are a few cases where qemu needs to access it via a
special fd for the purpose.
In order to batch accesses to the fd in case (3), we use a somewhat awkward
ppc_hash64_start_access() / ppc_hash64_stop_access() pair, which for case
(3) reads / releases several HPTEs from the kernel as a batch (usually a
whole PTEG). For cases (1) & (2) it just returns an address value. The
actual HPTE load helpers then need to interpret the returned token
differently in the 3 cases.
This patch keeps the same basic structure, but simplfiies the details.
First start_access() / stop_access() are renamed to map_hptes() and
unmap_hptes() to make their operation more obvious. Second, map_hptes()
now always returns a qemu pointer, which can always be used in the same way
by the load_hpte() helpers. In case (1) it comes from address_space_map()
in case (2) directly from qemu's HPT buffer and in case (3) from a
temporary buffer read from the KVM fd.
While we're at it, make things a bit more consistent in terms of types and
variable names: avoid variables named 'index' (it shadows index(3) which
can lead to confusing results), use 'hwaddr ptex' for HPTE indices and
uint64_t for each of the HPTE words, use ptex throughout the call stack
instead of pte_offset in some places (we still need that at the bottom
layer, but nowhere else).
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
2017-02-27 08:03:41 +03:00
|
|
|
/* Types used to describe some PowerPC registers etc. */
|
2014-11-26 13:39:48 +03:00
|
|
|
typedef struct DisasContext DisasContext;
|
2009-10-02 01:12:16 +04:00
|
|
|
typedef struct ppc_spr_t ppc_spr_t;
|
|
|
|
typedef union ppc_tlb_t ppc_tlb_t;
|
target/ppc: Fix KVM-HV HPTE accessors
When a 'pseries' guest is running with KVM-HV, the guest's hashed page
table (HPT) is stored within the host kernel, so it is not directly
accessible to qemu. Most of the time, qemu doesn't need to access it:
we're using the hardware MMU, and KVM itself implements the guest
hypercalls for manipulating the HPT.
However, qemu does need access to the in-KVM HPT to implement
get_phys_page_debug() for the benefit of the gdbstub, and maybe for
other debug operations.
To allow this, 7c43bca "target-ppc: Fix page table lookup with kvm
enabled" added kvmppc_hash64_read_pteg() to target/ppc/kvm.c to read
in a batch of HPTEs from the KVM table. Unfortunately, there are a
couple of problems with this:
First, the name of the function implies it always reads a whole PTEG
from the HPT, but in fact in some cases it's used to grab individual
HPTEs (which ends up pulling 8 HPTEs, not aligned to a PTEG from the
kernel).
Second, and more importantly, the code to read the HPTEs from KVM is
simply wrong, in general. The data from the fd that KVM provides is
designed mostly for compact migration rather than this sort of one-off
access, and so needs some decoding for this purpose. The current code
will work in some cases, but if there are invalid HPTEs then it will
not get sane results.
This patch rewrite the HPTE reading function to have a simpler
interface (just read n HPTEs into a caller provided buffer), and to
correctly decode the stream from the kernel.
For consistency we also clean up the similar function for altering
HPTEs within KVM (introduced in c138593 "target-ppc: Update
ppc_hash64_store_hpte to support updating in-kernel htab").
Cc: Aneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
2017-02-27 07:34:19 +03:00
|
|
|
typedef struct ppc_hash_pte64 ppc_hash_pte64_t;
|
2007-03-07 11:32:30 +03:00
|
|
|
|
2005-07-03 00:59:34 +04:00
|
|
|
/* SPR access micro-ops generations callbacks */
|
2009-10-02 01:12:16 +04:00
|
|
|
struct ppc_spr_t {
|
2014-11-26 13:39:48 +03:00
|
|
|
void (*uea_read)(DisasContext *ctx, int gpr_num, int spr_num);
|
|
|
|
void (*uea_write)(DisasContext *ctx, int spr_num, int gpr_num);
|
2007-03-07 11:32:30 +03:00
|
|
|
#if !defined(CONFIG_USER_ONLY)
|
2014-11-26 13:39:48 +03:00
|
|
|
void (*oea_read)(DisasContext *ctx, int gpr_num, int spr_num);
|
|
|
|
void (*oea_write)(DisasContext *ctx, int spr_num, int gpr_num);
|
|
|
|
void (*hea_read)(DisasContext *ctx, int gpr_num, int spr_num);
|
|
|
|
void (*hea_write)(DisasContext *ctx, int spr_num, int gpr_num);
|
2019-02-06 19:51:33 +03:00
|
|
|
unsigned int gdb_id;
|
2007-03-07 11:32:30 +03:00
|
|
|
#endif
|
2008-09-20 12:07:15 +04:00
|
|
|
const char *name;
|
2014-03-19 17:03:57 +04:00
|
|
|
target_ulong default_value;
|
2013-02-20 20:41:50 +04:00
|
|
|
#ifdef CONFIG_KVM
|
2019-03-21 08:29:36 +03:00
|
|
|
/*
|
|
|
|
* We (ab)use the fact that all the SPRs will have ids for the
|
2013-02-20 20:41:50 +04:00
|
|
|
* ONE_REG interface will have KVM_REG_PPC to use 0 as meaning,
|
2019-03-21 08:29:36 +03:00
|
|
|
* don't sync this
|
|
|
|
*/
|
2013-02-20 20:41:50 +04:00
|
|
|
uint64_t one_reg_id;
|
|
|
|
#endif
|
2005-07-03 00:59:34 +04:00
|
|
|
};
|
|
|
|
|
2019-01-02 12:14:21 +03:00
|
|
|
/* VSX/Altivec registers (128 bits) */
|
|
|
|
typedef union _ppc_vsr_t {
|
2007-10-07 22:19:26 +04:00
|
|
|
uint8_t u8[16];
|
|
|
|
uint16_t u16[8];
|
|
|
|
uint32_t u32[4];
|
2019-01-02 12:14:21 +03:00
|
|
|
uint64_t u64[2];
|
2008-12-15 10:03:06 +03:00
|
|
|
int8_t s8[16];
|
|
|
|
int16_t s16[8];
|
|
|
|
int32_t s32[4];
|
2014-02-13 01:22:53 +04:00
|
|
|
int64_t s64[2];
|
2019-01-02 12:14:21 +03:00
|
|
|
float32 f32[4];
|
|
|
|
float64 f64[2];
|
|
|
|
float128 f128;
|
2014-02-13 01:22:53 +04:00
|
|
|
#ifdef CONFIG_INT128
|
|
|
|
__uint128_t u128;
|
|
|
|
#endif
|
2019-01-02 12:14:21 +03:00
|
|
|
Int128 s128;
|
|
|
|
} ppc_vsr_t;
|
|
|
|
|
|
|
|
typedef ppc_vsr_t ppc_avr_t;
|
2004-05-21 16:59:32 +04:00
|
|
|
|
2010-03-01 07:11:28 +03:00
|
|
|
#if !defined(CONFIG_USER_ONLY)
|
2005-07-03 00:59:34 +04:00
|
|
|
/* Software TLB cache */
|
2009-10-02 01:12:16 +04:00
|
|
|
typedef struct ppc6xx_tlb_t ppc6xx_tlb_t;
|
|
|
|
struct ppc6xx_tlb_t {
|
2007-03-07 11:32:30 +03:00
|
|
|
target_ulong pte0;
|
|
|
|
target_ulong pte1;
|
|
|
|
target_ulong EPN;
|
2007-03-31 15:10:49 +04:00
|
|
|
};
|
|
|
|
|
2009-10-02 01:12:16 +04:00
|
|
|
typedef struct ppcemb_tlb_t ppcemb_tlb_t;
|
|
|
|
struct ppcemb_tlb_t {
|
2012-12-03 20:42:14 +04:00
|
|
|
uint64_t RPN;
|
2007-03-31 15:10:49 +04:00
|
|
|
target_ulong EPN;
|
2007-03-07 11:32:30 +03:00
|
|
|
target_ulong PID;
|
2007-04-16 13:21:46 +04:00
|
|
|
target_ulong size;
|
|
|
|
uint32_t prot;
|
|
|
|
uint32_t attr; /* Storage attributes */
|
2007-03-31 15:10:49 +04:00
|
|
|
};
|
|
|
|
|
2011-06-16 20:45:43 +04:00
|
|
|
typedef struct ppcmas_tlb_t {
|
|
|
|
uint32_t mas8;
|
|
|
|
uint32_t mas1;
|
|
|
|
uint64_t mas2;
|
|
|
|
uint64_t mas7_3;
|
|
|
|
} ppcmas_tlb_t;
|
|
|
|
|
2009-10-02 01:12:16 +04:00
|
|
|
union ppc_tlb_t {
|
2011-06-17 03:00:28 +04:00
|
|
|
ppc6xx_tlb_t *tlb6;
|
|
|
|
ppcemb_tlb_t *tlbe;
|
|
|
|
ppcmas_tlb_t *tlbm;
|
2005-07-03 00:59:34 +04:00
|
|
|
};
|
2011-06-17 03:00:28 +04:00
|
|
|
|
|
|
|
/* possible TLB variants */
|
|
|
|
#define TLB_NONE 0
|
|
|
|
#define TLB_6XX 1
|
|
|
|
#define TLB_EMB 2
|
|
|
|
#define TLB_MAS 3
|
2010-03-01 07:11:28 +03:00
|
|
|
#endif
|
2005-07-03 00:59:34 +04:00
|
|
|
|
2018-03-23 05:31:52 +03:00
|
|
|
typedef struct PPCHash64SegmentPageSizes PPCHash64SegmentPageSizes;
|
|
|
|
|
2009-10-02 01:12:16 +04:00
|
|
|
typedef struct ppc_slb_t ppc_slb_t;
|
|
|
|
struct ppc_slb_t {
|
2011-04-01 08:15:08 +04:00
|
|
|
uint64_t esid;
|
|
|
|
uint64_t vsid;
|
2018-03-23 05:31:52 +03:00
|
|
|
const PPCHash64SegmentPageSizes *sps;
|
2009-03-07 23:57:42 +03:00
|
|
|
};
|
|
|
|
|
2013-10-01 20:19:31 +04:00
|
|
|
#define MAX_SLB_ENTRIES 64
|
2011-04-01 08:15:08 +04:00
|
|
|
#define SEGMENT_SHIFT_256M 28
|
|
|
|
#define SEGMENT_MASK_256M (~((1ULL << SEGMENT_SHIFT_256M) - 1))
|
|
|
|
|
2011-04-01 08:15:18 +04:00
|
|
|
#define SEGMENT_SHIFT_1T 40
|
|
|
|
#define SEGMENT_MASK_1T (~((1ULL << SEGMENT_SHIFT_1T) - 1))
|
|
|
|
|
2019-02-15 20:00:27 +03:00
|
|
|
typedef struct ppc_v3_pate_t {
|
|
|
|
uint64_t dw0;
|
|
|
|
uint64_t dw1;
|
|
|
|
} ppc_v3_pate_t;
|
2011-04-01 08:15:18 +04:00
|
|
|
|
2005-07-03 00:59:34 +04:00
|
|
|
/*****************************************************************************/
|
|
|
|
/* Machine state register bits definition */
|
2007-03-07 11:32:30 +03:00
|
|
|
#define MSR_SF 63 /* Sixty-four-bit mode hflags */
|
2007-11-21 16:08:23 +03:00
|
|
|
#define MSR_TAG 62 /* Tag-active mode (POWERx ?) */
|
2005-07-03 00:59:34 +04:00
|
|
|
#define MSR_ISF 61 /* Sixty-four-bit interrupt mode on 630 */
|
2007-11-18 00:14:09 +03:00
|
|
|
#define MSR_SHV 60 /* hypervisor state hflags */
|
2014-06-04 16:50:59 +04:00
|
|
|
#define MSR_TS0 34 /* Transactional state, 2 bits (Book3s) */
|
|
|
|
#define MSR_TS1 33
|
|
|
|
#define MSR_TM 32 /* Transactional Memory Available (Book3s) */
|
2007-03-30 14:07:33 +04:00
|
|
|
#define MSR_CM 31 /* Computation mode for BookE hflags */
|
|
|
|
#define MSR_ICM 30 /* Interrupt computation mode for BookE */
|
2007-11-18 00:14:09 +03:00
|
|
|
#define MSR_THV 29 /* hypervisor state for 32 bits PowerPC hflags */
|
2011-05-01 01:34:56 +04:00
|
|
|
#define MSR_GS 28 /* guest state for BookE */
|
2007-03-30 14:07:33 +04:00
|
|
|
#define MSR_UCLE 26 /* User-mode cache lock enable for BookE */
|
2007-10-07 18:41:00 +04:00
|
|
|
#define MSR_VR 25 /* altivec available x hflags */
|
|
|
|
#define MSR_SPE 25 /* SPE enable for BookE x hflags */
|
2007-03-07 11:32:30 +03:00
|
|
|
#define MSR_AP 23 /* Access privilege state on 602 hflags */
|
2013-10-22 15:06:17 +04:00
|
|
|
#define MSR_VSX 23 /* Vector Scalar Extension (ISA 2.06 and later) x hflags */
|
2007-03-07 11:32:30 +03:00
|
|
|
#define MSR_SA 22 /* Supervisor access mode on 602 hflags */
|
2005-07-03 00:59:34 +04:00
|
|
|
#define MSR_KEY 19 /* key bit on 603e */
|
2007-10-08 06:58:07 +04:00
|
|
|
#define MSR_POW 18 /* Power management */
|
2007-10-07 18:41:00 +04:00
|
|
|
#define MSR_TGPR 17 /* TGPR usage on 602/603 x */
|
|
|
|
#define MSR_CE 17 /* Critical interrupt enable on embedded PowerPC x */
|
2005-07-03 00:59:34 +04:00
|
|
|
#define MSR_ILE 16 /* Interrupt little-endian mode */
|
|
|
|
#define MSR_EE 15 /* External interrupt enable */
|
2007-03-07 11:32:30 +03:00
|
|
|
#define MSR_PR 14 /* Problem state hflags */
|
|
|
|
#define MSR_FP 13 /* Floating point available hflags */
|
2005-07-03 00:59:34 +04:00
|
|
|
#define MSR_ME 12 /* Machine check interrupt enable */
|
2007-03-07 11:32:30 +03:00
|
|
|
#define MSR_FE0 11 /* Floating point exception mode 0 hflags */
|
2007-10-07 18:41:00 +04:00
|
|
|
#define MSR_SE 10 /* Single-step trace enable x hflags */
|
|
|
|
#define MSR_DWE 10 /* Debug wait enable on 405 x */
|
|
|
|
#define MSR_UBLE 10 /* User BTB lock enable on e500 x */
|
|
|
|
#define MSR_BE 9 /* Branch trace enable x hflags */
|
|
|
|
#define MSR_DE 9 /* Debug interrupts enable on embedded PowerPC x */
|
2007-03-07 11:32:30 +03:00
|
|
|
#define MSR_FE1 8 /* Floating point exception mode 1 hflags */
|
2005-07-03 00:59:34 +04:00
|
|
|
#define MSR_AL 7 /* AL bit on POWER */
|
2007-10-26 01:35:50 +04:00
|
|
|
#define MSR_EP 6 /* Exception prefix on 601 */
|
2005-07-03 00:59:34 +04:00
|
|
|
#define MSR_IR 5 /* Instruction relocate */
|
|
|
|
#define MSR_DR 4 /* Data relocate */
|
2016-05-03 19:03:24 +03:00
|
|
|
#define MSR_IS 5 /* Instruction address space (BookE) */
|
|
|
|
#define MSR_DS 4 /* Data address space (BookE) */
|
2007-10-08 06:58:07 +04:00
|
|
|
#define MSR_PE 3 /* Protection enable on 403 */
|
2007-10-07 18:41:00 +04:00
|
|
|
#define MSR_PX 2 /* Protection exclusive on 403 x */
|
|
|
|
#define MSR_PMM 2 /* Performance monitor mark on POWER x */
|
|
|
|
#define MSR_RI 1 /* Recoverable interrupt 1 */
|
|
|
|
#define MSR_LE 0 /* Little-endian mode 1 hflags */
|
2007-10-26 01:35:50 +04:00
|
|
|
|
2016-03-21 15:52:31 +03:00
|
|
|
/* LPCR bits */
|
2017-12-06 12:41:50 +03:00
|
|
|
#define LPCR_VPM0 PPC_BIT(0)
|
|
|
|
#define LPCR_VPM1 PPC_BIT(1)
|
|
|
|
#define LPCR_ISL PPC_BIT(2)
|
|
|
|
#define LPCR_KBV PPC_BIT(3)
|
2016-06-27 09:55:15 +03:00
|
|
|
#define LPCR_DPFD_SHIFT (63 - 11)
|
2017-02-10 08:25:52 +03:00
|
|
|
#define LPCR_DPFD (0x7ull << LPCR_DPFD_SHIFT)
|
2016-06-27 09:55:15 +03:00
|
|
|
#define LPCR_VRMASD_SHIFT (63 - 16)
|
|
|
|
#define LPCR_VRMASD (0x1full << LPCR_VRMASD_SHIFT)
|
2017-02-10 08:25:53 +03:00
|
|
|
/* P9: Power-saving mode Exit Cause Enable (Upper Section) Mask */
|
|
|
|
#define LPCR_PECE_U_SHIFT (63 - 19)
|
|
|
|
#define LPCR_PECE_U_MASK (0x7ull << LPCR_PECE_U_SHIFT)
|
2017-12-06 12:41:50 +03:00
|
|
|
#define LPCR_HVEE PPC_BIT(17) /* Hypervisor Virt Exit Enable */
|
2016-06-27 09:55:15 +03:00
|
|
|
#define LPCR_RMLS_SHIFT (63 - 37)
|
|
|
|
#define LPCR_RMLS (0xfull << LPCR_RMLS_SHIFT)
|
2017-12-06 12:41:50 +03:00
|
|
|
#define LPCR_ILE PPC_BIT(38)
|
2016-03-21 15:52:31 +03:00
|
|
|
#define LPCR_AIL_SHIFT (63 - 40) /* Alternate interrupt location */
|
|
|
|
#define LPCR_AIL (3ull << LPCR_AIL_SHIFT)
|
2017-12-06 12:41:50 +03:00
|
|
|
#define LPCR_UPRT PPC_BIT(41) /* Use Process Table */
|
|
|
|
#define LPCR_EVIRT PPC_BIT(42) /* Enhanced Virtualisation */
|
2019-02-15 20:00:18 +03:00
|
|
|
#define LPCR_HR PPC_BIT(43) /* Host Radix */
|
2017-12-06 12:41:50 +03:00
|
|
|
#define LPCR_ONL PPC_BIT(45)
|
|
|
|
#define LPCR_LD PPC_BIT(46) /* Large Decrementer */
|
|
|
|
#define LPCR_P7_PECE0 PPC_BIT(49)
|
|
|
|
#define LPCR_P7_PECE1 PPC_BIT(50)
|
|
|
|
#define LPCR_P7_PECE2 PPC_BIT(51)
|
|
|
|
#define LPCR_P8_PECE0 PPC_BIT(47)
|
|
|
|
#define LPCR_P8_PECE1 PPC_BIT(48)
|
|
|
|
#define LPCR_P8_PECE2 PPC_BIT(49)
|
|
|
|
#define LPCR_P8_PECE3 PPC_BIT(50)
|
|
|
|
#define LPCR_P8_PECE4 PPC_BIT(51)
|
2017-02-10 08:25:53 +03:00
|
|
|
/* P9: Power-saving mode Exit Cause Enable (Lower Section) Mask */
|
|
|
|
#define LPCR_PECE_L_SHIFT (63 - 51)
|
|
|
|
#define LPCR_PECE_L_MASK (0x1full << LPCR_PECE_L_SHIFT)
|
2017-12-06 12:41:50 +03:00
|
|
|
#define LPCR_PDEE PPC_BIT(47) /* Privileged Doorbell Exit EN */
|
|
|
|
#define LPCR_HDEE PPC_BIT(48) /* Hyperv Doorbell Exit Enable */
|
|
|
|
#define LPCR_EEE PPC_BIT(49) /* External Exit Enable */
|
|
|
|
#define LPCR_DEE PPC_BIT(50) /* Decrementer Exit Enable */
|
|
|
|
#define LPCR_OEE PPC_BIT(51) /* Other Exit Enable */
|
|
|
|
#define LPCR_MER PPC_BIT(52)
|
|
|
|
#define LPCR_GTSE PPC_BIT(53) /* Guest Translation Shootdown */
|
|
|
|
#define LPCR_TC PPC_BIT(54)
|
|
|
|
#define LPCR_HEIC PPC_BIT(59) /* HV Extern Interrupt Control */
|
|
|
|
#define LPCR_LPES0 PPC_BIT(60)
|
|
|
|
#define LPCR_LPES1 PPC_BIT(61)
|
|
|
|
#define LPCR_RMI PPC_BIT(62)
|
|
|
|
#define LPCR_HVICE PPC_BIT(62) /* HV Virtualisation Int Enable */
|
|
|
|
#define LPCR_HDICE PPC_BIT(63)
|
2013-08-07 04:47:01 +04:00
|
|
|
|
2019-02-15 19:16:41 +03:00
|
|
|
/* PSSCR bits */
|
|
|
|
#define PSSCR_ESL PPC_BIT(42) /* Enable State Loss */
|
|
|
|
#define PSSCR_EC PPC_BIT(43) /* Exit Criterion */
|
|
|
|
|
2007-10-26 01:35:50 +04:00
|
|
|
#define msr_sf ((env->msr >> MSR_SF) & 1)
|
|
|
|
#define msr_isf ((env->msr >> MSR_ISF) & 1)
|
2007-11-18 00:14:09 +03:00
|
|
|
#define msr_shv ((env->msr >> MSR_SHV) & 1)
|
2007-10-26 01:35:50 +04:00
|
|
|
#define msr_cm ((env->msr >> MSR_CM) & 1)
|
|
|
|
#define msr_icm ((env->msr >> MSR_ICM) & 1)
|
2007-11-18 00:14:09 +03:00
|
|
|
#define msr_thv ((env->msr >> MSR_THV) & 1)
|
2011-05-01 01:34:56 +04:00
|
|
|
#define msr_gs ((env->msr >> MSR_GS) & 1)
|
2007-10-26 01:35:50 +04:00
|
|
|
#define msr_ucle ((env->msr >> MSR_UCLE) & 1)
|
|
|
|
#define msr_vr ((env->msr >> MSR_VR) & 1)
|
2008-05-06 18:58:15 +04:00
|
|
|
#define msr_spe ((env->msr >> MSR_SPE) & 1)
|
2007-10-26 01:35:50 +04:00
|
|
|
#define msr_ap ((env->msr >> MSR_AP) & 1)
|
2013-10-22 15:06:17 +04:00
|
|
|
#define msr_vsx ((env->msr >> MSR_VSX) & 1)
|
2007-10-26 01:35:50 +04:00
|
|
|
#define msr_sa ((env->msr >> MSR_SA) & 1)
|
|
|
|
#define msr_key ((env->msr >> MSR_KEY) & 1)
|
|
|
|
#define msr_pow ((env->msr >> MSR_POW) & 1)
|
|
|
|
#define msr_tgpr ((env->msr >> MSR_TGPR) & 1)
|
|
|
|
#define msr_ce ((env->msr >> MSR_CE) & 1)
|
|
|
|
#define msr_ile ((env->msr >> MSR_ILE) & 1)
|
|
|
|
#define msr_ee ((env->msr >> MSR_EE) & 1)
|
|
|
|
#define msr_pr ((env->msr >> MSR_PR) & 1)
|
|
|
|
#define msr_fp ((env->msr >> MSR_FP) & 1)
|
|
|
|
#define msr_me ((env->msr >> MSR_ME) & 1)
|
|
|
|
#define msr_fe0 ((env->msr >> MSR_FE0) & 1)
|
|
|
|
#define msr_se ((env->msr >> MSR_SE) & 1)
|
|
|
|
#define msr_dwe ((env->msr >> MSR_DWE) & 1)
|
|
|
|
#define msr_uble ((env->msr >> MSR_UBLE) & 1)
|
|
|
|
#define msr_be ((env->msr >> MSR_BE) & 1)
|
|
|
|
#define msr_de ((env->msr >> MSR_DE) & 1)
|
|
|
|
#define msr_fe1 ((env->msr >> MSR_FE1) & 1)
|
|
|
|
#define msr_al ((env->msr >> MSR_AL) & 1)
|
|
|
|
#define msr_ep ((env->msr >> MSR_EP) & 1)
|
|
|
|
#define msr_ir ((env->msr >> MSR_IR) & 1)
|
|
|
|
#define msr_dr ((env->msr >> MSR_DR) & 1)
|
2016-05-03 19:03:24 +03:00
|
|
|
#define msr_is ((env->msr >> MSR_IS) & 1)
|
|
|
|
#define msr_ds ((env->msr >> MSR_DS) & 1)
|
2007-10-26 01:35:50 +04:00
|
|
|
#define msr_pe ((env->msr >> MSR_PE) & 1)
|
|
|
|
#define msr_px ((env->msr >> MSR_PX) & 1)
|
|
|
|
#define msr_pmm ((env->msr >> MSR_PMM) & 1)
|
|
|
|
#define msr_ri ((env->msr >> MSR_RI) & 1)
|
|
|
|
#define msr_le ((env->msr >> MSR_LE) & 1)
|
2014-06-04 16:50:59 +04:00
|
|
|
#define msr_ts ((env->msr >> MSR_TS1) & 3)
|
|
|
|
#define msr_tm ((env->msr >> MSR_TM) & 1)
|
|
|
|
|
2018-08-14 19:09:51 +03:00
|
|
|
#define DBCR0_ICMP (1 << 27)
|
|
|
|
#define DBCR0_BRT (1 << 26)
|
|
|
|
#define DBSR_ICMP (1 << 27)
|
|
|
|
#define DBSR_BRT (1 << 26)
|
|
|
|
|
2007-11-18 00:14:09 +03:00
|
|
|
/* Hypervisor bit is more specific */
|
|
|
|
#if defined(TARGET_PPC64)
|
|
|
|
#define MSR_HVB (1ULL << MSR_SHV)
|
|
|
|
#define msr_hv msr_shv
|
|
|
|
#else
|
|
|
|
#if defined(PPC_EMULATE_32BITS_HYPV)
|
|
|
|
#define MSR_HVB (1ULL << MSR_THV)
|
|
|
|
#define msr_hv msr_thv
|
|
|
|
#else
|
|
|
|
#define MSR_HVB (0ULL)
|
|
|
|
#define msr_hv (0)
|
|
|
|
#endif
|
|
|
|
#endif
|
2003-11-23 17:55:54 +03:00
|
|
|
|
2017-03-01 10:12:55 +03:00
|
|
|
/* DSISR */
|
|
|
|
#define DSISR_NOPTE 0x40000000
|
|
|
|
/* Not permitted by access authority of encoded access authority */
|
|
|
|
#define DSISR_PROTFAULT 0x08000000
|
|
|
|
#define DSISR_ISSTORE 0x02000000
|
|
|
|
/* Not permitted by virtual page class key protection */
|
|
|
|
#define DSISR_AMR 0x00200000
|
2017-05-02 09:37:17 +03:00
|
|
|
/* Unsupported Radix Tree Configuration */
|
|
|
|
#define DSISR_R_BADCONFIG 0x00080000
|
2017-03-01 10:12:55 +03:00
|
|
|
|
2017-03-01 10:12:52 +03:00
|
|
|
/* SRR1 error code fields */
|
|
|
|
|
2017-03-01 10:12:55 +03:00
|
|
|
#define SRR1_NOPTE DSISR_NOPTE
|
|
|
|
/* Not permitted due to no-execute or guard bit set */
|
2017-03-01 10:12:54 +03:00
|
|
|
#define SRR1_NOEXEC_GUARD 0x10000000
|
2017-03-01 10:12:55 +03:00
|
|
|
#define SRR1_PROTFAULT DSISR_PROTFAULT
|
|
|
|
#define SRR1_IAMR DSISR_AMR
|
2017-03-01 10:12:52 +03:00
|
|
|
|
2014-06-04 16:50:56 +04:00
|
|
|
/* Facility Status and Control (FSCR) bits */
|
|
|
|
#define FSCR_EBB (63 - 56) /* Event-Based Branch Facility */
|
|
|
|
#define FSCR_TAR (63 - 55) /* Target Address Register */
|
|
|
|
/* Interrupt cause mask and position in FSCR. HFSCR has the same format */
|
|
|
|
#define FSCR_IC_MASK (0xFFULL)
|
|
|
|
#define FSCR_IC_POS (63 - 7)
|
|
|
|
#define FSCR_IC_DSCR_SPR3 2
|
|
|
|
#define FSCR_IC_PMU 3
|
|
|
|
#define FSCR_IC_BHRB 4
|
|
|
|
#define FSCR_IC_TM 5
|
|
|
|
#define FSCR_IC_EBB 7
|
|
|
|
#define FSCR_IC_TAR 8
|
|
|
|
|
2010-09-20 21:06:32 +04:00
|
|
|
/* Exception state register bits definition */
|
2017-12-06 12:41:50 +03:00
|
|
|
#define ESR_PIL PPC_BIT(36) /* Illegal Instruction */
|
|
|
|
#define ESR_PPR PPC_BIT(37) /* Privileged Instruction */
|
|
|
|
#define ESR_PTR PPC_BIT(38) /* Trap */
|
|
|
|
#define ESR_FP PPC_BIT(39) /* Floating-Point Operation */
|
|
|
|
#define ESR_ST PPC_BIT(40) /* Store Operation */
|
|
|
|
#define ESR_AP PPC_BIT(44) /* Auxiliary Processor Operation */
|
|
|
|
#define ESR_PUO PPC_BIT(45) /* Unimplemented Operation */
|
|
|
|
#define ESR_BO PPC_BIT(46) /* Byte Ordering */
|
|
|
|
#define ESR_PIE PPC_BIT(47) /* Imprecise exception */
|
|
|
|
#define ESR_DATA PPC_BIT(53) /* Data Access (Embedded page table) */
|
|
|
|
#define ESR_TLBI PPC_BIT(54) /* TLB Ineligible (Embedded page table) */
|
|
|
|
#define ESR_PT PPC_BIT(55) /* Page Table (Embedded page table) */
|
|
|
|
#define ESR_SPV PPC_BIT(56) /* SPE/VMX operation */
|
|
|
|
#define ESR_EPID PPC_BIT(57) /* External Process ID operation */
|
|
|
|
#define ESR_VLEMI PPC_BIT(58) /* VLE operation */
|
|
|
|
#define ESR_MIF PPC_BIT(62) /* Misaligned instruction (VLE) */
|
2010-09-20 21:06:32 +04:00
|
|
|
|
2014-12-18 19:34:33 +03:00
|
|
|
/* Transaction EXception And Summary Register bits */
|
|
|
|
#define TEXASR_FAILURE_PERSISTENT (63 - 7)
|
|
|
|
#define TEXASR_DISALLOWED (63 - 8)
|
|
|
|
#define TEXASR_NESTING_OVERFLOW (63 - 9)
|
|
|
|
#define TEXASR_FOOTPRINT_OVERFLOW (63 - 10)
|
|
|
|
#define TEXASR_SELF_INDUCED_CONFLICT (63 - 11)
|
|
|
|
#define TEXASR_NON_TRANSACTIONAL_CONFLICT (63 - 12)
|
|
|
|
#define TEXASR_TRANSACTION_CONFLICT (63 - 13)
|
|
|
|
#define TEXASR_TRANSLATION_INVALIDATION_CONFLICT (63 - 14)
|
|
|
|
#define TEXASR_IMPLEMENTATION_SPECIFIC (63 - 15)
|
|
|
|
#define TEXASR_INSTRUCTION_FETCH_CONFLICT (63 - 16)
|
|
|
|
#define TEXASR_ABORT (63 - 31)
|
|
|
|
#define TEXASR_SUSPENDED (63 - 32)
|
|
|
|
#define TEXASR_PRIVILEGE_HV (63 - 34)
|
|
|
|
#define TEXASR_PRIVILEGE_PR (63 - 35)
|
|
|
|
#define TEXASR_FAILURE_SUMMARY (63 - 36)
|
|
|
|
#define TEXASR_TFIAR_EXACT (63 - 37)
|
|
|
|
#define TEXASR_ROT (63 - 38)
|
|
|
|
#define TEXASR_TRANSACTION_LEVEL (63 - 52) /* 12 bits */
|
|
|
|
|
2007-10-07 18:41:00 +04:00
|
|
|
enum {
|
2007-11-19 04:48:12 +03:00
|
|
|
POWERPC_FLAG_NONE = 0x00000000,
|
2007-10-07 18:41:00 +04:00
|
|
|
/* Flag for MSR bit 25 signification (VRE/SPE) */
|
2007-11-19 04:48:12 +03:00
|
|
|
POWERPC_FLAG_SPE = 0x00000001,
|
|
|
|
POWERPC_FLAG_VRE = 0x00000002,
|
2007-10-07 18:41:00 +04:00
|
|
|
/* Flag for MSR bit 17 signification (TGPR/CE) */
|
2007-11-19 04:48:12 +03:00
|
|
|
POWERPC_FLAG_TGPR = 0x00000004,
|
|
|
|
POWERPC_FLAG_CE = 0x00000008,
|
2007-10-07 18:41:00 +04:00
|
|
|
/* Flag for MSR bit 10 signification (SE/DWE/UBLE) */
|
2007-11-19 04:48:12 +03:00
|
|
|
POWERPC_FLAG_SE = 0x00000010,
|
|
|
|
POWERPC_FLAG_DWE = 0x00000020,
|
|
|
|
POWERPC_FLAG_UBLE = 0x00000040,
|
2007-10-07 18:41:00 +04:00
|
|
|
/* Flag for MSR bit 9 signification (BE/DE) */
|
2007-11-19 04:48:12 +03:00
|
|
|
POWERPC_FLAG_BE = 0x00000080,
|
|
|
|
POWERPC_FLAG_DE = 0x00000100,
|
2007-11-18 00:14:09 +03:00
|
|
|
/* Flag for MSR bit 2 signification (PX/PMM) */
|
2007-11-19 04:48:12 +03:00
|
|
|
POWERPC_FLAG_PX = 0x00000200,
|
|
|
|
POWERPC_FLAG_PMM = 0x00000400,
|
|
|
|
/* Flag for special features */
|
|
|
|
/* Decrementer clock: RTC clock (POWER, 601) or bus clock */
|
|
|
|
POWERPC_FLAG_RTC_CLK = 0x00010000,
|
|
|
|
POWERPC_FLAG_BUS_CLK = 0x00020000,
|
2011-08-31 19:45:10 +04:00
|
|
|
/* Has CFAR */
|
|
|
|
POWERPC_FLAG_CFAR = 0x00040000,
|
2013-10-22 15:05:46 +04:00
|
|
|
/* Has VSX */
|
|
|
|
POWERPC_FLAG_VSX = 0x00080000,
|
2014-12-18 19:34:30 +03:00
|
|
|
/* Has Transaction Memory (ISA 2.07) */
|
|
|
|
POWERPC_FLAG_TM = 0x00100000,
|
2007-10-07 18:41:00 +04:00
|
|
|
};
|
|
|
|
|
2007-10-27 21:54:30 +04:00
|
|
|
/*****************************************************************************/
|
|
|
|
/* Floating point status and control register */
|
|
|
|
#define FPSCR_FX 31 /* Floating-point exception summary */
|
|
|
|
#define FPSCR_FEX 30 /* Floating-point enabled exception summary */
|
|
|
|
#define FPSCR_VX 29 /* Floating-point invalid operation exception summ. */
|
|
|
|
#define FPSCR_OX 28 /* Floating-point overflow exception */
|
|
|
|
#define FPSCR_UX 27 /* Floating-point underflow exception */
|
|
|
|
#define FPSCR_ZX 26 /* Floating-point zero divide exception */
|
|
|
|
#define FPSCR_XX 25 /* Floating-point inexact exception */
|
|
|
|
#define FPSCR_VXSNAN 24 /* Floating-point invalid operation exception (sNan) */
|
|
|
|
#define FPSCR_VXISI 23 /* Floating-point invalid operation exception (inf) */
|
|
|
|
#define FPSCR_VXIDI 22 /* Floating-point invalid operation exception (inf) */
|
|
|
|
#define FPSCR_VXZDZ 21 /* Floating-point invalid operation exception (zero) */
|
|
|
|
#define FPSCR_VXIMZ 20 /* Floating-point invalid operation exception (inf) */
|
|
|
|
#define FPSCR_VXVC 19 /* Floating-point invalid operation exception (comp) */
|
|
|
|
#define FPSCR_FR 18 /* Floating-point fraction rounded */
|
|
|
|
#define FPSCR_FI 17 /* Floating-point fraction inexact */
|
|
|
|
#define FPSCR_C 16 /* Floating-point result class descriptor */
|
|
|
|
#define FPSCR_FL 15 /* Floating-point less than or negative */
|
|
|
|
#define FPSCR_FG 14 /* Floating-point greater than or negative */
|
|
|
|
#define FPSCR_FE 13 /* Floating-point equal or zero */
|
|
|
|
#define FPSCR_FU 12 /* Floating-point unordered or NaN */
|
|
|
|
#define FPSCR_FPCC 12 /* Floating-point condition code */
|
|
|
|
#define FPSCR_FPRF 12 /* Floating-point result flags */
|
|
|
|
#define FPSCR_VXSOFT 10 /* Floating-point invalid operation exception (soft) */
|
|
|
|
#define FPSCR_VXSQRT 9 /* Floating-point invalid operation exception (sqrt) */
|
|
|
|
#define FPSCR_VXCVI 8 /* Floating-point invalid operation exception (int) */
|
|
|
|
#define FPSCR_VE 7 /* Floating-point invalid operation exception enable */
|
|
|
|
#define FPSCR_OE 6 /* Floating-point overflow exception enable */
|
|
|
|
#define FPSCR_UE 5 /* Floating-point undeflow exception enable */
|
|
|
|
#define FPSCR_ZE 4 /* Floating-point zero divide exception enable */
|
|
|
|
#define FPSCR_XE 3 /* Floating-point inexact exception enable */
|
|
|
|
#define FPSCR_NI 2 /* Floating-point non-IEEE mode */
|
|
|
|
#define FPSCR_RN1 1
|
|
|
|
#define FPSCR_RN 0 /* Floating-point rounding control */
|
|
|
|
#define fpscr_fex (((env->fpscr) >> FPSCR_FEX) & 0x1)
|
|
|
|
#define fpscr_vx (((env->fpscr) >> FPSCR_VX) & 0x1)
|
|
|
|
#define fpscr_ox (((env->fpscr) >> FPSCR_OX) & 0x1)
|
|
|
|
#define fpscr_ux (((env->fpscr) >> FPSCR_UX) & 0x1)
|
|
|
|
#define fpscr_zx (((env->fpscr) >> FPSCR_ZX) & 0x1)
|
|
|
|
#define fpscr_xx (((env->fpscr) >> FPSCR_XX) & 0x1)
|
|
|
|
#define fpscr_vxsnan (((env->fpscr) >> FPSCR_VXSNAN) & 0x1)
|
|
|
|
#define fpscr_vxisi (((env->fpscr) >> FPSCR_VXISI) & 0x1)
|
|
|
|
#define fpscr_vxidi (((env->fpscr) >> FPSCR_VXIDI) & 0x1)
|
|
|
|
#define fpscr_vxzdz (((env->fpscr) >> FPSCR_VXZDZ) & 0x1)
|
|
|
|
#define fpscr_vximz (((env->fpscr) >> FPSCR_VXIMZ) & 0x1)
|
|
|
|
#define fpscr_vxvc (((env->fpscr) >> FPSCR_VXVC) & 0x1)
|
|
|
|
#define fpscr_fpcc (((env->fpscr) >> FPSCR_FPCC) & 0xF)
|
|
|
|
#define fpscr_vxsoft (((env->fpscr) >> FPSCR_VXSOFT) & 0x1)
|
|
|
|
#define fpscr_vxsqrt (((env->fpscr) >> FPSCR_VXSQRT) & 0x1)
|
|
|
|
#define fpscr_vxcvi (((env->fpscr) >> FPSCR_VXCVI) & 0x1)
|
|
|
|
#define fpscr_ve (((env->fpscr) >> FPSCR_VE) & 0x1)
|
|
|
|
#define fpscr_oe (((env->fpscr) >> FPSCR_OE) & 0x1)
|
|
|
|
#define fpscr_ue (((env->fpscr) >> FPSCR_UE) & 0x1)
|
|
|
|
#define fpscr_ze (((env->fpscr) >> FPSCR_ZE) & 0x1)
|
|
|
|
#define fpscr_xe (((env->fpscr) >> FPSCR_XE) & 0x1)
|
|
|
|
#define fpscr_ni (((env->fpscr) >> FPSCR_NI) & 0x1)
|
|
|
|
#define fpscr_rn (((env->fpscr) >> FPSCR_RN) & 0x3)
|
|
|
|
/* Invalid operation exception summary */
|
|
|
|
#define fpscr_ix ((env->fpscr) & ((1 << FPSCR_VXSNAN) | (1 << FPSCR_VXISI) | \
|
|
|
|
(1 << FPSCR_VXIDI) | (1 << FPSCR_VXZDZ) | \
|
|
|
|
(1 << FPSCR_VXIMZ) | (1 << FPSCR_VXVC) | \
|
|
|
|
(1 << FPSCR_VXSOFT) | (1 << FPSCR_VXSQRT) | \
|
|
|
|
(1 << FPSCR_VXCVI)))
|
|
|
|
/* exception summary */
|
|
|
|
#define fpscr_ex (((env->fpscr) >> FPSCR_XX) & 0x1F)
|
|
|
|
/* enabled exception summary */
|
|
|
|
#define fpscr_eex (((env->fpscr) >> FPSCR_XX) & ((env->fpscr) >> FPSCR_XE) & \
|
|
|
|
0x1F)
|
|
|
|
|
2019-03-21 08:29:36 +03:00
|
|
|
#define FP_FX (1ull << FPSCR_FX)
|
|
|
|
#define FP_FEX (1ull << FPSCR_FEX)
|
|
|
|
#define FP_VX (1ull << FPSCR_VX)
|
|
|
|
#define FP_OX (1ull << FPSCR_OX)
|
|
|
|
#define FP_UX (1ull << FPSCR_UX)
|
|
|
|
#define FP_ZX (1ull << FPSCR_ZX)
|
|
|
|
#define FP_XX (1ull << FPSCR_XX)
|
|
|
|
#define FP_VXSNAN (1ull << FPSCR_VXSNAN)
|
|
|
|
#define FP_VXISI (1ull << FPSCR_VXISI)
|
|
|
|
#define FP_VXIDI (1ull << FPSCR_VXIDI)
|
|
|
|
#define FP_VXZDZ (1ull << FPSCR_VXZDZ)
|
|
|
|
#define FP_VXIMZ (1ull << FPSCR_VXIMZ)
|
|
|
|
#define FP_VXVC (1ull << FPSCR_VXVC)
|
|
|
|
#define FP_FR (1ull << FSPCR_FR)
|
|
|
|
#define FP_FI (1ull << FPSCR_FI)
|
|
|
|
#define FP_C (1ull << FPSCR_C)
|
|
|
|
#define FP_FL (1ull << FPSCR_FL)
|
|
|
|
#define FP_FG (1ull << FPSCR_FG)
|
|
|
|
#define FP_FE (1ull << FPSCR_FE)
|
|
|
|
#define FP_FU (1ull << FPSCR_FU)
|
|
|
|
#define FP_FPCC (FP_FL | FP_FG | FP_FE | FP_FU)
|
|
|
|
#define FP_FPRF (FP_C | FP_FL | FP_FG | FP_FE | FP_FU)
|
|
|
|
#define FP_VXSOFT (1ull << FPSCR_VXSOFT)
|
|
|
|
#define FP_VXSQRT (1ull << FPSCR_VXSQRT)
|
|
|
|
#define FP_VXCVI (1ull << FPSCR_VXCVI)
|
|
|
|
#define FP_VE (1ull << FPSCR_VE)
|
|
|
|
#define FP_OE (1ull << FPSCR_OE)
|
|
|
|
#define FP_UE (1ull << FPSCR_UE)
|
|
|
|
#define FP_ZE (1ull << FPSCR_ZE)
|
|
|
|
#define FP_XE (1ull << FPSCR_XE)
|
|
|
|
#define FP_NI (1ull << FPSCR_NI)
|
|
|
|
#define FP_RN1 (1ull << FPSCR_RN1)
|
|
|
|
#define FP_RN (1ull << FPSCR_RN)
|
2015-11-20 14:31:47 +03:00
|
|
|
|
target-ppc: mcrfs should always update FEX/VX and only clear exception bits
Here is the description of the mcrfs instruction from the PowerPC Architecture
Book, Version 2.02, Book I: PowerPC User Instruction Set Architecture
(http://www.ibm.com/developerworks/systems/library/es-archguide-v2.html), found
on page 120:
The contents of FPSCR field BFA are copied to Condition Register field BF.
All exception bits copied are set to 0 in the FPSCR. If the FX bit is
copied, it is set to 0 in the FPSCR.
Special Registers Altered:
CR field BF
FX OX (if BFA=0)
UX ZX XX VXSNAN (if BFA=1)
VXISI VXIDI VXZDZ VXIMZ (if BFA=2)
VXVC (if BFA=3)
VXSOFT VXSQRT VXCVI (if BFA=5)
However, currently every bit in FPSCR field BFA is set to 0, including ones not
on that list.
This can be seen in the following simple C program:
#include <fenv.h>
#include <stdio.h>
int main(int argc, char **argv) {
int ret;
ret = fegetround();
printf("Current rounding: %d\n", ret);
ret = fesetround(FE_UPWARD);
printf("Setting to FE_UPWARD (%d): %d\n", FE_UPWARD, ret);
ret = fegetround();
printf("Current rounding: %d\n", ret);
ret = fegetround();
printf("Current rounding: %d\n", ret);
return 0;
}
which gave the output (before this commit):
Current rounding: 0
Setting to FE_UPWARD (2): 0
Current rounding: 2
Current rounding: 0
instead of (after this commit):
Current rounding: 0
Setting to FE_UPWARD (2): 0
Current rounding: 2
Current rounding: 2
The relevant disassembly is in fegetround(), which, on my system, is:
__GI___fegetround:
<+0>: mcrfs cr7, cr7
<+4>: mfcr r3
<+8>: clrldi r3, r3, 62
<+12>: blr
What happens is that, the first time fegetround() is called, FPSCR field 7 is
retrieved. However, because of the bug in mcrfs, the entirety of field 7 is set
to 0, which includes the rounding mode.
There are other issues this will fix, such as condition flags not persisting
when they should if read, and if you were to read a specific field with some
exception bits set, but no others were set in the entire register, then the
bits would be cleared correctly, but FEX/VX would not be updated to 0 as they
should be.
Signed-off-by: James Clarke <jrtc27@jrtc27.com>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
2016-01-29 21:40:21 +03:00
|
|
|
/* the exception bits which can be cleared by mcrfs - includes FX */
|
|
|
|
#define FP_EX_CLEAR_BITS (FP_FX | FP_OX | FP_UX | FP_ZX | \
|
|
|
|
FP_XX | FP_VXSNAN | FP_VXISI | FP_VXIDI | \
|
|
|
|
FP_VXZDZ | FP_VXIMZ | FP_VXVC | FP_VXSOFT | \
|
|
|
|
FP_VXSQRT | FP_VXCVI)
|
|
|
|
|
2007-10-27 21:54:30 +04:00
|
|
|
/*****************************************************************************/
|
2009-01-03 17:04:11 +03:00
|
|
|
/* Vector status and control register */
|
2019-03-21 08:29:36 +03:00
|
|
|
#define VSCR_NJ 16 /* Vector non-java */
|
|
|
|
#define VSCR_SAT 0 /* Vector saturation */
|
2009-01-03 17:04:11 +03:00
|
|
|
|
2011-05-01 01:34:58 +04:00
|
|
|
/*****************************************************************************/
|
|
|
|
/* BookE e500 MMU registers */
|
|
|
|
|
|
|
|
#define MAS0_NV_SHIFT 0
|
|
|
|
#define MAS0_NV_MASK (0xfff << MAS0_NV_SHIFT)
|
|
|
|
|
|
|
|
#define MAS0_WQ_SHIFT 12
|
|
|
|
#define MAS0_WQ_MASK (3 << MAS0_WQ_SHIFT)
|
|
|
|
/* Write TLB entry regardless of reservation */
|
|
|
|
#define MAS0_WQ_ALWAYS (0 << MAS0_WQ_SHIFT)
|
|
|
|
/* Write TLB entry only already in use */
|
|
|
|
#define MAS0_WQ_COND (1 << MAS0_WQ_SHIFT)
|
|
|
|
/* Clear TLB entry */
|
|
|
|
#define MAS0_WQ_CLR_RSRV (2 << MAS0_WQ_SHIFT)
|
|
|
|
|
|
|
|
#define MAS0_HES_SHIFT 14
|
|
|
|
#define MAS0_HES (1 << MAS0_HES_SHIFT)
|
|
|
|
|
|
|
|
#define MAS0_ESEL_SHIFT 16
|
|
|
|
#define MAS0_ESEL_MASK (0xfff << MAS0_ESEL_SHIFT)
|
|
|
|
|
|
|
|
#define MAS0_TLBSEL_SHIFT 28
|
|
|
|
#define MAS0_TLBSEL_MASK (3 << MAS0_TLBSEL_SHIFT)
|
|
|
|
#define MAS0_TLBSEL_TLB0 (0 << MAS0_TLBSEL_SHIFT)
|
|
|
|
#define MAS0_TLBSEL_TLB1 (1 << MAS0_TLBSEL_SHIFT)
|
|
|
|
#define MAS0_TLBSEL_TLB2 (2 << MAS0_TLBSEL_SHIFT)
|
|
|
|
#define MAS0_TLBSEL_TLB3 (3 << MAS0_TLBSEL_SHIFT)
|
|
|
|
|
|
|
|
#define MAS0_ATSEL_SHIFT 31
|
|
|
|
#define MAS0_ATSEL (1 << MAS0_ATSEL_SHIFT)
|
|
|
|
#define MAS0_ATSEL_TLB 0
|
|
|
|
#define MAS0_ATSEL_LRAT MAS0_ATSEL
|
|
|
|
|
2011-08-18 14:38:40 +04:00
|
|
|
#define MAS1_TSIZE_SHIFT 7
|
|
|
|
#define MAS1_TSIZE_MASK (0x1f << MAS1_TSIZE_SHIFT)
|
2011-05-01 01:34:58 +04:00
|
|
|
|
|
|
|
#define MAS1_TS_SHIFT 12
|
|
|
|
#define MAS1_TS (1 << MAS1_TS_SHIFT)
|
|
|
|
|
|
|
|
#define MAS1_IND_SHIFT 13
|
|
|
|
#define MAS1_IND (1 << MAS1_IND_SHIFT)
|
|
|
|
|
|
|
|
#define MAS1_TID_SHIFT 16
|
|
|
|
#define MAS1_TID_MASK (0x3fff << MAS1_TID_SHIFT)
|
|
|
|
|
|
|
|
#define MAS1_IPROT_SHIFT 30
|
|
|
|
#define MAS1_IPROT (1 << MAS1_IPROT_SHIFT)
|
|
|
|
|
|
|
|
#define MAS1_VALID_SHIFT 31
|
|
|
|
#define MAS1_VALID 0x80000000
|
|
|
|
|
|
|
|
#define MAS2_EPN_SHIFT 12
|
2012-06-21 15:34:20 +04:00
|
|
|
#define MAS2_EPN_MASK (~0ULL << MAS2_EPN_SHIFT)
|
2011-05-01 01:34:58 +04:00
|
|
|
|
|
|
|
#define MAS2_ACM_SHIFT 6
|
|
|
|
#define MAS2_ACM (1 << MAS2_ACM_SHIFT)
|
|
|
|
|
|
|
|
#define MAS2_VLE_SHIFT 5
|
|
|
|
#define MAS2_VLE (1 << MAS2_VLE_SHIFT)
|
|
|
|
|
|
|
|
#define MAS2_W_SHIFT 4
|
|
|
|
#define MAS2_W (1 << MAS2_W_SHIFT)
|
|
|
|
|
|
|
|
#define MAS2_I_SHIFT 3
|
|
|
|
#define MAS2_I (1 << MAS2_I_SHIFT)
|
|
|
|
|
|
|
|
#define MAS2_M_SHIFT 2
|
|
|
|
#define MAS2_M (1 << MAS2_M_SHIFT)
|
|
|
|
|
|
|
|
#define MAS2_G_SHIFT 1
|
|
|
|
#define MAS2_G (1 << MAS2_G_SHIFT)
|
|
|
|
|
|
|
|
#define MAS2_E_SHIFT 0
|
|
|
|
#define MAS2_E (1 << MAS2_E_SHIFT)
|
|
|
|
|
|
|
|
#define MAS3_RPN_SHIFT 12
|
|
|
|
#define MAS3_RPN_MASK (0xfffff << MAS3_RPN_SHIFT)
|
|
|
|
|
|
|
|
#define MAS3_U0 0x00000200
|
|
|
|
#define MAS3_U1 0x00000100
|
|
|
|
#define MAS3_U2 0x00000080
|
|
|
|
#define MAS3_U3 0x00000040
|
|
|
|
#define MAS3_UX 0x00000020
|
|
|
|
#define MAS3_SX 0x00000010
|
|
|
|
#define MAS3_UW 0x00000008
|
|
|
|
#define MAS3_SW 0x00000004
|
|
|
|
#define MAS3_UR 0x00000002
|
|
|
|
#define MAS3_SR 0x00000001
|
|
|
|
#define MAS3_SPSIZE_SHIFT 1
|
|
|
|
#define MAS3_SPSIZE_MASK (0x3e << MAS3_SPSIZE_SHIFT)
|
|
|
|
|
|
|
|
#define MAS4_TLBSELD_SHIFT MAS0_TLBSEL_SHIFT
|
|
|
|
#define MAS4_TLBSELD_MASK MAS0_TLBSEL_MASK
|
|
|
|
#define MAS4_TIDSELD_MASK 0x00030000
|
|
|
|
#define MAS4_TIDSELD_PID0 0x00000000
|
|
|
|
#define MAS4_TIDSELD_PID1 0x00010000
|
|
|
|
#define MAS4_TIDSELD_PID2 0x00020000
|
|
|
|
#define MAS4_TIDSELD_PIDZ 0x00030000
|
|
|
|
#define MAS4_INDD 0x00008000 /* Default IND */
|
|
|
|
#define MAS4_TSIZED_SHIFT MAS1_TSIZE_SHIFT
|
|
|
|
#define MAS4_TSIZED_MASK MAS1_TSIZE_MASK
|
|
|
|
#define MAS4_ACMD 0x00000040
|
|
|
|
#define MAS4_VLED 0x00000020
|
|
|
|
#define MAS4_WD 0x00000010
|
|
|
|
#define MAS4_ID 0x00000008
|
|
|
|
#define MAS4_MD 0x00000004
|
|
|
|
#define MAS4_GD 0x00000002
|
|
|
|
#define MAS4_ED 0x00000001
|
|
|
|
#define MAS4_WIMGED_MASK 0x0000001f /* Default WIMGE */
|
|
|
|
#define MAS4_WIMGED_SHIFT 0
|
|
|
|
|
|
|
|
#define MAS5_SGS 0x80000000
|
|
|
|
#define MAS5_SLPID_MASK 0x00000fff
|
|
|
|
|
|
|
|
#define MAS6_SPID0 0x3fff0000
|
|
|
|
#define MAS6_SPID1 0x00007ffe
|
|
|
|
#define MAS6_ISIZE(x) MAS1_TSIZE(x)
|
|
|
|
#define MAS6_SAS 0x00000001
|
|
|
|
#define MAS6_SPID MAS6_SPID0
|
|
|
|
#define MAS6_SIND 0x00000002 /* Indirect page */
|
|
|
|
#define MAS6_SIND_SHIFT 1
|
|
|
|
#define MAS6_SPID_MASK 0x3fff0000
|
|
|
|
#define MAS6_SPID_SHIFT 16
|
|
|
|
#define MAS6_ISIZE_MASK 0x00000f80
|
|
|
|
#define MAS6_ISIZE_SHIFT 7
|
|
|
|
|
|
|
|
#define MAS7_RPN 0xffffffff
|
|
|
|
|
|
|
|
#define MAS8_TGS 0x80000000
|
|
|
|
#define MAS8_VF 0x40000000
|
|
|
|
#define MAS8_TLBPID 0x00000fff
|
|
|
|
|
|
|
|
/* Bit definitions for MMUCFG */
|
|
|
|
#define MMUCFG_MAVN 0x00000003 /* MMU Architecture Version Number */
|
|
|
|
#define MMUCFG_MAVN_V1 0x00000000 /* v1.0 */
|
|
|
|
#define MMUCFG_MAVN_V2 0x00000001 /* v2.0 */
|
|
|
|
#define MMUCFG_NTLBS 0x0000000c /* Number of TLBs */
|
|
|
|
#define MMUCFG_PIDSIZE 0x000007c0 /* PID Reg Size */
|
|
|
|
#define MMUCFG_TWC 0x00008000 /* TLB Write Conditional (v2.0) */
|
|
|
|
#define MMUCFG_LRAT 0x00010000 /* LRAT Supported (v2.0) */
|
|
|
|
#define MMUCFG_RASIZE 0x00fe0000 /* Real Addr Size */
|
|
|
|
#define MMUCFG_LPIDSIZE 0x0f000000 /* LPID Reg Size */
|
|
|
|
|
|
|
|
/* Bit definitions for MMUCSR0 */
|
|
|
|
#define MMUCSR0_TLB1FI 0x00000002 /* TLB1 Flash invalidate */
|
|
|
|
#define MMUCSR0_TLB0FI 0x00000004 /* TLB0 Flash invalidate */
|
|
|
|
#define MMUCSR0_TLB2FI 0x00000040 /* TLB2 Flash invalidate */
|
|
|
|
#define MMUCSR0_TLB3FI 0x00000020 /* TLB3 Flash invalidate */
|
|
|
|
#define MMUCSR0_TLBFI (MMUCSR0_TLB0FI | MMUCSR0_TLB1FI | \
|
|
|
|
MMUCSR0_TLB2FI | MMUCSR0_TLB3FI)
|
|
|
|
#define MMUCSR0_TLB0PS 0x00000780 /* TLB0 Page Size */
|
|
|
|
#define MMUCSR0_TLB1PS 0x00007800 /* TLB1 Page Size */
|
|
|
|
#define MMUCSR0_TLB2PS 0x00078000 /* TLB2 Page Size */
|
|
|
|
#define MMUCSR0_TLB3PS 0x00780000 /* TLB3 Page Size */
|
|
|
|
|
|
|
|
/* TLBnCFG encoding */
|
|
|
|
#define TLBnCFG_N_ENTRY 0x00000fff /* number of entries */
|
|
|
|
#define TLBnCFG_HES 0x00002000 /* HW select supported */
|
|
|
|
#define TLBnCFG_AVAIL 0x00004000 /* variable page size */
|
|
|
|
#define TLBnCFG_IPROT 0x00008000 /* IPROT supported */
|
|
|
|
#define TLBnCFG_GTWE 0x00010000 /* Guest can write */
|
|
|
|
#define TLBnCFG_IND 0x00020000 /* IND entries supported */
|
|
|
|
#define TLBnCFG_PT 0x00040000 /* Can load from page table */
|
|
|
|
#define TLBnCFG_MINSIZE 0x00f00000 /* Minimum Page Size (v1.0) */
|
|
|
|
#define TLBnCFG_MINSIZE_SHIFT 20
|
|
|
|
#define TLBnCFG_MAXSIZE 0x000f0000 /* Maximum Page Size (v1.0) */
|
|
|
|
#define TLBnCFG_MAXSIZE_SHIFT 16
|
|
|
|
#define TLBnCFG_ASSOC 0xff000000 /* Associativity */
|
|
|
|
#define TLBnCFG_ASSOC_SHIFT 24
|
|
|
|
|
|
|
|
/* TLBnPS encoding */
|
|
|
|
#define TLBnPS_4K 0x00000004
|
|
|
|
#define TLBnPS_8K 0x00000008
|
|
|
|
#define TLBnPS_16K 0x00000010
|
|
|
|
#define TLBnPS_32K 0x00000020
|
|
|
|
#define TLBnPS_64K 0x00000040
|
|
|
|
#define TLBnPS_128K 0x00000080
|
|
|
|
#define TLBnPS_256K 0x00000100
|
|
|
|
#define TLBnPS_512K 0x00000200
|
|
|
|
#define TLBnPS_1M 0x00000400
|
|
|
|
#define TLBnPS_2M 0x00000800
|
|
|
|
#define TLBnPS_4M 0x00001000
|
|
|
|
#define TLBnPS_8M 0x00002000
|
|
|
|
#define TLBnPS_16M 0x00004000
|
|
|
|
#define TLBnPS_32M 0x00008000
|
|
|
|
#define TLBnPS_64M 0x00010000
|
|
|
|
#define TLBnPS_128M 0x00020000
|
|
|
|
#define TLBnPS_256M 0x00040000
|
|
|
|
#define TLBnPS_512M 0x00080000
|
|
|
|
#define TLBnPS_1G 0x00100000
|
|
|
|
#define TLBnPS_2G 0x00200000
|
|
|
|
#define TLBnPS_4G 0x00400000
|
|
|
|
#define TLBnPS_8G 0x00800000
|
|
|
|
#define TLBnPS_16G 0x01000000
|
|
|
|
#define TLBnPS_32G 0x02000000
|
|
|
|
#define TLBnPS_64G 0x04000000
|
|
|
|
#define TLBnPS_128G 0x08000000
|
|
|
|
#define TLBnPS_256G 0x10000000
|
|
|
|
|
|
|
|
/* tlbilx action encoding */
|
|
|
|
#define TLBILX_T_ALL 0
|
|
|
|
#define TLBILX_T_TID 1
|
|
|
|
#define TLBILX_T_FULLMATCH 3
|
|
|
|
#define TLBILX_T_CLASS0 4
|
|
|
|
#define TLBILX_T_CLASS1 5
|
|
|
|
#define TLBILX_T_CLASS2 6
|
|
|
|
#define TLBILX_T_CLASS3 7
|
|
|
|
|
|
|
|
/* BookE 2.06 helper defines */
|
|
|
|
|
|
|
|
#define BOOKE206_FLUSH_TLB0 (1 << 0)
|
|
|
|
#define BOOKE206_FLUSH_TLB1 (1 << 1)
|
|
|
|
#define BOOKE206_FLUSH_TLB2 (1 << 2)
|
|
|
|
#define BOOKE206_FLUSH_TLB3 (1 << 3)
|
|
|
|
|
|
|
|
/* number of possible TLBs */
|
|
|
|
#define BOOKE206_MAX_TLBN 4
|
|
|
|
|
2018-09-21 09:59:07 +03:00
|
|
|
#define EPID_EPID_SHIFT 0x0
|
|
|
|
#define EPID_EPID 0xFF
|
|
|
|
#define EPID_ELPID_SHIFT 0x10
|
|
|
|
#define EPID_ELPID 0x3F0000
|
|
|
|
#define EPID_EGS 0x20000000
|
|
|
|
#define EPID_EGS_SHIFT 29
|
|
|
|
#define EPID_EAS 0x40000000
|
|
|
|
#define EPID_EAS_SHIFT 30
|
|
|
|
#define EPID_EPR 0x80000000
|
|
|
|
#define EPID_EPR_SHIFT 31
|
|
|
|
/* We don't support EGS and ELPID */
|
|
|
|
#define EPID_MASK (EPID_EPID | EPID_EAS | EPID_EPR)
|
|
|
|
|
2012-01-31 06:11:32 +04:00
|
|
|
/*****************************************************************************/
|
2018-01-18 17:54:03 +03:00
|
|
|
/* Server and Embedded Processor Control */
|
2012-01-31 06:11:32 +04:00
|
|
|
|
|
|
|
#define DBELL_TYPE_SHIFT 27
|
|
|
|
#define DBELL_TYPE_MASK (0x1f << DBELL_TYPE_SHIFT)
|
|
|
|
#define DBELL_TYPE_DBELL (0x00 << DBELL_TYPE_SHIFT)
|
|
|
|
#define DBELL_TYPE_DBELL_CRIT (0x01 << DBELL_TYPE_SHIFT)
|
|
|
|
#define DBELL_TYPE_G_DBELL (0x02 << DBELL_TYPE_SHIFT)
|
|
|
|
#define DBELL_TYPE_G_DBELL_CRIT (0x03 << DBELL_TYPE_SHIFT)
|
|
|
|
#define DBELL_TYPE_G_DBELL_MC (0x04 << DBELL_TYPE_SHIFT)
|
|
|
|
|
2018-01-18 17:54:03 +03:00
|
|
|
#define DBELL_TYPE_DBELL_SERVER (0x05 << DBELL_TYPE_SHIFT)
|
|
|
|
|
|
|
|
#define DBELL_BRDCAST PPC_BIT(37)
|
2012-01-31 06:11:32 +04:00
|
|
|
#define DBELL_LPIDTAG_SHIFT 14
|
|
|
|
#define DBELL_LPIDTAG_MASK (0xfff << DBELL_LPIDTAG_SHIFT)
|
|
|
|
#define DBELL_PIRTAG_MASK 0x3fff
|
|
|
|
|
2018-01-18 17:54:03 +03:00
|
|
|
#define DBELL_PROCIDTAG_MASK PPC_BITMASK(44, 63)
|
|
|
|
|
ppc64: Rudimentary Support for extra page sizes on server CPUs
More recent Power server chips (i.e. based on the 64 bit hash MMU)
support more than just the traditional 4k and 16M page sizes. This
can get quite complicated, because which page sizes are supported,
which combinations are supported within an MMU segment and how these
page sizes are encoded both in the SLB entry and the hash PTE can vary
depending on the CPU model (they are not specified by the
architecture). In addition the firmware or hypervisor may not permit
use of certain page sizes, for various reasons. Whether various page
sizes are supported on KVM, for example, depends on whether the PR or
HV variant of KVM is in use, and on the page size of the memory
backing the guest's RAM.
This patch adds information to the CPUState and cpu defs to describe
the supported page sizes and encodings. Since TCG does not yet
support any extended page sizes, we just set this to NULL in the
static CPU definitions, expanding this to the default 4k and 16M page
sizes when we initialize the cpu state. When using KVM, however, we
instead determine available page sizes using the new
KVM_PPC_GET_SMMU_INFO call. For old kernels without that call, we use
some defaults, with some guesswork which should do the right thing for
existing HV and PR implementations. The fallback might not be correct
for future versions, but that's ok, because they'll have
KVM_PPC_GET_SMMU_INFO.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Alexander Graf <agraf@suse.de>
2012-06-18 23:56:25 +04:00
|
|
|
#define PPC_PAGE_SIZES_MAX_SZ 8
|
|
|
|
|
2017-03-20 02:46:43 +03:00
|
|
|
struct ppc_radix_page_info {
|
|
|
|
uint32_t count;
|
|
|
|
uint32_t entries[PPC_PAGE_SIZES_MAX_SZ];
|
|
|
|
};
|
ppc64: Rudimentary Support for extra page sizes on server CPUs
More recent Power server chips (i.e. based on the 64 bit hash MMU)
support more than just the traditional 4k and 16M page sizes. This
can get quite complicated, because which page sizes are supported,
which combinations are supported within an MMU segment and how these
page sizes are encoded both in the SLB entry and the hash PTE can vary
depending on the CPU model (they are not specified by the
architecture). In addition the firmware or hypervisor may not permit
use of certain page sizes, for various reasons. Whether various page
sizes are supported on KVM, for example, depends on whether the PR or
HV variant of KVM is in use, and on the page size of the memory
backing the guest's RAM.
This patch adds information to the CPUState and cpu defs to describe
the supported page sizes and encodings. Since TCG does not yet
support any extended page sizes, we just set this to NULL in the
static CPU definitions, expanding this to the default 4k and 16M page
sizes when we initialize the cpu state. When using KVM, however, we
instead determine available page sizes using the new
KVM_PPC_GET_SMMU_INFO call. For old kernels without that call, we use
some defaults, with some guesswork which should do the right thing for
existing HV and PR implementations. The fallback might not be correct
for future versions, but that's ok, because they'll have
KVM_PPC_GET_SMMU_INFO.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Alexander Graf <agraf@suse.de>
2012-06-18 23:56:25 +04:00
|
|
|
|
2009-01-03 17:04:11 +03:00
|
|
|
/*****************************************************************************/
|
2007-10-27 21:54:30 +04:00
|
|
|
/* The whole PowerPC CPU context */
|
2018-09-21 09:59:07 +03:00
|
|
|
|
2019-03-21 08:29:36 +03:00
|
|
|
/*
|
|
|
|
* PowerPC needs eight modes for different hypervisor/supervisor/guest
|
|
|
|
* + real/paged mode combinations. The other two modes are for
|
|
|
|
* external PID load/store.
|
2018-09-21 09:59:07 +03:00
|
|
|
*/
|
|
|
|
#define MMU_MODE8_SUFFIX _epl
|
|
|
|
#define MMU_MODE9_SUFFIX _eps
|
|
|
|
#define PPC_TLB_EPID_LOAD 8
|
|
|
|
#define PPC_TLB_EPID_STORE 9
|
2007-10-14 11:07:08 +04:00
|
|
|
|
2014-09-26 13:07:37 +04:00
|
|
|
#define PPC_CPU_OPCODES_LEN 0x40
|
|
|
|
#define PPC_CPU_INDIRECT_OPCODES_LEN 0x20
|
2013-06-10 00:11:49 +04:00
|
|
|
|
2005-07-03 00:59:34 +04:00
|
|
|
struct CPUPPCState {
|
2019-03-21 08:29:36 +03:00
|
|
|
/*
|
|
|
|
* First are the most commonly used resources during translated
|
|
|
|
* code execution
|
2005-07-03 00:59:34 +04:00
|
|
|
*/
|
2003-11-23 17:55:54 +03:00
|
|
|
/* general purpose registers */
|
2008-09-04 09:26:09 +04:00
|
|
|
target_ulong gpr[32];
|
2007-11-12 04:56:18 +03:00
|
|
|
/* Storage for GPR MSB, used by the SPE extension */
|
2008-09-04 09:26:09 +04:00
|
|
|
target_ulong gprh[32];
|
2005-07-03 00:59:34 +04:00
|
|
|
/* LR */
|
|
|
|
target_ulong lr;
|
|
|
|
/* CTR */
|
|
|
|
target_ulong ctr;
|
|
|
|
/* condition register */
|
2008-09-04 21:06:47 +04:00
|
|
|
uint32_t crf[8];
|
2011-08-31 19:45:10 +04:00
|
|
|
#if defined(TARGET_PPC64)
|
|
|
|
/* CFAR */
|
|
|
|
target_ulong cfar;
|
|
|
|
#endif
|
2013-02-20 11:52:13 +04:00
|
|
|
/* XER (with SO, OV, CA split out) */
|
2008-10-21 15:28:46 +04:00
|
|
|
target_ulong xer;
|
2013-02-20 11:52:13 +04:00
|
|
|
target_ulong so;
|
|
|
|
target_ulong ov;
|
|
|
|
target_ulong ca;
|
target/ppc: support for 32-bit carry and overflow
POWER ISA 3.0 adds CA32 and OV32 status in 64-bit mode. Add the flags
and corresponding defines.
Moreover, CA32 is updated when CA is updated and OV32 is updated when OV
is updated.
Arithmetic instructions:
* Addition and Substractions:
addic, addic., subfic, addc, subfc, adde, subfe, addme, subfme,
addze, and subfze always updates CA and CA32.
=> CA reflects the carry out of bit 0 in 64-bit mode and out of
bit 32 in 32-bit mode.
=> CA32 reflects the carry out of bit 32 independent of the
mode.
=> SO and OV reflects overflow of the 64-bit result in 64-bit
mode and overflow of the low-order 32-bit result in 32-bit
mode
=> OV32 reflects overflow of the low-order 32-bit independent of
the mode
* Multiply Low and Divide:
For mulld, divd, divde, divdu and divdeu: SO, OV, and OV32 bits
reflects overflow of the 64-bit result
For mullw, divw, divwe, divwu and divweu: SO, OV, and OV32 bits
reflects overflow of the 32-bit result
* Negate with OE=1 (nego)
For 64-bit mode if the register RA contains
0x8000_0000_0000_0000, OV and OV32 are set to 1.
For 32-bit mode if the register RA contains 0x8000_0000, OV and
OV32 are set to 1.
Signed-off-by: Nikunj A Dadhania <nikunj@linux.vnet.ibm.com>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
2017-02-27 07:57:54 +03:00
|
|
|
target_ulong ov32;
|
|
|
|
target_ulong ca32;
|
2003-11-23 17:55:54 +03:00
|
|
|
/* Reservation address */
|
2009-08-03 19:43:25 +04:00
|
|
|
target_ulong reserve_addr;
|
|
|
|
/* Reservation value */
|
|
|
|
target_ulong reserve_val;
|
2014-02-10 21:27:00 +04:00
|
|
|
target_ulong reserve_val2;
|
2005-07-03 00:59:34 +04:00
|
|
|
|
|
|
|
/* Those ones are used in supervisor mode only */
|
2003-11-23 17:55:54 +03:00
|
|
|
/* machine state register */
|
2007-10-26 01:35:50 +04:00
|
|
|
target_ulong msr;
|
2005-07-03 00:59:34 +04:00
|
|
|
/* temporary general purpose registers */
|
2008-09-04 09:26:09 +04:00
|
|
|
target_ulong tgpr[4]; /* Used to speed-up TLB assist handlers */
|
2005-07-03 00:59:34 +04:00
|
|
|
|
|
|
|
/* Floating point execution context */
|
2005-03-13 20:01:22 +03:00
|
|
|
float_status fp_status;
|
2005-07-03 00:59:34 +04:00
|
|
|
/* floating point status and control register */
|
2012-10-29 21:24:59 +04:00
|
|
|
target_ulong fpscr;
|
2005-03-13 20:01:22 +03:00
|
|
|
|
2009-10-22 16:55:37 +04:00
|
|
|
/* Next instruction pointer */
|
|
|
|
target_ulong nip;
|
2005-11-20 13:32:34 +03:00
|
|
|
|
2018-06-26 19:19:10 +03:00
|
|
|
/* High part of 128-bit helper return. */
|
|
|
|
uint64_t retxh;
|
|
|
|
|
2019-03-21 08:29:36 +03:00
|
|
|
/* when a memory exception occurs, the access type is stored here */
|
|
|
|
int access_type;
|
2004-04-13 00:39:29 +04:00
|
|
|
|
2007-10-07 19:43:50 +04:00
|
|
|
/* MMU context - only relevant for full system emulation */
|
|
|
|
#if !defined(CONFIG_USER_ONLY)
|
|
|
|
#if defined(TARGET_PPC64)
|
|
|
|
/* PowerPC 64 SLB area */
|
2013-10-01 20:19:31 +04:00
|
|
|
ppc_slb_t slb[MAX_SLB_ENTRIES];
|
ppc: Do some batching of TCG tlb flushes
On ppc64 especially, we flush the tlb on any slbie or tlbie instruction.
However, those instructions often come in bursts of 3 or more (context
switch will favor a series of slbie's for example to an slbia if the
SLB has less than a certain number of entries in it, and tlbie's can
happen in a series, with PAPR, H_BULK_REMOVE can remove up to 4 entries
at a time.
Doing a tlb_flush() each time is a waste of time. We end up doing a memset
of the whole TLB, reloading it for the next instruction, memset'ing again,
etc...
Those instructions don't have to take effect immediately. For slbie, they
can wait for the next context synchronizing event. For tlbie, the next
tlbsync.
This implements batching by keeping a flag that indicates that we have a
TLB in need of flushing. We check it on interrupts, rfi's, isync's and
tlbsync and flush the TLB if needed.
This reduces the number of tlb_flush() on a boot to a ubuntu installer
first dialog screen from roughly 360K down to 36K.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
[clg: added a 'CPUPPCState *' variable in h_remove() and
h_bulk_remove() ]
Signed-off-by: Cédric Le Goater <clg@kaod.org>
[dwg: removed spurious whitespace change, use 0/1 not true/false
consistently, since tlb_need_flush has int type]
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
2016-05-03 19:03:25 +03:00
|
|
|
/* tcg TLB needs flush (deferred slb inval instruction typically) */
|
2007-10-07 19:43:50 +04:00
|
|
|
#endif
|
2005-07-03 00:59:34 +04:00
|
|
|
/* segment registers */
|
2008-12-07 00:46:17 +03:00
|
|
|
target_ulong sr[32];
|
2005-07-03 00:59:34 +04:00
|
|
|
/* BATs */
|
2013-07-18 23:32:54 +04:00
|
|
|
uint32_t nb_BATs;
|
2005-07-03 00:59:34 +04:00
|
|
|
target_ulong DBAT[2][8];
|
|
|
|
target_ulong IBAT[2][8];
|
2011-05-01 01:34:58 +04:00
|
|
|
/* PowerPC TLB registers (for 4xx, e500 and 60x software driven TLBs) */
|
2013-07-18 23:32:54 +04:00
|
|
|
int32_t nb_tlb; /* Total number of TLB */
|
2007-10-07 19:43:50 +04:00
|
|
|
int tlb_per_way; /* Speed-up helper: used to avoid divisions at run time */
|
|
|
|
int nb_ways; /* Number of ways in the TLB set */
|
|
|
|
int last_way; /* Last used way used to allocate TLB in a LRU way */
|
|
|
|
int id_tlbs; /* If 1, MMU has separated TLBs for instructions & data */
|
|
|
|
int nb_pids; /* Number of available PID registers */
|
2011-06-17 03:00:28 +04:00
|
|
|
int tlb_type; /* Type of TLB we're dealing with */
|
|
|
|
ppc_tlb_t tlb; /* TLB is optional. Allocate them only if needed */
|
2007-10-07 19:43:50 +04:00
|
|
|
/* 403 dedicated access protection registers */
|
|
|
|
target_ulong pb[4];
|
2011-08-31 15:26:56 +04:00
|
|
|
bool tlb_dirty; /* Set to non-zero when modifying TLB */
|
|
|
|
bool kvm_sw_tlb; /* non-zero if KVM SW TLB API is active */
|
2016-06-07 05:50:22 +03:00
|
|
|
uint32_t tlb_need_flush; /* Delayed flush needed */
|
2016-09-20 19:34:59 +03:00
|
|
|
#define TLB_NEED_LOCAL_FLUSH 0x1
|
2016-09-20 19:35:01 +03:00
|
|
|
#define TLB_NEED_GLOBAL_FLUSH 0x2
|
2007-10-07 19:43:50 +04:00
|
|
|
#endif
|
2004-05-21 16:59:32 +04:00
|
|
|
|
2005-07-03 00:59:34 +04:00
|
|
|
/* Other registers */
|
|
|
|
/* Special purpose registers */
|
|
|
|
target_ulong spr[1024];
|
2009-10-02 01:12:16 +04:00
|
|
|
ppc_spr_t spr_cb[1024];
|
2019-02-15 13:00:56 +03:00
|
|
|
/* Vector status and control register, minus VSCR_SAT. */
|
2005-07-03 00:59:34 +04:00
|
|
|
uint32_t vscr;
|
2019-01-02 12:14:22 +03:00
|
|
|
/* VSX registers (including FP and AVR) */
|
|
|
|
ppc_vsr_t vsr[64] QEMU_ALIGNED(16);
|
2019-02-15 13:00:56 +03:00
|
|
|
/* Non-zero if and only if VSCR_SAT should be set. */
|
|
|
|
ppc_vsr_t vscr_sat QEMU_ALIGNED(16);
|
2007-03-17 17:02:15 +03:00
|
|
|
/* SPE registers */
|
2008-12-19 01:43:25 +03:00
|
|
|
uint64_t spe_acc;
|
2007-03-17 17:02:15 +03:00
|
|
|
uint32_t spe_fscr;
|
2019-03-21 08:29:36 +03:00
|
|
|
/*
|
|
|
|
* SPE and Altivec can share a status since they will never be
|
|
|
|
* used simultaneously
|
|
|
|
*/
|
2009-02-03 22:55:51 +03:00
|
|
|
float_status vec_status;
|
2005-07-03 00:59:34 +04:00
|
|
|
|
|
|
|
/* Internal devices resources */
|
2004-05-21 16:59:32 +04:00
|
|
|
/* Time base and decrementer */
|
2009-10-02 01:12:16 +04:00
|
|
|
ppc_tb_t *tb_env;
|
2005-07-03 00:59:34 +04:00
|
|
|
/* Device control registers */
|
2009-10-02 01:12:16 +04:00
|
|
|
ppc_dcr_t *dcr_env;
|
2005-07-03 00:59:34 +04:00
|
|
|
|
2007-10-04 04:51:58 +04:00
|
|
|
int dcache_line_size;
|
|
|
|
int icache_line_size;
|
|
|
|
|
2005-07-03 00:59:34 +04:00
|
|
|
/* Those resources are used during exception processing */
|
|
|
|
/* CPU model definition */
|
Great rework and cleanups to ease PowerPC implementations definitions.
* cleanup cpu.h, removing definitions used only in translate.c/translate_init.c
* add new flags to define instructions sets more precisely
* various changes in MMU models definitions
* add definitions for PowerPC 440/460 support (insns and SPRs).
* add definitions for PowerPC 401/403 and 620 input pins model
* Fix definitions for most PowerPC 401, 403, 405, 440, 601, 602, 603 and 7x0
* Preliminary support for PowerPC 74xx (aka G4) without altivec.
* Code provision for other PowerPC support (7x5, 970, ...).
* New SPR and PVR defined, from PowerPC 2.04 specification and other sources
* Misc code bugs, error messages and styles fixes.
* Update status files for PowerPC cores support.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@3244 c046a42c-6fe2-441c-8c8c-71466251a162
2007-09-27 03:54:22 +04:00
|
|
|
target_ulong msr_mask;
|
2009-10-02 01:12:16 +04:00
|
|
|
powerpc_mmu_t mmu_model;
|
|
|
|
powerpc_excp_t excp_model;
|
|
|
|
powerpc_input_t bus_model;
|
2007-09-29 16:01:46 +04:00
|
|
|
int bfd_mach;
|
2005-07-03 00:59:34 +04:00
|
|
|
uint32_t flags;
|
2009-05-12 23:26:57 +04:00
|
|
|
uint64_t insns_flags;
|
2011-05-01 02:00:58 +04:00
|
|
|
uint64_t insns_flags2;
|
ppc64: Rudimentary Support for extra page sizes on server CPUs
More recent Power server chips (i.e. based on the 64 bit hash MMU)
support more than just the traditional 4k and 16M page sizes. This
can get quite complicated, because which page sizes are supported,
which combinations are supported within an MMU segment and how these
page sizes are encoded both in the SLB entry and the hash PTE can vary
depending on the CPU model (they are not specified by the
architecture). In addition the firmware or hypervisor may not permit
use of certain page sizes, for various reasons. Whether various page
sizes are supported on KVM, for example, depends on whether the PR or
HV variant of KVM is in use, and on the page size of the memory
backing the guest's RAM.
This patch adds information to the CPUState and cpu defs to describe
the supported page sizes and encodings. Since TCG does not yet
support any extended page sizes, we just set this to NULL in the
static CPU definitions, expanding this to the default 4k and 16M page
sizes when we initialize the cpu state. When using KVM, however, we
instead determine available page sizes using the new
KVM_PPC_GET_SMMU_INFO call. For old kernels without that call, we use
some defaults, with some guesswork which should do the right thing for
existing HV and PR implementations. The fallback might not be correct
for future versions, but that's ok, because they'll have
KVM_PPC_GET_SMMU_INFO.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Alexander Graf <agraf@suse.de>
2012-06-18 23:56:25 +04:00
|
|
|
#if defined(TARGET_PPC64)
|
2016-07-05 00:37:08 +03:00
|
|
|
ppc_slb_t vrma_slb;
|
|
|
|
target_ulong rmls;
|
ppc64: Rudimentary Support for extra page sizes on server CPUs
More recent Power server chips (i.e. based on the 64 bit hash MMU)
support more than just the traditional 4k and 16M page sizes. This
can get quite complicated, because which page sizes are supported,
which combinations are supported within an MMU segment and how these
page sizes are encoded both in the SLB entry and the hash PTE can vary
depending on the CPU model (they are not specified by the
architecture). In addition the firmware or hypervisor may not permit
use of certain page sizes, for various reasons. Whether various page
sizes are supported on KVM, for example, depends on whether the PR or
HV variant of KVM is in use, and on the page size of the memory
backing the guest's RAM.
This patch adds information to the CPUState and cpu defs to describe
the supported page sizes and encodings. Since TCG does not yet
support any extended page sizes, we just set this to NULL in the
static CPU definitions, expanding this to the default 4k and 16M page
sizes when we initialize the cpu state. When using KVM, however, we
instead determine available page sizes using the new
KVM_PPC_GET_SMMU_INFO call. For old kernels without that call, we use
some defaults, with some guesswork which should do the right thing for
existing HV and PR implementations. The fallback might not be correct
for future versions, but that's ok, because they'll have
KVM_PPC_GET_SMMU_INFO.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Alexander Graf <agraf@suse.de>
2012-06-18 23:56:25 +04:00
|
|
|
#endif
|
2005-07-03 00:59:34 +04:00
|
|
|
|
|
|
|
int error_code;
|
2007-03-30 13:38:04 +04:00
|
|
|
uint32_t pending_interrupts;
|
2007-04-10 02:45:36 +04:00
|
|
|
#if !defined(CONFIG_USER_ONLY)
|
2019-03-21 08:29:36 +03:00
|
|
|
/*
|
|
|
|
* This is the IRQ controller, which is implementation dependent
|
2007-04-10 02:45:36 +04:00
|
|
|
* and only relevant when emulating a complete machine.
|
|
|
|
*/
|
|
|
|
uint32_t irq_input_state;
|
|
|
|
void **irq_inputs;
|
2007-09-29 17:06:16 +04:00
|
|
|
/* Exception vectors */
|
|
|
|
target_ulong excp_vectors[POWERPC_EXCP_NB];
|
|
|
|
target_ulong excp_prefix;
|
|
|
|
target_ulong ivor_mask;
|
|
|
|
target_ulong ivpr_mask;
|
2007-10-04 04:51:58 +04:00
|
|
|
target_ulong hreset_vector;
|
2013-01-04 14:21:04 +04:00
|
|
|
hwaddr mpic_iack;
|
|
|
|
/* true when the external proxy facility mode is enabled */
|
|
|
|
bool mpic_proxy;
|
2019-03-21 08:29:36 +03:00
|
|
|
/*
|
|
|
|
* set when the processor has an HV mode, thus HV priv
|
2016-06-03 15:11:19 +03:00
|
|
|
* instructions and SPRs are diallowed if MSR:HV is 0
|
|
|
|
*/
|
|
|
|
bool has_hv_mode;
|
2019-02-15 19:16:41 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
* On P7/P8/P9, set when in PM state, we need to handle resume in
|
2019-02-15 19:16:43 +03:00
|
|
|
* a special way (such as routing some resume causes to 0x100, ie,
|
|
|
|
* sreset), so flag this here.
|
2016-06-22 00:48:55 +03:00
|
|
|
*/
|
2019-02-15 19:16:43 +03:00
|
|
|
bool resume_as_sreset;
|
2007-04-10 02:45:36 +04:00
|
|
|
#endif
|
2005-07-03 00:59:34 +04:00
|
|
|
|
|
|
|
/* Those resources are used only during code translation */
|
|
|
|
/* opcode handlers */
|
2013-06-10 00:11:49 +04:00
|
|
|
opc_handler_t *opcodes[PPC_CPU_OPCODES_LEN];
|
2005-07-03 00:59:34 +04:00
|
|
|
|
2012-04-07 11:23:39 +04:00
|
|
|
/* Those resources are used only in QEMU core */
|
2007-11-04 05:55:33 +03:00
|
|
|
target_ulong hflags; /* hflags is a MSR & HFLAGS_MASK */
|
2011-11-22 14:06:21 +04:00
|
|
|
target_ulong hflags_nmsr; /* specific hflags, not coming from MSR */
|
2016-05-03 19:03:24 +03:00
|
|
|
int immu_idx; /* precomputed MMU index to speed up insn access */
|
|
|
|
int dmmu_idx; /* precomputed MMU index to speed up data accesses */
|
2005-07-03 00:59:34 +04:00
|
|
|
|
2004-05-21 16:59:32 +04:00
|
|
|
/* Power management */
|
2007-10-26 03:27:04 +04:00
|
|
|
int (*check_pow)(CPUPPCState *env);
|
2004-04-13 00:39:29 +04:00
|
|
|
|
2010-09-29 17:31:44 +04:00
|
|
|
#if !defined(CONFIG_USER_ONLY)
|
|
|
|
void *load_info; /* Holds boot loading state. */
|
|
|
|
#endif
|
2011-09-13 08:00:32 +04:00
|
|
|
|
|
|
|
/* booke timers */
|
|
|
|
|
2019-03-21 08:29:36 +03:00
|
|
|
/*
|
|
|
|
* Specifies bit locations of the Time Base used to signal a fixed
|
|
|
|
* timer exception on a transition from 0 to 1. (watchdog or
|
|
|
|
* fixed-interval timer)
|
2011-09-13 08:00:32 +04:00
|
|
|
*
|
|
|
|
* 0 selects the least significant bit.
|
|
|
|
* 63 selects the most significant bit.
|
|
|
|
*/
|
|
|
|
uint8_t fit_period[4];
|
|
|
|
uint8_t wdt_period[4];
|
2014-06-04 16:51:00 +04:00
|
|
|
|
|
|
|
/* Transactional memory state */
|
|
|
|
target_ulong tm_gpr[32];
|
|
|
|
ppc_avr_t tm_vsr[64];
|
|
|
|
uint64_t tm_cr;
|
|
|
|
uint64_t tm_lr;
|
|
|
|
uint64_t tm_ctr;
|
|
|
|
uint64_t tm_fpscr;
|
|
|
|
uint64_t tm_amr;
|
|
|
|
uint64_t tm_ppr;
|
|
|
|
uint64_t tm_vrsave;
|
|
|
|
uint32_t tm_vscr;
|
|
|
|
uint64_t tm_dscr;
|
|
|
|
uint64_t tm_tar;
|
2005-07-03 00:59:34 +04:00
|
|
|
};
|
2003-11-23 17:55:54 +03:00
|
|
|
|
2011-09-13 08:00:32 +04:00
|
|
|
#define SET_FIT_PERIOD(a_, b_, c_, d_) \
|
|
|
|
do { \
|
|
|
|
env->fit_period[0] = (a_); \
|
|
|
|
env->fit_period[1] = (b_); \
|
|
|
|
env->fit_period[2] = (c_); \
|
|
|
|
env->fit_period[3] = (d_); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define SET_WDT_PERIOD(a_, b_, c_, d_) \
|
|
|
|
do { \
|
|
|
|
env->wdt_period[0] = (a_); \
|
|
|
|
env->wdt_period[1] = (b_); \
|
|
|
|
env->wdt_period[2] = (c_); \
|
|
|
|
env->wdt_period[3] = (d_); \
|
|
|
|
} while (0)
|
|
|
|
|
2016-10-28 14:06:21 +03:00
|
|
|
typedef struct PPCVirtualHypervisor PPCVirtualHypervisor;
|
|
|
|
typedef struct PPCVirtualHypervisorClass PPCVirtualHypervisorClass;
|
2019-01-10 10:09:13 +03:00
|
|
|
|
2016-03-15 15:49:25 +03:00
|
|
|
/**
|
|
|
|
* PowerPCCPU:
|
|
|
|
* @env: #CPUPPCState
|
2017-08-03 09:28:44 +03:00
|
|
|
* @vcpu_id: vCPU identifier given to KVM
|
2016-10-28 14:09:37 +03:00
|
|
|
* @compat_pvr: Current logical PVR, zero if in "raw" mode
|
2016-03-15 15:49:25 +03:00
|
|
|
*
|
|
|
|
* A PowerPC CPU.
|
|
|
|
*/
|
|
|
|
struct PowerPCCPU {
|
|
|
|
/*< private >*/
|
|
|
|
CPUState parent_obj;
|
|
|
|
/*< public >*/
|
|
|
|
|
2019-03-23 03:16:06 +03:00
|
|
|
CPUNegativeOffsetState neg;
|
2016-03-15 15:49:25 +03:00
|
|
|
CPUPPCState env;
|
2019-03-23 03:16:06 +03:00
|
|
|
|
2017-08-03 09:28:44 +03:00
|
|
|
int vcpu_id;
|
2016-10-28 14:09:37 +03:00
|
|
|
uint32_t compat_pvr;
|
2016-10-28 14:06:21 +03:00
|
|
|
PPCVirtualHypervisor *vhyp;
|
2018-06-13 09:22:18 +03:00
|
|
|
void *machine_data;
|
2017-05-30 19:24:00 +03:00
|
|
|
int32_t node_id; /* NUMA node this CPU belongs to */
|
2018-03-23 05:31:52 +03:00
|
|
|
PPCHash64Options *hash64_opts;
|
2016-11-21 08:28:12 +03:00
|
|
|
|
2016-11-21 08:29:30 +03:00
|
|
|
/* Fields related to migration compatibility hacks */
|
|
|
|
bool pre_2_8_migration;
|
2016-11-21 08:28:12 +03:00
|
|
|
target_ulong mig_msr_mask;
|
|
|
|
uint64_t mig_insns_flags;
|
|
|
|
uint64_t mig_insns_flags2;
|
|
|
|
uint32_t mig_nb_BATs;
|
ppc: Rework CPU compatibility testing across migration
Migrating between different CPU versions is a bit complicated for ppc.
A long time ago, we ensured identical CPU versions at either end by
checking the PVR had the same value. However, this breaks under KVM
HV, because we always have to use the host's PVR - it's not
virtualized. That would mean we couldn't migrate between hosts with
different PVRs, even if the CPUs are close enough to compatible in
practice (sometimes identical cores with different surrounding logic
have different PVRs, so this happens in practice quite often).
So, we removed the PVR check, but instead checked that several flags
indicating supported instructions matched. This turns out to be a bad
idea, because those instruction masks are not architected information, but
essentially a TCG implementation detail. So changes to qemu internal CPU
modelling can break migration - this happened between qemu-2.6 and
qemu-2.7. That was addressed by 146c11f1 "target-ppc: Allow eventual
removal of old migration mistakes".
Now, verification of CPU compatibility across a migration basically doesn't
happen. We simply ignore the PVR of the incoming migration, and hope the
cpu on the destination is close enough to work.
Now that we've cleaned up handling of processor compatibility modes
for pseries machine type, we can do better. For new machine types
(pseries-2.10+) We allow migration if:
* The source and destination PVRs are for the same type of CPU, as
determined by CPU class's pvr_match function
OR * When the source was in a compatibility mode, and the destination CPU
supports the same compatibility mode
For older machine types we retain the existing behaviour - current CAS
code will usually set a compat mode which would break backwards
migration if we made them use the new behaviour. [Fixed from an
earlier version by Greg Kurz].
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Greg Kurz <groug@kaod.org>
Reviewed-by: Suraj Jitindar Singh <sjitindarsingh@gmail.com>
Tested-by: Andrea Bolognani <abologna@redhat.com>
2017-06-02 05:26:11 +03:00
|
|
|
bool pre_2_10_migration;
|
2018-05-22 13:39:59 +03:00
|
|
|
bool pre_3_0_migration;
|
2018-03-29 10:29:38 +03:00
|
|
|
int32_t mig_slb_nr;
|
2016-03-15 15:49:25 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
PowerPCCPUClass *ppc_cpu_class_by_pvr(uint32_t pvr);
|
|
|
|
PowerPCCPUClass *ppc_cpu_class_by_pvr_mask(uint32_t pvr);
|
2017-05-10 07:19:32 +03:00
|
|
|
PowerPCCPUClass *ppc_cpu_get_family_class(PowerPCCPUClass *pcc);
|
2016-03-15 15:49:25 +03:00
|
|
|
|
2016-10-28 14:06:21 +03:00
|
|
|
struct PPCVirtualHypervisor {
|
|
|
|
Object parent;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct PPCVirtualHypervisorClass {
|
|
|
|
InterfaceClass parent;
|
|
|
|
void (*hypercall)(PPCVirtualHypervisor *vhyp, PowerPCCPU *cpu);
|
2017-02-23 03:39:18 +03:00
|
|
|
hwaddr (*hpt_mask)(PPCVirtualHypervisor *vhyp);
|
|
|
|
const ppc_hash_pte64_t *(*map_hptes)(PPCVirtualHypervisor *vhyp,
|
|
|
|
hwaddr ptex, int n);
|
|
|
|
void (*unmap_hptes)(PPCVirtualHypervisor *vhyp,
|
|
|
|
const ppc_hash_pte64_t *hptes,
|
|
|
|
hwaddr ptex, int n);
|
2019-04-11 11:00:01 +03:00
|
|
|
void (*hpte_set_c)(PPCVirtualHypervisor *vhyp, hwaddr ptex, uint64_t pte1);
|
|
|
|
void (*hpte_set_r)(PPCVirtualHypervisor *vhyp, hwaddr ptex, uint64_t pte1);
|
2019-02-15 20:00:27 +03:00
|
|
|
void (*get_pate)(PPCVirtualHypervisor *vhyp, ppc_v3_pate_t *entry);
|
2017-09-25 14:00:02 +03:00
|
|
|
target_ulong (*encode_hpt_for_kvm_pr)(PPCVirtualHypervisor *vhyp);
|
2016-10-28 14:06:21 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
#define TYPE_PPC_VIRTUAL_HYPERVISOR "ppc-virtual-hypervisor"
|
|
|
|
#define PPC_VIRTUAL_HYPERVISOR(obj) \
|
|
|
|
OBJECT_CHECK(PPCVirtualHypervisor, (obj), TYPE_PPC_VIRTUAL_HYPERVISOR)
|
|
|
|
#define PPC_VIRTUAL_HYPERVISOR_CLASS(klass) \
|
|
|
|
OBJECT_CLASS_CHECK(PPCVirtualHypervisorClass, (klass), \
|
|
|
|
TYPE_PPC_VIRTUAL_HYPERVISOR)
|
|
|
|
#define PPC_VIRTUAL_HYPERVISOR_GET_CLASS(obj) \
|
|
|
|
OBJECT_GET_CLASS(PPCVirtualHypervisorClass, (obj), \
|
|
|
|
TYPE_PPC_VIRTUAL_HYPERVISOR)
|
|
|
|
|
2016-03-15 15:49:25 +03:00
|
|
|
void ppc_cpu_do_interrupt(CPUState *cpu);
|
|
|
|
bool ppc_cpu_exec_interrupt(CPUState *cpu, int int_req);
|
2019-04-17 22:18:02 +03:00
|
|
|
void ppc_cpu_dump_state(CPUState *cpu, FILE *f, int flags);
|
2019-04-17 22:18:00 +03:00
|
|
|
void ppc_cpu_dump_statistics(CPUState *cpu, int flags);
|
2016-03-15 15:49:25 +03:00
|
|
|
hwaddr ppc_cpu_get_phys_page_debug(CPUState *cpu, vaddr addr);
|
|
|
|
int ppc_cpu_gdb_read_register(CPUState *cpu, uint8_t *buf, int reg);
|
|
|
|
int ppc_cpu_gdb_read_register_apple(CPUState *cpu, uint8_t *buf, int reg);
|
|
|
|
int ppc_cpu_gdb_write_register(CPUState *cpu, uint8_t *buf, int reg);
|
|
|
|
int ppc_cpu_gdb_write_register_apple(CPUState *cpu, uint8_t *buf, int reg);
|
2019-02-06 19:51:33 +03:00
|
|
|
#ifndef CONFIG_USER_ONLY
|
|
|
|
void ppc_gdb_gen_spr_xml(PowerPCCPU *cpu);
|
|
|
|
const char *ppc_gdb_get_dynamic_xml(CPUState *cs, const char *xml_name);
|
|
|
|
#endif
|
2016-03-15 15:49:25 +03:00
|
|
|
int ppc64_cpu_write_elf64_note(WriteCoreDumpFunction f, CPUState *cs,
|
|
|
|
int cpuid, void *opaque);
|
2017-02-28 16:32:17 +03:00
|
|
|
int ppc32_cpu_write_elf32_note(WriteCoreDumpFunction f, CPUState *cs,
|
|
|
|
int cpuid, void *opaque);
|
2016-03-15 15:49:25 +03:00
|
|
|
#ifndef CONFIG_USER_ONLY
|
|
|
|
void ppc_cpu_do_system_reset(CPUState *cs);
|
2019-08-12 08:23:44 +03:00
|
|
|
extern const VMStateDescription vmstate_ppc_cpu;
|
2016-03-15 15:49:25 +03:00
|
|
|
#endif
|
2012-04-06 16:39:03 +04:00
|
|
|
|
2005-07-03 00:59:34 +04:00
|
|
|
/*****************************************************************************/
|
2008-06-29 05:03:05 +04:00
|
|
|
void ppc_translate_init(void);
|
2019-03-21 08:29:36 +03:00
|
|
|
/*
|
|
|
|
* you can call this signal handler from your SIGBUS and SIGSEGV
|
|
|
|
* signal handlers to inform the virtual CPU of exceptions. non zero
|
|
|
|
* is returned if the signal was handled by the virtual CPU.
|
|
|
|
*/
|
|
|
|
int cpu_ppc_signal_handler(int host_signum, void *pinfo, void *puc);
|
2019-04-02 13:03:41 +03:00
|
|
|
bool ppc_cpu_tlb_fill(CPUState *cs, vaddr address, int size,
|
|
|
|
MMUAccessType access_type, int mmu_idx,
|
|
|
|
bool probe, uintptr_t retaddr);
|
2004-04-13 00:39:29 +04:00
|
|
|
|
2007-03-07 11:32:30 +03:00
|
|
|
#if !defined(CONFIG_USER_ONLY)
|
2019-03-21 08:29:36 +03:00
|
|
|
void ppc_store_sdr1(CPUPPCState *env, target_ulong value);
|
2018-04-24 14:30:42 +03:00
|
|
|
void ppc_store_ptcr(CPUPPCState *env, target_ulong value);
|
2007-10-06 02:06:02 +04:00
|
|
|
#endif /* !defined(CONFIG_USER_ONLY) */
|
2019-03-21 08:29:36 +03:00
|
|
|
void ppc_store_msr(CPUPPCState *env, target_ulong value);
|
2005-07-03 00:59:34 +04:00
|
|
|
|
2019-04-17 22:17:57 +03:00
|
|
|
void ppc_cpu_list(void);
|
2007-11-10 18:15:54 +03:00
|
|
|
|
2004-05-21 16:59:32 +04:00
|
|
|
/* Time-base and decrementer management */
|
|
|
|
#ifndef NO_CPU_IO_DEFS
|
2019-03-21 08:29:36 +03:00
|
|
|
uint64_t cpu_ppc_load_tbl(CPUPPCState *env);
|
|
|
|
uint32_t cpu_ppc_load_tbu(CPUPPCState *env);
|
|
|
|
void cpu_ppc_store_tbu(CPUPPCState *env, uint32_t value);
|
|
|
|
void cpu_ppc_store_tbl(CPUPPCState *env, uint32_t value);
|
|
|
|
uint64_t cpu_ppc_load_atbl(CPUPPCState *env);
|
|
|
|
uint32_t cpu_ppc_load_atbu(CPUPPCState *env);
|
|
|
|
void cpu_ppc_store_atbl(CPUPPCState *env, uint32_t value);
|
|
|
|
void cpu_ppc_store_atbu(CPUPPCState *env, uint32_t value);
|
2014-04-06 03:32:06 +04:00
|
|
|
bool ppc_decr_clear_on_delivery(CPUPPCState *env);
|
2019-03-01 05:43:15 +03:00
|
|
|
target_ulong cpu_ppc_load_decr(CPUPPCState *env);
|
|
|
|
void cpu_ppc_store_decr(CPUPPCState *env, target_ulong value);
|
|
|
|
target_ulong cpu_ppc_load_hdecr(CPUPPCState *env);
|
|
|
|
void cpu_ppc_store_hdecr(CPUPPCState *env, target_ulong value);
|
2019-03-21 08:29:36 +03:00
|
|
|
uint64_t cpu_ppc_load_purr(CPUPPCState *env);
|
|
|
|
uint32_t cpu_ppc601_load_rtcl(CPUPPCState *env);
|
|
|
|
uint32_t cpu_ppc601_load_rtcu(CPUPPCState *env);
|
2007-03-17 17:02:15 +03:00
|
|
|
#if !defined(CONFIG_USER_ONLY)
|
2019-03-21 08:29:36 +03:00
|
|
|
void cpu_ppc601_store_rtcl(CPUPPCState *env, uint32_t value);
|
|
|
|
void cpu_ppc601_store_rtcu(CPUPPCState *env, uint32_t value);
|
|
|
|
target_ulong load_40x_pit(CPUPPCState *env);
|
|
|
|
void store_40x_pit(CPUPPCState *env, target_ulong val);
|
|
|
|
void store_40x_dbcr0(CPUPPCState *env, uint32_t val);
|
|
|
|
void store_40x_sler(CPUPPCState *env, uint32_t val);
|
|
|
|
void store_booke_tcr(CPUPPCState *env, target_ulong val);
|
|
|
|
void store_booke_tsr(CPUPPCState *env, target_ulong val);
|
|
|
|
void ppc_tlb_invalidate_all(CPUPPCState *env);
|
|
|
|
void ppc_tlb_invalidate_one(CPUPPCState *env, target_ulong addr);
|
2018-04-05 09:02:51 +03:00
|
|
|
void cpu_ppc_set_vhyp(PowerPCCPU *cpu, PPCVirtualHypervisor *vhyp);
|
2007-03-17 17:02:15 +03:00
|
|
|
#endif
|
2004-05-21 16:59:32 +04:00
|
|
|
#endif
|
2003-11-23 17:55:54 +03:00
|
|
|
|
2013-03-19 11:41:53 +04:00
|
|
|
void store_fpscr(CPUPPCState *env, uint64_t arg, uint32_t mask);
|
|
|
|
|
2009-08-16 13:06:54 +04:00
|
|
|
static inline uint64_t ppc_dump_gpr(CPUPPCState *env, int gprn)
|
2007-11-24 05:03:55 +03:00
|
|
|
{
|
|
|
|
uint64_t gprv;
|
|
|
|
|
|
|
|
gprv = env->gpr[gprn];
|
|
|
|
if (env->flags & POWERPC_FLAG_SPE) {
|
2019-03-21 08:29:36 +03:00
|
|
|
/*
|
|
|
|
* If the CPU implements the SPE extension, we have to get the
|
2007-11-24 05:03:55 +03:00
|
|
|
* high bits of the GPR from the gprh storage area
|
|
|
|
*/
|
|
|
|
gprv &= 0xFFFFFFFFULL;
|
|
|
|
gprv |= (uint64_t)env->gprh[gprn] << 32;
|
|
|
|
}
|
|
|
|
|
|
|
|
return gprv;
|
|
|
|
}
|
|
|
|
|
2007-04-13 01:11:03 +04:00
|
|
|
/* Device control registers */
|
2019-03-21 08:29:36 +03:00
|
|
|
int ppc_dcr_read(ppc_dcr_t *dcr_env, int dcrn, uint32_t *valp);
|
|
|
|
int ppc_dcr_write(ppc_dcr_t *dcr_env, int dcrn, uint32_t val);
|
2007-04-13 01:11:03 +04:00
|
|
|
|
2017-08-30 16:24:29 +03:00
|
|
|
#define POWERPC_CPU_TYPE_SUFFIX "-" TYPE_POWERPC_CPU
|
|
|
|
#define POWERPC_CPU_TYPE_NAME(model) model POWERPC_CPU_TYPE_SUFFIX
|
2018-02-07 13:40:25 +03:00
|
|
|
#define CPU_RESOLVING_TYPE TYPE_POWERPC_CPU
|
2017-08-30 16:24:29 +03:00
|
|
|
|
2007-06-04 01:02:38 +04:00
|
|
|
#define cpu_signal_handler cpu_ppc_signal_handler
|
2007-10-12 10:47:46 +04:00
|
|
|
#define cpu_list ppc_cpu_list
|
2007-06-04 01:02:38 +04:00
|
|
|
|
2007-10-14 11:07:08 +04:00
|
|
|
/* MMU modes definitions */
|
|
|
|
#define MMU_USER_IDX 0
|
2019-03-21 08:29:36 +03:00
|
|
|
static inline int cpu_mmu_index(CPUPPCState *env, bool ifetch)
|
2007-10-14 11:07:08 +04:00
|
|
|
{
|
2016-05-03 19:03:24 +03:00
|
|
|
return ifetch ? env->immu_idx : env->dmmu_idx;
|
2007-10-14 11:07:08 +04:00
|
|
|
}
|
|
|
|
|
2017-01-04 08:19:50 +03:00
|
|
|
/* Compatibility modes */
|
|
|
|
#if defined(TARGET_PPC64)
|
2016-10-28 14:51:46 +03:00
|
|
|
bool ppc_check_compat(PowerPCCPU *cpu, uint32_t compat_pvr,
|
|
|
|
uint32_t min_compat_pvr, uint32_t max_compat_pvr);
|
2018-06-14 09:33:58 +03:00
|
|
|
bool ppc_type_check_compat(const char *cputype, uint32_t compat_pvr,
|
|
|
|
uint32_t min_compat_pvr, uint32_t max_compat_pvr);
|
|
|
|
|
2017-01-04 08:19:50 +03:00
|
|
|
void ppc_set_compat(PowerPCCPU *cpu, uint32_t compat_pvr, Error **errp);
|
2018-06-14 09:33:58 +03:00
|
|
|
|
2016-11-10 06:37:38 +03:00
|
|
|
#if !defined(CONFIG_USER_ONLY)
|
|
|
|
void ppc_set_compat_all(uint32_t compat_pvr, Error **errp);
|
|
|
|
#endif
|
2018-01-15 08:40:23 +03:00
|
|
|
int ppc_compat_max_vthreads(PowerPCCPU *cpu);
|
2017-06-11 15:33:59 +03:00
|
|
|
void ppc_compat_add_property(Object *obj, const char *name,
|
|
|
|
uint32_t *compat_pvr, const char *basedesc,
|
|
|
|
Error **errp);
|
2017-01-04 08:19:50 +03:00
|
|
|
#endif /* defined(TARGET_PPC64) */
|
|
|
|
|
2019-03-23 01:32:23 +03:00
|
|
|
typedef CPUPPCState CPUArchState;
|
2019-03-23 01:56:19 +03:00
|
|
|
typedef PowerPCCPU ArchCPU;
|
2019-03-23 01:32:23 +03:00
|
|
|
|
2012-12-17 21:19:49 +04:00
|
|
|
#include "exec/cpu-all.h"
|
2003-11-23 17:55:54 +03:00
|
|
|
|
2005-07-03 00:59:34 +04:00
|
|
|
/*****************************************************************************/
|
2008-10-21 15:31:14 +04:00
|
|
|
/* CRF definitions */
|
2016-11-23 14:37:11 +03:00
|
|
|
#define CRF_LT_BIT 3
|
|
|
|
#define CRF_GT_BIT 2
|
|
|
|
#define CRF_EQ_BIT 1
|
|
|
|
#define CRF_SO_BIT 0
|
|
|
|
#define CRF_LT (1 << CRF_LT_BIT)
|
|
|
|
#define CRF_GT (1 << CRF_GT_BIT)
|
|
|
|
#define CRF_EQ (1 << CRF_EQ_BIT)
|
|
|
|
#define CRF_SO (1 << CRF_SO_BIT)
|
|
|
|
/* For SPE extensions */
|
|
|
|
#define CRF_CH (1 << CRF_LT_BIT)
|
|
|
|
#define CRF_CL (1 << CRF_GT_BIT)
|
|
|
|
#define CRF_CH_OR_CL (1 << CRF_EQ_BIT)
|
|
|
|
#define CRF_CH_AND_CL (1 << CRF_SO_BIT)
|
2008-10-21 15:31:14 +04:00
|
|
|
|
|
|
|
/* XER definitions */
|
2008-10-21 15:28:46 +04:00
|
|
|
#define XER_SO 31
|
|
|
|
#define XER_OV 30
|
|
|
|
#define XER_CA 29
|
target/ppc: support for 32-bit carry and overflow
POWER ISA 3.0 adds CA32 and OV32 status in 64-bit mode. Add the flags
and corresponding defines.
Moreover, CA32 is updated when CA is updated and OV32 is updated when OV
is updated.
Arithmetic instructions:
* Addition and Substractions:
addic, addic., subfic, addc, subfc, adde, subfe, addme, subfme,
addze, and subfze always updates CA and CA32.
=> CA reflects the carry out of bit 0 in 64-bit mode and out of
bit 32 in 32-bit mode.
=> CA32 reflects the carry out of bit 32 independent of the
mode.
=> SO and OV reflects overflow of the 64-bit result in 64-bit
mode and overflow of the low-order 32-bit result in 32-bit
mode
=> OV32 reflects overflow of the low-order 32-bit independent of
the mode
* Multiply Low and Divide:
For mulld, divd, divde, divdu and divdeu: SO, OV, and OV32 bits
reflects overflow of the 64-bit result
For mullw, divw, divwe, divwu and divweu: SO, OV, and OV32 bits
reflects overflow of the 32-bit result
* Negate with OE=1 (nego)
For 64-bit mode if the register RA contains
0x8000_0000_0000_0000, OV and OV32 are set to 1.
For 32-bit mode if the register RA contains 0x8000_0000, OV and
OV32 are set to 1.
Signed-off-by: Nikunj A Dadhania <nikunj@linux.vnet.ibm.com>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
2017-02-27 07:57:54 +03:00
|
|
|
#define XER_OV32 19
|
|
|
|
#define XER_CA32 18
|
2008-10-21 15:28:46 +04:00
|
|
|
#define XER_CMP 8
|
|
|
|
#define XER_BC 0
|
2013-02-20 11:52:13 +04:00
|
|
|
#define xer_so (env->so)
|
|
|
|
#define xer_ov (env->ov)
|
|
|
|
#define xer_ca (env->ca)
|
target/ppc: support for 32-bit carry and overflow
POWER ISA 3.0 adds CA32 and OV32 status in 64-bit mode. Add the flags
and corresponding defines.
Moreover, CA32 is updated when CA is updated and OV32 is updated when OV
is updated.
Arithmetic instructions:
* Addition and Substractions:
addic, addic., subfic, addc, subfc, adde, subfe, addme, subfme,
addze, and subfze always updates CA and CA32.
=> CA reflects the carry out of bit 0 in 64-bit mode and out of
bit 32 in 32-bit mode.
=> CA32 reflects the carry out of bit 32 independent of the
mode.
=> SO and OV reflects overflow of the 64-bit result in 64-bit
mode and overflow of the low-order 32-bit result in 32-bit
mode
=> OV32 reflects overflow of the low-order 32-bit independent of
the mode
* Multiply Low and Divide:
For mulld, divd, divde, divdu and divdeu: SO, OV, and OV32 bits
reflects overflow of the 64-bit result
For mullw, divw, divwe, divwu and divweu: SO, OV, and OV32 bits
reflects overflow of the 32-bit result
* Negate with OE=1 (nego)
For 64-bit mode if the register RA contains
0x8000_0000_0000_0000, OV and OV32 are set to 1.
For 32-bit mode if the register RA contains 0x8000_0000, OV and
OV32 are set to 1.
Signed-off-by: Nikunj A Dadhania <nikunj@linux.vnet.ibm.com>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
2017-02-27 07:57:54 +03:00
|
|
|
#define xer_ov32 (env->ov)
|
|
|
|
#define xer_ca32 (env->ca)
|
2008-10-21 15:28:46 +04:00
|
|
|
#define xer_cmp ((env->xer >> XER_CMP) & 0xFF)
|
|
|
|
#define xer_bc ((env->xer >> XER_BC) & 0x7F)
|
2003-11-23 17:55:54 +03:00
|
|
|
|
2005-07-03 00:59:34 +04:00
|
|
|
/* SPR definitions */
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_MQ (0x000)
|
|
|
|
#define SPR_XER (0x001)
|
|
|
|
#define SPR_601_VRTCU (0x004)
|
|
|
|
#define SPR_601_VRTCL (0x005)
|
|
|
|
#define SPR_601_UDECR (0x006)
|
|
|
|
#define SPR_LR (0x008)
|
|
|
|
#define SPR_CTR (0x009)
|
2017-03-08 22:58:43 +03:00
|
|
|
#define SPR_UAMR (0x00D)
|
2011-08-31 19:45:10 +04:00
|
|
|
#define SPR_DSCR (0x011)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_DSISR (0x012)
|
|
|
|
#define SPR_DAR (0x013) /* DAE for PowerPC 601 */
|
|
|
|
#define SPR_601_RTCU (0x014)
|
|
|
|
#define SPR_601_RTCL (0x015)
|
|
|
|
#define SPR_DECR (0x016)
|
|
|
|
#define SPR_SDR1 (0x019)
|
|
|
|
#define SPR_SRR0 (0x01A)
|
|
|
|
#define SPR_SRR1 (0x01B)
|
2011-08-31 19:45:10 +04:00
|
|
|
#define SPR_CFAR (0x01C)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_AMR (0x01D)
|
2016-03-21 15:52:40 +03:00
|
|
|
#define SPR_ACOP (0x01F)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_BOOKE_PID (0x030)
|
2016-03-21 15:52:40 +03:00
|
|
|
#define SPR_BOOKS_PID (0x030)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_BOOKE_DECAR (0x036)
|
|
|
|
#define SPR_BOOKE_CSRR0 (0x03A)
|
|
|
|
#define SPR_BOOKE_CSRR1 (0x03B)
|
|
|
|
#define SPR_BOOKE_DEAR (0x03D)
|
2016-03-21 15:52:38 +03:00
|
|
|
#define SPR_IAMR (0x03D)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_BOOKE_ESR (0x03E)
|
|
|
|
#define SPR_BOOKE_IVPR (0x03F)
|
|
|
|
#define SPR_MPC_EIE (0x050)
|
|
|
|
#define SPR_MPC_EID (0x051)
|
|
|
|
#define SPR_MPC_NRI (0x052)
|
2014-06-04 16:50:59 +04:00
|
|
|
#define SPR_TFHAR (0x080)
|
|
|
|
#define SPR_TFIAR (0x081)
|
|
|
|
#define SPR_TEXASR (0x082)
|
|
|
|
#define SPR_TEXASRU (0x083)
|
2013-12-20 10:41:32 +04:00
|
|
|
#define SPR_UCTRL (0x088)
|
2017-08-08 06:42:53 +03:00
|
|
|
#define SPR_TIDR (0x090)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_MPC_CMPA (0x090)
|
|
|
|
#define SPR_MPC_CMPB (0x091)
|
|
|
|
#define SPR_MPC_CMPC (0x092)
|
|
|
|
#define SPR_MPC_CMPD (0x093)
|
|
|
|
#define SPR_MPC_ECR (0x094)
|
|
|
|
#define SPR_MPC_DER (0x095)
|
|
|
|
#define SPR_MPC_COUNTA (0x096)
|
|
|
|
#define SPR_MPC_COUNTB (0x097)
|
2013-12-20 10:41:32 +04:00
|
|
|
#define SPR_CTRL (0x098)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_MPC_CMPE (0x098)
|
|
|
|
#define SPR_MPC_CMPF (0x099)
|
2014-06-04 16:50:56 +04:00
|
|
|
#define SPR_FSCR (0x099)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_MPC_CMPG (0x09A)
|
|
|
|
#define SPR_MPC_CMPH (0x09B)
|
|
|
|
#define SPR_MPC_LCTRL1 (0x09C)
|
|
|
|
#define SPR_MPC_LCTRL2 (0x09D)
|
2013-03-12 04:31:47 +04:00
|
|
|
#define SPR_UAMOR (0x09D)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_MPC_ICTRL (0x09E)
|
|
|
|
#define SPR_MPC_BAR (0x09F)
|
2016-03-02 23:19:20 +03:00
|
|
|
#define SPR_PSPB (0x09F)
|
2016-03-21 15:52:31 +03:00
|
|
|
#define SPR_DAWR (0x0B4)
|
|
|
|
#define SPR_RPR (0x0BA)
|
2016-03-21 15:52:39 +03:00
|
|
|
#define SPR_CIABR (0x0BB)
|
2016-03-21 15:52:31 +03:00
|
|
|
#define SPR_DAWRX (0x0BC)
|
|
|
|
#define SPR_HFSCR (0x0BE)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_VRSAVE (0x100)
|
|
|
|
#define SPR_USPRG0 (0x100)
|
|
|
|
#define SPR_USPRG1 (0x101)
|
|
|
|
#define SPR_USPRG2 (0x102)
|
|
|
|
#define SPR_USPRG3 (0x103)
|
|
|
|
#define SPR_USPRG4 (0x104)
|
|
|
|
#define SPR_USPRG5 (0x105)
|
|
|
|
#define SPR_USPRG6 (0x106)
|
|
|
|
#define SPR_USPRG7 (0x107)
|
|
|
|
#define SPR_VTBL (0x10C)
|
|
|
|
#define SPR_VTBU (0x10D)
|
|
|
|
#define SPR_SPRG0 (0x110)
|
|
|
|
#define SPR_SPRG1 (0x111)
|
|
|
|
#define SPR_SPRG2 (0x112)
|
|
|
|
#define SPR_SPRG3 (0x113)
|
|
|
|
#define SPR_SPRG4 (0x114)
|
|
|
|
#define SPR_SCOMC (0x114)
|
|
|
|
#define SPR_SPRG5 (0x115)
|
|
|
|
#define SPR_SCOMD (0x115)
|
|
|
|
#define SPR_SPRG6 (0x116)
|
|
|
|
#define SPR_SPRG7 (0x117)
|
|
|
|
#define SPR_ASR (0x118)
|
|
|
|
#define SPR_EAR (0x11A)
|
|
|
|
#define SPR_TBL (0x11C)
|
|
|
|
#define SPR_TBU (0x11D)
|
|
|
|
#define SPR_TBU40 (0x11E)
|
|
|
|
#define SPR_SVR (0x11E)
|
|
|
|
#define SPR_BOOKE_PIR (0x11E)
|
|
|
|
#define SPR_PVR (0x11F)
|
|
|
|
#define SPR_HSPRG0 (0x130)
|
|
|
|
#define SPR_BOOKE_DBSR (0x130)
|
|
|
|
#define SPR_HSPRG1 (0x131)
|
|
|
|
#define SPR_HDSISR (0x132)
|
|
|
|
#define SPR_HDAR (0x133)
|
2011-04-30 02:10:23 +04:00
|
|
|
#define SPR_BOOKE_EPCR (0x133)
|
2011-04-01 08:15:19 +04:00
|
|
|
#define SPR_SPURR (0x134)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_BOOKE_DBCR0 (0x134)
|
|
|
|
#define SPR_IBCR (0x135)
|
|
|
|
#define SPR_PURR (0x135)
|
|
|
|
#define SPR_BOOKE_DBCR1 (0x135)
|
|
|
|
#define SPR_DBCR (0x136)
|
|
|
|
#define SPR_HDEC (0x136)
|
|
|
|
#define SPR_BOOKE_DBCR2 (0x136)
|
|
|
|
#define SPR_HIOR (0x137)
|
|
|
|
#define SPR_MBAR (0x137)
|
|
|
|
#define SPR_RMOR (0x138)
|
|
|
|
#define SPR_BOOKE_IAC1 (0x138)
|
|
|
|
#define SPR_HRMOR (0x139)
|
|
|
|
#define SPR_BOOKE_IAC2 (0x139)
|
|
|
|
#define SPR_HSRR0 (0x13A)
|
|
|
|
#define SPR_BOOKE_IAC3 (0x13A)
|
|
|
|
#define SPR_HSRR1 (0x13B)
|
|
|
|
#define SPR_BOOKE_IAC4 (0x13B)
|
|
|
|
#define SPR_BOOKE_DAC1 (0x13C)
|
2016-03-21 15:52:31 +03:00
|
|
|
#define SPR_MMCRH (0x13C)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_DABR2 (0x13D)
|
|
|
|
#define SPR_BOOKE_DAC2 (0x13D)
|
2016-03-21 15:52:31 +03:00
|
|
|
#define SPR_TFMR (0x13D)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_BOOKE_DVC1 (0x13E)
|
2013-12-20 10:41:30 +04:00
|
|
|
#define SPR_LPCR (0x13E)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_BOOKE_DVC2 (0x13F)
|
2016-03-21 15:52:31 +03:00
|
|
|
#define SPR_LPIDR (0x13F)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_BOOKE_TSR (0x150)
|
2016-03-21 15:52:31 +03:00
|
|
|
#define SPR_HMER (0x150)
|
|
|
|
#define SPR_HMEER (0x151)
|
2014-05-23 06:26:52 +04:00
|
|
|
#define SPR_PCR (0x152)
|
2016-03-21 15:52:31 +03:00
|
|
|
#define SPR_BOOKE_LPIDR (0x152)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_BOOKE_TCR (0x154)
|
2012-01-21 07:45:46 +04:00
|
|
|
#define SPR_BOOKE_TLB0PS (0x158)
|
|
|
|
#define SPR_BOOKE_TLB1PS (0x159)
|
|
|
|
#define SPR_BOOKE_TLB2PS (0x15A)
|
|
|
|
#define SPR_BOOKE_TLB3PS (0x15B)
|
2016-03-21 15:52:31 +03:00
|
|
|
#define SPR_AMOR (0x15D)
|
2012-06-20 23:19:09 +04:00
|
|
|
#define SPR_BOOKE_MAS7_MAS3 (0x174)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_BOOKE_IVOR0 (0x190)
|
|
|
|
#define SPR_BOOKE_IVOR1 (0x191)
|
|
|
|
#define SPR_BOOKE_IVOR2 (0x192)
|
|
|
|
#define SPR_BOOKE_IVOR3 (0x193)
|
|
|
|
#define SPR_BOOKE_IVOR4 (0x194)
|
|
|
|
#define SPR_BOOKE_IVOR5 (0x195)
|
|
|
|
#define SPR_BOOKE_IVOR6 (0x196)
|
|
|
|
#define SPR_BOOKE_IVOR7 (0x197)
|
|
|
|
#define SPR_BOOKE_IVOR8 (0x198)
|
|
|
|
#define SPR_BOOKE_IVOR9 (0x199)
|
|
|
|
#define SPR_BOOKE_IVOR10 (0x19A)
|
|
|
|
#define SPR_BOOKE_IVOR11 (0x19B)
|
|
|
|
#define SPR_BOOKE_IVOR12 (0x19C)
|
|
|
|
#define SPR_BOOKE_IVOR13 (0x19D)
|
|
|
|
#define SPR_BOOKE_IVOR14 (0x19E)
|
|
|
|
#define SPR_BOOKE_IVOR15 (0x19F)
|
2012-01-19 22:31:51 +04:00
|
|
|
#define SPR_BOOKE_IVOR38 (0x1B0)
|
|
|
|
#define SPR_BOOKE_IVOR39 (0x1B1)
|
|
|
|
#define SPR_BOOKE_IVOR40 (0x1B2)
|
|
|
|
#define SPR_BOOKE_IVOR41 (0x1B3)
|
|
|
|
#define SPR_BOOKE_IVOR42 (0x1B4)
|
2014-01-19 20:41:14 +04:00
|
|
|
#define SPR_BOOKE_GIVOR2 (0x1B8)
|
|
|
|
#define SPR_BOOKE_GIVOR3 (0x1B9)
|
|
|
|
#define SPR_BOOKE_GIVOR4 (0x1BA)
|
|
|
|
#define SPR_BOOKE_GIVOR8 (0x1BB)
|
|
|
|
#define SPR_BOOKE_GIVOR13 (0x1BC)
|
|
|
|
#define SPR_BOOKE_GIVOR14 (0x1BD)
|
2014-06-04 16:50:55 +04:00
|
|
|
#define SPR_TIR (0x1BE)
|
2018-04-24 14:30:42 +03:00
|
|
|
#define SPR_PTCR (0x1D0)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_BOOKE_SPEFSCR (0x200)
|
|
|
|
#define SPR_Exxx_BBEAR (0x201)
|
|
|
|
#define SPR_Exxx_BBTAR (0x202)
|
|
|
|
#define SPR_Exxx_L1CFG0 (0x203)
|
2014-01-19 20:47:43 +04:00
|
|
|
#define SPR_Exxx_L1CFG1 (0x204)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_Exxx_NPIDR (0x205)
|
|
|
|
#define SPR_ATBL (0x20E)
|
|
|
|
#define SPR_ATBU (0x20F)
|
|
|
|
#define SPR_IBAT0U (0x210)
|
|
|
|
#define SPR_BOOKE_IVOR32 (0x210)
|
|
|
|
#define SPR_RCPU_MI_GRA (0x210)
|
|
|
|
#define SPR_IBAT0L (0x211)
|
|
|
|
#define SPR_BOOKE_IVOR33 (0x211)
|
|
|
|
#define SPR_IBAT1U (0x212)
|
|
|
|
#define SPR_BOOKE_IVOR34 (0x212)
|
|
|
|
#define SPR_IBAT1L (0x213)
|
|
|
|
#define SPR_BOOKE_IVOR35 (0x213)
|
|
|
|
#define SPR_IBAT2U (0x214)
|
|
|
|
#define SPR_BOOKE_IVOR36 (0x214)
|
|
|
|
#define SPR_IBAT2L (0x215)
|
|
|
|
#define SPR_BOOKE_IVOR37 (0x215)
|
|
|
|
#define SPR_IBAT3U (0x216)
|
|
|
|
#define SPR_IBAT3L (0x217)
|
|
|
|
#define SPR_DBAT0U (0x218)
|
|
|
|
#define SPR_RCPU_L2U_GRA (0x218)
|
|
|
|
#define SPR_DBAT0L (0x219)
|
|
|
|
#define SPR_DBAT1U (0x21A)
|
|
|
|
#define SPR_DBAT1L (0x21B)
|
|
|
|
#define SPR_DBAT2U (0x21C)
|
|
|
|
#define SPR_DBAT2L (0x21D)
|
|
|
|
#define SPR_DBAT3U (0x21E)
|
|
|
|
#define SPR_DBAT3L (0x21F)
|
|
|
|
#define SPR_IBAT4U (0x230)
|
|
|
|
#define SPR_RPCU_BBCMCR (0x230)
|
|
|
|
#define SPR_MPC_IC_CST (0x230)
|
|
|
|
#define SPR_Exxx_CTXCR (0x230)
|
|
|
|
#define SPR_IBAT4L (0x231)
|
|
|
|
#define SPR_MPC_IC_ADR (0x231)
|
|
|
|
#define SPR_Exxx_DBCR3 (0x231)
|
|
|
|
#define SPR_IBAT5U (0x232)
|
|
|
|
#define SPR_MPC_IC_DAT (0x232)
|
|
|
|
#define SPR_Exxx_DBCNT (0x232)
|
|
|
|
#define SPR_IBAT5L (0x233)
|
|
|
|
#define SPR_IBAT6U (0x234)
|
|
|
|
#define SPR_IBAT6L (0x235)
|
|
|
|
#define SPR_IBAT7U (0x236)
|
|
|
|
#define SPR_IBAT7L (0x237)
|
|
|
|
#define SPR_DBAT4U (0x238)
|
|
|
|
#define SPR_RCPU_L2U_MCR (0x238)
|
|
|
|
#define SPR_MPC_DC_CST (0x238)
|
|
|
|
#define SPR_Exxx_ALTCTXCR (0x238)
|
|
|
|
#define SPR_DBAT4L (0x239)
|
|
|
|
#define SPR_MPC_DC_ADR (0x239)
|
|
|
|
#define SPR_DBAT5U (0x23A)
|
|
|
|
#define SPR_BOOKE_MCSRR0 (0x23A)
|
|
|
|
#define SPR_MPC_DC_DAT (0x23A)
|
|
|
|
#define SPR_DBAT5L (0x23B)
|
|
|
|
#define SPR_BOOKE_MCSRR1 (0x23B)
|
|
|
|
#define SPR_DBAT6U (0x23C)
|
|
|
|
#define SPR_BOOKE_MCSR (0x23C)
|
|
|
|
#define SPR_DBAT6L (0x23D)
|
|
|
|
#define SPR_Exxx_MCAR (0x23D)
|
|
|
|
#define SPR_DBAT7U (0x23E)
|
|
|
|
#define SPR_BOOKE_DSRR0 (0x23E)
|
|
|
|
#define SPR_DBAT7L (0x23F)
|
|
|
|
#define SPR_BOOKE_DSRR1 (0x23F)
|
|
|
|
#define SPR_BOOKE_SPRG8 (0x25C)
|
|
|
|
#define SPR_BOOKE_SPRG9 (0x25D)
|
|
|
|
#define SPR_BOOKE_MAS0 (0x270)
|
|
|
|
#define SPR_BOOKE_MAS1 (0x271)
|
|
|
|
#define SPR_BOOKE_MAS2 (0x272)
|
|
|
|
#define SPR_BOOKE_MAS3 (0x273)
|
|
|
|
#define SPR_BOOKE_MAS4 (0x274)
|
|
|
|
#define SPR_BOOKE_MAS5 (0x275)
|
|
|
|
#define SPR_BOOKE_MAS6 (0x276)
|
|
|
|
#define SPR_BOOKE_PID1 (0x279)
|
|
|
|
#define SPR_BOOKE_PID2 (0x27A)
|
|
|
|
#define SPR_MPC_DPDR (0x280)
|
|
|
|
#define SPR_MPC_IMMR (0x288)
|
|
|
|
#define SPR_BOOKE_TLB0CFG (0x2B0)
|
|
|
|
#define SPR_BOOKE_TLB1CFG (0x2B1)
|
|
|
|
#define SPR_BOOKE_TLB2CFG (0x2B2)
|
|
|
|
#define SPR_BOOKE_TLB3CFG (0x2B3)
|
|
|
|
#define SPR_BOOKE_EPR (0x2BE)
|
|
|
|
#define SPR_PERF0 (0x300)
|
|
|
|
#define SPR_RCPU_MI_RBA0 (0x300)
|
|
|
|
#define SPR_MPC_MI_CTR (0x300)
|
2016-03-02 23:19:22 +03:00
|
|
|
#define SPR_POWER_USIER (0x300)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERF1 (0x301)
|
|
|
|
#define SPR_RCPU_MI_RBA1 (0x301)
|
2014-06-04 16:50:58 +04:00
|
|
|
#define SPR_POWER_UMMCR2 (0x301)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERF2 (0x302)
|
|
|
|
#define SPR_RCPU_MI_RBA2 (0x302)
|
|
|
|
#define SPR_MPC_MI_AP (0x302)
|
2014-06-04 16:50:41 +04:00
|
|
|
#define SPR_POWER_UMMCRA (0x302)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERF3 (0x303)
|
|
|
|
#define SPR_RCPU_MI_RBA3 (0x303)
|
|
|
|
#define SPR_MPC_MI_EPN (0x303)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_UPMC1 (0x303)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERF4 (0x304)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_UPMC2 (0x304)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERF5 (0x305)
|
|
|
|
#define SPR_MPC_MI_TWC (0x305)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_UPMC3 (0x305)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERF6 (0x306)
|
|
|
|
#define SPR_MPC_MI_RPN (0x306)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_UPMC4 (0x306)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERF7 (0x307)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_UPMC5 (0x307)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERF8 (0x308)
|
|
|
|
#define SPR_RCPU_L2U_RBA0 (0x308)
|
|
|
|
#define SPR_MPC_MD_CTR (0x308)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_UPMC6 (0x308)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERF9 (0x309)
|
|
|
|
#define SPR_RCPU_L2U_RBA1 (0x309)
|
|
|
|
#define SPR_MPC_MD_CASID (0x309)
|
2014-06-04 16:50:43 +04:00
|
|
|
#define SPR_970_UPMC7 (0X309)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERFA (0x30A)
|
|
|
|
#define SPR_RCPU_L2U_RBA2 (0x30A)
|
|
|
|
#define SPR_MPC_MD_AP (0x30A)
|
2014-06-04 16:50:43 +04:00
|
|
|
#define SPR_970_UPMC8 (0X30A)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERFB (0x30B)
|
|
|
|
#define SPR_RCPU_L2U_RBA3 (0x30B)
|
|
|
|
#define SPR_MPC_MD_EPN (0x30B)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_UMMCR0 (0X30B)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERFC (0x30C)
|
|
|
|
#define SPR_MPC_MD_TWB (0x30C)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_USIAR (0X30C)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERFD (0x30D)
|
|
|
|
#define SPR_MPC_MD_TWC (0x30D)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_USDAR (0X30D)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERFE (0x30E)
|
|
|
|
#define SPR_MPC_MD_RPN (0x30E)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_UMMCR1 (0X30E)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PERFF (0x30F)
|
|
|
|
#define SPR_MPC_MD_TW (0x30F)
|
|
|
|
#define SPR_UPERF0 (0x310)
|
2016-03-02 23:19:22 +03:00
|
|
|
#define SPR_POWER_SIER (0x310)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERF1 (0x311)
|
2014-06-04 16:50:58 +04:00
|
|
|
#define SPR_POWER_MMCR2 (0x311)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERF2 (0x312)
|
2014-06-04 16:50:41 +04:00
|
|
|
#define SPR_POWER_MMCRA (0X312)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERF3 (0x313)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_PMC1 (0X313)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERF4 (0x314)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_PMC2 (0X314)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERF5 (0x315)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_PMC3 (0X315)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERF6 (0x316)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_PMC4 (0X316)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERF7 (0x317)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_PMC5 (0X317)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERF8 (0x318)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_PMC6 (0X318)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERF9 (0x319)
|
2014-06-04 16:50:43 +04:00
|
|
|
#define SPR_970_PMC7 (0X319)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERFA (0x31A)
|
2014-06-04 16:50:43 +04:00
|
|
|
#define SPR_970_PMC8 (0X31A)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERFB (0x31B)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_MMCR0 (0X31B)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERFC (0x31C)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_SIAR (0X31C)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERFD (0x31D)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_SDAR (0X31D)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERFE (0x31E)
|
2014-06-04 16:50:40 +04:00
|
|
|
#define SPR_POWER_MMCR1 (0X31E)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UPERFF (0x31F)
|
|
|
|
#define SPR_RCPU_MI_RA0 (0x320)
|
|
|
|
#define SPR_MPC_MI_DBCAM (0x320)
|
2014-06-04 16:51:01 +04:00
|
|
|
#define SPR_BESCRS (0x320)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_RCPU_MI_RA1 (0x321)
|
|
|
|
#define SPR_MPC_MI_DBRAM0 (0x321)
|
2014-06-04 16:51:01 +04:00
|
|
|
#define SPR_BESCRSU (0x321)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_RCPU_MI_RA2 (0x322)
|
|
|
|
#define SPR_MPC_MI_DBRAM1 (0x322)
|
2014-06-04 16:51:01 +04:00
|
|
|
#define SPR_BESCRR (0x322)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_RCPU_MI_RA3 (0x323)
|
2014-06-04 16:51:01 +04:00
|
|
|
#define SPR_BESCRRU (0x323)
|
|
|
|
#define SPR_EBBHR (0x324)
|
|
|
|
#define SPR_EBBRR (0x325)
|
|
|
|
#define SPR_BESCR (0x326)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_RCPU_L2U_RA0 (0x328)
|
|
|
|
#define SPR_MPC_MD_DBCAM (0x328)
|
|
|
|
#define SPR_RCPU_L2U_RA1 (0x329)
|
|
|
|
#define SPR_MPC_MD_DBRAM0 (0x329)
|
|
|
|
#define SPR_RCPU_L2U_RA2 (0x32A)
|
|
|
|
#define SPR_MPC_MD_DBRAM1 (0x32A)
|
|
|
|
#define SPR_RCPU_L2U_RA3 (0x32B)
|
2014-02-10 21:26:54 +04:00
|
|
|
#define SPR_TAR (0x32F)
|
2016-03-21 15:52:35 +03:00
|
|
|
#define SPR_IC (0x350)
|
2015-03-02 09:55:38 +03:00
|
|
|
#define SPR_VTB (0x351)
|
2016-03-21 15:52:31 +03:00
|
|
|
#define SPR_MMCRC (0x353)
|
2017-08-08 08:09:35 +03:00
|
|
|
#define SPR_PSSCR (0x357)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_440_INV0 (0x370)
|
|
|
|
#define SPR_440_INV1 (0x371)
|
|
|
|
#define SPR_440_INV2 (0x372)
|
|
|
|
#define SPR_440_INV3 (0x373)
|
|
|
|
#define SPR_440_ITV0 (0x374)
|
|
|
|
#define SPR_440_ITV1 (0x375)
|
|
|
|
#define SPR_440_ITV2 (0x376)
|
|
|
|
#define SPR_440_ITV3 (0x377)
|
|
|
|
#define SPR_440_CCR1 (0x378)
|
2016-03-02 23:19:22 +03:00
|
|
|
#define SPR_TACR (0x378)
|
|
|
|
#define SPR_TCSCR (0x379)
|
|
|
|
#define SPR_CSIGR (0x37a)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_DCRIPR (0x37B)
|
2016-03-02 23:19:22 +03:00
|
|
|
#define SPR_POWER_SPMC1 (0x37C)
|
|
|
|
#define SPR_POWER_SPMC2 (0x37D)
|
2014-06-04 16:50:58 +04:00
|
|
|
#define SPR_POWER_MMCRS (0x37E)
|
2016-03-21 15:52:40 +03:00
|
|
|
#define SPR_WORT (0x37F)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_PPR (0x380)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750_GQR0 (0x390)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_440_DNV0 (0x390)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750_GQR1 (0x391)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_440_DNV1 (0x391)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750_GQR2 (0x392)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_440_DNV2 (0x392)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750_GQR3 (0x393)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_440_DNV3 (0x393)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750_GQR4 (0x394)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_440_DTV0 (0x394)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750_GQR5 (0x395)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_440_DTV1 (0x395)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750_GQR6 (0x396)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_440_DTV2 (0x396)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750_GQR7 (0x397)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_440_DTV3 (0x397)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750_THRM4 (0x398)
|
|
|
|
#define SPR_750CL_HID2 (0x398)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_440_DVLIM (0x398)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750_WPAR (0x399)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_440_IVLIM (0x399)
|
2016-03-21 15:52:31 +03:00
|
|
|
#define SPR_TSCR (0x399)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750_DMAU (0x39A)
|
|
|
|
#define SPR_750_DMAL (0x39B)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_440_RSTCFG (0x39B)
|
|
|
|
#define SPR_BOOKE_DCDBTRL (0x39C)
|
|
|
|
#define SPR_BOOKE_DCDBTRH (0x39D)
|
|
|
|
#define SPR_BOOKE_ICDBTRL (0x39E)
|
|
|
|
#define SPR_BOOKE_ICDBTRH (0x39F)
|
2014-06-04 16:50:36 +04:00
|
|
|
#define SPR_74XX_UMMCR2 (0x3A0)
|
|
|
|
#define SPR_7XX_UPMC5 (0x3A1)
|
|
|
|
#define SPR_7XX_UPMC6 (0x3A2)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_UBAMR (0x3A7)
|
2014-06-04 16:50:36 +04:00
|
|
|
#define SPR_7XX_UMMCR0 (0x3A8)
|
|
|
|
#define SPR_7XX_UPMC1 (0x3A9)
|
|
|
|
#define SPR_7XX_UPMC2 (0x3AA)
|
|
|
|
#define SPR_7XX_USIAR (0x3AB)
|
|
|
|
#define SPR_7XX_UMMCR1 (0x3AC)
|
|
|
|
#define SPR_7XX_UPMC3 (0x3AD)
|
|
|
|
#define SPR_7XX_UPMC4 (0x3AE)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_USDA (0x3AF)
|
|
|
|
#define SPR_40x_ZPR (0x3B0)
|
|
|
|
#define SPR_BOOKE_MAS7 (0x3B0)
|
2014-06-04 16:50:36 +04:00
|
|
|
#define SPR_74XX_MMCR2 (0x3B0)
|
|
|
|
#define SPR_7XX_PMC5 (0x3B1)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_40x_PID (0x3B1)
|
2014-06-04 16:50:36 +04:00
|
|
|
#define SPR_7XX_PMC6 (0x3B2)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_440_MMUCR (0x3B2)
|
|
|
|
#define SPR_4xx_CCR0 (0x3B3)
|
|
|
|
#define SPR_BOOKE_EPLC (0x3B3)
|
|
|
|
#define SPR_405_IAC3 (0x3B4)
|
|
|
|
#define SPR_BOOKE_EPSC (0x3B4)
|
|
|
|
#define SPR_405_IAC4 (0x3B5)
|
|
|
|
#define SPR_405_DVC1 (0x3B6)
|
|
|
|
#define SPR_405_DVC2 (0x3B7)
|
|
|
|
#define SPR_BAMR (0x3B7)
|
2014-06-04 16:50:36 +04:00
|
|
|
#define SPR_7XX_MMCR0 (0x3B8)
|
|
|
|
#define SPR_7XX_PMC1 (0x3B9)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_40x_SGR (0x3B9)
|
2014-06-04 16:50:36 +04:00
|
|
|
#define SPR_7XX_PMC2 (0x3BA)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_40x_DCWR (0x3BA)
|
2014-06-04 16:50:36 +04:00
|
|
|
#define SPR_7XX_SIAR (0x3BB)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_405_SLER (0x3BB)
|
2014-06-04 16:50:36 +04:00
|
|
|
#define SPR_7XX_MMCR1 (0x3BC)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_405_SU0R (0x3BC)
|
|
|
|
#define SPR_401_SKR (0x3BC)
|
2014-06-04 16:50:36 +04:00
|
|
|
#define SPR_7XX_PMC3 (0x3BD)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_405_DBCR1 (0x3BD)
|
2014-06-04 16:50:36 +04:00
|
|
|
#define SPR_7XX_PMC4 (0x3BE)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_SDA (0x3BF)
|
|
|
|
#define SPR_403_VTBL (0x3CC)
|
|
|
|
#define SPR_403_VTBU (0x3CD)
|
|
|
|
#define SPR_DMISS (0x3D0)
|
|
|
|
#define SPR_DCMP (0x3D1)
|
|
|
|
#define SPR_HASH1 (0x3D2)
|
|
|
|
#define SPR_HASH2 (0x3D3)
|
|
|
|
#define SPR_BOOKE_ICDBDR (0x3D3)
|
|
|
|
#define SPR_TLBMISS (0x3D4)
|
|
|
|
#define SPR_IMISS (0x3D4)
|
|
|
|
#define SPR_40x_ESR (0x3D4)
|
|
|
|
#define SPR_PTEHI (0x3D5)
|
|
|
|
#define SPR_ICMP (0x3D5)
|
|
|
|
#define SPR_40x_DEAR (0x3D5)
|
|
|
|
#define SPR_PTELO (0x3D6)
|
|
|
|
#define SPR_RPA (0x3D6)
|
|
|
|
#define SPR_40x_EVPR (0x3D6)
|
|
|
|
#define SPR_L3PM (0x3D7)
|
|
|
|
#define SPR_403_CDBCR (0x3D7)
|
2007-12-10 10:40:16 +03:00
|
|
|
#define SPR_L3ITCR0 (0x3D8)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_TCR (0x3D8)
|
|
|
|
#define SPR_40x_TSR (0x3D8)
|
|
|
|
#define SPR_IBR (0x3DA)
|
|
|
|
#define SPR_40x_TCR (0x3DA)
|
|
|
|
#define SPR_ESASRR (0x3DB)
|
|
|
|
#define SPR_40x_PIT (0x3DB)
|
|
|
|
#define SPR_403_TBL (0x3DC)
|
|
|
|
#define SPR_403_TBU (0x3DD)
|
|
|
|
#define SPR_SEBR (0x3DE)
|
|
|
|
#define SPR_40x_SRR2 (0x3DE)
|
|
|
|
#define SPR_SER (0x3DF)
|
|
|
|
#define SPR_40x_SRR3 (0x3DF)
|
2007-12-10 10:40:16 +03:00
|
|
|
#define SPR_L3OHCR (0x3E8)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_L3ITCR1 (0x3E9)
|
|
|
|
#define SPR_L3ITCR2 (0x3EA)
|
|
|
|
#define SPR_L3ITCR3 (0x3EB)
|
|
|
|
#define SPR_HID0 (0x3F0)
|
|
|
|
#define SPR_40x_DBSR (0x3F0)
|
|
|
|
#define SPR_HID1 (0x3F1)
|
|
|
|
#define SPR_IABR (0x3F2)
|
|
|
|
#define SPR_40x_DBCR0 (0x3F2)
|
|
|
|
#define SPR_601_HID2 (0x3F2)
|
|
|
|
#define SPR_Exxx_L1CSR0 (0x3F2)
|
|
|
|
#define SPR_ICTRL (0x3F3)
|
|
|
|
#define SPR_HID2 (0x3F3)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750CL_HID4 (0x3F3)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_Exxx_L1CSR1 (0x3F3)
|
|
|
|
#define SPR_440_DBDR (0x3F3)
|
|
|
|
#define SPR_LDSTDB (0x3F4)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750_TDCL (0x3F4)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_40x_IAC1 (0x3F4)
|
|
|
|
#define SPR_MMUCSR0 (0x3F4)
|
2014-06-04 16:50:44 +04:00
|
|
|
#define SPR_970_HID4 (0x3F4)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_DABR (0x3F5)
|
2005-07-03 00:59:34 +04:00
|
|
|
#define DABR_MASK (~(target_ulong)0x7)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_Exxx_BUCSR (0x3F5)
|
|
|
|
#define SPR_40x_IAC2 (0x3F5)
|
|
|
|
#define SPR_601_HID5 (0x3F5)
|
|
|
|
#define SPR_40x_DAC1 (0x3F6)
|
|
|
|
#define SPR_MSSCR0 (0x3F6)
|
|
|
|
#define SPR_970_HID5 (0x3F6)
|
|
|
|
#define SPR_MSSSR0 (0x3F7)
|
2007-12-10 10:40:16 +03:00
|
|
|
#define SPR_MSSCR1 (0x3F7)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_DABRX (0x3F7)
|
|
|
|
#define SPR_40x_DAC2 (0x3F7)
|
|
|
|
#define SPR_MMUCFG (0x3F7)
|
|
|
|
#define SPR_LDSTCR (0x3F8)
|
|
|
|
#define SPR_L2PMCR (0x3F8)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750FX_HID2 (0x3F8)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_Exxx_L1FINV0 (0x3F8)
|
|
|
|
#define SPR_L2CR (0x3F9)
|
|
|
|
#define SPR_L3CR (0x3FA)
|
2007-11-21 16:08:23 +03:00
|
|
|
#define SPR_750_TDCH (0x3FA)
|
2007-11-18 02:02:20 +03:00
|
|
|
#define SPR_IABR2 (0x3FA)
|
|
|
|
#define SPR_40x_DCCR (0x3FA)
|
|
|
|
#define SPR_ICTC (0x3FB)
|
|
|
|
#define SPR_40x_ICCR (0x3FB)
|
|
|
|
#define SPR_THRM1 (0x3FC)
|
|
|
|
#define SPR_403_PBL1 (0x3FC)
|
|
|
|
#define SPR_SP (0x3FD)
|
|
|
|
#define SPR_THRM2 (0x3FD)
|
|
|
|
#define SPR_403_PBU1 (0x3FD)
|
|
|
|
#define SPR_604_HID13 (0x3FD)
|
|
|
|
#define SPR_LT (0x3FE)
|
|
|
|
#define SPR_THRM3 (0x3FE)
|
|
|
|
#define SPR_RCPU_FPECR (0x3FE)
|
|
|
|
#define SPR_403_PBL2 (0x3FE)
|
|
|
|
#define SPR_PIR (0x3FF)
|
|
|
|
#define SPR_403_PBU2 (0x3FF)
|
|
|
|
#define SPR_601_HID15 (0x3FF)
|
|
|
|
#define SPR_604_HID15 (0x3FF)
|
|
|
|
#define SPR_E500_SVR (0x3FF)
|
2003-11-23 17:55:54 +03:00
|
|
|
|
2012-06-20 23:19:09 +04:00
|
|
|
/* Disable MAS Interrupt Updates for Hypervisor */
|
|
|
|
#define EPCR_DMIUH (1 << 22)
|
|
|
|
/* Disable Guest TLB Management Instructions */
|
|
|
|
#define EPCR_DGTMI (1 << 23)
|
|
|
|
/* Guest Interrupt Computation Mode */
|
|
|
|
#define EPCR_GICM (1 << 24)
|
|
|
|
/* Interrupt Computation Mode */
|
|
|
|
#define EPCR_ICM (1 << 25)
|
|
|
|
/* Disable Embedded Hypervisor Debug */
|
|
|
|
#define EPCR_DUVD (1 << 26)
|
|
|
|
/* Instruction Storage Interrupt Directed to Guest State */
|
|
|
|
#define EPCR_ISIGS (1 << 27)
|
|
|
|
/* Data Storage Interrupt Directed to Guest State */
|
|
|
|
#define EPCR_DSIGS (1 << 28)
|
|
|
|
/* Instruction TLB Error Interrupt Directed to Guest State */
|
|
|
|
#define EPCR_ITLBGS (1 << 29)
|
|
|
|
/* Data TLB Error Interrupt Directed to Guest State */
|
|
|
|
#define EPCR_DTLBGS (1 << 30)
|
|
|
|
/* External Input Interrupt Directed to Guest State */
|
|
|
|
#define EPCR_EXTGS (1 << 31)
|
|
|
|
|
2019-03-21 08:29:36 +03:00
|
|
|
#define L1CSR0_CPE 0x00010000 /* Data Cache Parity Enable */
|
|
|
|
#define L1CSR0_CUL 0x00000400 /* (D-)Cache Unable to Lock */
|
|
|
|
#define L1CSR0_DCLFR 0x00000100 /* D-Cache Lock Flash Reset */
|
|
|
|
#define L1CSR0_DCFI 0x00000002 /* Data Cache Flash Invalidate */
|
|
|
|
#define L1CSR0_DCE 0x00000001 /* Data Cache Enable */
|
2014-01-19 20:49:11 +04:00
|
|
|
|
2019-03-21 08:29:36 +03:00
|
|
|
#define L1CSR1_CPE 0x00010000 /* Instruction Cache Parity Enable */
|
|
|
|
#define L1CSR1_ICUL 0x00000400 /* I-Cache Unable to Lock */
|
|
|
|
#define L1CSR1_ICLFR 0x00000100 /* I-Cache Lock Flash Reset */
|
|
|
|
#define L1CSR1_ICFI 0x00000002 /* Instruction Cache Flash Invalidate */
|
|
|
|
#define L1CSR1_ICE 0x00000001 /* Instruction Cache Enable */
|
2014-01-19 20:49:11 +04:00
|
|
|
|
2014-06-04 16:50:37 +04:00
|
|
|
/* HID0 bits */
|
2016-03-21 15:52:31 +03:00
|
|
|
#define HID0_DEEPNAP (1 << 24) /* pre-2.06 */
|
|
|
|
#define HID0_DOZE (1 << 23) /* pre-2.06 */
|
|
|
|
#define HID0_NAP (1 << 22) /* pre-2.06 */
|
2017-12-06 12:41:50 +03:00
|
|
|
#define HID0_HILE PPC_BIT(19) /* POWER8 */
|
2018-01-15 21:04:06 +03:00
|
|
|
#define HID0_POWER9_HILE PPC_BIT(4)
|
2014-06-04 16:50:37 +04:00
|
|
|
|
2009-05-12 23:26:57 +04:00
|
|
|
/*****************************************************************************/
|
|
|
|
/* PowerPC Instructions types definitions */
|
|
|
|
enum {
|
|
|
|
PPC_NONE = 0x0000000000000000ULL,
|
|
|
|
/* PowerPC base instructions set */
|
|
|
|
PPC_INSNS_BASE = 0x0000000000000001ULL,
|
|
|
|
/* integer operations instructions */
|
|
|
|
#define PPC_INTEGER PPC_INSNS_BASE
|
|
|
|
/* flow control instructions */
|
|
|
|
#define PPC_FLOW PPC_INSNS_BASE
|
|
|
|
/* virtual memory instructions */
|
|
|
|
#define PPC_MEM PPC_INSNS_BASE
|
|
|
|
/* ld/st with reservation instructions */
|
|
|
|
#define PPC_RES PPC_INSNS_BASE
|
|
|
|
/* spr/msr access instructions */
|
|
|
|
#define PPC_MISC PPC_INSNS_BASE
|
|
|
|
/* Deprecated instruction sets */
|
|
|
|
/* Original POWER instruction set */
|
|
|
|
PPC_POWER = 0x0000000000000002ULL,
|
|
|
|
/* POWER2 instruction set extension */
|
|
|
|
PPC_POWER2 = 0x0000000000000004ULL,
|
|
|
|
/* Power RTC support */
|
|
|
|
PPC_POWER_RTC = 0x0000000000000008ULL,
|
|
|
|
/* Power-to-PowerPC bridge (601) */
|
|
|
|
PPC_POWER_BR = 0x0000000000000010ULL,
|
|
|
|
/* 64 bits PowerPC instruction set */
|
|
|
|
PPC_64B = 0x0000000000000020ULL,
|
|
|
|
/* New 64 bits extensions (PowerPC 2.0x) */
|
|
|
|
PPC_64BX = 0x0000000000000040ULL,
|
|
|
|
/* 64 bits hypervisor extensions */
|
|
|
|
PPC_64H = 0x0000000000000080ULL,
|
|
|
|
/* New wait instruction (PowerPC 2.0x) */
|
|
|
|
PPC_WAIT = 0x0000000000000100ULL,
|
|
|
|
/* Time base mftb instruction */
|
|
|
|
PPC_MFTB = 0x0000000000000200ULL,
|
|
|
|
|
|
|
|
/* Fixed-point unit extensions */
|
|
|
|
/* PowerPC 602 specific */
|
|
|
|
PPC_602_SPEC = 0x0000000000000400ULL,
|
|
|
|
/* isel instruction */
|
|
|
|
PPC_ISEL = 0x0000000000000800ULL,
|
|
|
|
/* popcntb instruction */
|
|
|
|
PPC_POPCNTB = 0x0000000000001000ULL,
|
|
|
|
/* string load / store */
|
|
|
|
PPC_STRING = 0x0000000000002000ULL,
|
2016-06-22 00:48:52 +03:00
|
|
|
/* real mode cache inhibited load / store */
|
|
|
|
PPC_CILDST = 0x0000000000004000ULL,
|
2009-05-12 23:26:57 +04:00
|
|
|
|
|
|
|
/* Floating-point unit extensions */
|
|
|
|
/* Optional floating point instructions */
|
|
|
|
PPC_FLOAT = 0x0000000000010000ULL,
|
|
|
|
/* New floating-point extensions (PowerPC 2.0x) */
|
|
|
|
PPC_FLOAT_EXT = 0x0000000000020000ULL,
|
|
|
|
PPC_FLOAT_FSQRT = 0x0000000000040000ULL,
|
|
|
|
PPC_FLOAT_FRES = 0x0000000000080000ULL,
|
|
|
|
PPC_FLOAT_FRSQRTE = 0x0000000000100000ULL,
|
|
|
|
PPC_FLOAT_FRSQRTES = 0x0000000000200000ULL,
|
|
|
|
PPC_FLOAT_FSEL = 0x0000000000400000ULL,
|
|
|
|
PPC_FLOAT_STFIWX = 0x0000000000800000ULL,
|
|
|
|
|
|
|
|
/* Vector/SIMD extensions */
|
|
|
|
/* Altivec support */
|
|
|
|
PPC_ALTIVEC = 0x0000000001000000ULL,
|
|
|
|
/* PowerPC 2.03 SPE extension */
|
|
|
|
PPC_SPE = 0x0000000002000000ULL,
|
|
|
|
/* PowerPC 2.03 SPE single-precision floating-point extension */
|
|
|
|
PPC_SPE_SINGLE = 0x0000000004000000ULL,
|
|
|
|
/* PowerPC 2.03 SPE double-precision floating-point extension */
|
|
|
|
PPC_SPE_DOUBLE = 0x0000000008000000ULL,
|
|
|
|
|
|
|
|
/* Optional memory control instructions */
|
|
|
|
PPC_MEM_TLBIA = 0x0000000010000000ULL,
|
|
|
|
PPC_MEM_TLBIE = 0x0000000020000000ULL,
|
|
|
|
PPC_MEM_TLBSYNC = 0x0000000040000000ULL,
|
|
|
|
/* sync instruction */
|
|
|
|
PPC_MEM_SYNC = 0x0000000080000000ULL,
|
|
|
|
/* eieio instruction */
|
|
|
|
PPC_MEM_EIEIO = 0x0000000100000000ULL,
|
|
|
|
|
|
|
|
/* Cache control instructions */
|
|
|
|
PPC_CACHE = 0x0000000200000000ULL,
|
|
|
|
/* icbi instruction */
|
|
|
|
PPC_CACHE_ICBI = 0x0000000400000000ULL,
|
2013-01-29 16:36:02 +04:00
|
|
|
/* dcbz instruction */
|
2009-05-12 23:26:57 +04:00
|
|
|
PPC_CACHE_DCBZ = 0x0000000800000000ULL,
|
|
|
|
/* dcba instruction */
|
|
|
|
PPC_CACHE_DCBA = 0x0000002000000000ULL,
|
|
|
|
/* Freescale cache locking instructions */
|
|
|
|
PPC_CACHE_LOCK = 0x0000004000000000ULL,
|
|
|
|
|
|
|
|
/* MMU related extensions */
|
|
|
|
/* external control instructions */
|
|
|
|
PPC_EXTERN = 0x0000010000000000ULL,
|
|
|
|
/* segment register access instructions */
|
|
|
|
PPC_SEGMENT = 0x0000020000000000ULL,
|
|
|
|
/* PowerPC 6xx TLB management instructions */
|
|
|
|
PPC_6xx_TLB = 0x0000040000000000ULL,
|
|
|
|
/* PowerPC 74xx TLB management instructions */
|
|
|
|
PPC_74xx_TLB = 0x0000080000000000ULL,
|
|
|
|
/* PowerPC 40x TLB management instructions */
|
|
|
|
PPC_40x_TLB = 0x0000100000000000ULL,
|
|
|
|
/* segment register access instructions for PowerPC 64 "bridge" */
|
|
|
|
PPC_SEGMENT_64B = 0x0000200000000000ULL,
|
|
|
|
/* SLB management */
|
|
|
|
PPC_SLBI = 0x0000400000000000ULL,
|
|
|
|
|
|
|
|
/* Embedded PowerPC dedicated instructions */
|
|
|
|
PPC_WRTEE = 0x0001000000000000ULL,
|
|
|
|
/* PowerPC 40x exception model */
|
|
|
|
PPC_40x_EXCP = 0x0002000000000000ULL,
|
|
|
|
/* PowerPC 405 Mac instructions */
|
|
|
|
PPC_405_MAC = 0x0004000000000000ULL,
|
|
|
|
/* PowerPC 440 specific instructions */
|
|
|
|
PPC_440_SPEC = 0x0008000000000000ULL,
|
|
|
|
/* BookE (embedded) PowerPC specification */
|
|
|
|
PPC_BOOKE = 0x0010000000000000ULL,
|
|
|
|
/* mfapidi instruction */
|
|
|
|
PPC_MFAPIDI = 0x0020000000000000ULL,
|
|
|
|
/* tlbiva instruction */
|
|
|
|
PPC_TLBIVA = 0x0040000000000000ULL,
|
|
|
|
/* tlbivax instruction */
|
|
|
|
PPC_TLBIVAX = 0x0080000000000000ULL,
|
|
|
|
/* PowerPC 4xx dedicated instructions */
|
|
|
|
PPC_4xx_COMMON = 0x0100000000000000ULL,
|
|
|
|
/* PowerPC 40x ibct instructions */
|
|
|
|
PPC_40x_ICBT = 0x0200000000000000ULL,
|
|
|
|
/* rfmci is not implemented in all BookE PowerPC */
|
|
|
|
PPC_RFMCI = 0x0400000000000000ULL,
|
|
|
|
/* rfdi instruction */
|
|
|
|
PPC_RFDI = 0x0800000000000000ULL,
|
|
|
|
/* DCR accesses */
|
|
|
|
PPC_DCR = 0x1000000000000000ULL,
|
|
|
|
/* DCR extended accesse */
|
|
|
|
PPC_DCRX = 0x2000000000000000ULL,
|
|
|
|
/* user-mode DCR access, implemented in PowerPC 460 */
|
|
|
|
PPC_DCRUX = 0x4000000000000000ULL,
|
2011-04-01 08:15:13 +04:00
|
|
|
/* popcntw and popcntd instructions */
|
|
|
|
PPC_POPCNTWD = 0x8000000000000000ULL,
|
2011-05-01 01:34:58 +04:00
|
|
|
|
2011-10-30 19:51:24 +04:00
|
|
|
#define PPC_TCG_INSNS (PPC_INSNS_BASE | PPC_POWER | PPC_POWER2 \
|
|
|
|
| PPC_POWER_RTC | PPC_POWER_BR | PPC_64B \
|
|
|
|
| PPC_64BX | PPC_64H | PPC_WAIT | PPC_MFTB \
|
|
|
|
| PPC_602_SPEC | PPC_ISEL | PPC_POPCNTB \
|
|
|
|
| PPC_STRING | PPC_FLOAT | PPC_FLOAT_EXT \
|
|
|
|
| PPC_FLOAT_FSQRT | PPC_FLOAT_FRES \
|
|
|
|
| PPC_FLOAT_FRSQRTE | PPC_FLOAT_FRSQRTES \
|
|
|
|
| PPC_FLOAT_FSEL | PPC_FLOAT_STFIWX \
|
|
|
|
| PPC_ALTIVEC | PPC_SPE | PPC_SPE_SINGLE \
|
|
|
|
| PPC_SPE_DOUBLE | PPC_MEM_TLBIA \
|
|
|
|
| PPC_MEM_TLBIE | PPC_MEM_TLBSYNC \
|
|
|
|
| PPC_MEM_SYNC | PPC_MEM_EIEIO \
|
|
|
|
| PPC_CACHE | PPC_CACHE_ICBI \
|
2013-01-29 16:36:02 +04:00
|
|
|
| PPC_CACHE_DCBZ \
|
2011-10-30 19:51:24 +04:00
|
|
|
| PPC_CACHE_DCBA | PPC_CACHE_LOCK \
|
|
|
|
| PPC_EXTERN | PPC_SEGMENT | PPC_6xx_TLB \
|
|
|
|
| PPC_74xx_TLB | PPC_40x_TLB | PPC_SEGMENT_64B \
|
|
|
|
| PPC_SLBI | PPC_WRTEE | PPC_40x_EXCP \
|
|
|
|
| PPC_405_MAC | PPC_440_SPEC | PPC_BOOKE \
|
|
|
|
| PPC_MFAPIDI | PPC_TLBIVA | PPC_TLBIVAX \
|
|
|
|
| PPC_4xx_COMMON | PPC_40x_ICBT | PPC_RFMCI \
|
|
|
|
| PPC_RFDI | PPC_DCR | PPC_DCRX | PPC_DCRUX \
|
2016-06-22 00:48:52 +03:00
|
|
|
| PPC_POPCNTWD | PPC_CILDST)
|
2011-10-30 19:51:24 +04:00
|
|
|
|
2011-05-01 01:34:58 +04:00
|
|
|
/* extended type values */
|
|
|
|
|
|
|
|
/* BookE 2.06 PowerPC specification */
|
|
|
|
PPC2_BOOKE206 = 0x0000000000000001ULL,
|
2011-10-17 22:15:41 +04:00
|
|
|
/* VSX (extensions to Altivec / VMX) */
|
|
|
|
PPC2_VSX = 0x0000000000000002ULL,
|
|
|
|
/* Decimal Floating Point (DFP) */
|
|
|
|
PPC2_DFP = 0x0000000000000004ULL,
|
2012-01-31 06:13:30 +04:00
|
|
|
/* Embedded.Processor Control */
|
|
|
|
PPC2_PRCNTL = 0x0000000000000008ULL,
|
2012-02-27 21:18:08 +04:00
|
|
|
/* Byte-reversed, indexed, double-word load and store */
|
|
|
|
PPC2_DBRX = 0x0000000000000010ULL,
|
2013-04-20 12:56:15 +04:00
|
|
|
/* Book I 2.05 PowerPC specification */
|
|
|
|
PPC2_ISA205 = 0x0000000000000020ULL,
|
2014-01-15 18:10:28 +04:00
|
|
|
/* VSX additions in ISA 2.07 */
|
|
|
|
PPC2_VSX207 = 0x0000000000000040ULL,
|
2014-01-07 20:05:49 +04:00
|
|
|
/* ISA 2.06B bpermd */
|
|
|
|
PPC2_PERM_ISA206 = 0x0000000000000080ULL,
|
2014-01-07 20:05:50 +04:00
|
|
|
/* ISA 2.06B divide extended variants */
|
|
|
|
PPC2_DIVE_ISA206 = 0x0000000000000100ULL,
|
2014-01-07 20:05:55 +04:00
|
|
|
/* ISA 2.06B larx/stcx. instructions */
|
|
|
|
PPC2_ATOMIC_ISA206 = 0x0000000000000200ULL,
|
2014-01-07 20:05:58 +04:00
|
|
|
/* ISA 2.06B floating point integer conversion */
|
|
|
|
PPC2_FP_CVT_ISA206 = 0x0000000000000400ULL,
|
2014-01-07 20:06:06 +04:00
|
|
|
/* ISA 2.06B floating point test instructions */
|
|
|
|
PPC2_FP_TST_ISA206 = 0x0000000000000800ULL,
|
2014-02-10 21:26:53 +04:00
|
|
|
/* ISA 2.07 bctar instruction */
|
|
|
|
PPC2_BCTAR_ISA207 = 0x0000000000001000ULL,
|
2014-02-10 21:26:56 +04:00
|
|
|
/* ISA 2.07 load/store quadword */
|
|
|
|
PPC2_LSQ_ISA207 = 0x0000000000002000ULL,
|
2014-02-13 01:22:52 +04:00
|
|
|
/* ISA 2.07 Altivec */
|
|
|
|
PPC2_ALTIVEC_207 = 0x0000000000004000ULL,
|
2014-03-07 08:37:39 +04:00
|
|
|
/* PowerISA 2.07 Book3s specification */
|
|
|
|
PPC2_ISA207S = 0x0000000000008000ULL,
|
2014-09-12 23:31:32 +04:00
|
|
|
/* Double precision floating point conversion for signed integer 64 */
|
|
|
|
PPC2_FP_CVT_S64 = 0x0000000000010000ULL,
|
2014-12-18 19:34:29 +03:00
|
|
|
/* Transactional Memory (ISA 2.07, Book II) */
|
|
|
|
PPC2_TM = 0x0000000000020000ULL,
|
2016-06-22 00:48:55 +03:00
|
|
|
/* Server PM instructgions (ISA 2.06, Book III) */
|
|
|
|
PPC2_PM_ISA206 = 0x0000000000040000ULL,
|
2016-07-26 14:58:25 +03:00
|
|
|
/* POWER ISA 3.0 */
|
|
|
|
PPC2_ISA300 = 0x0000000000080000ULL,
|
2011-10-30 19:51:24 +04:00
|
|
|
|
2013-10-22 15:05:46 +04:00
|
|
|
#define PPC_TCG_INSNS2 (PPC2_BOOKE206 | PPC2_VSX | PPC2_PRCNTL | PPC2_DBRX | \
|
2014-01-07 20:05:50 +04:00
|
|
|
PPC2_ISA205 | PPC2_VSX207 | PPC2_PERM_ISA206 | \
|
2014-01-07 20:05:58 +04:00
|
|
|
PPC2_DIVE_ISA206 | PPC2_ATOMIC_ISA206 | \
|
2014-02-10 21:26:53 +04:00
|
|
|
PPC2_FP_CVT_ISA206 | PPC2_FP_TST_ISA206 | \
|
2014-02-13 01:22:52 +04:00
|
|
|
PPC2_BCTAR_ISA207 | PPC2_LSQ_ISA207 | \
|
2014-09-12 23:31:32 +04:00
|
|
|
PPC2_ALTIVEC_207 | PPC2_ISA207S | PPC2_DFP | \
|
2016-07-26 14:58:25 +03:00
|
|
|
PPC2_FP_CVT_S64 | PPC2_TM | PPC2_PM_ISA206 | \
|
|
|
|
PPC2_ISA300)
|
2009-05-12 23:26:57 +04:00
|
|
|
};
|
|
|
|
|
2007-03-07 11:32:30 +03:00
|
|
|
/*****************************************************************************/
|
2019-03-21 08:29:36 +03:00
|
|
|
/*
|
|
|
|
* Memory access type :
|
2004-01-05 01:58:38 +03:00
|
|
|
* may be needed for precise access rights control and precise exceptions.
|
|
|
|
*/
|
2003-11-23 17:55:54 +03:00
|
|
|
enum {
|
2004-01-05 01:58:38 +03:00
|
|
|
/* 1 bit to define user level / supervisor access */
|
|
|
|
ACCESS_USER = 0x00,
|
|
|
|
ACCESS_SUPER = 0x01,
|
|
|
|
/* Type of instruction that generated the access */
|
|
|
|
ACCESS_CODE = 0x10, /* Code fetch access */
|
|
|
|
ACCESS_INT = 0x20, /* Integer load/store access */
|
|
|
|
ACCESS_FLOAT = 0x30, /* floating point load/store access */
|
|
|
|
ACCESS_RES = 0x40, /* load/store with reservation */
|
|
|
|
ACCESS_EXT = 0x50, /* external access */
|
|
|
|
ACCESS_CACHE = 0x60, /* Cache manipulation */
|
|
|
|
};
|
|
|
|
|
2019-03-21 08:29:36 +03:00
|
|
|
/*
|
|
|
|
* Hardware interrupt sources:
|
|
|
|
* all those exception can be raised simulteaneously
|
2007-03-30 13:38:04 +04:00
|
|
|
*/
|
2007-04-10 02:45:36 +04:00
|
|
|
/* Input pins definitions */
|
|
|
|
enum {
|
|
|
|
/* 6xx bus input pins */
|
2007-04-13 01:24:29 +04:00
|
|
|
PPC6xx_INPUT_HRESET = 0,
|
|
|
|
PPC6xx_INPUT_SRESET = 1,
|
|
|
|
PPC6xx_INPUT_CKSTP_IN = 2,
|
|
|
|
PPC6xx_INPUT_MCP = 3,
|
|
|
|
PPC6xx_INPUT_SMI = 4,
|
|
|
|
PPC6xx_INPUT_INT = 5,
|
2007-10-14 13:27:16 +04:00
|
|
|
PPC6xx_INPUT_TBEN = 6,
|
|
|
|
PPC6xx_INPUT_WAKEUP = 7,
|
|
|
|
PPC6xx_INPUT_NB,
|
2007-04-13 01:24:29 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
2007-04-10 02:45:36 +04:00
|
|
|
/* Embedded PowerPC input pins */
|
2007-04-13 01:24:29 +04:00
|
|
|
PPCBookE_INPUT_HRESET = 0,
|
|
|
|
PPCBookE_INPUT_SRESET = 1,
|
|
|
|
PPCBookE_INPUT_CKSTP_IN = 2,
|
|
|
|
PPCBookE_INPUT_MCP = 3,
|
|
|
|
PPCBookE_INPUT_SMI = 4,
|
|
|
|
PPCBookE_INPUT_INT = 5,
|
|
|
|
PPCBookE_INPUT_CINT = 6,
|
2007-10-14 13:27:16 +04:00
|
|
|
PPCBookE_INPUT_NB,
|
2007-04-13 01:24:29 +04:00
|
|
|
};
|
|
|
|
|
2009-03-02 19:42:32 +03:00
|
|
|
enum {
|
|
|
|
/* PowerPC E500 input pins */
|
|
|
|
PPCE500_INPUT_RESET_CORE = 0,
|
|
|
|
PPCE500_INPUT_MCK = 1,
|
|
|
|
PPCE500_INPUT_CINT = 3,
|
|
|
|
PPCE500_INPUT_INT = 4,
|
|
|
|
PPCE500_INPUT_DEBUG = 6,
|
|
|
|
PPCE500_INPUT_NB,
|
|
|
|
};
|
|
|
|
|
Great rework and cleanups to ease PowerPC implementations definitions.
* cleanup cpu.h, removing definitions used only in translate.c/translate_init.c
* add new flags to define instructions sets more precisely
* various changes in MMU models definitions
* add definitions for PowerPC 440/460 support (insns and SPRs).
* add definitions for PowerPC 401/403 and 620 input pins model
* Fix definitions for most PowerPC 401, 403, 405, 440, 601, 602, 603 and 7x0
* Preliminary support for PowerPC 74xx (aka G4) without altivec.
* Code provision for other PowerPC support (7x5, 970, ...).
* New SPR and PVR defined, from PowerPC 2.04 specification and other sources
* Misc code bugs, error messages and styles fixes.
* Update status files for PowerPC cores support.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@3244 c046a42c-6fe2-441c-8c8c-71466251a162
2007-09-27 03:54:22 +04:00
|
|
|
enum {
|
2007-10-01 05:27:10 +04:00
|
|
|
/* PowerPC 40x input pins */
|
|
|
|
PPC40x_INPUT_RESET_CORE = 0,
|
|
|
|
PPC40x_INPUT_RESET_CHIP = 1,
|
|
|
|
PPC40x_INPUT_RESET_SYS = 2,
|
|
|
|
PPC40x_INPUT_CINT = 3,
|
|
|
|
PPC40x_INPUT_INT = 4,
|
|
|
|
PPC40x_INPUT_HALT = 5,
|
|
|
|
PPC40x_INPUT_DEBUG = 6,
|
|
|
|
PPC40x_INPUT_NB,
|
2007-04-10 02:45:36 +04:00
|
|
|
};
|
|
|
|
|
2007-11-18 01:42:36 +03:00
|
|
|
enum {
|
|
|
|
/* RCPU input pins */
|
|
|
|
PPCRCPU_INPUT_PORESET = 0,
|
|
|
|
PPCRCPU_INPUT_HRESET = 1,
|
|
|
|
PPCRCPU_INPUT_SRESET = 2,
|
|
|
|
PPCRCPU_INPUT_IRQ0 = 3,
|
|
|
|
PPCRCPU_INPUT_IRQ1 = 4,
|
|
|
|
PPCRCPU_INPUT_IRQ2 = 5,
|
|
|
|
PPCRCPU_INPUT_IRQ3 = 6,
|
|
|
|
PPCRCPU_INPUT_IRQ4 = 7,
|
|
|
|
PPCRCPU_INPUT_IRQ5 = 8,
|
|
|
|
PPCRCPU_INPUT_IRQ6 = 9,
|
|
|
|
PPCRCPU_INPUT_IRQ7 = 10,
|
|
|
|
PPCRCPU_INPUT_NB,
|
|
|
|
};
|
|
|
|
|
2007-10-03 05:05:39 +04:00
|
|
|
#if defined(TARGET_PPC64)
|
2007-04-16 11:34:39 +04:00
|
|
|
enum {
|
|
|
|
/* PowerPC 970 input pins */
|
|
|
|
PPC970_INPUT_HRESET = 0,
|
|
|
|
PPC970_INPUT_SRESET = 1,
|
|
|
|
PPC970_INPUT_CKSTP = 2,
|
|
|
|
PPC970_INPUT_TBEN = 3,
|
|
|
|
PPC970_INPUT_MCP = 4,
|
|
|
|
PPC970_INPUT_INT = 5,
|
|
|
|
PPC970_INPUT_THINT = 6,
|
2007-11-17 05:04:00 +03:00
|
|
|
PPC970_INPUT_NB,
|
2011-04-01 08:15:19 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
/* POWER7 input pins */
|
|
|
|
POWER7_INPUT_INT = 0,
|
2019-03-21 08:29:36 +03:00
|
|
|
/*
|
|
|
|
* POWER7 probably has other inputs, but we don't care about them
|
2011-04-01 08:15:19 +04:00
|
|
|
* for any existing machine. We can wire these up when we need
|
2019-03-21 08:29:36 +03:00
|
|
|
* them
|
|
|
|
*/
|
2011-04-01 08:15:19 +04:00
|
|
|
POWER7_INPUT_NB,
|
2007-04-16 11:34:39 +04:00
|
|
|
};
|
2019-02-15 19:16:47 +03:00
|
|
|
|
|
|
|
enum {
|
|
|
|
/* POWER9 input pins */
|
|
|
|
POWER9_INPUT_INT = 0,
|
|
|
|
POWER9_INPUT_HINT = 1,
|
|
|
|
POWER9_INPUT_NB,
|
|
|
|
};
|
2007-10-03 05:05:39 +04:00
|
|
|
#endif
|
2007-04-16 11:34:39 +04:00
|
|
|
|
2007-04-10 02:45:36 +04:00
|
|
|
/* Hardware exceptions definitions */
|
2007-03-30 13:38:04 +04:00
|
|
|
enum {
|
2007-04-10 02:45:36 +04:00
|
|
|
/* External hardware exception sources */
|
2007-09-29 17:06:16 +04:00
|
|
|
PPC_INTERRUPT_RESET = 0, /* Reset exception */
|
2007-10-14 13:27:16 +04:00
|
|
|
PPC_INTERRUPT_WAKEUP, /* Wakeup exception */
|
|
|
|
PPC_INTERRUPT_MCK, /* Machine check exception */
|
|
|
|
PPC_INTERRUPT_EXT, /* External interrupt */
|
|
|
|
PPC_INTERRUPT_SMI, /* System management interrupt */
|
|
|
|
PPC_INTERRUPT_CEXT, /* Critical external interrupt */
|
|
|
|
PPC_INTERRUPT_DEBUG, /* External debug exception */
|
|
|
|
PPC_INTERRUPT_THERM, /* Thermal exception */
|
2007-04-10 02:45:36 +04:00
|
|
|
/* Internal hardware exception sources */
|
2007-10-14 13:27:16 +04:00
|
|
|
PPC_INTERRUPT_DECR, /* Decrementer exception */
|
|
|
|
PPC_INTERRUPT_HDECR, /* Hypervisor decrementer exception */
|
|
|
|
PPC_INTERRUPT_PIT, /* Programmable inteval timer interrupt */
|
|
|
|
PPC_INTERRUPT_FIT, /* Fixed interval timer interrupt */
|
|
|
|
PPC_INTERRUPT_WDT, /* Watchdog timer interrupt */
|
|
|
|
PPC_INTERRUPT_CDOORBELL, /* Critical doorbell interrupt */
|
|
|
|
PPC_INTERRUPT_DOORBELL, /* Doorbell interrupt */
|
|
|
|
PPC_INTERRUPT_PERFM, /* Performance monitor interrupt */
|
2016-06-22 00:48:49 +03:00
|
|
|
PPC_INTERRUPT_HMI, /* Hypervisor Maintainance interrupt */
|
|
|
|
PPC_INTERRUPT_HDOORBELL, /* Hypervisor Doorbell interrupt */
|
2019-02-15 19:16:46 +03:00
|
|
|
PPC_INTERRUPT_HVIRT, /* Hypervisor virtualization interrupt */
|
2007-03-30 13:38:04 +04:00
|
|
|
};
|
|
|
|
|
2014-05-23 06:26:52 +04:00
|
|
|
/* Processor Compatibility mask (PCR) */
|
|
|
|
enum {
|
2017-12-22 12:55:51 +03:00
|
|
|
PCR_COMPAT_2_05 = PPC_BIT(62),
|
|
|
|
PCR_COMPAT_2_06 = PPC_BIT(61),
|
|
|
|
PCR_COMPAT_2_07 = PPC_BIT(60),
|
|
|
|
PCR_COMPAT_3_00 = PPC_BIT(59),
|
|
|
|
PCR_VEC_DIS = PPC_BIT(0), /* Vec. disable (bit NA since POWER8) */
|
|
|
|
PCR_VSX_DIS = PPC_BIT(1), /* VSX disable (bit NA since POWER8) */
|
|
|
|
PCR_TM_DIS = PPC_BIT(2), /* Trans. memory disable (POWER8) */
|
2014-05-23 06:26:52 +04:00
|
|
|
};
|
|
|
|
|
2016-03-21 15:52:31 +03:00
|
|
|
/* HMER/HMEER */
|
|
|
|
enum {
|
2017-12-22 12:55:51 +03:00
|
|
|
HMER_MALFUNCTION_ALERT = PPC_BIT(0),
|
|
|
|
HMER_PROC_RECV_DONE = PPC_BIT(2),
|
|
|
|
HMER_PROC_RECV_ERROR_MASKED = PPC_BIT(3),
|
|
|
|
HMER_TFAC_ERROR = PPC_BIT(4),
|
|
|
|
HMER_TFMR_PARITY_ERROR = PPC_BIT(5),
|
|
|
|
HMER_XSCOM_FAIL = PPC_BIT(8),
|
|
|
|
HMER_XSCOM_DONE = PPC_BIT(9),
|
|
|
|
HMER_PROC_RECV_AGAIN = PPC_BIT(11),
|
|
|
|
HMER_WARN_RISE = PPC_BIT(14),
|
|
|
|
HMER_WARN_FALL = PPC_BIT(15),
|
|
|
|
HMER_SCOM_FIR_HMI = PPC_BIT(16),
|
|
|
|
HMER_TRIG_FIR_HMI = PPC_BIT(17),
|
|
|
|
HMER_HYP_RESOURCE_ERR = PPC_BIT(20),
|
|
|
|
HMER_XSCOM_STATUS_MASK = PPC_BITMASK(21, 23),
|
2016-03-21 15:52:31 +03:00
|
|
|
};
|
|
|
|
|
2016-04-03 20:57:50 +03:00
|
|
|
/* Alternate Interrupt Location (AIL) */
|
|
|
|
enum {
|
|
|
|
AIL_NONE = 0,
|
|
|
|
AIL_RESERVED = 1,
|
|
|
|
AIL_0001_8000 = 2,
|
|
|
|
AIL_C000_0000_0000_4000 = 3,
|
|
|
|
};
|
|
|
|
|
2004-01-05 01:58:38 +03:00
|
|
|
/*****************************************************************************/
|
|
|
|
|
target/ppc: support for 32-bit carry and overflow
POWER ISA 3.0 adds CA32 and OV32 status in 64-bit mode. Add the flags
and corresponding defines.
Moreover, CA32 is updated when CA is updated and OV32 is updated when OV
is updated.
Arithmetic instructions:
* Addition and Substractions:
addic, addic., subfic, addc, subfc, adde, subfe, addme, subfme,
addze, and subfze always updates CA and CA32.
=> CA reflects the carry out of bit 0 in 64-bit mode and out of
bit 32 in 32-bit mode.
=> CA32 reflects the carry out of bit 32 independent of the
mode.
=> SO and OV reflects overflow of the 64-bit result in 64-bit
mode and overflow of the low-order 32-bit result in 32-bit
mode
=> OV32 reflects overflow of the low-order 32-bit independent of
the mode
* Multiply Low and Divide:
For mulld, divd, divde, divdu and divdeu: SO, OV, and OV32 bits
reflects overflow of the 64-bit result
For mullw, divw, divwe, divwu and divweu: SO, OV, and OV32 bits
reflects overflow of the 32-bit result
* Negate with OE=1 (nego)
For 64-bit mode if the register RA contains
0x8000_0000_0000_0000, OV and OV32 are set to 1.
For 32-bit mode if the register RA contains 0x8000_0000, OV and
OV32 are set to 1.
Signed-off-by: Nikunj A Dadhania <nikunj@linux.vnet.ibm.com>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
2017-02-27 07:57:54 +03:00
|
|
|
#define is_isa300(ctx) (!!(ctx->insns_flags2 & PPC2_ISA300))
|
2017-02-22 14:44:34 +03:00
|
|
|
target_ulong cpu_read_xer(CPUPPCState *env);
|
|
|
|
void cpu_write_xer(CPUPPCState *env, target_ulong xer);
|
2013-02-20 11:52:13 +04:00
|
|
|
|
2019-03-22 21:03:51 +03:00
|
|
|
/*
|
|
|
|
* All 64-bit server processors compliant with arch 2.x, ie. 970 and newer,
|
|
|
|
* have PPC_SEGMENT_64B.
|
|
|
|
*/
|
|
|
|
#define is_book3s_arch2x(ctx) (!!((ctx)->insns_flags & PPC_SEGMENT_64B))
|
|
|
|
|
2012-03-14 04:38:22 +04:00
|
|
|
static inline void cpu_get_tb_cpu_state(CPUPPCState *env, target_ulong *pc,
|
2016-04-07 20:19:22 +03:00
|
|
|
target_ulong *cs_base, uint32_t *flags)
|
2008-11-18 22:46:41 +03:00
|
|
|
{
|
|
|
|
*pc = env->nip;
|
|
|
|
*cs_base = 0;
|
|
|
|
*flags = env->hflags;
|
|
|
|
}
|
|
|
|
|
2016-07-27 09:56:19 +03:00
|
|
|
void QEMU_NORETURN raise_exception(CPUPPCState *env, uint32_t exception);
|
|
|
|
void QEMU_NORETURN raise_exception_ra(CPUPPCState *env, uint32_t exception,
|
|
|
|
uintptr_t raddr);
|
|
|
|
void QEMU_NORETURN raise_exception_err(CPUPPCState *env, uint32_t exception,
|
|
|
|
uint32_t error_code);
|
|
|
|
void QEMU_NORETURN raise_exception_err_ra(CPUPPCState *env, uint32_t exception,
|
|
|
|
uint32_t error_code, uintptr_t raddr);
|
|
|
|
|
2011-05-01 01:34:58 +04:00
|
|
|
#if !defined(CONFIG_USER_ONLY)
|
2012-03-14 04:38:22 +04:00
|
|
|
static inline int booke206_tlbm_id(CPUPPCState *env, ppcmas_tlb_t *tlbm)
|
2011-05-01 01:34:58 +04:00
|
|
|
{
|
2011-06-16 20:45:43 +04:00
|
|
|
uintptr_t tlbml = (uintptr_t)tlbm;
|
2011-06-17 03:00:28 +04:00
|
|
|
uintptr_t tlbl = (uintptr_t)env->tlb.tlbm;
|
2011-05-01 01:34:58 +04:00
|
|
|
|
2011-06-17 03:00:28 +04:00
|
|
|
return (tlbml - tlbl) / sizeof(env->tlb.tlbm[0]);
|
2011-05-01 01:34:58 +04:00
|
|
|
}
|
|
|
|
|
2012-03-14 04:38:22 +04:00
|
|
|
static inline int booke206_tlb_size(CPUPPCState *env, int tlbn)
|
2011-05-01 01:34:58 +04:00
|
|
|
{
|
|
|
|
uint32_t tlbncfg = env->spr[SPR_BOOKE_TLB0CFG + tlbn];
|
|
|
|
int r = tlbncfg & TLBnCFG_N_ENTRY;
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
2012-03-14 04:38:22 +04:00
|
|
|
static inline int booke206_tlb_ways(CPUPPCState *env, int tlbn)
|
2011-05-01 01:34:58 +04:00
|
|
|
{
|
|
|
|
uint32_t tlbncfg = env->spr[SPR_BOOKE_TLB0CFG + tlbn];
|
|
|
|
int r = tlbncfg >> TLBnCFG_ASSOC_SHIFT;
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
2012-03-14 04:38:22 +04:00
|
|
|
static inline int booke206_tlbm_to_tlbn(CPUPPCState *env, ppcmas_tlb_t *tlbm)
|
2011-05-01 01:34:58 +04:00
|
|
|
{
|
2011-06-16 20:45:43 +04:00
|
|
|
int id = booke206_tlbm_id(env, tlbm);
|
2011-05-01 01:34:58 +04:00
|
|
|
int end = 0;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 0; i < BOOKE206_MAX_TLBN; i++) {
|
|
|
|
end += booke206_tlb_size(env, i);
|
|
|
|
if (id < end) {
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-03-23 05:07:57 +03:00
|
|
|
cpu_abort(env_cpu(env), "Unknown TLBe: %d\n", id);
|
2011-05-01 01:34:58 +04:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2012-03-14 04:38:22 +04:00
|
|
|
static inline int booke206_tlbm_to_way(CPUPPCState *env, ppcmas_tlb_t *tlb)
|
2011-05-01 01:34:58 +04:00
|
|
|
{
|
2011-06-16 20:45:43 +04:00
|
|
|
int tlbn = booke206_tlbm_to_tlbn(env, tlb);
|
|
|
|
int tlbid = booke206_tlbm_id(env, tlb);
|
2011-05-01 01:34:58 +04:00
|
|
|
return tlbid & (booke206_tlb_ways(env, tlbn) - 1);
|
|
|
|
}
|
|
|
|
|
2012-03-14 04:38:22 +04:00
|
|
|
static inline ppcmas_tlb_t *booke206_get_tlbm(CPUPPCState *env, const int tlbn,
|
2011-05-01 01:34:58 +04:00
|
|
|
target_ulong ea, int way)
|
|
|
|
{
|
|
|
|
int r;
|
|
|
|
uint32_t ways = booke206_tlb_ways(env, tlbn);
|
2015-03-23 18:29:26 +03:00
|
|
|
int ways_bits = ctz32(ways);
|
|
|
|
int tlb_bits = ctz32(booke206_tlb_size(env, tlbn));
|
2011-05-01 01:34:58 +04:00
|
|
|
int i;
|
|
|
|
|
|
|
|
way &= ways - 1;
|
|
|
|
ea >>= MAS2_EPN_SHIFT;
|
|
|
|
ea &= (1 << (tlb_bits - ways_bits)) - 1;
|
|
|
|
r = (ea << ways_bits) | way;
|
|
|
|
|
2012-01-25 19:27:26 +04:00
|
|
|
if (r >= booke206_tlb_size(env, tlbn)) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2011-05-01 01:34:58 +04:00
|
|
|
/* bump up to tlbn index */
|
|
|
|
for (i = 0; i < tlbn; i++) {
|
|
|
|
r += booke206_tlb_size(env, i);
|
|
|
|
}
|
|
|
|
|
2011-06-17 03:00:28 +04:00
|
|
|
return &env->tlb.tlbm[r];
|
2011-05-01 01:34:58 +04:00
|
|
|
}
|
|
|
|
|
2012-01-21 07:45:46 +04:00
|
|
|
/* returns bitmap of supported page sizes for a given TLB */
|
2012-03-14 04:38:22 +04:00
|
|
|
static inline uint32_t booke206_tlbnps(CPUPPCState *env, const int tlbn)
|
2012-01-21 07:45:46 +04:00
|
|
|
{
|
|
|
|
uint32_t ret = 0;
|
|
|
|
|
2017-08-07 18:50:45 +03:00
|
|
|
if ((env->spr[SPR_MMUCFG] & MMUCFG_MAVN) == MMUCFG_MAVN_V2) {
|
|
|
|
/* MAV2 */
|
2012-01-21 07:45:46 +04:00
|
|
|
ret = env->spr[SPR_BOOKE_TLB0PS + tlbn];
|
|
|
|
} else {
|
|
|
|
uint32_t tlbncfg = env->spr[SPR_BOOKE_TLB0CFG + tlbn];
|
|
|
|
uint32_t min = (tlbncfg & TLBnCFG_MINSIZE) >> TLBnCFG_MINSIZE_SHIFT;
|
|
|
|
uint32_t max = (tlbncfg & TLBnCFG_MAXSIZE) >> TLBnCFG_MAXSIZE_SHIFT;
|
|
|
|
int i;
|
|
|
|
for (i = min; i <= max; i++) {
|
|
|
|
ret |= (1 << (i << 1));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2017-08-07 18:50:46 +03:00
|
|
|
static inline void booke206_fixed_size_tlbn(CPUPPCState *env, const int tlbn,
|
|
|
|
ppcmas_tlb_t *tlb)
|
|
|
|
{
|
|
|
|
uint8_t i;
|
|
|
|
int32_t tsize = -1;
|
|
|
|
|
|
|
|
for (i = 0; i < 32; i++) {
|
|
|
|
if ((env->spr[SPR_BOOKE_TLB0PS + tlbn]) & (1ULL << i)) {
|
|
|
|
if (tsize == -1) {
|
|
|
|
tsize = i;
|
|
|
|
} else {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* TLBnPS unimplemented? Odd.. */
|
|
|
|
assert(tsize != -1);
|
|
|
|
tlb->mas1 &= ~MAS1_TSIZE_MASK;
|
|
|
|
tlb->mas1 |= ((uint32_t)tsize) << MAS1_TSIZE_SHIFT;
|
|
|
|
}
|
|
|
|
|
2011-05-01 01:34:58 +04:00
|
|
|
#endif
|
|
|
|
|
2012-06-20 23:20:29 +04:00
|
|
|
static inline bool msr_is_64bit(CPUPPCState *env, target_ulong msr)
|
|
|
|
{
|
|
|
|
if (env->mmu_model == POWERPC_MMU_BOOKE206) {
|
|
|
|
return msr & (1ULL << MSR_CM);
|
|
|
|
}
|
|
|
|
|
|
|
|
return msr & (1ULL << MSR_SF);
|
|
|
|
}
|
|
|
|
|
2016-04-14 18:14:52 +03:00
|
|
|
/**
|
|
|
|
* Check whether register rx is in the range between start and
|
|
|
|
* start + nregs (as needed by the LSWX and LSWI instructions)
|
|
|
|
*/
|
|
|
|
static inline bool lsw_reg_in_range(int start, int nregs, int rx)
|
|
|
|
{
|
|
|
|
return (start + nregs <= 32 && rx >= start && rx < start + nregs) ||
|
|
|
|
(start + nregs > 32 && (rx >= start || rx < start + nregs - 32));
|
|
|
|
}
|
|
|
|
|
2019-01-02 12:14:22 +03:00
|
|
|
/* Accessors for FP, VMX and VSX registers */
|
2019-03-07 21:05:16 +03:00
|
|
|
#if defined(HOST_WORDS_BIGENDIAN)
|
|
|
|
#define VsrB(i) u8[i]
|
|
|
|
#define VsrSB(i) s8[i]
|
|
|
|
#define VsrH(i) u16[i]
|
|
|
|
#define VsrSH(i) s16[i]
|
|
|
|
#define VsrW(i) u32[i]
|
|
|
|
#define VsrSW(i) s32[i]
|
|
|
|
#define VsrD(i) u64[i]
|
|
|
|
#define VsrSD(i) s64[i]
|
|
|
|
#else
|
|
|
|
#define VsrB(i) u8[15 - (i)]
|
|
|
|
#define VsrSB(i) s8[15 - (i)]
|
|
|
|
#define VsrH(i) u16[7 - (i)]
|
|
|
|
#define VsrSH(i) s16[7 - (i)]
|
|
|
|
#define VsrW(i) u32[3 - (i)]
|
|
|
|
#define VsrSW(i) s32[3 - (i)]
|
|
|
|
#define VsrD(i) u64[1 - (i)]
|
|
|
|
#define VsrSD(i) s64[1 - (i)]
|
|
|
|
#endif
|
|
|
|
|
2019-03-07 21:05:20 +03:00
|
|
|
static inline int vsr64_offset(int i, bool high)
|
2019-03-07 21:05:14 +03:00
|
|
|
{
|
2019-03-07 21:05:20 +03:00
|
|
|
return offsetof(CPUPPCState, vsr[i].VsrD(high ? 0 : 1));
|
2019-03-07 21:05:14 +03:00
|
|
|
}
|
|
|
|
|
2019-03-07 21:05:20 +03:00
|
|
|
static inline int vsr_full_offset(int i)
|
2019-01-02 12:14:22 +03:00
|
|
|
{
|
2019-03-07 21:05:20 +03:00
|
|
|
return offsetof(CPUPPCState, vsr[i].u64[0]);
|
2019-01-02 12:14:22 +03:00
|
|
|
}
|
|
|
|
|
2019-03-07 21:05:20 +03:00
|
|
|
static inline int fpr_offset(int i)
|
2019-03-07 21:05:15 +03:00
|
|
|
{
|
2019-03-07 21:05:20 +03:00
|
|
|
return vsr64_offset(i, true);
|
2019-03-07 21:05:15 +03:00
|
|
|
}
|
|
|
|
|
2019-03-07 21:05:20 +03:00
|
|
|
static inline uint64_t *cpu_fpr_ptr(CPUPPCState *env, int i)
|
2019-03-07 21:05:17 +03:00
|
|
|
{
|
2019-03-07 21:05:20 +03:00
|
|
|
return (uint64_t *)((uintptr_t)env + fpr_offset(i));
|
2019-03-07 21:05:17 +03:00
|
|
|
}
|
|
|
|
|
2019-01-02 12:14:22 +03:00
|
|
|
static inline uint64_t *cpu_vsrl_ptr(CPUPPCState *env, int i)
|
|
|
|
{
|
2019-03-07 21:05:20 +03:00
|
|
|
return (uint64_t *)((uintptr_t)env + vsr64_offset(i, false));
|
2019-01-02 12:14:22 +03:00
|
|
|
}
|
|
|
|
|
2019-03-07 21:05:18 +03:00
|
|
|
static inline long avr64_offset(int i, bool high)
|
|
|
|
{
|
2019-03-07 21:05:20 +03:00
|
|
|
return vsr64_offset(i + 32, high);
|
2019-03-07 21:05:18 +03:00
|
|
|
}
|
|
|
|
|
2019-03-07 21:05:17 +03:00
|
|
|
static inline int avr_full_offset(int i)
|
|
|
|
{
|
|
|
|
return vsr_full_offset(i + 32);
|
|
|
|
}
|
|
|
|
|
2019-01-02 12:14:22 +03:00
|
|
|
static inline ppc_avr_t *cpu_avr_ptr(CPUPPCState *env, int i)
|
|
|
|
{
|
2019-03-07 21:05:17 +03:00
|
|
|
return (ppc_avr_t *)((uintptr_t)env + avr_full_offset(i));
|
2019-01-02 12:14:22 +03:00
|
|
|
}
|
|
|
|
|
2019-04-17 22:17:58 +03:00
|
|
|
void dump_mmu(CPUPPCState *env);
|
2011-08-18 14:38:42 +04:00
|
|
|
|
2016-01-15 18:00:18 +03:00
|
|
|
void ppc_maybe_bswap_register(CPUPPCState *env, uint8_t *mem_buf, int len);
|
2016-06-29 12:05:55 +03:00
|
|
|
#endif /* PPC_CPU_H */
|