All of lore.kernel.org
 help / color / mirror / Atom feed
From: <tony.nguyen@bt.com>
To: <qemu-devel@nongnu.org>
Cc: <frederic.konrad@adacore.com>, <berto@igalia.com>,
	<qemu-block@nongnu.org>, <arikalo@wavecomp.com>,
	<pasic@linux.ibm.com>, <hpoussin@reactos.org>,
	<anthony.perard@citrix.com>, <xen-devel@lists.xenproject.org>,
	<lersek@redhat.com>, <jasowang@redhat.com>,  <jiri@resnulli.us>,
	<ehabkost@redhat.com>, <b.galvani@gmail.com>,
	<eric.auger@redhat.com>, <alex.williamson@redhat.com>,
	<stefanha@redhat.com>,  <jsnow@redhat.com>, <rth@twiddle.net>,
	<kwolf@redhat.com>, <andrew@aj.id.au>,  <crwulff@gmail.com>,
	<laurent@vivier.eu>, <sundeep.lkml@gmail.com>, <michael@walle.cc>,
	<qemu-ppc@nongnu.org>, <kbastian@mail.uni-paderborn.de>,
	<imammedo@redhat.com>, <fam@euphon.net>,
	<peter.maydell@linaro.org>, <david@redhat.com>,
	<palmer@sifive.com>, <keith.busch@intel.com>,
	<jcmvbkbc@gmail.com>, <hare@suse.com>, <sstabellini@kernel.org>,
	<andrew.smirnov@gmail.com>, <deller@gmx.de>,
	<magnus.damm@gmail.com>, <atar4qemu@gmail.com>, <minyard@acm.org>,
	<sw@weilnetz.de>, <yuval.shaia@oracle.com>,
	<qemu-s390x@nongnu.org>, <qemu-arm@nongnu.org>,
	<jan.kiszka@web.de>, <clg@kaod.org>, <shorne@gmail.com>,
	<qemu-riscv@nongnu.org>, <i.mitsyanko@gmail.com>,
	<cohuck@redhat.com>, <philmd@redhat.com>,
	<amarkovic@wavecomp.com>, <peter.chubb@nicta.com.au>,
	<aurelien@aurel32.net>, <pburton@wavecomp.com>,
	<sagark@eecs.berkeley.edu>, <green@moxielogic.com>,
	<kraxel@redhat.com>, <edgar.iglesias@gmail.com>,
	<gxt@mprc.pku.edu.cn>, <robh@kernel.org>,
	<borntraeger@de.ibm.com>, <joel@jms.id.au>,
	<antonynpavlov@gmail.com>, <chouteau@adacore.com>,
	<Andrew.Baumann@microsoft.com>, <mreitz@redhat.com>,
	<walling@linux.ibm.com>,  <dmitry.fleytman@gmail.com>,
	<mst@redhat.com>, <mark.cave-ayland@ilande.co.uk>,
	<jslaby@suse.cz>, <marex@denx.de>, <proljc@gmail.com>,
	<marcandre.lureau@redhat.com>, <alistair@alistair23.me>,
	<paul.durrant@citrix.com>, <david@gibson.dropbear.id.au>,
	<xiaoguangrong.eric@gmail.com>, <huth@tuxfamily.org>,
	<jcd@tribudubois.net>, <pbonzini@redhat.com>,
	<stefanb@linux.ibm.com>
Subject: [Qemu-riscv] [Qemu-devel] [PATCH v6 20/26] memory: Access MemoryRegion with endianness
Date: Wed, 7 Aug 2019 08:33:15 +0000	[thread overview]
Message-ID: <1565166794966.57397@bt.com> (raw)
In-Reply-To: <45ec4924e0b34a3d9124e2db06af75b4@tpw09926dag18e.domain1.systemhost.net>

