Commit 7a69c0f2 authored by John Fastabend's avatar John Fastabend Committed by Daniel Borkmann

bpf: skmsg, replace comments with BUILD bug

Enforce comment on structure layout dependency with a BUILD_BUG_ON
to ensure the condition is maintained.
Suggested-by: default avatarDaniel Borkmann <daniel@iogearbox.net>
Signed-off-by: default avatarJohn Fastabend <john.fastabend@gmail.com>
Signed-off-by: default avatarDaniel Borkmann <daniel@iogearbox.net>
parent bc1b4f01
...@@ -36,9 +36,7 @@ struct sk_msg_sg { ...@@ -36,9 +36,7 @@ struct sk_msg_sg {
struct scatterlist data[MAX_MSG_FRAGS + 1]; struct scatterlist data[MAX_MSG_FRAGS + 1];
}; };
/* UAPI in filter.c depends on struct sk_msg_sg being first element. If /* UAPI in filter.c depends on struct sk_msg_sg being first element. */
* this is moved filter.c also must be updated.
*/
struct sk_msg { struct sk_msg {
struct sk_msg_sg sg; struct sk_msg_sg sg;
void *data; void *data;
......
...@@ -7425,6 +7425,9 @@ static u32 sk_msg_convert_ctx_access(enum bpf_access_type type, ...@@ -7425,6 +7425,9 @@ static u32 sk_msg_convert_ctx_access(enum bpf_access_type type,
int off; int off;
#endif #endif
/* convert ctx uses the fact sg element is first in struct */
BUILD_BUG_ON(offsetof(struct sk_msg, sg) != 0);
switch (si->off) { switch (si->off) {
case offsetof(struct sk_msg_md, data): case offsetof(struct sk_msg_md, data):
*insn++ = BPF_LDX_MEM(BPF_FIELD_SIZEOF(struct sk_msg, data), *insn++ = BPF_LDX_MEM(BPF_FIELD_SIZEOF(struct sk_msg, data),
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment