3 # Copyright (c) 2014 The FreeBSD Foundation
5 # Copyright 2019 Enji Cooper
7 # This software was developed by John-Mark Gurney under
8 # the sponsorship from the FreeBSD Foundation.
9 # Redistribution and use in source and binary forms, with or without
10 # modification, are permitted provided that the following conditions
12 # 1. Redistributions of source code must retain the above copyright
13 # notice, this list of conditions and the following disclaimer.
14 # 2. Redistributions in binary form must reproduce the above copyright
15 # notice, this list of conditions and the following disclaimer in the
16 # documentation and/or other materials provided with the distribution.
18 # THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
19 # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21 # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
22 # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23 # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
24 # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25 # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27 # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35 if [ ! -d /usr/local/share/nist-kat ]; then
36 echo "1..0 # SKIP: nist-kat package not installed for test vectors"
40 if ! $PYTHON -c "from dpkt import dpkt"; then
41 echo "1..0 # SKIP: py-dpkt package not installed"
52 if [ -n "$oldcdas" ]; then
53 sysctl "$oldcdas" 2>/dev/null
56 # Unload modules in reverse order
57 for loaded_module in $(echo $loaded_modules | tr ' ' '\n' | sort -r); do
58 kldunload $loaded_module
61 trap cleanup_tests EXIT INT TERM
63 cpu_type="$(uname -p)"
68 cpu_module="nexus/armv8crypto nexus/ossl"
71 cpu_module="nexus/aesni nexus/ossl"
75 for required_module in $cpu_module cryptodev; do
76 if ! kldstat -q -m $required_module; then
77 module_to_load=${required_module#nexus/}
78 if ! kldload ${module_to_load}; then
79 echo "1..0 # SKIP: could not load ${module_to_load}"
82 loaded_modules="$loaded_modules $required_module"
86 cdas_sysctl=kern.crypto.allow_soft
87 if ! oldcdas=$(sysctl -e $cdas_sysctl); then
88 echo "1..0 # SKIP: could not resolve sysctl: $cdas_sysctl"
91 if ! sysctl $cdas_sysctl=1; then
92 echo "1..0 # SKIP: could not enable /dev/crypto access via $cdas_sysctl sysctl."
97 if "$PYTHON" $(dirname $0)/cryptotest.py $CRYPTOTEST_ARGS; then