ppc patch queue for qemu-2.5 20151130
target-ppc and related bugfix patches for qemu-2.5 I don't have the facilities to test the Macintosh and BookE related patches. I've sanity checked them (inspection + make check), but I'm otherwise relying on the submitters. -----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQIcBAABAgAGBQJWXAvZAAoJEGw4ysog2bOSoysQALRPBXJfhPpX/tZ8+EtS5nto vyjghW3UGQWOi3TTBedVbFqvaOpkqh2MjtE3WVtK+TK0vy9uY1hOjBhJrJjL93eZ pC0Soh2cN7vsKxkDF18UFhISxnfzmozQ4F8UnhaX/IO3HiIIzhfaIAbOZ1ztrPNG 72YztHUjilpfS2cX4fYbpk+znGzOaNCS99iSbxMsXiM44DT8ehp1Zs9LAfP+PoPa JN7138vmVVJmkkkeHh74SnG9XATvwtPnjvcf9sRAq5FjAW4+BsfeXYTK1wDouXGc nm4DlmiQNFXJMJ0Wa0rVa61WMmSrSNUe++HNPV03huVrrZPmVByH2l7qQHBufJ3e BVciQvtA7oVt6Zu34qHLTORxkSS7pg6SOqNTTNPPfdBzHg0WCOj20EYO8I76fCBN Pz6iHEeLfUmCWNKVcNix+S0AN5X/oalG/VkhH9JPzyGmJRLPBDE/TG4qgdMXIN97 AlnVb6l4zDNj6XVuKKuWNIAP9bCZS2nOn5huijL3YlG4HhymAXqfx/Gb9pyJM9jq sDR+m2r5ku+D6keyfyGy4Yko0+1THZ6ViJe7d+3oELV4wXnf4Mt7LaJbdoL+uicy OZEnPknu/7bM7IFBGOFVxPRrcVkPaiwFOXAa+7evcDM3MiJvHfuT8SHiu7HUgyX0 KDov5hfObYa9W88FlkHr =yDkn -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/dgibson/tags/ppc-for-2.5-20151130' into staging ppc patch queue for qemu-2.5 20151130 target-ppc and related bugfix patches for qemu-2.5 I don't have the facilities to test the Macintosh and BookE related patches. I've sanity checked them (inspection + make check), but I'm otherwise relying on the submitters. # gpg: Signature made Mon 30 Nov 2015 08:42:01 GMT using RSA key ID 20D9B392 # gpg: Good signature from "David Gibson <david@gibson.dropbear.id.au>" # gpg: aka "David Gibson (Red Hat) <dgibson@redhat.com>" # gpg: aka "David Gibson (ozlabs.org) <dgibson@ozlabs.org>" # gpg: WARNING: This key is not certified with sufficiently trusted signatures! # gpg: It is not certain that the signature belongs to the owner. # Primary key fingerprint: 75F4 6586 AE61 A66C C44E 87DC 6C38 CACA 20D9 B392 * remotes/dgibson/tags/ppc-for-2.5-20151130: target-ppc/fpu_helper: fix FPSCR_FX bit shift operation target-ppc: Move the FPSCR bit update macros to cpu.h hw/ppc/ppc405_boards: Fix infinite recursion by converting taihu_cpld from old_mmio hw/ppc/spapr: Remove duplicated "pseries" alias mac_dbdma: always initialize channel field in DBDMA_channel Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
a2485925f7
@ -557,7 +557,6 @@ void DBDMA_register_channel(void *dbdma, int nchan, qemu_irq irq,
|
|||||||
DBDMA_DPRINTF("DBDMA_register_channel 0x%x\n", nchan);
|
DBDMA_DPRINTF("DBDMA_register_channel 0x%x\n", nchan);
|
||||||
|
|
||||||
ch->irq = irq;
|
ch->irq = irq;
|
||||||
ch->channel = nchan;
|
|
||||||
ch->rw = rw;
|
ch->rw = rw;
|
||||||
ch->flush = flush;
|
ch->flush = flush;
|
||||||
ch->io.opaque = opaque;
|
ch->io.opaque = opaque;
|
||||||
@ -753,6 +752,7 @@ void* DBDMA_init (MemoryRegion **dbdma_mem)
|
|||||||
for (i = 0; i < DBDMA_CHANNELS; i++) {
|
for (i = 0; i < DBDMA_CHANNELS; i++) {
|
||||||
DBDMA_io *io = &s->channels[i].io;
|
DBDMA_io *io = &s->channels[i].io;
|
||||||
qemu_iovec_init(&io->iov, 1);
|
qemu_iovec_init(&io->iov, 1);
|
||||||
|
s->channels[i].channel = i;
|
||||||
}
|
}
|
||||||
|
|
||||||
memory_region_init_io(&s->mem, NULL, &dbdma_ops, s, "dbdma", 0x1000);
|
memory_region_init_io(&s->mem, NULL, &dbdma_ops, s, "dbdma", 0x1000);
|
||||||
|
@ -408,7 +408,7 @@ struct taihu_cpld_t {
|
|||||||
uint8_t reg1;
|
uint8_t reg1;
|
||||||
};
|
};
|
||||||
|
|
||||||
static uint32_t taihu_cpld_readb (void *opaque, hwaddr addr)
|
static uint64_t taihu_cpld_read(void *opaque, hwaddr addr, unsigned size)
|
||||||
{
|
{
|
||||||
taihu_cpld_t *cpld;
|
taihu_cpld_t *cpld;
|
||||||
uint32_t ret;
|
uint32_t ret;
|
||||||
@ -429,8 +429,8 @@ static uint32_t taihu_cpld_readb (void *opaque, hwaddr addr)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void taihu_cpld_writeb (void *opaque,
|
static void taihu_cpld_write(void *opaque, hwaddr addr,
|
||||||
hwaddr addr, uint32_t value)
|
uint64_t value, unsigned size)
|
||||||
{
|
{
|
||||||
taihu_cpld_t *cpld;
|
taihu_cpld_t *cpld;
|
||||||
|
|
||||||
@ -447,48 +447,12 @@ static void taihu_cpld_writeb (void *opaque,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static uint32_t taihu_cpld_readw (void *opaque, hwaddr addr)
|
|
||||||
{
|
|
||||||
uint32_t ret;
|
|
||||||
|
|
||||||
ret = taihu_cpld_readb(opaque, addr) << 8;
|
|
||||||
ret |= taihu_cpld_readb(opaque, addr + 1);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void taihu_cpld_writew (void *opaque,
|
|
||||||
hwaddr addr, uint32_t value)
|
|
||||||
{
|
|
||||||
taihu_cpld_writeb(opaque, addr, (value >> 8) & 0xFF);
|
|
||||||
taihu_cpld_writeb(opaque, addr + 1, value & 0xFF);
|
|
||||||
}
|
|
||||||
|
|
||||||
static uint32_t taihu_cpld_readl (void *opaque, hwaddr addr)
|
|
||||||
{
|
|
||||||
uint32_t ret;
|
|
||||||
|
|
||||||
ret = taihu_cpld_readb(opaque, addr) << 24;
|
|
||||||
ret |= taihu_cpld_readb(opaque, addr + 1) << 16;
|
|
||||||
ret |= taihu_cpld_readb(opaque, addr + 2) << 8;
|
|
||||||
ret |= taihu_cpld_readb(opaque, addr + 3);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void taihu_cpld_writel (void *opaque,
|
|
||||||
hwaddr addr, uint32_t value)
|
|
||||||
{
|
|
||||||
taihu_cpld_writel(opaque, addr, (value >> 24) & 0xFF);
|
|
||||||
taihu_cpld_writel(opaque, addr + 1, (value >> 16) & 0xFF);
|
|
||||||
taihu_cpld_writel(opaque, addr + 2, (value >> 8) & 0xFF);
|
|
||||||
taihu_cpld_writeb(opaque, addr + 3, value & 0xFF);
|
|
||||||
}
|
|
||||||
|
|
||||||
static const MemoryRegionOps taihu_cpld_ops = {
|
static const MemoryRegionOps taihu_cpld_ops = {
|
||||||
.old_mmio = {
|
.read = taihu_cpld_read,
|
||||||
.read = { taihu_cpld_readb, taihu_cpld_readw, taihu_cpld_readl, },
|
.write = taihu_cpld_write,
|
||||||
.write = { taihu_cpld_writeb, taihu_cpld_writew, taihu_cpld_writel, },
|
.impl = {
|
||||||
|
.min_access_size = 1,
|
||||||
|
.max_access_size = 1,
|
||||||
},
|
},
|
||||||
.endianness = DEVICE_NATIVE_ENDIAN,
|
.endianness = DEVICE_NATIVE_ENDIAN,
|
||||||
};
|
};
|
||||||
|
@ -2423,8 +2423,6 @@ static void spapr_machine_2_4_class_init(ObjectClass *oc, void *data)
|
|||||||
MachineClass *mc = MACHINE_CLASS(oc);
|
MachineClass *mc = MACHINE_CLASS(oc);
|
||||||
|
|
||||||
mc->desc = "pSeries Logical Partition (PAPR compliant) v2.4";
|
mc->desc = "pSeries Logical Partition (PAPR compliant) v2.4";
|
||||||
mc->alias = "pseries";
|
|
||||||
mc->is_default = 0;
|
|
||||||
mc->compat_props = compat_props;
|
mc->compat_props = compat_props;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -684,6 +684,27 @@ enum {
|
|||||||
#define fpscr_eex (((env->fpscr) >> FPSCR_XX) & ((env->fpscr) >> FPSCR_XE) & \
|
#define fpscr_eex (((env->fpscr) >> FPSCR_XX) & ((env->fpscr) >> FPSCR_XE) & \
|
||||||
0x1F)
|
0x1F)
|
||||||
|
|
||||||
|
#define FP_FX (1ull << FPSCR_FX)
|
||||||
|
#define FP_FEX (1ull << FPSCR_FEX)
|
||||||
|
#define FP_OX (1ull << FPSCR_OX)
|
||||||
|
#define FP_OE (1ull << FPSCR_OE)
|
||||||
|
#define FP_UX (1ull << FPSCR_UX)
|
||||||
|
#define FP_UE (1ull << FPSCR_UE)
|
||||||
|
#define FP_XX (1ull << FPSCR_XX)
|
||||||
|
#define FP_XE (1ull << FPSCR_XE)
|
||||||
|
#define FP_ZX (1ull << FPSCR_ZX)
|
||||||
|
#define FP_ZE (1ull << FPSCR_ZE)
|
||||||
|
#define FP_VX (1ull << FPSCR_VX)
|
||||||
|
#define FP_VXSNAN (1ull << FPSCR_VXSNAN)
|
||||||
|
#define FP_VXISI (1ull << FPSCR_VXISI)
|
||||||
|
#define FP_VXIMZ (1ull << FPSCR_VXIMZ)
|
||||||
|
#define FP_VXZDZ (1ull << FPSCR_VXZDZ)
|
||||||
|
#define FP_VXIDI (1ull << FPSCR_VXIDI)
|
||||||
|
#define FP_VXVC (1ull << FPSCR_VXVC)
|
||||||
|
#define FP_VXCVI (1ull << FPSCR_VXCVI)
|
||||||
|
#define FP_VE (1ull << FPSCR_VE)
|
||||||
|
#define FP_FI (1ull << FPSCR_FI)
|
||||||
|
|
||||||
/*****************************************************************************/
|
/*****************************************************************************/
|
||||||
/* Vector status and control register */
|
/* Vector status and control register */
|
||||||
#define VSCR_NJ 16 /* Vector non-java */
|
#define VSCR_NJ 16 /* Vector non-java */
|
||||||
|
@ -170,27 +170,6 @@ static void dfp_prepare_decimal128(struct PPC_DFP *dfp, uint64_t *a,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define FP_FX (1ull << FPSCR_FX)
|
|
||||||
#define FP_FEX (1ull << FPSCR_FEX)
|
|
||||||
#define FP_OX (1ull << FPSCR_OX)
|
|
||||||
#define FP_OE (1ull << FPSCR_OE)
|
|
||||||
#define FP_UX (1ull << FPSCR_UX)
|
|
||||||
#define FP_UE (1ull << FPSCR_UE)
|
|
||||||
#define FP_XX (1ull << FPSCR_XX)
|
|
||||||
#define FP_XE (1ull << FPSCR_XE)
|
|
||||||
#define FP_ZX (1ull << FPSCR_ZX)
|
|
||||||
#define FP_ZE (1ull << FPSCR_ZE)
|
|
||||||
#define FP_VX (1ull << FPSCR_VX)
|
|
||||||
#define FP_VXSNAN (1ull << FPSCR_VXSNAN)
|
|
||||||
#define FP_VXISI (1ull << FPSCR_VXISI)
|
|
||||||
#define FP_VXIMZ (1ull << FPSCR_VXIMZ)
|
|
||||||
#define FP_VXZDZ (1ull << FPSCR_VXZDZ)
|
|
||||||
#define FP_VXIDI (1ull << FPSCR_VXIDI)
|
|
||||||
#define FP_VXVC (1ull << FPSCR_VXVC)
|
|
||||||
#define FP_VXCVI (1ull << FPSCR_VXCVI)
|
|
||||||
#define FP_VE (1ull << FPSCR_VE)
|
|
||||||
#define FP_FI (1ull << FPSCR_FI)
|
|
||||||
|
|
||||||
static void dfp_set_FPSCR_flag(struct PPC_DFP *dfp, uint64_t flag,
|
static void dfp_set_FPSCR_flag(struct PPC_DFP *dfp, uint64_t flag,
|
||||||
uint64_t enabled)
|
uint64_t enabled)
|
||||||
{
|
{
|
||||||
|
@ -194,7 +194,7 @@ static inline uint64_t fload_invalid_op_excp(CPUPPCState *env, int op,
|
|||||||
/* Update the floating-point invalid operation summary */
|
/* Update the floating-point invalid operation summary */
|
||||||
env->fpscr |= 1 << FPSCR_VX;
|
env->fpscr |= 1 << FPSCR_VX;
|
||||||
/* Update the floating-point exception summary */
|
/* Update the floating-point exception summary */
|
||||||
env->fpscr |= 1 << FPSCR_FX;
|
env->fpscr |= FP_FX;
|
||||||
if (ve != 0) {
|
if (ve != 0) {
|
||||||
/* Update the floating-point enabled exception summary */
|
/* Update the floating-point enabled exception summary */
|
||||||
env->fpscr |= 1 << FPSCR_FEX;
|
env->fpscr |= 1 << FPSCR_FEX;
|
||||||
@ -211,7 +211,7 @@ static inline void float_zero_divide_excp(CPUPPCState *env)
|
|||||||
env->fpscr |= 1 << FPSCR_ZX;
|
env->fpscr |= 1 << FPSCR_ZX;
|
||||||
env->fpscr &= ~((1 << FPSCR_FR) | (1 << FPSCR_FI));
|
env->fpscr &= ~((1 << FPSCR_FR) | (1 << FPSCR_FI));
|
||||||
/* Update the floating-point exception summary */
|
/* Update the floating-point exception summary */
|
||||||
env->fpscr |= 1 << FPSCR_FX;
|
env->fpscr |= FP_FX;
|
||||||
if (fpscr_ze != 0) {
|
if (fpscr_ze != 0) {
|
||||||
/* Update the floating-point enabled exception summary */
|
/* Update the floating-point enabled exception summary */
|
||||||
env->fpscr |= 1 << FPSCR_FEX;
|
env->fpscr |= 1 << FPSCR_FEX;
|
||||||
@ -228,7 +228,7 @@ static inline void float_overflow_excp(CPUPPCState *env)
|
|||||||
|
|
||||||
env->fpscr |= 1 << FPSCR_OX;
|
env->fpscr |= 1 << FPSCR_OX;
|
||||||
/* Update the floating-point exception summary */
|
/* Update the floating-point exception summary */
|
||||||
env->fpscr |= 1 << FPSCR_FX;
|
env->fpscr |= FP_FX;
|
||||||
if (fpscr_oe != 0) {
|
if (fpscr_oe != 0) {
|
||||||
/* XXX: should adjust the result */
|
/* XXX: should adjust the result */
|
||||||
/* Update the floating-point enabled exception summary */
|
/* Update the floating-point enabled exception summary */
|
||||||
@ -248,7 +248,7 @@ static inline void float_underflow_excp(CPUPPCState *env)
|
|||||||
|
|
||||||
env->fpscr |= 1 << FPSCR_UX;
|
env->fpscr |= 1 << FPSCR_UX;
|
||||||
/* Update the floating-point exception summary */
|
/* Update the floating-point exception summary */
|
||||||
env->fpscr |= 1 << FPSCR_FX;
|
env->fpscr |= FP_FX;
|
||||||
if (fpscr_ue != 0) {
|
if (fpscr_ue != 0) {
|
||||||
/* XXX: should adjust the result */
|
/* XXX: should adjust the result */
|
||||||
/* Update the floating-point enabled exception summary */
|
/* Update the floating-point enabled exception summary */
|
||||||
@ -265,7 +265,7 @@ static inline void float_inexact_excp(CPUPPCState *env)
|
|||||||
|
|
||||||
env->fpscr |= 1 << FPSCR_XX;
|
env->fpscr |= 1 << FPSCR_XX;
|
||||||
/* Update the floating-point exception summary */
|
/* Update the floating-point exception summary */
|
||||||
env->fpscr |= 1 << FPSCR_FX;
|
env->fpscr |= FP_FX;
|
||||||
if (fpscr_xe != 0) {
|
if (fpscr_xe != 0) {
|
||||||
/* Update the floating-point enabled exception summary */
|
/* Update the floating-point enabled exception summary */
|
||||||
env->fpscr |= 1 << FPSCR_FEX;
|
env->fpscr |= 1 << FPSCR_FEX;
|
||||||
@ -330,31 +330,31 @@ void helper_fpscr_setbit(CPUPPCState *env, uint32_t bit)
|
|||||||
if (prev == 0) {
|
if (prev == 0) {
|
||||||
switch (bit) {
|
switch (bit) {
|
||||||
case FPSCR_VX:
|
case FPSCR_VX:
|
||||||
env->fpscr |= 1 << FPSCR_FX;
|
env->fpscr |= FP_FX;
|
||||||
if (fpscr_ve) {
|
if (fpscr_ve) {
|
||||||
goto raise_ve;
|
goto raise_ve;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case FPSCR_OX:
|
case FPSCR_OX:
|
||||||
env->fpscr |= 1 << FPSCR_FX;
|
env->fpscr |= FP_FX;
|
||||||
if (fpscr_oe) {
|
if (fpscr_oe) {
|
||||||
goto raise_oe;
|
goto raise_oe;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case FPSCR_UX:
|
case FPSCR_UX:
|
||||||
env->fpscr |= 1 << FPSCR_FX;
|
env->fpscr |= FP_FX;
|
||||||
if (fpscr_ue) {
|
if (fpscr_ue) {
|
||||||
goto raise_ue;
|
goto raise_ue;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case FPSCR_ZX:
|
case FPSCR_ZX:
|
||||||
env->fpscr |= 1 << FPSCR_FX;
|
env->fpscr |= FP_FX;
|
||||||
if (fpscr_ze) {
|
if (fpscr_ze) {
|
||||||
goto raise_ze;
|
goto raise_ze;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case FPSCR_XX:
|
case FPSCR_XX:
|
||||||
env->fpscr |= 1 << FPSCR_FX;
|
env->fpscr |= FP_FX;
|
||||||
if (fpscr_xe) {
|
if (fpscr_xe) {
|
||||||
goto raise_xe;
|
goto raise_xe;
|
||||||
}
|
}
|
||||||
@ -369,7 +369,7 @@ void helper_fpscr_setbit(CPUPPCState *env, uint32_t bit)
|
|||||||
case FPSCR_VXSQRT:
|
case FPSCR_VXSQRT:
|
||||||
case FPSCR_VXCVI:
|
case FPSCR_VXCVI:
|
||||||
env->fpscr |= 1 << FPSCR_VX;
|
env->fpscr |= 1 << FPSCR_VX;
|
||||||
env->fpscr |= 1 << FPSCR_FX;
|
env->fpscr |= FP_FX;
|
||||||
if (fpscr_ve != 0) {
|
if (fpscr_ve != 0) {
|
||||||
goto raise_ve;
|
goto raise_ve;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user