mirror of
https://github.com/torvalds/linux.git
synced 2026-04-18 14:53:58 -04:00
With trusted args now being the default, the NULL pointer check runs before type-specific validation. Update test3 to expect the new error message "Possibly NULL pointer passed to trusted arg0" instead of the old dynptr-specific error message. Acked-by: Eduard Zingerman <eddyz87@gmail.com> Reviewed-by: Emil Tsalapatis <emil@etsalapatis.com> Signed-off-by: Puranjay Mohan <puranjay@kernel.org> Link: https://lore.kernel.org/r/20260102180038.2708325-7-puranjay@kernel.org Signed-off-by: Alexei Starovoitov <ast@kernel.org>
44 lines
874 B
C
44 lines
874 B
C
// SPDX-License-Identifier: GPL-2.0
|
|
/* Copyright (c) 2024 Meta Platforms, Inc */
|
|
#include <vmlinux.h>
|
|
#include <bpf/bpf_helpers.h>
|
|
#include "bpf_misc.h"
|
|
#include "bpf_kfuncs.h"
|
|
#include "../test_kmods/bpf_testmod_kfunc.h"
|
|
|
|
SEC("tc")
|
|
int kfunc_dynptr_nullable_test1(struct __sk_buff *skb)
|
|
{
|
|
struct bpf_dynptr data;
|
|
|
|
bpf_dynptr_from_skb(skb, 0, &data);
|
|
bpf_kfunc_dynptr_test(&data, NULL);
|
|
|
|
return 0;
|
|
}
|
|
|
|
SEC("tc")
|
|
int kfunc_dynptr_nullable_test2(struct __sk_buff *skb)
|
|
{
|
|
struct bpf_dynptr data;
|
|
|
|
bpf_dynptr_from_skb(skb, 0, &data);
|
|
bpf_kfunc_dynptr_test(&data, &data);
|
|
|
|
return 0;
|
|
}
|
|
|
|
SEC("tc")
|
|
__failure __msg("Possibly NULL pointer passed to trusted arg0")
|
|
int kfunc_dynptr_nullable_test3(struct __sk_buff *skb)
|
|
{
|
|
struct bpf_dynptr data;
|
|
|
|
bpf_dynptr_from_skb(skb, 0, &data);
|
|
bpf_kfunc_dynptr_test(NULL, &data);
|
|
|
|
return 0;
|
|
}
|
|
|
|
char _license[] SEC("license") = "GPL";
|