blob: 4f6444bcd53f93bb904ef22bd53744d7d32b1e84 [file] [log] [blame]
Rolf Eike Beerd979e132016-12-14 11:58:20 +01001#!/bin/sh
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01002# SPDX-License-Identifier: GPL-2.0
Daniel Borkmann5aa5bd12016-10-17 14:28:36 +02003
Jeffrin Jose T81e167c2018-06-21 22:30:20 +05304# Kselftest framework requirement - SKIP code is 4.
5ksft_skip=4
6
7msg="skip all tests:"
8if [ "$(id -u)" != "0" ]; then
9 echo $msg please run this as root >&2
10 exit $ksft_skip
11fi
12
Ilya Leoshkevich2ea48592020-07-17 18:53:22 +020013if [ "$building_out_of_srctree" ]; then
14 # We are in linux-build/kselftest/bpf
15 OUTPUT=../../
16else
17 # We are in linux/tools/testing/selftests/bpf
18 OUTPUT=../../../../
19fi
Daniel Borkmann5aa5bd12016-10-17 14:28:36 +020020
21test_run()
22{
23 sysctl -w net.core.bpf_jit_enable=$1 2>&1 > /dev/null
24 sysctl -w net.core.bpf_jit_harden=$2 2>&1 > /dev/null
25
26 echo "[ JIT enabled:$1 hardened:$2 ]"
27 dmesg -C
Ilya Leoshkevich2ea48592020-07-17 18:53:22 +020028 if [ -f ${OUTPUT}/lib/test_bpf.ko ]; then
29 insmod ${OUTPUT}/lib/test_bpf.ko 2> /dev/null
Naresh Kamboju035d8082018-02-07 23:45:34 +053030 if [ $? -ne 0 ]; then
31 rc=1
32 fi
33 else
34 # Use modprobe dry run to check for missing test_bpf module
35 if ! /sbin/modprobe -q -n test_bpf; then
36 echo "test_bpf: [SKIP]"
37 elif /sbin/modprobe -q test_bpf; then
38 echo "test_bpf: ok"
39 else
40 echo "test_bpf: [FAIL]"
41 rc=1
42 fi
Daniel Borkmann5aa5bd12016-10-17 14:28:36 +020043 fi
44 rmmod test_bpf 2> /dev/null
45 dmesg | grep FAIL
46}
47
48test_save()
49{
50 JE=`sysctl -n net.core.bpf_jit_enable`
51 JH=`sysctl -n net.core.bpf_jit_harden`
52}
53
54test_restore()
55{
56 sysctl -w net.core.bpf_jit_enable=$JE 2>&1 > /dev/null
57 sysctl -w net.core.bpf_jit_harden=$JH 2>&1 > /dev/null
58}
59
60rc=0
61test_save
62test_run 0 0
63test_run 1 0
64test_run 1 1
65test_run 1 2
66test_restore
67exit $rc