flexible-array member conversion patches for 5.8-rc2
Hi Linus, Please, pull the following patches that replace zero-length arrays with flexible-array members. Notice that all of these patches have been baking in linux-next for two development cycles now. There is a regular need in the kernel to provide a way to declare having a dynamically sized set of trailing elements in a structure. Kernel code should always use “flexible array members”[1] for these cases. The older style of one-element or zero-length arrays should no longer be used[2]. C99 introduced “flexible array members”, which lacks a numeric size for the array declaration entirely: struct something { size_t count; struct foo items[]; }; This is the way the kernel expects dynamically sized trailing elements to be declared. It allows the compiler to generate errors when the flexible array does not occur last in the structure, which helps to prevent some kind of undefined behavior[3] bugs from being inadvertently introduced to the codebase. It also allows the compiler to correctly analyze array sizes (via sizeof(), CONFIG_FORTIFY_SOURCE, and CONFIG_UBSAN_BOUNDS). For instance, there is no mechanism that warns us that the following application of the sizeof() operator to a zero-length array always results in zero: struct something { size_t count; struct foo items[0]; }; struct something *instance; instance = kmalloc(struct_size(instance, items, count), GFP_KERNEL); instance->count = count; size = sizeof(instance->items) * instance->count; memcpy(instance->items, source, size); At the last line of code above, size turns out to be zero, when one might have thought it represents the total size in bytes of the dynamic memory recently allocated for the trailing array items. Here are a couple examples of this issue[4][5]. Instead, flexible array members have incomplete type, and so the sizeof() operator may not be applied[6], so any misuse of such operators will be immediately noticed at build time. The cleanest and least error-prone way to implement this is through the use of a flexible array member: struct something { size_t count; struct foo items[]; }; struct something *instance; instance = kmalloc(struct_size(instance, items, count), GFP_KERNEL); instance->count = count; size = sizeof(instance->items[0]) * instance->count; memcpy(instance->items, source, size); Thanks -- Gustavo [1] https://en.wikipedia.org/wiki/Flexible_array_member [2] https://github.com/KSPP/linux/issues/21 [3] https://git.kernel.org/linus/76497732932f15e7323dc805e8ea8dc11bb587cf [4] https://git.kernel.org/linus/f2cd32a443da694ac4e28fbf4ac6f9d5cc63a539 [5] https://git.kernel.org/linus/ab91c2a89f86be2898cee208d492816ec238b2cf [6] https://gcc.gnu.org/onlinedocs/gcc/Zero-Length.html -----BEGIN PGP SIGNATURE----- iQIzBAABCAAdFiEEkmRahXBSurMIg1YvRwW0y0cG2zEFAl7oSmYACgkQRwW0y0cG 2zGEiw/9FiH3MBwMlPVJPcneY1wCH/N6ZSf+kr7SJiVwV/YbBe9EWuaKZ0D4vAWm kTACkOfsZ1me1OKz9wNrOxn0zezTMFQK2PLPgzKIPuK0Hg8MW1EU63RIRsnr0bPc b90wZwyBQtLbGRC3/9yAACKwFZe/SeYoV5rr8uylffA35HZW3SZbTex6XnGCF9Q5 UYwnz7vNg+9VH1GRQeB5jlqL7mAoRzJ49I/TL3zJr04Mn+xC+vVBS7XwipDd03p+ foC6/KmGhlCO9HMPASReGrOYNPydDAMKLNPdIfUlcTKHWsoTjGOcW/dzfT4rUu6n nKr5rIqJ4FdlIvXZL5P5w7Uhkwbd3mus5G0HBk+V/cUScckCpBou+yuGzjxXSitQ o0qPsGjWr3v+gxRWHj8YO/9MhKKKW0Iy+QmAC9+uLnbfJdbUwYbLIXbsOKnokCA8 jkDEr64F5hFTKtajIK4VToJK1CsM3D9dwTub27lwZysHn3RYSQdcyN+9OiZgdzpc GlI6QoaqKR9AT4b/eBmqlQAKgA07zSQ5RsIjRm6hN3d7u/77x2kyrreo+trJyVY2 F17uEOzfTqZyxtkPayE8DVjTtbByoCuBR0Vm1oMAFxjyqZQY5daalB0DKd1mdYqi khIXqNAuYqHOb898fEuzidjV38hxZ9y8SAym3P7WnYl+Hxz+8Jo= =8HUQ -----END PGP SIGNATURE----- Merge tag 'flex-array-conversions-5.8-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/gustavoars/linux Pull flexible-array member conversions from Gustavo A. R. Silva: "Replace zero-length arrays with flexible-array members. Notice that all of these patches have been baking in linux-next for two development cycles now. There is a regular need in the kernel to provide a way to declare having a dynamically sized set of trailing elements in a structure. Kernel code should always use “flexible array members”[1] for these cases. The older style of one-element or zero-length arrays should no longer be used[2]. C99 introduced “flexible array members”, which lacks a numeric size for the array declaration entirely: struct something { size_t count; struct foo items[]; }; This is the way the kernel expects dynamically sized trailing elements to be declared. It allows the compiler to generate errors when the flexible array does not occur last in the structure, which helps to prevent some kind of undefined behavior[3] bugs from being inadvertently introduced to the codebase. It also allows the compiler to correctly analyze array sizes (via sizeof(), CONFIG_FORTIFY_SOURCE, and CONFIG_UBSAN_BOUNDS). For instance, there is no mechanism that warns us that the following application of the sizeof() operator to a zero-length array always results in zero: struct something { size_t count; struct foo items[0]; }; struct something *instance; instance = kmalloc(struct_size(instance, items, count), GFP_KERNEL); instance->count = count; size = sizeof(instance->items) * instance->count; memcpy(instance->items, source, size); At the last line of code above, size turns out to be zero, when one might have thought it represents the total size in bytes of the dynamic memory recently allocated for the trailing array items. Here are a couple examples of this issue[4][5]. Instead, flexible array members have incomplete type, and so the sizeof() operator may not be applied[6], so any misuse of such operators will be immediately noticed at build time. The cleanest and least error-prone way to implement this is through the use of a flexible array member: struct something { size_t count; struct foo items[]; }; struct something *instance; instance = kmalloc(struct_size(instance, items, count), GFP_KERNEL); instance->count = count; size = sizeof(instance->items[0]) * instance->count; memcpy(instance->items, source, size); instead" [1] https://en.wikipedia.org/wiki/Flexible_array_member [2] https://github.com/KSPP/linux/issues/21 [3] commit7649773293
("cxgb3/l2t: Fix undefined behaviour") [4] commitf2cd32a443
("rndis_wlan: Remove logically dead code") [5] commitab91c2a89f
("tpm: eventlog: Replace zero-length array with flexible-array member") [6] https://gcc.gnu.org/onlinedocs/gcc/Zero-Length.html * tag 'flex-array-conversions-5.8-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/gustavoars/linux: (41 commits) w1: Replace zero-length array with flexible-array tracing/probe: Replace zero-length array with flexible-array soc: ti: Replace zero-length array with flexible-array tifm: Replace zero-length array with flexible-array dmaengine: tegra-apb: Replace zero-length array with flexible-array stm class: Replace zero-length array with flexible-array Squashfs: Replace zero-length array with flexible-array ASoC: SOF: Replace zero-length array with flexible-array ima: Replace zero-length array with flexible-array sctp: Replace zero-length array with flexible-array phy: samsung: Replace zero-length array with flexible-array RxRPC: Replace zero-length array with flexible-array rapidio: Replace zero-length array with flexible-array media: pwc: Replace zero-length array with flexible-array firmware: pcdp: Replace zero-length array with flexible-array oprofile: Replace zero-length array with flexible-array block: Replace zero-length array with flexible-array tools/testing/nvdimm: Replace zero-length array with flexible-array libata: Replace zero-length array with flexible-array kprobes: Replace zero-length array with flexible-array ...
This commit is contained in:
commit
ffbc93768e
@ -42,7 +42,7 @@ enum unw_register_index {
|
||||
|
||||
struct unw_info_block {
|
||||
u64 header;
|
||||
u64 desc[0]; /* unwind descriptors */
|
||||
u64 desc[]; /* unwind descriptors */
|
||||
/* personality routine and language-specific data follow behind descriptors */
|
||||
};
|
||||
|
||||
|
@ -93,7 +93,7 @@ struct frag { /* VBLK Fragment handling */
|
||||
u8 num; /* Total number of records */
|
||||
u8 rec; /* This is record number n */
|
||||
u8 map; /* Which portions are in use */
|
||||
u8 data[0];
|
||||
u8 data[];
|
||||
};
|
||||
|
||||
/* In memory LDM database structures. */
|
||||
|
@ -120,7 +120,7 @@ static const u32 tegra_ahb_gizmo[] = {
|
||||
struct tegra_ahb {
|
||||
void __iomem *regs;
|
||||
struct device *dev;
|
||||
u32 ctx[0];
|
||||
u32 ctx[];
|
||||
};
|
||||
|
||||
static inline u32 gizmo_readl(struct tegra_ahb *ahb, u32 offset)
|
||||
|
@ -620,7 +620,7 @@ struct fifo_buffer {
|
||||
unsigned int head_index;
|
||||
unsigned int size;
|
||||
int total; /* sum of all values */
|
||||
int values[0];
|
||||
int values[];
|
||||
};
|
||||
extern struct fifo_buffer *fifo_alloc(unsigned int fifo_size);
|
||||
|
||||
|
@ -271,7 +271,7 @@ struct p_rs_param {
|
||||
u32 resync_rate;
|
||||
|
||||
/* Since protocol version 88 and higher. */
|
||||
char verify_alg[0];
|
||||
char verify_alg[];
|
||||
} __packed;
|
||||
|
||||
struct p_rs_param_89 {
|
||||
@ -305,7 +305,7 @@ struct p_protocol {
|
||||
u32 two_primaries;
|
||||
|
||||
/* Since protocol version 87 and higher. */
|
||||
char integrity_alg[0];
|
||||
char integrity_alg[];
|
||||
|
||||
} __packed;
|
||||
|
||||
@ -360,7 +360,7 @@ struct p_sizes {
|
||||
u16 dds_flags; /* use enum dds_flags here. */
|
||||
|
||||
/* optional queue_limits if (agreed_features & DRBD_FF_WSAME) */
|
||||
struct o_qlim qlim[0];
|
||||
struct o_qlim qlim[];
|
||||
} __packed;
|
||||
|
||||
struct p_state {
|
||||
@ -409,7 +409,7 @@ struct p_compressed_bm {
|
||||
*/
|
||||
u8 encoding;
|
||||
|
||||
u8 code[0];
|
||||
u8 code[];
|
||||
} __packed;
|
||||
|
||||
struct p_delay_probe93 {
|
||||
|
@ -223,7 +223,7 @@ struct chcr_authenc_ctx {
|
||||
|
||||
struct __aead_ctx {
|
||||
struct chcr_gcm_ctx gcm[0];
|
||||
struct chcr_authenc_ctx authenc[0];
|
||||
struct chcr_authenc_ctx authenc[];
|
||||
};
|
||||
|
||||
struct chcr_aead_ctx {
|
||||
@ -235,7 +235,7 @@ struct chcr_aead_ctx {
|
||||
u8 nonce[4];
|
||||
u16 hmac_ctrl;
|
||||
u16 mayverify;
|
||||
struct __aead_ctx ctx[0];
|
||||
struct __aead_ctx ctx[];
|
||||
};
|
||||
|
||||
struct hmac_ctx {
|
||||
@ -247,7 +247,7 @@ struct hmac_ctx {
|
||||
struct __crypto_ctx {
|
||||
struct hmac_ctx hmacctx[0];
|
||||
struct ablk_ctx ablkctx[0];
|
||||
struct chcr_aead_ctx aeadctx[0];
|
||||
struct chcr_aead_ctx aeadctx[];
|
||||
};
|
||||
|
||||
struct chcr_context {
|
||||
@ -257,7 +257,7 @@ struct chcr_context {
|
||||
unsigned int ntxq;
|
||||
unsigned int nrxq;
|
||||
struct completion cbc_aes_aio_done;
|
||||
struct __crypto_ctx crypto_ctx[0];
|
||||
struct __crypto_ctx crypto_ctx[];
|
||||
};
|
||||
|
||||
struct chcr_hctx_per_wr {
|
||||
|
@ -77,7 +77,7 @@ struct milbeaut_hdmac_device {
|
||||
struct dma_device ddev;
|
||||
struct clk *clk;
|
||||
void __iomem *reg_base;
|
||||
struct milbeaut_hdmac_chan channels[0];
|
||||
struct milbeaut_hdmac_chan channels[];
|
||||
};
|
||||
|
||||
static struct milbeaut_hdmac_chan *
|
||||
|
@ -74,7 +74,7 @@ struct milbeaut_xdmac_chan {
|
||||
struct milbeaut_xdmac_device {
|
||||
struct dma_device ddev;
|
||||
void __iomem *reg_base;
|
||||
struct milbeaut_xdmac_chan channels[0];
|
||||
struct milbeaut_xdmac_chan channels[];
|
||||
};
|
||||
|
||||
static struct milbeaut_xdmac_chan *
|
||||
|
@ -127,7 +127,7 @@ struct moxart_desc {
|
||||
unsigned int dma_cycles;
|
||||
struct virt_dma_desc vd;
|
||||
uint8_t es;
|
||||
struct moxart_sg sg[0];
|
||||
struct moxart_sg sg[];
|
||||
};
|
||||
|
||||
struct moxart_chan {
|
||||
|
@ -225,7 +225,7 @@ struct tegra_dma {
|
||||
u32 global_pause_count;
|
||||
|
||||
/* Last member of the structure */
|
||||
struct tegra_dma_channel channels[0];
|
||||
struct tegra_dma_channel channels[];
|
||||
};
|
||||
|
||||
static inline void tdma_write(struct tegra_dma *tdma, u32 reg, u32 val)
|
||||
|
@ -211,7 +211,7 @@ struct edma_desc {
|
||||
u32 residue;
|
||||
u32 residue_stat;
|
||||
|
||||
struct edma_pset pset[0];
|
||||
struct edma_pset pset[];
|
||||
};
|
||||
|
||||
struct edma_cc;
|
||||
|
@ -170,7 +170,7 @@ struct udma_desc {
|
||||
void *metadata; /* pointer to provided metadata buffer (EPIP, PSdata) */
|
||||
|
||||
unsigned int hwdesc_count;
|
||||
struct udma_hwdesc hwdesc[0];
|
||||
struct udma_hwdesc hwdesc[];
|
||||
};
|
||||
|
||||
enum udma_chan_state {
|
||||
|
@ -88,7 +88,7 @@ struct timb_dma {
|
||||
struct dma_device dma;
|
||||
void __iomem *membase;
|
||||
struct tasklet_struct tasklet;
|
||||
struct timb_dma_chan channels[0];
|
||||
struct timb_dma_chan channels[];
|
||||
};
|
||||
|
||||
static struct device *chan2dev(struct dma_chan *chan)
|
||||
|
@ -117,7 +117,7 @@ struct inbound_transaction_resource {
|
||||
struct descriptor_resource {
|
||||
struct client_resource resource;
|
||||
struct fw_descriptor descriptor;
|
||||
u32 data[0];
|
||||
u32 data[];
|
||||
};
|
||||
|
||||
struct iso_resource {
|
||||
|
@ -620,7 +620,7 @@ struct fw_request {
|
||||
u32 request_header[4];
|
||||
int ack;
|
||||
u32 length;
|
||||
u32 data[0];
|
||||
u32 data[];
|
||||
};
|
||||
|
||||
static void free_response_callback(struct fw_packet *packet,
|
||||
|
@ -191,7 +191,7 @@ struct fw_node {
|
||||
/* Upper layer specific data. */
|
||||
void *data;
|
||||
|
||||
struct fw_node *ports[0];
|
||||
struct fw_node *ports[];
|
||||
};
|
||||
|
||||
static inline struct fw_node *fw_node_get(struct fw_node *node)
|
||||
|
@ -52,7 +52,7 @@ struct pcl {
|
||||
|
||||
struct packet {
|
||||
unsigned int length;
|
||||
char data[0];
|
||||
char data[];
|
||||
};
|
||||
|
||||
struct packet_buffer {
|
||||
|
@ -111,7 +111,7 @@ struct descriptor_buffer {
|
||||
dma_addr_t buffer_bus;
|
||||
size_t buffer_size;
|
||||
size_t used;
|
||||
struct descriptor buffer[0];
|
||||
struct descriptor buffer[];
|
||||
};
|
||||
|
||||
struct context {
|
||||
|
@ -262,7 +262,7 @@ struct dmi_system_event_log {
|
||||
u8 header_format;
|
||||
u8 type_descriptors_supported_count;
|
||||
u8 per_log_type_descriptor_length;
|
||||
u8 supported_log_type_descriptos[0];
|
||||
u8 supported_log_type_descriptos[];
|
||||
} __packed;
|
||||
|
||||
#define DMI_SYSFS_SEL_FIELD(_field) \
|
||||
|
@ -21,7 +21,7 @@
|
||||
struct cbmem_cons {
|
||||
u32 size_dont_access_after_boot;
|
||||
u32 cursor;
|
||||
u8 body[0];
|
||||
u8 body[];
|
||||
} __packed;
|
||||
|
||||
#define CURSOR_MASK ((1 << 28) - 1)
|
||||
|
@ -32,7 +32,7 @@ struct vpd_cbmem {
|
||||
u32 version;
|
||||
u32 ro_size;
|
||||
u32 rw_size;
|
||||
u8 blob[0];
|
||||
u8 blob[];
|
||||
};
|
||||
|
||||
struct vpd_section {
|
||||
|
@ -104,7 +104,7 @@ struct ibft_control {
|
||||
u16 tgt0_off;
|
||||
u16 nic1_off;
|
||||
u16 tgt1_off;
|
||||
u16 expansion[0];
|
||||
u16 expansion[];
|
||||
} __attribute__((__packed__));
|
||||
|
||||
struct ibft_initiator {
|
||||
|
@ -103,6 +103,6 @@ struct pcdp {
|
||||
u8 creator_id[4];
|
||||
u32 creator_rev;
|
||||
u32 num_uarts;
|
||||
struct pcdp_uart uart[0]; /* actual size is num_uarts */
|
||||
struct pcdp_uart uart[]; /* actual size is num_uarts */
|
||||
/* remainder of table is pcdp_device structures */
|
||||
} __attribute__((packed));
|
||||
|
@ -34,7 +34,7 @@ struct stp_policy_node {
|
||||
unsigned int first_channel;
|
||||
unsigned int last_channel;
|
||||
/* this is the one that's exposed to the attributes */
|
||||
unsigned char priv[0];
|
||||
unsigned char priv[];
|
||||
};
|
||||
|
||||
void *stp_policy_node_priv(struct stp_policy_node *pn)
|
||||
|
@ -23,7 +23,7 @@ void *stp_policy_node_priv(struct stp_policy_node *pn);
|
||||
|
||||
struct stp_master {
|
||||
unsigned int nr_free;
|
||||
unsigned long chan_map[0];
|
||||
unsigned long chan_map[];
|
||||
};
|
||||
|
||||
struct stm_device {
|
||||
@ -42,7 +42,7 @@ struct stm_device {
|
||||
const struct config_item_type *pdrv_node_type;
|
||||
/* master allocation */
|
||||
spinlock_t mc_lock;
|
||||
struct stp_master *masters[0];
|
||||
struct stp_master *masters[];
|
||||
};
|
||||
|
||||
#define to_stm_device(_d) \
|
||||
|
@ -193,7 +193,7 @@ struct pwc_raw_frame {
|
||||
decompressor) */
|
||||
__u8 cmd[4]; /* the four byte of the command (in case of
|
||||
nala, only the first 3 bytes is filled) */
|
||||
__u8 rawframe[0]; /* frame_size = H / 4 * vbandlength */
|
||||
__u8 rawframe[]; /* frame_size = H / 4 * vbandlength */
|
||||
} __packed;
|
||||
|
||||
/* intermediate buffers with raw data from the USB cam */
|
||||
|
@ -146,7 +146,7 @@ struct pciefd_rx_dma {
|
||||
__le32 irq_status;
|
||||
__le32 sys_time_low;
|
||||
__le32 sys_time_high;
|
||||
struct pucan_rx_msg msg[0];
|
||||
struct pucan_rx_msg msg[];
|
||||
} __packed __aligned(4);
|
||||
|
||||
/* Tx Link record */
|
||||
@ -194,7 +194,7 @@ struct pciefd_board {
|
||||
struct pci_dev *pci_dev;
|
||||
int can_count;
|
||||
spinlock_t cmd_lock; /* 64-bits cmds must be atomic */
|
||||
struct pciefd_can *can[0]; /* array of network devices */
|
||||
struct pciefd_can *can[]; /* array of network devices */
|
||||
};
|
||||
|
||||
/* supported device ids. */
|
||||
|
@ -33,7 +33,7 @@ void flush_cpu_work(void);
|
||||
struct op_sample {
|
||||
unsigned long eip;
|
||||
unsigned long event;
|
||||
unsigned long data[0];
|
||||
unsigned long data[];
|
||||
};
|
||||
|
||||
struct op_entry;
|
||||
|
@ -43,7 +43,7 @@ struct samsung_usb2_phy_driver {
|
||||
struct regmap *reg_pmu;
|
||||
struct regmap *reg_sys;
|
||||
spinlock_t lock;
|
||||
struct samsung_usb2_phy_instance instances[0];
|
||||
struct samsung_usb2_phy_instance instances[];
|
||||
};
|
||||
|
||||
struct samsung_usb2_common_phy {
|
||||
|
@ -39,7 +39,7 @@ struct rio_id_table {
|
||||
u16 start; /* logical minimal id */
|
||||
u32 max; /* max number of IDs in table */
|
||||
spinlock_t lock;
|
||||
unsigned long table[0];
|
||||
unsigned long table[];
|
||||
};
|
||||
|
||||
static int next_destid = 0;
|
||||
|
@ -67,7 +67,7 @@ struct knav_reg_config {
|
||||
u32 link_ram_size0;
|
||||
u32 link_ram_base1;
|
||||
u32 __pad2[2];
|
||||
u32 starvation[0];
|
||||
u32 starvation[];
|
||||
};
|
||||
|
||||
struct knav_reg_region {
|
||||
|
@ -73,7 +73,7 @@ struct w1_netlink_msg
|
||||
__u32 res;
|
||||
} mst;
|
||||
} id;
|
||||
__u8 data[0];
|
||||
__u8 data[];
|
||||
};
|
||||
|
||||
/**
|
||||
@ -122,7 +122,7 @@ struct w1_netlink_cmd
|
||||
__u8 cmd;
|
||||
__u8 res;
|
||||
__u16 len;
|
||||
__u8 data[0];
|
||||
__u8 data[];
|
||||
};
|
||||
|
||||
#ifdef __KERNEL__
|
||||
|
2
fs/aio.c
2
fs/aio.c
@ -67,7 +67,7 @@ struct aio_ring {
|
||||
unsigned header_length; /* size of aio_ring */
|
||||
|
||||
|
||||
struct io_event io_events[0];
|
||||
struct io_event io_events[];
|
||||
}; /* 128 bytes + ring size */
|
||||
|
||||
/*
|
||||
|
@ -259,7 +259,7 @@ struct jffs2_full_dirent
|
||||
uint32_t ino; /* == zero for unlink */
|
||||
unsigned int nhash;
|
||||
unsigned char type;
|
||||
unsigned char name[0];
|
||||
unsigned char name[];
|
||||
};
|
||||
|
||||
/*
|
||||
|
@ -61,7 +61,7 @@ struct jffs2_sum_dirent_flash
|
||||
jint32_t ino; /* == zero for unlink */
|
||||
uint8_t nsize; /* dirent name size */
|
||||
uint8_t type; /* dirent type */
|
||||
uint8_t name[0]; /* dirent name */
|
||||
uint8_t name[]; /* dirent name */
|
||||
} __attribute__((packed));
|
||||
|
||||
struct jffs2_sum_xattr_flash
|
||||
@ -117,7 +117,7 @@ struct jffs2_sum_dirent_mem
|
||||
jint32_t ino; /* == zero for unlink */
|
||||
uint8_t nsize; /* dirent name size */
|
||||
uint8_t type; /* dirent type */
|
||||
uint8_t name[0]; /* dirent name */
|
||||
uint8_t name[]; /* dirent name */
|
||||
} __attribute__((packed));
|
||||
|
||||
struct jffs2_sum_xattr_mem
|
||||
|
@ -262,7 +262,7 @@ struct squashfs_dir_index {
|
||||
__le32 index;
|
||||
__le32 start_block;
|
||||
__le32 size;
|
||||
unsigned char name[0];
|
||||
unsigned char name[];
|
||||
};
|
||||
|
||||
struct squashfs_base_inode {
|
||||
@ -327,7 +327,7 @@ struct squashfs_symlink_inode {
|
||||
__le32 inode_number;
|
||||
__le32 nlink;
|
||||
__le32 symlink_size;
|
||||
char symlink[0];
|
||||
char symlink[];
|
||||
};
|
||||
|
||||
struct squashfs_reg_inode {
|
||||
@ -341,7 +341,7 @@ struct squashfs_reg_inode {
|
||||
__le32 fragment;
|
||||
__le32 offset;
|
||||
__le32 file_size;
|
||||
__le16 block_list[0];
|
||||
__le16 block_list[];
|
||||
};
|
||||
|
||||
struct squashfs_lreg_inode {
|
||||
@ -358,7 +358,7 @@ struct squashfs_lreg_inode {
|
||||
__le32 fragment;
|
||||
__le32 offset;
|
||||
__le32 xattr;
|
||||
__le16 block_list[0];
|
||||
__le16 block_list[];
|
||||
};
|
||||
|
||||
struct squashfs_dir_inode {
|
||||
@ -389,7 +389,7 @@ struct squashfs_ldir_inode {
|
||||
__le16 i_count;
|
||||
__le16 offset;
|
||||
__le32 xattr;
|
||||
struct squashfs_dir_index index[0];
|
||||
struct squashfs_dir_index index[];
|
||||
};
|
||||
|
||||
union squashfs_inode {
|
||||
@ -410,7 +410,7 @@ struct squashfs_dir_entry {
|
||||
__le16 inode_number;
|
||||
__le16 type;
|
||||
__le16 size;
|
||||
char name[0];
|
||||
char name[];
|
||||
};
|
||||
|
||||
struct squashfs_dir_header {
|
||||
@ -428,12 +428,12 @@ struct squashfs_fragment_entry {
|
||||
struct squashfs_xattr_entry {
|
||||
__le16 type;
|
||||
__le16 size;
|
||||
char data[0];
|
||||
char data[];
|
||||
};
|
||||
|
||||
struct squashfs_xattr_val {
|
||||
__le32 vsize;
|
||||
char value[0];
|
||||
char value[];
|
||||
};
|
||||
|
||||
struct squashfs_xattr_id {
|
||||
|
@ -89,7 +89,7 @@ struct displayid_detailed_timings_1 {
|
||||
|
||||
struct displayid_detailed_timing_block {
|
||||
struct displayid_block base;
|
||||
struct displayid_detailed_timings_1 timings[0];
|
||||
struct displayid_detailed_timings_1 timings[];
|
||||
};
|
||||
|
||||
#define for_each_displayid_db(displayid, block, idx, length) \
|
||||
|
@ -27,7 +27,7 @@ struct encrypted_key_payload {
|
||||
unsigned short payload_datalen; /* payload data length */
|
||||
unsigned short encrypted_key_format; /* encrypted key format */
|
||||
u8 *decrypted_data; /* decrypted data */
|
||||
u8 payload_data[0]; /* payload data + datablob + hmac */
|
||||
u8 payload_data[]; /* payload data + datablob + hmac */
|
||||
};
|
||||
|
||||
extern struct key_type key_type_encrypted;
|
||||
|
@ -28,7 +28,7 @@ struct rxkad_key {
|
||||
u8 primary_flag; /* T if key for primary cell for this user */
|
||||
u16 ticket_len; /* length of ticket[] */
|
||||
u8 session_key[8]; /* DES session key */
|
||||
u8 ticket[0]; /* the encrypted ticket */
|
||||
u8 ticket[]; /* the encrypted ticket */
|
||||
};
|
||||
|
||||
/*
|
||||
@ -100,7 +100,7 @@ struct rxrpc_key_data_v1 {
|
||||
u32 expiry; /* time_t */
|
||||
u32 kvno;
|
||||
u8 session_key[8];
|
||||
u8 ticket[0];
|
||||
u8 ticket[];
|
||||
};
|
||||
|
||||
/*
|
||||
|
@ -34,7 +34,7 @@
|
||||
struct can_skb_priv {
|
||||
int ifindex;
|
||||
int skbcnt;
|
||||
struct can_frame cf[0];
|
||||
struct can_frame cf[];
|
||||
};
|
||||
|
||||
static inline struct can_skb_priv *can_skb_prv(struct sk_buff *skb)
|
||||
|
@ -36,7 +36,7 @@ struct cb710_chip {
|
||||
unsigned slot_mask;
|
||||
unsigned slots;
|
||||
spinlock_t irq_lock;
|
||||
struct cb710_slot slot[0];
|
||||
struct cb710_slot slot[];
|
||||
};
|
||||
|
||||
/* NOTE: cb710_chip.slots is modified only during device init/exit and
|
||||
|
@ -153,7 +153,7 @@ struct dma_interleaved_template {
|
||||
bool dst_sgl;
|
||||
size_t numf;
|
||||
size_t frame_size;
|
||||
struct data_chunk sgl[0];
|
||||
struct data_chunk sgl[];
|
||||
};
|
||||
|
||||
/**
|
||||
@ -535,7 +535,7 @@ struct dmaengine_unmap_data {
|
||||
struct device *dev;
|
||||
struct kref kref;
|
||||
size_t len;
|
||||
dma_addr_t addr[0];
|
||||
dma_addr_t addr[];
|
||||
};
|
||||
|
||||
struct dma_async_tx_descriptor;
|
||||
|
@ -46,7 +46,7 @@ struct fscache_cache_tag {
|
||||
unsigned long flags;
|
||||
#define FSCACHE_TAG_RESERVED 0 /* T if tag is reserved for a cache */
|
||||
atomic_t usage;
|
||||
char name[0]; /* tag name */
|
||||
char name[]; /* tag name */
|
||||
};
|
||||
|
||||
/*
|
||||
|
@ -208,7 +208,7 @@ struct crash_mem_range {
|
||||
struct crash_mem {
|
||||
unsigned int max_nr_ranges;
|
||||
unsigned int nr_ranges;
|
||||
struct crash_mem_range ranges[0];
|
||||
struct crash_mem_range ranges[];
|
||||
};
|
||||
|
||||
extern int crash_exclude_mem_range(struct crash_mem *mem,
|
||||
|
@ -161,7 +161,7 @@ struct kretprobe_instance {
|
||||
kprobe_opcode_t *ret_addr;
|
||||
struct task_struct *task;
|
||||
void *fp;
|
||||
char data[0];
|
||||
char data[];
|
||||
};
|
||||
|
||||
struct kretprobe_blackpoint {
|
||||
|
@ -409,7 +409,7 @@ struct kvm_irq_routing_table {
|
||||
* Array indexed by gsi. Each entry contains list of irq chips
|
||||
* the gsi is connected to.
|
||||
*/
|
||||
struct hlist_head map[0];
|
||||
struct hlist_head map[];
|
||||
};
|
||||
#endif
|
||||
|
||||
|
@ -609,7 +609,7 @@ struct ata_host {
|
||||
struct task_struct *eh_owner;
|
||||
|
||||
struct ata_port *simplex_claimed; /* channel owning the DMA */
|
||||
struct ata_port *ports[0];
|
||||
struct ata_port *ports[];
|
||||
};
|
||||
|
||||
struct ata_queued_cmd {
|
||||
|
@ -221,7 +221,7 @@ struct sctp_datahdr {
|
||||
__be16 stream;
|
||||
__be16 ssn;
|
||||
__u32 ppid;
|
||||
__u8 payload[0];
|
||||
__u8 payload[];
|
||||
};
|
||||
|
||||
struct sctp_data_chunk {
|
||||
@ -269,7 +269,7 @@ struct sctp_inithdr {
|
||||
__be16 num_outbound_streams;
|
||||
__be16 num_inbound_streams;
|
||||
__be32 initial_tsn;
|
||||
__u8 params[0];
|
||||
__u8 params[];
|
||||
};
|
||||
|
||||
struct sctp_init_chunk {
|
||||
@ -299,13 +299,13 @@ struct sctp_cookie_preserve_param {
|
||||
/* Section 3.3.2.1 Host Name Address (11) */
|
||||
struct sctp_hostname_param {
|
||||
struct sctp_paramhdr param_hdr;
|
||||
uint8_t hostname[0];
|
||||
uint8_t hostname[];
|
||||
};
|
||||
|
||||
/* Section 3.3.2.1 Supported Address Types (12) */
|
||||
struct sctp_supported_addrs_param {
|
||||
struct sctp_paramhdr param_hdr;
|
||||
__be16 types[0];
|
||||
__be16 types[];
|
||||
};
|
||||
|
||||
/* ADDIP Section 3.2.6 Adaptation Layer Indication */
|
||||
@ -317,25 +317,25 @@ struct sctp_adaptation_ind_param {
|
||||
/* ADDIP Section 4.2.7 Supported Extensions Parameter */
|
||||
struct sctp_supported_ext_param {
|
||||
struct sctp_paramhdr param_hdr;
|
||||
__u8 chunks[0];
|
||||
__u8 chunks[];
|
||||
};
|
||||
|
||||
/* AUTH Section 3.1 Random */
|
||||
struct sctp_random_param {
|
||||
struct sctp_paramhdr param_hdr;
|
||||
__u8 random_val[0];
|
||||
__u8 random_val[];
|
||||
};
|
||||
|
||||
/* AUTH Section 3.2 Chunk List */
|
||||
struct sctp_chunks_param {
|
||||
struct sctp_paramhdr param_hdr;
|
||||
__u8 chunks[0];
|
||||
__u8 chunks[];
|
||||
};
|
||||
|
||||
/* AUTH Section 3.3 HMAC Algorithm */
|
||||
struct sctp_hmac_algo_param {
|
||||
struct sctp_paramhdr param_hdr;
|
||||
__be16 hmac_ids[0];
|
||||
__be16 hmac_ids[];
|
||||
};
|
||||
|
||||
/* RFC 2960. Section 3.3.3 Initiation Acknowledgement (INIT ACK) (2):
|
||||
@ -350,7 +350,7 @@ struct sctp_initack_chunk {
|
||||
/* Section 3.3.3.1 State Cookie (7) */
|
||||
struct sctp_cookie_param {
|
||||
struct sctp_paramhdr p;
|
||||
__u8 body[0];
|
||||
__u8 body[];
|
||||
};
|
||||
|
||||
/* Section 3.3.3.1 Unrecognized Parameters (8) */
|
||||
@ -384,7 +384,7 @@ struct sctp_sackhdr {
|
||||
__be32 a_rwnd;
|
||||
__be16 num_gap_ack_blocks;
|
||||
__be16 num_dup_tsns;
|
||||
union sctp_sack_variable variable[0];
|
||||
union sctp_sack_variable variable[];
|
||||
};
|
||||
|
||||
struct sctp_sack_chunk {
|
||||
@ -436,7 +436,7 @@ struct sctp_shutdown_chunk {
|
||||
struct sctp_errhdr {
|
||||
__be16 cause;
|
||||
__be16 length;
|
||||
__u8 variable[0];
|
||||
__u8 variable[];
|
||||
};
|
||||
|
||||
struct sctp_operr_chunk {
|
||||
@ -594,7 +594,7 @@ struct sctp_fwdtsn_skip {
|
||||
|
||||
struct sctp_fwdtsn_hdr {
|
||||
__be32 new_cum_tsn;
|
||||
struct sctp_fwdtsn_skip skip[0];
|
||||
struct sctp_fwdtsn_skip skip[];
|
||||
};
|
||||
|
||||
struct sctp_fwdtsn_chunk {
|
||||
@ -611,7 +611,7 @@ struct sctp_ifwdtsn_skip {
|
||||
|
||||
struct sctp_ifwdtsn_hdr {
|
||||
__be32 new_cum_tsn;
|
||||
struct sctp_ifwdtsn_skip skip[0];
|
||||
struct sctp_ifwdtsn_skip skip[];
|
||||
};
|
||||
|
||||
struct sctp_ifwdtsn_chunk {
|
||||
@ -658,7 +658,7 @@ struct sctp_addip_param {
|
||||
|
||||
struct sctp_addiphdr {
|
||||
__be32 serial;
|
||||
__u8 params[0];
|
||||
__u8 params[];
|
||||
};
|
||||
|
||||
struct sctp_addip_chunk {
|
||||
@ -718,7 +718,7 @@ struct sctp_addip_chunk {
|
||||
struct sctp_authhdr {
|
||||
__be16 shkey_id;
|
||||
__be16 hmac_id;
|
||||
__u8 hmac[0];
|
||||
__u8 hmac[];
|
||||
};
|
||||
|
||||
struct sctp_auth_chunk {
|
||||
@ -733,7 +733,7 @@ struct sctp_infox {
|
||||
|
||||
struct sctp_reconf_chunk {
|
||||
struct sctp_chunkhdr chunk_hdr;
|
||||
__u8 params[0];
|
||||
__u8 params[];
|
||||
};
|
||||
|
||||
struct sctp_strreset_outreq {
|
||||
@ -741,13 +741,13 @@ struct sctp_strreset_outreq {
|
||||
__be32 request_seq;
|
||||
__be32 response_seq;
|
||||
__be32 send_reset_at_tsn;
|
||||
__be16 list_of_streams[0];
|
||||
__be16 list_of_streams[];
|
||||
};
|
||||
|
||||
struct sctp_strreset_inreq {
|
||||
struct sctp_paramhdr param_hdr;
|
||||
__be32 request_seq;
|
||||
__be16 list_of_streams[0];
|
||||
__be16 list_of_streams[];
|
||||
};
|
||||
|
||||
struct sctp_strreset_tsnreq {
|
||||
|
@ -124,7 +124,7 @@ struct tifm_adapter {
|
||||
int (*has_ms_pif)(struct tifm_adapter *fm,
|
||||
struct tifm_dev *sock);
|
||||
|
||||
struct tifm_dev *sockets[0];
|
||||
struct tifm_dev *sockets[];
|
||||
};
|
||||
|
||||
struct tifm_adapter *tifm_alloc_adapter(unsigned int num_sockets,
|
||||
|
@ -236,7 +236,7 @@ struct trace_probe_event {
|
||||
struct trace_event_call call;
|
||||
struct list_head files;
|
||||
struct list_head probes;
|
||||
struct trace_uprobe_filter filter[0];
|
||||
struct trace_uprobe_filter filter[];
|
||||
};
|
||||
|
||||
struct trace_probe {
|
||||
|
@ -267,7 +267,7 @@ struct amt_host_if_msg_header {
|
||||
struct amt_host_if_resp_header {
|
||||
struct amt_host_if_msg_header header;
|
||||
uint32_t status;
|
||||
unsigned char data[0];
|
||||
unsigned char data[];
|
||||
} __attribute__((packed));
|
||||
|
||||
const uuid_le MEI_IAMTHIF = UUID_LE(0x12f80028, 0xb4b7, 0x4b2d, \
|
||||
|
@ -107,7 +107,7 @@ struct ima_digest_data {
|
||||
} ng;
|
||||
u8 data[2];
|
||||
} xattr;
|
||||
u8 digest[0];
|
||||
u8 digest[];
|
||||
} __packed;
|
||||
|
||||
/*
|
||||
@ -119,7 +119,7 @@ struct signature_v2_hdr {
|
||||
uint8_t hash_algo; /* Digest algorithm [enum hash_algo] */
|
||||
__be32 keyid; /* IMA key identifier - not X509/PGP specific */
|
||||
__be16 sig_size; /* signature size */
|
||||
uint8_t sig[0]; /* signature payload */
|
||||
uint8_t sig[]; /* signature payload */
|
||||
} __packed;
|
||||
|
||||
/* integrity data associated with an inode */
|
||||
|
@ -36,7 +36,7 @@ struct sof_probe_point_desc {
|
||||
struct sof_ipc_probe_dma_add_params {
|
||||
struct sof_ipc_cmd_hdr hdr;
|
||||
unsigned int num_elems;
|
||||
struct sof_probe_dma dma[0];
|
||||
struct sof_probe_dma dma[];
|
||||
} __packed;
|
||||
|
||||
struct sof_ipc_probe_info_params {
|
||||
@ -51,19 +51,19 @@ struct sof_ipc_probe_info_params {
|
||||
struct sof_ipc_probe_dma_remove_params {
|
||||
struct sof_ipc_cmd_hdr hdr;
|
||||
unsigned int num_elems;
|
||||
unsigned int stream_tag[0];
|
||||
unsigned int stream_tag[];
|
||||
} __packed;
|
||||
|
||||
struct sof_ipc_probe_point_add_params {
|
||||
struct sof_ipc_cmd_hdr hdr;
|
||||
unsigned int num_elems;
|
||||
struct sof_probe_point_desc desc[0];
|
||||
struct sof_probe_point_desc desc[];
|
||||
} __packed;
|
||||
|
||||
struct sof_ipc_probe_point_remove_params {
|
||||
struct sof_ipc_cmd_hdr hdr;
|
||||
unsigned int num_elems;
|
||||
unsigned int buffer_id[0];
|
||||
unsigned int buffer_id[];
|
||||
} __packed;
|
||||
|
||||
int sof_ipc_probe_init(struct snd_sof_dev *sdev,
|
||||
|
@ -51,7 +51,7 @@ struct nd_cmd_translate_spa {
|
||||
__u32 nfit_device_handle;
|
||||
__u32 _reserved;
|
||||
__u64 dpa;
|
||||
} __packed devices[0];
|
||||
} __packed devices[];
|
||||
|
||||
} __packed;
|
||||
|
||||
@ -74,7 +74,7 @@ struct nd_cmd_ars_err_inj_stat {
|
||||
struct nd_error_stat_query_record {
|
||||
__u64 err_inj_stat_spa_range_base;
|
||||
__u64 err_inj_stat_spa_range_length;
|
||||
} __packed record[0];
|
||||
} __packed record[];
|
||||
} __packed;
|
||||
|
||||
#define ND_INTEL_SMART 1
|
||||
@ -180,7 +180,7 @@ struct nd_intel_fw_send_data {
|
||||
__u32 context;
|
||||
__u32 offset;
|
||||
__u32 length;
|
||||
__u8 data[0];
|
||||
__u8 data[];
|
||||
/* this field is not declared due ot variable data from input */
|
||||
/* __u32 status; */
|
||||
} __packed;
|
||||
|
Loading…
Reference in New Issue
Block a user