aboutsummaryrefslogtreecommitdiff
path: root/hw/core
diff options
context:
space:
mode:
authorPeter Maydell <peter.maydell@linaro.org>2018-09-27 17:42:00 +0100
committerEric Blake <eblake@redhat.com>2018-10-03 09:58:43 -0500
commit80c7c2b00d607221bb43815d2c1951d54229b3ee (patch)
tree7d9f3932b246f2b17d6ba6d7dbd4f9966c8071b1 /hw/core
parentdafd95053611aa14dda40266857608d12ddce658 (diff)
downloadqemu-80c7c2b00d607221bb43815d2c1951d54229b3ee.zip
qemu-80c7c2b00d607221bb43815d2c1951d54229b3ee.tar.gz
qemu-80c7c2b00d607221bb43815d2c1951d54229b3ee.tar.bz2
nbd: Don't take address of fields in packed structs
Taking the address of a field in a packed struct is a bad idea, because it might not be actually aligned enough for that pointer type (and thus cause a crash on dereference on some host architectures). Newer versions of clang warn about this. Avoid the bug by not using the "modify in place" byte swapping functions. This patch was produced with the following spatch script: @@ expression E; @@ -be16_to_cpus(&E); +E = be16_to_cpu(E); @@ expression E; @@ -be32_to_cpus(&E); +E = be32_to_cpu(E); @@ expression E; @@ -be64_to_cpus(&E); +E = be64_to_cpu(E); @@ expression E; @@ -cpu_to_be16s(&E); +E = cpu_to_be16(E); @@ expression E; @@ -cpu_to_be32s(&E); +E = cpu_to_be32(E); @@ expression E; @@ -cpu_to_be64s(&E); +E = cpu_to_be64(E); Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Message-Id: <20180927164200.15097-1-peter.maydell@linaro.org> Reviewed-by: Eric Blake <eblake@redhat.com> [eblake: rebase, and squash in missed changes] Signed-off-by: Eric Blake <eblake@redhat.com>
Diffstat (limited to 'hw/core')
0 files changed, 0 insertions, 0 deletions