[-- Attachment #1: Type: text/plain, Size: 7225 bytes --]

Preparation for collapsing the two byte swaps adjust_endianness and
handle_bswap into the former.

Call memory_region_dispatch_{read|write} with endianness encoded into
the "MemOp op" operand.

This patch does not change any behaviour as
memory_region_dispatch_{read|write} is yet to handle the endianness.

Once it does handle endianness, callers with byte swaps need to
collapse them into adjust_endianness.

Signed-off-by: Tony Nguyen <tony.nguyen@bt.com>
---
 hw/s390x/s390-pci-inst.c |  3 ++-
 hw/virtio/virtio-pci.c   |  2 ++
 include/exec/memop.h     |  4 ++++
 memory_ldst.inc.c        | 20 +++++++++++++-------
 target/mips/op_helper.c  |  4 ++--
 5 files changed, 23 insertions(+), 10 deletions(-)

diff --git a/hw/s390x/s390-pci-inst.c b/hw/s390x/s390-pci-inst.c
index 0e92a37..d322b86 100644
--- a/hw/s390x/s390-pci-inst.c
+++ b/hw/s390x/s390-pci-inst.c
@@ -782,7 +782,8 @@ int pcistb_service_call(S390CPU *cpu, uint8_t r1, uint8_t r3, uint64_t gaddr,
     for (i = 0; i < len / 8; i++) {
         result = memory_region_dispatch_write(mr, offset + i * 8,
                                               ldq_p(buffer + i * 8),
-                                              MO_64, MEMTXATTRS_UNSPECIFIED);
+                                              MO_64 | MO_TE,
+                                              MEMTXATTRS_UNSPECIFIED);
         if (result != MEMTX_OK) {
             s390_program_interrupt(env, PGM_OPERAND, 6, ra);
             return 0;
diff --git a/hw/virtio/virtio-pci.c b/hw/virtio/virtio-pci.c
index b929e44..70eb161 100644
--- a/hw/virtio/virtio-pci.c
+++ b/hw/virtio/virtio-pci.c
@@ -551,6 +551,7 @@ void virtio_address_space_write(VirtIOPCIProxy *proxy, hwaddr addr,
         /* As length is under guest control, handle illegal values. */
         return;
     }
+    /* FIXME: memory_region_dispatch_write ignores MO_BSWAP.  */
     memory_region_dispatch_write(mr, addr, val, size_memop(len),
                                  MEMTXATTRS_UNSPECIFIED);
 }
@@ -575,6 +576,7 @@ virtio_address_space_read(VirtIOPCIProxy *proxy, hwaddr addr,
     /* Make sure caller aligned buf properly */
     assert(!(((uintptr_t)buf) & (len - 1)));

+    /* FIXME: memory_region_dispatch_read ignores MO_BSWAP.  */
     memory_region_dispatch_read(mr, addr, &val, size_memop(len),
                                 MEMTXATTRS_UNSPECIFIED);
     switch (len) {
diff --git a/include/exec/memop.h b/include/exec/memop.h
index 4a4212d..47a5500 100644
--- a/include/exec/memop.h
+++ b/include/exec/memop.h
@@ -122,7 +122,11 @@ static inline MemOp size_memop(unsigned size)
     /* Power of 2 up to 8.  */
     assert((size & (size - 1)) == 0 && size >= 1 && size <= 8);
 #endif
+#ifdef NEED_CPU_H
+    return ctz32(size) | MO_TE;
+#else
     return ctz32(size);
+#endif
 }

 #endif
diff --git a/memory_ldst.inc.c b/memory_ldst.inc.c
index d7e28d0..ff28b30 100644
--- a/memory_ldst.inc.c
+++ b/memory_ldst.inc.c
@@ -37,7 +37,8 @@ static inline uint32_t glue(address_space_ldl_internal, SUFFIX)(ARG1_DECL,
         release_lock |= prepare_mmio_access(mr);

         /* I/O case */
-        r = memory_region_dispatch_read(mr, addr1, &val, MO_32, attrs);
+        /* FIXME: memory_region_dispatch_read ignores MO_BSWAP.  */
+        r = memory_region_dispatch_read(mr, addr1, &val, MO_32 | endian, attrs);
 #if defined(TARGET_WORDS_BIGENDIAN)
         if (endian == MO_LE) {
             val = bswap32(val);
@@ -112,7 +113,8 @@ static inline uint64_t glue(address_space_ldq_internal, SUFFIX)(ARG1_DECL,
         release_lock |= prepare_mmio_access(mr);

         /* I/O case */
-        r = memory_region_dispatch_read(mr, addr1, &val, MO_64, attrs);
+        /* FIXME: memory_region_dispatch_read ignores MO_BSWAP.  */
+        r = memory_region_dispatch_read(mr, addr1, &val, MO_64 | endian, attrs);
 #if defined(TARGET_WORDS_BIGENDIAN)
         if (endian == MO_LE) {
             val = bswap64(val);
@@ -221,7 +223,8 @@ static inline uint32_t glue(address_space_lduw_internal, SUFFIX)(ARG1_DECL,
         release_lock |= prepare_mmio_access(mr);

         /* I/O case */
-        r = memory_region_dispatch_read(mr, addr1, &val, MO_16, attrs);
+        /* FIXME: memory_region_dispatch_read ignores MO_BSWAP.  */
+        r = memory_region_dispatch_read(mr, addr1, &val, MO_16 | endian, attrs);
 #if defined(TARGET_WORDS_BIGENDIAN)
         if (endian == MO_LE) {
             val = bswap16(val);
@@ -297,7 +300,7 @@ void glue(address_space_stl_notdirty, SUFFIX)(ARG1_DECL,
     if (l < 4 || !memory_access_is_direct(mr, true)) {
         release_lock |= prepare_mmio_access(mr);

-        r = memory_region_dispatch_write(mr, addr1, val, MO_32, attrs);
+        r = memory_region_dispatch_write(mr, addr1, val, MO_32 | MO_TE, attrs);
     } else {
         ptr = qemu_map_ram_ptr(mr->ram_block, addr1);
         stl_p(ptr, val);
@@ -343,7 +346,8 @@ static inline void glue(address_space_stl_internal, SUFFIX)(ARG1_DECL,
             val = bswap32(val);
         }
 #endif
-        r = memory_region_dispatch_write(mr, addr1, val, MO_32, attrs);
+        /* FIXME: memory_region_dispatch_write ignores MO_BSWAP.  */
+        r = memory_region_dispatch_write(mr, addr1, val, MO_32 | endian, attrs);
     } else {
         /* RAM case */
         ptr = qemu_map_ram_ptr(mr->ram_block, addr1);
@@ -448,7 +452,8 @@ static inline void glue(address_space_stw_internal, SUFFIX)(ARG1_DECL,
             val = bswap16(val);
         }
 #endif
-        r = memory_region_dispatch_write(mr, addr1, val, MO_16, attrs);
+        /* FIXME: memory_region_dispatch_write ignores MO_BSWAP.  */
+        r = memory_region_dispatch_write(mr, addr1, val, MO_16 | endian, attrs);
     } else {
         /* RAM case */
         ptr = qemu_map_ram_ptr(mr->ram_block, addr1);
@@ -521,7 +526,8 @@ static void glue(address_space_stq_internal, SUFFIX)(ARG1_DECL,
             val = bswap64(val);
         }
 #endif
-        r = memory_region_dispatch_write(mr, addr1, val, MO_64, attrs);
+        /* FIXME: memory_region_dispatch_write ignores MO_BSWAP.  */
+        r = memory_region_dispatch_write(mr, addr1, val, MO_64 | endian, attrs);
     } else {
         /* RAM case */
         ptr = qemu_map_ram_ptr(mr->ram_block, addr1);
diff --git a/target/mips/op_helper.c b/target/mips/op_helper.c
index e79f99d..1b475f3 100644
--- a/target/mips/op_helper.c
+++ b/target/mips/op_helper.c
@@ -4741,11 +4741,11 @@ void helper_cache(CPUMIPSState *env, target_ulong addr, uint32_t op)
     if (op == 9) {
         /* Index Store Tag */
         memory_region_dispatch_write(env->itc_tag, index, env->CP0_TagLo,
-                                     MO_64, MEMTXATTRS_UNSPECIFIED);
+                                     MO_64 | MO_TE, MEMTXATTRS_UNSPECIFIED);
     } else if (op == 5) {
         /* Index Load Tag */
         memory_region_dispatch_read(env->itc_tag, index, &env->CP0_TagLo,
-                                    MO_64, MEMTXATTRS_UNSPECIFIED);
+                                    MO_64 | MO_TE, MEMTXATTRS_UNSPECIFIED);
     }
 #endif
 }
--
1.8.3.1

?


[-- Attachment #2: Type: text/html, Size: 12996 bytes --]

WARNING: multiple messages have this Message-ID (diff)
From: <tony.nguyen@bt.com>
To: <qemu-devel@nongnu.org>
Cc: fam@euphon.net, peter.maydell@linaro.org, walling@linux.ibm.com,
	cohuck@redhat.com, sagark@eecs.berkeley.edu, david@redhat.com,
	jasowang@redhat.com, palmer@sifive.com,
	mark.cave-ayland@ilande.co.uk, i.mitsyanko@gmail.com,
	keith.busch@intel.com, jcmvbkbc@gmail.com,
	frederic.konrad@adacore.com, dmitry.fleytman@gmail.com,
	kraxel@redhat.com, gxt@mprc.pku.edu.cn, pburton@wavecomp.com,
	xiaoguangrong.eric@gmail.com, peter.chubb@nicta.com.au,
	philmd@redhat.com, robh@kernel.org, hare@suse.com,
	sstabellini@kernel.org, berto@igalia.com, chouteau@adacore.com,
	qemu-block@nongnu.org, arikalo@wavecomp.com, jslaby@suse.cz,
	deller@gmx.de, mst@redhat.com, magnus.damm@gmail.com,
	jcd@tribudubois.net, pasic@linux.ibm.com, borntraeger@de.ibm.com,
	mreitz@redhat.com, hpoussin@reactos.org, joel@jms.id.au,
	anthony.perard@citrix.com, xen-devel@lists.xenproject.org,
	david@gibson.dropbear.id.au, lersek@redhat.com,
	green@moxielogic.com, atar4qemu@gmail.com,
	antonynpavlov@gmail.com, marex@denx.de, jiri@resnulli.us,
	ehabkost@redhat.com, minyard@acm.org, qemu-s390x@nongnu.org,
	sw@weilnetz.de, alistair@alistair23.me, yuval.shaia@oracle.com,
	b.galvani@gmail.com, eric.auger@redhat.com,
	alex.williamson@redhat.com, qemu-arm@nongnu.org,
	jan.kiszka@web.de, clg@kaod.org, stefanha@redhat.com,
	marcandre.lureau@redhat.com, shorne@gmail.com, jsnow@redhat.com,
	rth@twiddle.net, kwolf@redhat.com, qemu-riscv@nongnu.org,
	proljc@gmail.com, pbonzini@redhat.com, andrew@aj.id.au,
	kbastian@mail.uni-paderborn.de, crwulff@gmail.com,
	laurent@vivier.eu, Andrew.Baumann@microsoft.com,
	sundeep.lkml@gmail.com, andrew.smirnov@gmail.com,
	michael@walle.cc, paul.durrant@citrix.com, qemu-ppc@nongnu.org,
	huth@tuxfamily.org, amarkovic@wavecomp.com, imammedo@redhat.com,
	aurelien@aurel32.net, stefanb@linux.ibm.com
Subject: [Qemu-arm] [Qemu-devel] [PATCH v6 20/26] memory: Access MemoryRegion with endianness
Date: Wed, 7 Aug 2019 08:33:15 +0000	[thread overview]
Message-ID: <1565166794966.57397@bt.com> (raw)
In-Reply-To: <45ec4924e0b34a3d9124e2db06af75b4@tpw09926dag18e.domain1.systemhost.net>

[-- Attachment #1: Type: text/plain, Size: 7225 bytes --]

Preparation for collapsing the two byte swaps adjust_endianness and
handle_bswap into the former.

Call memory_region_dispatch_{read|write} with endianness encoded into
the "MemOp op" operand.

This patch does not change any behaviour as
memory_region_dispatch_{read|write} is yet to handle the endianness.

Once it does handle endianness, callers with byte swaps need to
collapse them into adjust_endianness.

Signed-off-by: Tony Nguyen <tony.nguyen@bt.com>
---
 hw/s390x/s390-pci-inst.c |  3 ++-
 hw/virtio/virtio-pci.c   |  2 ++
 include/exec/memop.h     |  4 ++++
 memory_ldst.inc.c        | 20 +++++++++++++-------
 target/mips/op_helper.c  |  4 ++--
 5 files changed, 23 insertions(+), 10 deletions(-)

diff --git a/hw/s390x/s390-pci-inst.c b/hw/s390x/s390-pci-inst.c
index 0e92a37..d322b86 100644
--- a/hw/s390x/s390-pci-inst.c
+++ b/hw/s390x/s390-pci-inst.c
@@ -782,7 +782,8 @@ int pcistb_service_call(S390CPU *cpu, uint8_t r1, uint8_t r3, uint64_t gaddr,
     for (i = 0; i < len / 8; i++) {
         result = memory_region_dispatch_write(mr, offset + i * 8,
                                               ldq_p(buffer + i * 8),
-                                              MO_64, MEMTXATTRS_UNSPECIFIED);
+                                              MO_64 | MO_TE,
+                                              MEMTXATTRS_UNSPECIFIED);
         if (result != MEMTX_OK) {
             s390_program_interrupt(env, PGM_OPERAND, 6, ra);
             return 0;
diff --git a/hw/virtio/virtio-pci.c b/hw/virtio/virtio-pci.c
index b929e44..70eb161 100644
--- a/hw/virtio/virtio-pci.c
+++ b/hw/virtio/virtio-pci.c
@@ -551,6 +551,7 @@ void virtio_address_space_write(VirtIOPCIProxy *proxy, hwaddr addr,
         /* As length is under guest control, handle illegal values. */
         return;
     }
+    /* FIXME: memory_region_dispatch_write ignores MO_BSWAP.  */
     memory_region_dispatch_write(mr, addr, val, size_memop(len),
                                  MEMTXATTRS_UNSPECIFIED);
 }
@@ -575,6 +576,7 @@ virtio_address_space_read(VirtIOPCIProxy *proxy, hwaddr addr,
     /* Make sure caller aligned buf properly */
     assert(!(((uintptr_t)buf) & (len - 1)));

+    /* FIXME: memory_region_dispatch_read ignores MO_BSWAP.  */
     memory_region_dispatch_read(mr, addr, &val, size_memop(len),
                                 MEMTXATTRS_UNSPECIFIED);
     switch (len) {
diff --git a/include/exec/memop.h b/include/exec/memop.h
index 4a4212d..47a5500 100644
--- a/include/exec/memop.h
+++ b/include/exec/memop.h
@@ -122,7 +122,11 @@ static inline MemOp size_memop(unsigned size)
     /* Power of 2 up to 8.  */
     assert((size & (size - 1)) == 0 && size >= 1 && size <= 8);
 #endif
+#ifdef NEED_CPU_H
+    return ctz32(size) | MO_TE;
+#else
     return ctz32(size);
+#endif
 }

 #endif
diff --git a/memory_ldst.inc.c b/memory_ldst.inc.c
index d7e28d0..ff28b30 100644
--- a/memory_ldst.inc.c
+++ b/memory_ldst.inc.c
@@ -37,7 +37,8 @@ static inline uint32_t glue(address_space_ldl_internal, SUFFIX)(ARG1_DECL,
         release_lock |= prepare_mmio_access(mr);

         /* I/O case */
-        r = memory_region_dispatch_read(mr, addr1, &val, MO_32, attrs);
+        /* FIXME: memory_region_dispatch_read ignores MO_BSWAP.  */
+        r = memory_region_dispatch_read(mr, addr1, &val, MO_32 | endian, attrs);
 #if defined(TARGET_WORDS_BIGENDIAN)
         if (endian == MO_LE) {
             val = bswap32(val);
@@ -112,7 +113,8 @@ static inline uint64_t glue(address_space_ldq_internal, SUFFIX)(ARG1_DECL,
         release_lock |= prepare_mmio_access(mr);

         /* I/O case */
-        r = memory_region_dispatch_read(mr, addr1, &val, MO_64, attrs);
+        /* FIXME: memory_region_dispatch_read ignores MO_BSWAP.  */
+        r = memory_region_dispatch_read(mr, addr1, &val, MO_64 | endian, attrs);
 #if defined(TARGET_WORDS_BIGENDIAN)
         if (endian == MO_LE) {
             val = bswap64(val);
@@ -221,7 +223,8 @@ static inline uint32_t glue(address_space_lduw_internal, SUFFIX)(ARG1_DECL,
         release_lock |= prepare_mmio_access(mr);

         /* I/O case */
-        r = memory_region_dispatch_read(mr, addr1, &val, MO_16, attrs);
+        /* FIXME: memory_region_dispatch_read ignores MO_BSWAP.  */
+        r = memory_region_dispatch_read(mr, addr1, &val, MO_16 | endian, attrs);
 #if defined(TARGET_WORDS_BIGENDIAN)
         if (endian == MO_LE) {
             val = bswap16(val);
@@ -297,7 +300,7 @@ void glue(address_space_stl_notdirty, SUFFIX)(ARG1_DECL,
     if (l < 4 || !memory_access_is_direct(mr, true)) {
         release_lock |= prepare_mmio_access(mr);

-        r = memory_region_dispatch_write(mr, addr1, val, MO_32, attrs);
+        r = memory_region_dispatch_write(mr, addr1, val, MO_32 | MO_TE, attrs);
     } else {
         ptr = qemu_map_ram_ptr(mr->ram_block, addr1);
         stl_p(ptr, val);
@@ -343,7 +346,8 @@ static inline void glue(address_space_stl_internal, SUFFIX)(ARG1_DECL,
             val = bswap32(val);
         }
 #endif
-        r = memory_region_dispatch_write(mr, addr1, val, MO_32, attrs);
+        /* FIXME: memory_region_dispatch_write ignores MO_BSWAP.  */
+        r = memory_region_dispatch_write(mr, addr1, val, MO_32 | endian, attrs);
     } else {
         /* RAM case */
         ptr = qemu_map_ram_ptr(mr->ram_block, addr1);
@@ -448,7 +452,8 @@ static inline void glue(address_space_stw_internal, SUFFIX)(ARG1_DECL,
             val = bswap16(val);
         }
 #endif
-        r = memory_region_dispatch_write(mr, addr1, val, MO_16, attrs);
+        /* FIXME: memory_region_dispatch_write ignores MO_BSWAP.  */
+        r = memory_region_dispatch_write(mr, addr1, val, MO_16 | endian, attrs);
     } else {
         /* RAM case */
         ptr = qemu_map_ram_ptr(mr->ram_block, addr1);
@@ -521,7 +526,8 @@ static void glue(address_space_stq_internal, SUFFIX)(ARG1_DECL,
             val = bswap64(val);
         }
 #endif
-        r = memory_region_dispatch_write(mr, addr1, val, MO_64, attrs);
+        /* FIXME: memory_region_dispatch_write ignores MO_BSWAP.  */
+        r = memory_region_dispatch_write(mr, addr1, val, MO_64 | endian, attrs);
     } else {
         /* RAM case */
         ptr = qemu_map_ram_ptr(mr->ram_block, addr1);
diff --git a/target/mips/op_helper.c b/target/mips/op_helper.c
index e79f99d..1b475f3 100644
--- a/target/mips/op_helper.c
+++ b/target/mips/op_helper.c
@@ -4741,11 +4741,11 @@ void helper_cache(CPUMIPSState *env, target_ulong addr, uint32_t op)
     if (op == 9) {
         /* Index Store Tag */
         memory_region_dispatch_write(env->itc_tag, index, env->CP0_TagLo,
-                                     MO_64, MEMTXATTRS_UNSPECIFIED);
+                                     MO_64 | MO_TE, MEMTXATTRS_UNSPECIFIED);
     } else if (op == 5) {
         /* Index Load Tag */
         memory_region_dispatch_read(env->itc_tag, index, &env->CP0_TagLo,
-                                    MO_64, MEMTXATTRS_UNSPECIFIED);
+                                    MO_64 | MO_TE, MEMTXATTRS_UNSPECIFIED);
     }
 #endif
 }
--
1.8.3.1

?


[-- Attachment #2: Type: text/html, Size: 12996 bytes --]

WARNING: multiple messages have this Message-ID (diff)
From: <tony.nguyen@bt.com>
To: <qemu-devel@nongnu.org>
Cc: fam@euphon.net, peter.maydell@linaro.org, walling@linux.ibm.com,
	cohuck@redhat.com, sagark@eecs.berkeley.edu, david@redhat.com,
	jasowang@redhat.com, palmer@sifive.com,
	mark.cave-ayland@ilande.co.uk, i.mitsyanko@gmail.com,
	keith.busch@intel.com, jcmvbkbc@gmail.com,
	frederic.konrad@adacore.com, dmitry.fleytman@gmail.com,
	kraxel@redhat.com, edgar.iglesias@gmail.com, gxt@mprc.pku.edu.cn,
	pburton@wavecomp.com, xiaoguangrong.eric@gmail.com,
	peter.chubb@nicta.com.au, philmd@redhat.com, robh@kernel.org,
	hare@suse.com, sstabellini@kernel.org, berto@igalia.com,
	chouteau@adacore.com, qemu-block@nongnu.org,
	arikalo@wavecomp.com, jslaby@suse.cz, deller@gmx.de,
	mst@redhat.com, magnus.damm@gmail.com, jcd@tribudubois.net,
	pasic@linux.ibm.com, borntraeger@de.ibm.com, mreitz@redhat.com,
	hpoussin@reactos.org, joel@jms.id.au, anthony.perard@citrix.com,
	xen-devel@lists.xenproject.org, david@gibson.dropbear.id.au,
	lersek@redhat.com, green@moxielogic.com, atar4qemu@gmail.com,
	antonynpavlov@gmail.com, marex@denx.de, jiri@resnulli.us,
	ehabkost@redhat.com, minyard@acm.org, qemu-s390x@nongnu.org,
	sw@weilnetz.de, alistair@alistair23.me, yuval.shaia@oracle.com,
	b.galvani@gmail.com, eric.auger@redhat.com,
	alex.williamson@redhat.com, qemu-arm@nongnu.org,
	jan.kiszka@web.de, clg@kaod.org, stefanha@redhat.com,
	marcandre.lureau@redhat.com, shorne@gmail.com, jsnow@redhat.com,
	rth@twiddle.net, kwolf@redhat.com, qemu-riscv@nongnu.org,
	proljc@gmail.com, pbonzini@redhat.com, andrew@aj.id.au,
	kbastian@mail.uni-paderborn.de, crwulff@gmail.com,
	laurent@vivier.eu, Andrew.Baumann@microsoft.com,
	sundeep.lkml@gmail.com, andrew.smirnov@gmail.com,
	michael@walle.cc, paul.durrant@citrix.com, qemu-ppc@nongnu.org,
	huth@tuxfamily.org, amarkovic@wavecomp.com, imammedo@redhat.com,
	aurelien@aurel32.net, stefanb@linux.ibm.com
Subject: [Xen-devel] [Qemu-devel] [PATCH v6 20/26] memory: Access MemoryRegion with endianness
Date: Wed, 7 Aug 2019 08:33:15 +0000	[thread overview]
Message-ID: <1565166794966.57397@bt.com> (raw)
In-Reply-To: <45ec4924e0b34a3d9124e2db06af75b4@tpw09926dag18e.domain1.systemhost.net>


[-- Attachment #1.1: Type: text/plain, Size: 7225 bytes --]

Preparation for collapsing the two byte swaps adjust_endianness and
handle_bswap into the former.

Call memory_region_dispatch_{read|write} with endianness encoded into
the "MemOp op" operand.

This patch does not change any behaviour as
memory_region_dispatch_{read|write} is yet to handle the endianness.

Once it does handle endianness, callers with byte swaps need to
collapse them into adjust_endianness.

Signed-off-by: Tony Nguyen <tony.nguyen@bt.com>
---
 hw/s390x/s390-pci-inst.c |  3 ++-
 hw/virtio/virtio-pci.c   |  2 ++
 include/exec/memop.h     |  4 ++++
 memory_ldst.inc.c        | 20 +++++++++++++-------
 target/mips/op_helper.c  |  4 ++--
 5 files changed, 23 insertions(+), 10 deletions(-)

diff --git a/hw/s390x/s390-pci-inst.c b/hw/s390x/s390-pci-inst.c
index 0e92a37..d322b86 100644
--- a/hw/s390x/s390-pci-inst.c
+++ b/hw/s390x/s390-pci-inst.c
@@ -782,7 +782,8 @@ int pcistb_service_call(S390CPU *cpu, uint8_t r1, uint8_t r3, uint64_t gaddr,
     for (i = 0; i < len / 8; i++) {
         result = memory_region_dispatch_write(mr, offset + i * 8,
                                               ldq_p(buffer + i * 8),
-                                              MO_64, MEMTXATTRS_UNSPECIFIED);
+                                              MO_64 | MO_TE,
+                                              MEMTXATTRS_UNSPECIFIED);
         if (result != MEMTX_OK) {
             s390_program_interrupt(env, PGM_OPERAND, 6, ra);
             return 0;
diff --git a/hw/virtio/virtio-pci.c b/hw/virtio/virtio-pci.c
index b929e44..70eb161 100644
--- a/hw/virtio/virtio-pci.c
+++ b/hw/virtio/virtio-pci.c
@@ -551,6 +551,7 @@ void virtio_address_space_write(VirtIOPCIProxy *proxy, hwaddr addr,
         /* As length is under guest control, handle illegal values. */
         return;
     }
+    /* FIXME: memory_region_dispatch_write ignores MO_BSWAP.  */
     memory_region_dispatch_write(mr, addr, val, size_memop(len),
                                  MEMTXATTRS_UNSPECIFIED);
 }
@@ -575,6 +576,7 @@ virtio_address_space_read(VirtIOPCIProxy *proxy, hwaddr addr,
     /* Make sure caller aligned buf properly */
     assert(!(((uintptr_t)buf) & (len - 1)));

+    /* FIXME: memory_region_dispatch_read ignores MO_BSWAP.  */
     memory_region_dispatch_read(mr, addr, &val, size_memop(len),
                                 MEMTXATTRS_UNSPECIFIED);
     switch (len) {
diff --git a/include/exec/memop.h b/include/exec/memop.h
index 4a4212d..47a5500 100644
--- a/include/exec/memop.h
+++ b/include/exec/memop.h
@@ -122,7 +122,11 @@ static inline MemOp size_memop(unsigned size)
     /* Power of 2 up to 8.  */
     assert((size & (size - 1)) == 0 && size >= 1 && size <= 8);
 #endif
+#ifdef NEED_CPU_H
+    return ctz32(size) | MO_TE;
+#else
     return ctz32(size);
+#endif
 }

 #endif
diff --git a/memory_ldst.inc.c b/memory_ldst.inc.c
index d7e28d0..ff28b30 100644
--- a/memory_ldst.inc.c
+++ b/memory_ldst.inc.c
@@ -37,7 +37,8 @@ static inline uint32_t glue(address_space_ldl_internal, SUFFIX)(ARG1_DECL,
         release_lock |= prepare_mmio_access(mr);

         /* I/O case */
-        r = memory_region_dispatch_read(mr, addr1, &val, MO_32, attrs);
+        /* FIXME: memory_region_dispatch_read ignores MO_BSWAP.  */
+        r = memory_region_dispatch_read(mr, addr1, &val, MO_32 | endian, attrs);
 #if defined(TARGET_WORDS_BIGENDIAN)
         if (endian == MO_LE) {
             val = bswap32(val);
@@ -112,7 +113,8 @@ static inline uint64_t glue(address_space_ldq_internal, SUFFIX)(ARG1_DECL,
         release_lock |= prepare_mmio_access(mr);

         /* I/O case */
-        r = memory_region_dispatch_read(mr, addr1, &val, MO_64, attrs);
+        /* FIXME: memory_region_dispatch_read ignores MO_BSWAP.  */
+        r = memory_region_dispatch_read(mr, addr1, &val, MO_64 | endian, attrs);
 #if defined(TARGET_WORDS_BIGENDIAN)
         if (endian == MO_LE) {
             val = bswap64(val);
@@ -221,7 +223,8 @@ static inline uint32_t glue(address_space_lduw_internal, SUFFIX)(ARG1_DECL,
         release_lock |= prepare_mmio_access(mr);

         /* I/O case */
-        r = memory_region_dispatch_read(mr, addr1, &val, MO_16, attrs);
+        /* FIXME: memory_region_dispatch_read ignores MO_BSWAP.  */
+        r = memory_region_dispatch_read(mr, addr1, &val, MO_16 | endian, attrs);
 #if defined(TARGET_WORDS_BIGENDIAN)
         if (endian == MO_LE) {
             val = bswap16(val);
@@ -297,7 +300,7 @@ void glue(address_space_stl_notdirty, SUFFIX)(ARG1_DECL,
     if (l < 4 || !memory_access_is_direct(mr, true)) {
         release_lock |= prepare_mmio_access(mr);

-        r = memory_region_dispatch_write(mr, addr1, val, MO_32, attrs);
+        r = memory_region_dispatch_write(mr, addr1, val, MO_32 | MO_TE, attrs);
     } else {
         ptr = qemu_map_ram_ptr(mr->ram_block, addr1);
         stl_p(ptr, val);
@@ -343,7 +346,8 @@ static inline void glue(address_space_stl_internal, SUFFIX)(ARG1_DECL,
             val = bswap32(val);
         }
 #endif
-        r = memory_region_dispatch_write(mr, addr1, val, MO_32, attrs);
+        /* FIXME: memory_region_dispatch_write ignores MO_BSWAP.  */
+        r = memory_region_dispatch_write(mr, addr1, val, MO_32 | endian, attrs);
     } else {
         /* RAM case */
         ptr = qemu_map_ram_ptr(mr->ram_block, addr1);
@@ -448,7 +452,8 @@ static inline void glue(address_space_stw_internal, SUFFIX)(ARG1_DECL,
             val = bswap16(val);
         }
 #endif
-        r = memory_region_dispatch_write(mr, addr1, val, MO_16, attrs);
+        /* FIXME: memory_region_dispatch_write ignores MO_BSWAP.  */
+        r = memory_region_dispatch_write(mr, addr1, val, MO_16 | endian, attrs);
     } else {
         /* RAM case */
         ptr = qemu_map_ram_ptr(mr->ram_block, addr1);
@@ -521,7 +526,8 @@ static void glue(address_space_stq_internal, SUFFIX)(ARG1_DECL,
             val = bswap64(val);
         }
 #endif
-        r = memory_region_dispatch_write(mr, addr1, val, MO_64, attrs);
+        /* FIXME: memory_region_dispatch_write ignores MO_BSWAP.  */
+        r = memory_region_dispatch_write(mr, addr1, val, MO_64 | endian, attrs);
     } else {
         /* RAM case */
         ptr = qemu_map_ram_ptr(mr->ram_block, addr1);
diff --git a/target/mips/op_helper.c b/target/mips/op_helper.c
index e79f99d..1b475f3 100644
--- a/target/mips/op_helper.c
+++ b/target/mips/op_helper.c
@@ -4741,11 +4741,11 @@ void helper_cache(CPUMIPSState *env, target_ulong addr, uint32_t op)
     if (op == 9) {
         /* Index Store Tag */
         memory_region_dispatch_write(env->itc_tag, index, env->CP0_TagLo,
-                                     MO_64, MEMTXATTRS_UNSPECIFIED);
+                                     MO_64 | MO_TE, MEMTXATTRS_UNSPECIFIED);
     } else if (op == 5) {
         /* Index Load Tag */
         memory_region_dispatch_read(env->itc_tag, index, &env->CP0_TagLo,
-                                    MO_64, MEMTXATTRS_UNSPECIFIED);
+                                    MO_64 | MO_TE, MEMTXATTRS_UNSPECIFIED);
     }
 #endif
 }
--
1.8.3.1

?


[-- Attachment #1.2: Type: text/html, Size: 12996 bytes --]

[-- Attachment #2: Type: text/plain, Size: 157 bytes --]

_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xenproject.org
https://lists.xenproject.org/mailman/listinfo/xen-devel

  parent reply	other threads:[~2019-08-07 13:05 UTC|newest]

Thread overview: 182+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-08-07  8:23 [Qemu-riscv] [Qemu-devel] [PATCH v6 00/26] Invert Endian bit in SPARCv9 MMU TTE tony.nguyen
2019-08-07  8:23 ` [Xen-devel] " tony.nguyen
2019-08-07  8:23 ` [Qemu-arm] " tony.nguyen
2019-08-07  8:25 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 01/26] configure: Define TARGET_ALIGNED_ONLY tony.nguyen
2019-08-07  8:25   ` [Xen-devel] " tony.nguyen
2019-08-07  8:25   ` [Qemu-arm] " tony.nguyen
2019-08-08 14:08   ` [Qemu-riscv] " Cornelia Huck
2019-08-08 14:08     ` [Xen-devel] " Cornelia Huck
2019-08-08 14:08     ` [Qemu-arm] " Cornelia Huck
2019-08-07  8:26 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 02/26] tcg: TCGMemOp is now accelerator independent MemOp tony.nguyen
2019-08-07  8:26   ` [Xen-devel] " tony.nguyen
2019-08-07  8:26   ` [Qemu-arm] " tony.nguyen
2019-08-08 14:14   ` [Qemu-riscv] " Cornelia Huck
2019-08-08 14:14     ` [Xen-devel] " Cornelia Huck
2019-08-08 14:14     ` [Qemu-arm] " Cornelia Huck
2019-08-07  8:26 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 03/26] memory: Introduce size_memop tony.nguyen
2019-08-07  8:26   ` [Xen-devel] " tony.nguyen
2019-08-07  8:26   ` [Qemu-arm] " tony.nguyen
2019-08-07 15:30   ` [Qemu-riscv] " Richard Henderson
2019-08-07 15:30     ` [Xen-devel] " Richard Henderson
2019-08-07 15:30     ` Richard Henderson
2019-08-07  8:27 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 04/26] target/mips: Access MemoryRegion with MemOp tony.nguyen
2019-08-07  8:27   ` [Xen-devel] " tony.nguyen
2019-08-07  8:27   ` [Qemu-arm] " tony.nguyen
2019-08-07 12:50   ` [Qemu-riscv] " tony.nguyen
2019-08-07 12:50     ` [Xen-devel] " tony.nguyen
2019-08-07 12:50     ` [Qemu-arm] " tony.nguyen
2019-08-07  8:27 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 05/26] hw/s390x: " tony.nguyen
2019-08-07  8:27   ` [Xen-devel] " tony.nguyen
2019-08-07  8:27   ` [Qemu-arm] " tony.nguyen
2019-08-08 14:31   ` [Qemu-riscv] " Cornelia Huck
2019-08-08 14:31     ` [Xen-devel] " Cornelia Huck
2019-08-08 14:31     ` [Qemu-arm] " Cornelia Huck
2019-08-07  8:27 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 06/26] hw/intc/armv7m_nic: " tony.nguyen
2019-08-07  8:27   ` [Xen-devel] " tony.nguyen
2019-08-07  8:27   ` [Qemu-arm] " tony.nguyen
2019-08-07 12:54   ` [Qemu-riscv] " tony.nguyen
2019-08-07 12:54     ` [Xen-devel] " tony.nguyen
2019-08-07 12:54     ` [Qemu-arm] " tony.nguyen
2019-08-07  8:28 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 07/26] hw/virtio: " tony.nguyen
2019-08-07  8:28   ` [Xen-devel] " tony.nguyen
2019-08-07  8:28   ` [Qemu-arm] " tony.nguyen
2019-08-08 14:32   ` [Qemu-riscv] " Cornelia Huck
2019-08-08 14:32     ` [Xen-devel] " Cornelia Huck
2019-08-08 14:32     ` [Qemu-arm] " Cornelia Huck
2019-08-07  8:28 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 08/26] hw/vfio: " tony.nguyen
2019-08-07  8:28   ` [Xen-devel] " tony.nguyen
2019-08-07  8:28   ` [Qemu-arm] " tony.nguyen
2019-08-08 14:34   ` [Qemu-riscv] " Cornelia Huck
2019-08-08 14:34     ` [Xen-devel] " Cornelia Huck
2019-08-08 14:34     ` [Qemu-arm] " Cornelia Huck
2019-08-07  8:28 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 09/26] exec: " tony.nguyen
2019-08-07  8:28   ` [Xen-devel] " tony.nguyen
2019-08-07  8:28   ` [Qemu-arm] " tony.nguyen
2019-08-07 12:56   ` [Qemu-riscv] " tony.nguyen
2019-08-07 12:56     ` [Xen-devel] " tony.nguyen
2019-08-07 12:56     ` [Qemu-arm] " tony.nguyen
2019-08-07  8:29 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 10/26] cputlb: " tony.nguyen
2019-08-07  8:29   ` [Xen-devel] " tony.nguyen
2019-08-07  8:29   ` [Qemu-arm] " tony.nguyen
2019-08-07 12:45   ` [Qemu-riscv] " tony.nguyen
2019-08-07 12:45     ` [Xen-devel] " tony.nguyen
2019-08-07 12:45     ` [Qemu-arm] " tony.nguyen
2019-08-07 15:32   ` [Qemu-riscv] " Richard Henderson
2019-08-07 15:32     ` [Xen-devel] " Richard Henderson
2019-08-07 15:32     ` [Qemu-arm] " Richard Henderson
2019-08-07  8:29 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 11/26] memory: " tony.nguyen
2019-08-07  8:29   ` [Xen-devel] " tony.nguyen
2019-08-07  8:29   ` tony.nguyen
2019-08-07 15:38   ` [Qemu-riscv] " Richard Henderson
2019-08-07 15:38     ` [Xen-devel] " Richard Henderson
2019-08-07 15:38     ` [Qemu-arm] " Richard Henderson
2019-08-07  8:30 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 12/26] hw/s390x: Hard code size with MO_{8|16|32|64} tony.nguyen
2019-08-07  8:30   ` [Xen-devel] " tony.nguyen
2019-08-07  8:30   ` tony.nguyen
2019-08-07 15:47   ` [Qemu-riscv] " Richard Henderson
2019-08-07 15:47     ` [Xen-devel] " Richard Henderson
2019-08-07 15:47     ` Richard Henderson
2019-08-08 14:44   ` [Qemu-riscv] " Cornelia Huck
2019-08-08 14:44     ` [Xen-devel] " Cornelia Huck
2019-08-08 14:44     ` [Qemu-arm] " Cornelia Huck
2019-08-07  8:30 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 13/26] target/mips: " tony.nguyen
2019-08-07  8:30   ` [Xen-devel] " tony.nguyen
2019-08-07  8:30   ` [Qemu-arm] " tony.nguyen
2019-08-07 15:47   ` [Qemu-riscv] " Richard Henderson
2019-08-07 15:47     ` [Xen-devel] " Richard Henderson
2019-08-07 15:47     ` [Qemu-arm] " Richard Henderson
2019-08-07  8:30 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 14/26] exec: " tony.nguyen
2019-08-07  8:30   ` [Xen-devel] " tony.nguyen
2019-08-07  8:30   ` [Qemu-arm] " tony.nguyen
2019-08-07 15:48   ` [Qemu-riscv] " Richard Henderson
2019-08-07 15:48     ` [Xen-devel] " Richard Henderson
2019-08-07 15:48     ` [Qemu-arm] " Richard Henderson
2019-08-07  8:31 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 15/26] build: Correct non-common common-obj-* to obj-* tony.nguyen
2019-08-07  8:31   ` [Xen-devel] " tony.nguyen
2019-08-07  8:31   ` [Qemu-arm] " tony.nguyen
2019-08-07 10:42   ` [Qemu-riscv] " Paolo Bonzini
2019-08-07 10:42     ` [Xen-devel] " Paolo Bonzini
2019-08-07 10:42     ` [Qemu-arm] " Paolo Bonzini
2019-08-07  8:31 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 16/26] exec: Map device_endian onto MemOp tony.nguyen
2019-08-07  8:31   ` [Xen-devel] " tony.nguyen
2019-08-07  8:31   ` [Qemu-arm] " tony.nguyen
2019-08-07 15:55   ` [Qemu-riscv] " Richard Henderson
2019-08-07 15:55     ` [Xen-devel] " Richard Henderson
2019-08-07 15:55     ` [Qemu-arm] " Richard Henderson
2019-08-07 15:59   ` [Qemu-riscv] " Richard Henderson
2019-08-07 15:59     ` [Xen-devel] " Richard Henderson
2019-08-07 15:59     ` Richard Henderson
2019-08-07 16:06     ` [Qemu-riscv] " Richard Henderson
2019-08-07 16:06       ` [Xen-devel] " Richard Henderson
2019-08-07 16:06       ` [Qemu-arm] " Richard Henderson
2019-08-07  8:31 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 17/26] exec: Replace device_endian with MemOp tony.nguyen
2019-08-07  8:31   ` [Qemu-arm] " tony.nguyen
2019-08-07 16:23   ` [Qemu-riscv] " Richard Henderson
2019-08-07 16:23     ` [Xen-devel] " Richard Henderson
2019-08-07 16:23     ` Richard Henderson
2019-08-09  0:35   ` [Qemu-riscv] " David Gibson
2019-08-09  0:35     ` [Xen-devel] " David Gibson
2019-08-09  0:35     ` [Qemu-arm] " David Gibson
2019-08-07  8:32 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 18/26] exec: Delete device_endian tony.nguyen
2019-08-07  8:32   ` [Xen-devel] " tony.nguyen
2019-08-07  8:32   ` [Qemu-arm] " tony.nguyen
2019-08-07 16:23   ` [Qemu-riscv] " Richard Henderson
2019-08-07 16:23     ` [Xen-devel] " Richard Henderson
2019-08-07 16:23     ` Richard Henderson
2019-08-07  8:32 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 19/26] exec: Delete DEVICE_HOST_ENDIAN tony.nguyen
2019-08-07  8:32   ` [Xen-devel] " tony.nguyen
2019-08-07  8:32   ` [Qemu-arm] " tony.nguyen
2019-08-07 10:22   ` [Qemu-riscv] " Paolo Bonzini
2019-08-07 10:22     ` [Xen-devel] " Paolo Bonzini
2019-08-07 10:22     ` Paolo Bonzini
2019-08-07 15:03     ` [Qemu-riscv] " Richard Henderson
2019-08-07 15:03       ` [Xen-devel] " Richard Henderson
2019-08-07 15:03       ` [Qemu-arm] " Richard Henderson
2019-08-07  8:33 ` tony.nguyen [this message]
2019-08-07  8:33   ` [Xen-devel] [Qemu-devel] [PATCH v6 20/26] memory: Access MemoryRegion with endianness tony.nguyen
2019-08-07  8:33   ` [Qemu-arm] " tony.nguyen
2019-08-07 10:27   ` [Qemu-riscv] " Paolo Bonzini
2019-08-07 10:27     ` [Xen-devel] " Paolo Bonzini
2019-08-07 10:27     ` Paolo Bonzini
2019-08-07 17:49   ` [Qemu-riscv] " Richard Henderson
2019-08-07 17:49     ` [Xen-devel] " Richard Henderson
2019-08-07 17:49     ` [Qemu-arm] " Richard Henderson
2019-08-07 18:00     ` [Qemu-riscv] " Paolo Bonzini
2019-08-07 18:00       ` [Xen-devel] " Paolo Bonzini
2019-08-07 18:00       ` [Qemu-arm] " Paolo Bonzini
2019-08-07 18:23       ` [Qemu-riscv] " Richard Henderson
2019-08-07 18:23         ` [Xen-devel] " Richard Henderson
2019-08-07 18:23         ` [Qemu-arm] " Richard Henderson
2019-08-07  8:33 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 21/26] cputlb: Replace size and endian operands for MemOp tony.nguyen
2019-08-07  8:33   ` [Xen-devel] " tony.nguyen
2019-08-07  8:33   ` [Qemu-arm] " tony.nguyen
2019-08-07 17:38   ` [Qemu-riscv] " Richard Henderson
2019-08-07 17:38     ` [Xen-devel] " Richard Henderson
2019-08-07 17:38     ` [Qemu-arm] " Richard Henderson
2019-08-07  8:34 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 22/26] memory: Single byte swap along the I/O path tony.nguyen
2019-08-07  8:34   ` [Xen-devel] " tony.nguyen
2019-08-07  8:34   ` tony.nguyen
2019-08-07  8:34 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 23/26] cpu: TLB_FLAGS_MASK bit to force memory slow path tony.nguyen
2019-08-07  8:34   ` [Xen-devel] " tony.nguyen
2019-08-07  8:34   ` tony.nguyen
2019-08-07  8:34 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 24/26] cputlb: Byte swap memory transaction attribute tony.nguyen
2019-08-07  8:34   ` [Xen-devel] " tony.nguyen
2019-08-07  8:34   ` tony.nguyen
2019-08-07  8:35 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 25/26] target/sparc: Add TLB entry with attributes tony.nguyen
2019-08-07  8:35   ` [Xen-devel] " tony.nguyen
2019-08-07  8:35   ` tony.nguyen
2019-08-07  8:35 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 26/26] target/sparc: sun4u Invert Endian TTE bit tony.nguyen
2019-08-07  8:35   ` [Xen-devel] " tony.nguyen
2019-08-07  8:35   ` [Qemu-arm] " tony.nguyen
2019-08-07 13:04   ` [Qemu-riscv] " tony.nguyen
2019-08-07 13:04     ` [Xen-devel] " tony.nguyen
2019-08-07 13:04     ` [Qemu-arm] " tony.nguyen
2019-08-07 10:37 ` [Qemu-riscv] [Qemu-devel] [PATCH v6 00/26] Invert Endian bit in SPARCv9 MMU TTE Philippe Mathieu-Daudé
2019-08-07 10:37   ` [Xen-devel] " Philippe Mathieu-Daudé
2019-08-07 10:37   ` [Qemu-arm] " Philippe Mathieu-Daudé
2019-08-07 12:41   ` [Qemu-riscv] " tony.nguyen
2019-08-07 12:41     ` [Xen-devel] " tony.nguyen
2019-08-07 12:41     ` [Qemu-arm] " tony.nguyen
2019-08-07 12:54     ` [Qemu-riscv] " Philippe Mathieu-Daudé
2019-08-07 12:54       ` [Xen-devel] " Philippe Mathieu-Daudé
2019-08-07 12:54       ` Philippe Mathieu-Daudé

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1565166794966.57397@bt.com \
    --to=tony.nguyen@bt.com \
    --cc=Andrew.Baumann@microsoft.com \
    --cc=alex.williamson@redhat.com \
    --cc=alistair@alistair23.me \
    --cc=amarkovic@wavecomp.com \
    --cc=andrew.smirnov@gmail.com \
    --cc=andrew@aj.id.au \
    --cc=anthony.perard@citrix.com \
    --cc=antonynpavlov@gmail.com \
    --cc=arikalo@wavecomp.com \
    --cc=atar4qemu@gmail.com \
    --cc=aurelien@aurel32.net \
    --cc=b.galvani@gmail.com \
    --cc=berto@igalia.com \
    --cc=borntraeger@de.ibm.com \
    --cc=chouteau@adacore.com \
    --cc=clg@kaod.org \
    --cc=cohuck@redhat.com \
    --cc=crwulff@gmail.com \
    --cc=david@gibson.dropbear.id.au \
    --cc=david@redhat.com \
    --cc=deller@gmx.de \
    --cc=dmitry.fleytman@gmail.com \
    --cc=edgar.iglesias@gmail.com \
    --cc=ehabkost@redhat.com \
    --cc=eric.auger@redhat.com \
    --cc=fam@euphon.net \
    --cc=frederic.konrad@adacore.com \
    --cc=green@moxielogic.com \
    --cc=gxt@mprc.pku.edu.cn \
    --cc=hare@suse.com \
    --cc=hpoussin@reactos.org \
    --cc=huth@tuxfamily.org \
    --cc=i.mitsyanko@gmail.com \
    --cc=imammedo@redhat.com \
    --cc=jan.kiszka@web.de \
    --cc=jasowang@redhat.com \
    --cc=jcd@tribudubois.net \
    --cc=jcmvbkbc@gmail.com \
    --cc=jiri@resnulli.us \
    --cc=joel@jms.id.au \
    --cc=jslaby@suse.cz \
    --cc=jsnow@redhat.com \
    --cc=kbastian@mail.uni-paderborn.de \
    --cc=keith.busch@intel.com \
    --cc=kraxel@redhat.com \
    --cc=kwolf@redhat.com \
    --cc=laurent@vivier.eu \
    --cc=lersek@redhat.com \
    --cc=magnus.damm@gmail.com \
    --cc=marcandre.lureau@redhat.com \
    --cc=marex@denx.de \
    --cc=mark.cave-ayland@ilande.co.uk \
    --cc=michael@walle.cc \
    --cc=minyard@acm.org \
    --cc=mreitz@redhat.com \
    --cc=mst@redhat.com \
    --cc=palmer@sifive.com \
    --cc=pasic@linux.ibm.com \
    --cc=paul.durrant@citrix.com \
    --cc=pbonzini@redhat.com \
    --cc=pburton@wavecomp.com \
    --cc=peter.chubb@nicta.com.au \
    --cc=peter.maydell@linaro.org \
    --cc=philmd@redhat.com \
    --cc=proljc@gmail.com \
    --cc=qemu-arm@nongnu.org \
    --cc=qemu-block@nongnu.org \
    --cc=qemu-devel@nongnu.org \
    --cc=qemu-ppc@nongnu.org \
    --cc=qemu-riscv@nongnu.org \
    --cc=qemu-s390x@nongnu.org \
    --cc=robh@kernel.org \
    --cc=rth@twiddle.net \
    --cc=sagark@eecs.berkeley.edu \
    --cc=shorne@gmail.com \
    --cc=sstabellini@kernel.org \
    --cc=stefanb@linux.ibm.com \
    --cc=stefanha@redhat.com \
    --cc=sundeep.lkml@gmail.com \
    --cc=sw@weilnetz.de \
    --cc=walling@linux.ibm.com \
    --cc=xen-devel@lists.xenproject.org \
    --cc=xiaoguangrong.eric@gmail.com \
    --cc=yuval.shaia@oracle.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.