[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH v4 13/14] target-aarch64: Generate fences for aarch6
From: |
Pranith Kumar |
Subject: |
[Qemu-devel] [PATCH v4 13/14] target-aarch64: Generate fences for aarch64 |
Date: |
Thu, 14 Jul 2016 16:20:25 -0400 |
Signed-off-by: Pranith Kumar <address@hidden>
---
target-arm/translate-a64.c | 14 +++++++++++++-
1 file changed, 13 insertions(+), 1 deletion(-)
diff --git a/target-arm/translate-a64.c b/target-arm/translate-a64.c
index f5e29d2..09877bc 100644
--- a/target-arm/translate-a64.c
+++ b/target-arm/translate-a64.c
@@ -1305,7 +1305,7 @@ static void handle_sync(DisasContext *s, uint32_t insn,
return;
case 4: /* DSB */
case 5: /* DMB */
- /* We don't emulate caches so barriers are no-ops */
+ tcg_gen_mb(TCG_MO_ALL | TCG_BAR_SC);
return;
case 6: /* ISB */
/* We need to break the TB after this insn to execute
@@ -1934,7 +1934,13 @@ static void disas_ldst_excl(DisasContext *s, uint32_t
insn)
if (!is_store) {
s->is_ldex = true;
gen_load_exclusive(s, rt, rt2, tcg_addr, size, is_pair);
+ if (is_lasr) {
+ tcg_gen_mb(TCG_MO_ALL | TCG_BAR_LDAQ);
+ }
} else {
+ if (is_lasr) {
+ tcg_gen_mb(TCG_MO_ALL | TCG_BAR_STRL);
+ }
gen_store_exclusive(s, rs, rt, rt2, tcg_addr, size, is_pair);
}
} else {
@@ -1943,11 +1949,17 @@ static void disas_ldst_excl(DisasContext *s, uint32_t
insn)
/* Generate ISS for non-exclusive accesses including LASR. */
if (is_store) {
+ if (is_lasr) {
+ tcg_gen_mb(TCG_MO_ALL | TCG_BAR_STRL);
+ }
do_gpr_st(s, tcg_rt, tcg_addr, size,
true, rt, iss_sf, is_lasr);
} else {
do_gpr_ld(s, tcg_rt, tcg_addr, size, false, false,
true, rt, iss_sf, is_lasr);
+ if (is_lasr) {
+ tcg_gen_mb(TCG_MO_ALL | TCG_BAR_LDAQ);
+ }
}
}
}
--
2.9.0
- [Qemu-devel] [PATCH v4 03/14] tcg/aarch64: Add support for fence, (continued)
- [Qemu-devel] [PATCH v4 03/14] tcg/aarch64: Add support for fence, Pranith Kumar, 2016/07/14
- [Qemu-devel] [PATCH v4 07/14] tcg/ppc: Add support for fence, Pranith Kumar, 2016/07/14
- [Qemu-devel] [PATCH v4 08/14] tcg/s390: Add support for fence, Pranith Kumar, 2016/07/14
- [Qemu-devel] [PATCH v4 06/14] tcg/mips: Add support for fence, Pranith Kumar, 2016/07/14
- [Qemu-devel] [PATCH v4 04/14] tcg/arm: Add support for fence, Pranith Kumar, 2016/07/14
- [Qemu-devel] [PATCH v4 09/14] tcg/sparc: Add support for fence, Pranith Kumar, 2016/07/14
- [Qemu-devel] [PATCH v4 10/14] tcg/tci: Add support for fence, Pranith Kumar, 2016/07/14
- [Qemu-devel] [PATCH v4 12/14] target-alpha: Generate fence op, Pranith Kumar, 2016/07/14
- [Qemu-devel] [PATCH v4 11/14] target-arm: Generate fences in ARMv7 frontend, Pranith Kumar, 2016/07/14
- [Qemu-devel] [PATCH v4 14/14] target-i386: Generate fences for x86, Pranith Kumar, 2016/07/14
- [Qemu-devel] [PATCH v4 13/14] target-aarch64: Generate fences for aarch64,
Pranith Kumar <=
- Re: [Qemu-devel] [PATCH v4 00/14] tcg: Add support for fence generation, Pranith Kumar, 2016/07/23