aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorRichard Henderson <richard.henderson@linaro.org>2020-12-15 11:47:59 -0600
committerRichard Henderson <richard.henderson@linaro.org>2021-01-04 06:32:58 -1000
commit6d3ef04893bdea3e7aa08be3cce5141902836a31 (patch)
treeeae5ae6605ba168477024c0497e77c7c0c1e74ee /include
parent41192db338588051f21501abc13743e62b0a5605 (diff)
downloadqemu-6d3ef04893bdea3e7aa08be3cce5141902836a31.zip
qemu-6d3ef04893bdea3e7aa08be3cce5141902836a31.tar.gz
qemu-6d3ef04893bdea3e7aa08be3cce5141902836a31.tar.bz2
tcg: Use memset for large vector byte replication
In f47db80cc07, we handled odd-sized tail clearing for the case of hosts that have vector operations, but did not handle the case of hosts that do not have vector ops. This was ok until e2e7168a214b, which changed the encoding of simd_desc such that the odd sizes are impossible. Add memset as a tcg helper, and use that for all out-of-line byte stores to vectors. This includes, but is not limited to, the tail clearing operation in question. Cc: qemu-stable@nongnu.org Buglink: https://bugs.launchpad.net/bugs/1907817 Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
Diffstat (limited to 'include')
-rw-r--r--include/exec/helper-proto.h4
1 files changed, 4 insertions, 0 deletions
diff --git a/include/exec/helper-proto.h b/include/exec/helper-proto.h
index a0a8d9a..659f929 100644
--- a/include/exec/helper-proto.h
+++ b/include/exec/helper-proto.h
@@ -35,11 +35,15 @@ dh_ctype(ret) HELPER(name) (dh_ctype(t1), dh_ctype(t2), dh_ctype(t3), \
dh_ctype(t4), dh_ctype(t5), dh_ctype(t6), \
dh_ctype(t7));
+#define IN_HELPER_PROTO
+
#include "helper.h"
#include "trace/generated-helpers.h"
#include "tcg-runtime.h"
#include "plugin-helpers.h"
+#undef IN_HELPER_PROTO
+
#undef DEF_HELPER_FLAGS_0
#undef DEF_HELPER_FLAGS_1
#undef DEF_HELPER_FLAGS_2