mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/herbert/cryptodev-2.6.git
synced 2026-04-23 05:56:14 -04:00
selftests: bpf: centre kernel bpf objects under new subdir "progs"
At the moment, all kernel bpf objects are listed under BPF_OBJ_FILES. Listing them manually sometimes causing patch conflict when people are adding new testcases simultaneously. It is better to centre all the related source files under a subdir "progs", then auto-generate the object file list. Suggested-by: Alexei Starovoitov <ast@kernel.org> Reviewed-by: Jakub Kicinski <jakub.kicinski@netronome.com> Signed-off-by: Jiong Wang <jiong.wang@netronome.com> Signed-off-by: Alexei Starovoitov <ast@kernel.org>
This commit is contained in:
committed by
Alexei Starovoitov
parent
4836b4637e
commit
bd4aed0ee7
46
tools/testing/selftests/bpf/progs/test_pkt_md_access.c
Normal file
46
tools/testing/selftests/bpf/progs/test_pkt_md_access.c
Normal file
@@ -0,0 +1,46 @@
|
||||
/* Copyright (c) 2017 Facebook
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of version 2 of the GNU General Public
|
||||
* License as published by the Free Software Foundation.
|
||||
*/
|
||||
#include <stddef.h>
|
||||
#include <string.h>
|
||||
#include <linux/bpf.h>
|
||||
#include <linux/pkt_cls.h>
|
||||
#include "bpf_helpers.h"
|
||||
|
||||
int _version SEC("version") = 1;
|
||||
|
||||
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
|
||||
#define TEST_FIELD(TYPE, FIELD, MASK) \
|
||||
{ \
|
||||
TYPE tmp = *(volatile TYPE *)&skb->FIELD; \
|
||||
if (tmp != ((*(volatile __u32 *)&skb->FIELD) & MASK)) \
|
||||
return TC_ACT_SHOT; \
|
||||
}
|
||||
#else
|
||||
#define TEST_FIELD_OFFSET(a, b) ((sizeof(a) - sizeof(b)) / sizeof(b))
|
||||
#define TEST_FIELD(TYPE, FIELD, MASK) \
|
||||
{ \
|
||||
TYPE tmp = *((volatile TYPE *)&skb->FIELD + \
|
||||
TEST_FIELD_OFFSET(skb->FIELD, TYPE)); \
|
||||
if (tmp != ((*(volatile __u32 *)&skb->FIELD) & MASK)) \
|
||||
return TC_ACT_SHOT; \
|
||||
}
|
||||
#endif
|
||||
|
||||
SEC("test1")
|
||||
int process(struct __sk_buff *skb)
|
||||
{
|
||||
TEST_FIELD(__u8, len, 0xFF);
|
||||
TEST_FIELD(__u16, len, 0xFFFF);
|
||||
TEST_FIELD(__u32, len, 0xFFFFFFFF);
|
||||
TEST_FIELD(__u16, protocol, 0xFFFF);
|
||||
TEST_FIELD(__u32, protocol, 0xFFFFFFFF);
|
||||
TEST_FIELD(__u8, hash, 0xFF);
|
||||
TEST_FIELD(__u16, hash, 0xFFFF);
|
||||
TEST_FIELD(__u32, hash, 0xFFFFFFFF);
|
||||
|
||||
return TC_ACT_OK;
|
||||
}
|
||||
Reference in New Issue
Block a user