aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/include/linux/greybus/greybus_protocols.h
diff options
context:
space:
mode:
authorKees Cook <keescook@chromium.org>2024-03-04 13:19:45 -0800
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2024-03-05 13:59:43 +0000
commit7ba59ac7da2aae2fbcfe90352ee40d30cecca10d (patch)
tree70ada7e0c73c7c7d99542efe100a6790abaf1d3b /include/linux/greybus/greybus_protocols.h
parentstaging: greybus: fix get_channel_from_mode() failure path (diff)
downloadwireguard-linux-7ba59ac7da2aae2fbcfe90352ee40d30cecca10d.tar.xz
wireguard-linux-7ba59ac7da2aae2fbcfe90352ee40d30cecca10d.zip
greybus: Avoid fake flexible array for response data
FORTIFY_SOURCE has been ignoring 0-sized destinations while the kernel code base has been converted to flexible arrays. In order to enforce the 0-sized destinations (e.g. with __counted_by), the remaining 0-sized destinations need to be handled. Instead of converting an empty struct into using a flexible array, just directly use a pointer without any additional indirection. Remove struct gb_bootrom_get_firmware_response and struct gb_fw_download_fetch_firmware_response. Signed-off-by: Kees Cook <keescook@chromium.org> Reviewed-by: Alex Elder <elder@linaro.org> Link: https://lore.kernel.org/r/20240304211940.it.083-kees@kernel.org Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'include/linux/greybus/greybus_protocols.h')
-rw-r--r--include/linux/greybus/greybus_protocols.h8
1 files changed, 2 insertions, 6 deletions
diff --git a/include/linux/greybus/greybus_protocols.h b/include/linux/greybus/greybus_protocols.h
index aeb8f9243545..820134b0105c 100644
--- a/include/linux/greybus/greybus_protocols.h
+++ b/include/linux/greybus/greybus_protocols.h
@@ -232,9 +232,7 @@ struct gb_fw_download_fetch_firmware_request {
__le32 size;
} __packed;
-struct gb_fw_download_fetch_firmware_response {
- __u8 data[0];
-} __packed;
+/* gb_fw_download_fetch_firmware_response contains no other data */
/* firmware download release firmware request */
struct gb_fw_download_release_firmware_request {
@@ -414,9 +412,7 @@ struct gb_bootrom_get_firmware_request {
__le32 size;
} __packed;
-struct gb_bootrom_get_firmware_response {
- __u8 data[0];
-} __packed;
+/* gb_bootrom_get_firmware_response contains no other data */
/* Bootrom protocol Ready to boot request */
struct gb_bootrom_ready_to_boot_request {