diff options
author | Peter Maydell <peter.maydell@linaro.org> | 2021-06-14 16:09:26 +0100 |
---|---|---|
committer | Peter Maydell <peter.maydell@linaro.org> | 2021-06-16 14:33:52 +0100 |
commit | dbcf6f9367a6a4af05b18cf0d7badf7677f403c4 (patch) | |
tree | 3969e4b2ce66b4113fda93eae7fe9d364348ee70 /target | |
parent | 77f96148f3f6c4106a2a3cee8146690f954fd6cd (diff) | |
download | qemu-dbcf6f9367a6a4af05b18cf0d7badf7677f403c4.zip qemu-dbcf6f9367a6a4af05b18cf0d7badf7677f403c4.tar.gz qemu-dbcf6f9367a6a4af05b18cf0d7badf7677f403c4.tar.bz2 |
bitops.h: Provide hswap32(), hswap64(), wswap64() swapping operations
Currently the ARM SVE helper code defines locally some utility
functions for swapping 16-bit halfwords within 32-bit or 64-bit
values and for swapping 32-bit words within 64-bit values,
parallel to the byte-swapping bswap16/32/64 functions.
We want these also for the ARM MVE code, and they're potentially
generally useful for other targets, so move them to bitops.h.
(We don't put them in bswap.h with the bswap* functions because
they are implemented in terms of the rotate operations also
defined in bitops.h, and including bitops.h from bswap.h seems
better avoided.)
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Message-id: 20210614151007.4545-17-peter.maydell@linaro.org
Diffstat (limited to 'target')
-rw-r--r-- | target/arm/sve_helper.c | 20 |
1 files changed, 0 insertions, 20 deletions
diff --git a/target/arm/sve_helper.c b/target/arm/sve_helper.c index 321098e..dab5f1d 100644 --- a/target/arm/sve_helper.c +++ b/target/arm/sve_helper.c @@ -152,26 +152,6 @@ static inline uint64_t expand_pred_s(uint8_t byte) return word[byte & 0x11]; } -/* Swap 16-bit words within a 32-bit word. */ -static inline uint32_t hswap32(uint32_t h) -{ - return rol32(h, 16); -} - -/* Swap 16-bit words within a 64-bit word. */ -static inline uint64_t hswap64(uint64_t h) -{ - uint64_t m = 0x0000ffff0000ffffull; - h = rol64(h, 32); - return ((h & m) << 16) | ((h >> 16) & m); -} - -/* Swap 32-bit words within a 64-bit word. */ -static inline uint64_t wswap64(uint64_t h) -{ - return rol64(h, 32); -} - #define LOGICAL_PPPP(NAME, FUNC) \ void HELPER(NAME)(void *vd, void *vn, void *vm, void *vg, uint32_t desc) \ { \ |