Home | History | Annotate | Line # | Download | only in if_bridge
t_bridge.sh revision 1.2
      1  1.1  ozaki #! /usr/bin/atf-sh
      2  1.2  ozaki #	$NetBSD: t_bridge.sh,v 1.2 2015/01/07 08:55:01 ozaki-r Exp $
      3  1.1  ozaki #
      4  1.1  ozaki # Copyright (c) 2014 The NetBSD Foundation, Inc.
      5  1.1  ozaki # All rights reserved.
      6  1.1  ozaki #
      7  1.1  ozaki # Redistribution and use in source and binary forms, with or without
      8  1.1  ozaki # modification, are permitted provided that the following conditions
      9  1.1  ozaki # are met:
     10  1.1  ozaki # 1. Redistributions of source code must retain the above copyright
     11  1.1  ozaki #    notice, this list of conditions and the following disclaimer.
     12  1.1  ozaki # 2. Redistributions in binary form must reproduce the above copyright
     13  1.1  ozaki #    notice, this list of conditions and the following disclaimer in the
     14  1.1  ozaki #    documentation and/or other materials provided with the distribution.
     15  1.1  ozaki #
     16  1.1  ozaki # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     17  1.1  ozaki # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     18  1.1  ozaki # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     19  1.1  ozaki # PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     20  1.1  ozaki # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     21  1.1  ozaki # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     22  1.1  ozaki # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     23  1.1  ozaki # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     24  1.1  ozaki # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     25  1.1  ozaki # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     26  1.1  ozaki # POSSIBILITY OF SUCH DAMAGE.
     27  1.1  ozaki #
     28  1.1  ozaki 
     29  1.1  ozaki inetserver="rump_server -lrumpnet -lrumpnet_net -lrumpnet_netinet -lrumpnet_bridge -lrumpnet_shmif"
     30  1.1  ozaki inet6server="rump_server -lrumpnet -lrumpnet_net -lrumpnet_netinet -lrumpnet_netinet6 -lrumpnet_bridge -lrumpnet_shmif"
     31  1.1  ozaki 
     32  1.1  ozaki SOCK1=unix://commsock1
     33  1.1  ozaki SOCK2=unix://commsock2
     34  1.1  ozaki SOCK3=unix://commsock3
     35  1.1  ozaki IP1=10.0.0.1
     36  1.1  ozaki IP2=10.0.0.2
     37  1.1  ozaki IP61=fc00::1
     38  1.1  ozaki IP62=fc00::2
     39  1.1  ozaki 
     40  1.1  ozaki atf_test_case basic cleanup
     41  1.1  ozaki atf_test_case basic6 cleanup
     42  1.2  ozaki atf_test_case rtable cleanup
     43  1.1  ozaki 
     44  1.1  ozaki basic_head()
     45  1.1  ozaki {
     46  1.1  ozaki 	atf_set "descr" "Does simple if_bridge tests"
     47  1.1  ozaki 	atf_set "require.progs" "rump_server"
     48  1.1  ozaki }
     49  1.1  ozaki 
     50  1.1  ozaki basic6_head()
     51  1.1  ozaki {
     52  1.1  ozaki 	atf_set "descr" "Does simple if_bridge tests (IPv6)"
     53  1.1  ozaki 	atf_set "require.progs" "rump_server"
     54  1.1  ozaki }
     55  1.1  ozaki 
     56  1.2  ozaki rtable_head()
     57  1.2  ozaki {
     58  1.2  ozaki 	atf_set "descr" "Tests route table operations of if_bridge"
     59  1.2  ozaki 	atf_set "require.progs" "rump_server"
     60  1.2  ozaki }
     61  1.2  ozaki 
     62  1.1  ozaki setup_endpoint()
     63  1.1  ozaki {
     64  1.1  ozaki 	sock=${1}
     65  1.1  ozaki 	addr=${2}
     66  1.1  ozaki 	bus=${3}
     67  1.1  ozaki 	mode=${4}
     68  1.1  ozaki 
     69  1.1  ozaki 	export RUMP_SERVER=${sock}
     70  1.1  ozaki 	atf_check -s exit:0 rump.ifconfig shmif0 create
     71  1.1  ozaki 	atf_check -s exit:0 rump.ifconfig shmif0 linkstr ${bus}
     72  1.1  ozaki 	if [ $mode = "ipv6" ]; then
     73  1.1  ozaki 		atf_check -s exit:0 rump.ifconfig shmif0 inet6 ${addr}
     74  1.1  ozaki 	else
     75  1.1  ozaki 		atf_check -s exit:0 rump.ifconfig shmif0 inet ${addr} netmask 0xffffff00
     76  1.1  ozaki 	fi
     77  1.1  ozaki 
     78  1.1  ozaki 	atf_check -s exit:0 rump.ifconfig shmif0 up
     79  1.1  ozaki 	rump.ifconfig shmif0
     80  1.1  ozaki }
     81  1.1  ozaki 
     82  1.1  ozaki test_endpoint()
     83  1.1  ozaki {
     84  1.1  ozaki 	sock=${1}
     85  1.1  ozaki 	addr=${2}
     86  1.1  ozaki 	bus=${3}
     87  1.1  ozaki 	mode=${4}
     88  1.1  ozaki 
     89  1.1  ozaki 	export RUMP_SERVER=${sock}
     90  1.1  ozaki 	atf_check -s exit:0 -o match:shmif0 rump.ifconfig
     91  1.1  ozaki 	if [ $mode = "ipv6" ]; then
     92  1.1  ozaki 		export LD_PRELOAD=/usr/lib/librumphijack.so
     93  1.1  ozaki 		atf_check -s exit:0 -o ignore ping6 -n -c 1 ${addr}
     94  1.1  ozaki 		unset LD_PRELOAD
     95  1.1  ozaki 	else
     96  1.1  ozaki 		atf_check -s exit:0 -o ignore rump.ping -n -w 1 -c 1 ${addr}
     97  1.1  ozaki 	fi
     98  1.1  ozaki }
     99  1.1  ozaki 
    100  1.1  ozaki show_endpoint()
    101  1.1  ozaki {
    102  1.1  ozaki 	sock=${1}
    103  1.1  ozaki 
    104  1.1  ozaki 	export RUMP_SERVER=${sock}
    105  1.1  ozaki 	rump.ifconfig -v shmif0
    106  1.1  ozaki }
    107  1.1  ozaki 
    108  1.1  ozaki test_setup()
    109  1.1  ozaki {
    110  1.1  ozaki 	test_endpoint $SOCK1 $IP1 bus1 ipv4
    111  1.1  ozaki 	test_endpoint $SOCK3 $IP2 bus2 ipv4
    112  1.1  ozaki 
    113  1.1  ozaki 	export RUMP_SERVER=$SOCK2
    114  1.1  ozaki 	atf_check -s exit:0 -o match:shmif0 rump.ifconfig
    115  1.1  ozaki 	atf_check -s exit:0 -o match:shmif1 rump.ifconfig
    116  1.1  ozaki }
    117  1.1  ozaki 
    118  1.1  ozaki test_setup6()
    119  1.1  ozaki {
    120  1.1  ozaki 	test_endpoint $SOCK1 $IP61 bus1 ipv6
    121  1.1  ozaki 	test_endpoint $SOCK3 $IP62 bus2 ipv6
    122  1.1  ozaki 
    123  1.1  ozaki 	export RUMP_SERVER=$SOCK2
    124  1.1  ozaki 	atf_check -s exit:0 -o match:shmif0 rump.ifconfig
    125  1.1  ozaki 	atf_check -s exit:0 -o match:shmif1 rump.ifconfig
    126  1.1  ozaki }
    127  1.1  ozaki 
    128  1.1  ozaki setup_bridge_server()
    129  1.1  ozaki {
    130  1.1  ozaki 	export RUMP_SERVER=$SOCK2
    131  1.1  ozaki 	atf_check -s exit:0 rump.ifconfig shmif0 create
    132  1.1  ozaki 	atf_check -s exit:0 rump.ifconfig shmif0 linkstr bus1
    133  1.1  ozaki 	atf_check -s exit:0 rump.ifconfig shmif0 up
    134  1.1  ozaki 
    135  1.1  ozaki 	atf_check -s exit:0 rump.ifconfig shmif1 create
    136  1.1  ozaki 	atf_check -s exit:0 rump.ifconfig shmif1 linkstr bus2
    137  1.1  ozaki 	atf_check -s exit:0 rump.ifconfig shmif1 up
    138  1.1  ozaki }
    139  1.1  ozaki 
    140  1.1  ozaki setup()
    141  1.1  ozaki {
    142  1.1  ozaki 	atf_check -s exit:0 ${inetserver} $SOCK1
    143  1.1  ozaki 	atf_check -s exit:0 ${inetserver} $SOCK2
    144  1.1  ozaki 	atf_check -s exit:0 ${inetserver} $SOCK3
    145  1.1  ozaki 
    146  1.1  ozaki 	setup_endpoint $SOCK1 $IP1 bus1 ipv4
    147  1.1  ozaki 	setup_endpoint $SOCK3 $IP2 bus2 ipv4
    148  1.1  ozaki 	setup_bridge_server
    149  1.1  ozaki }
    150  1.1  ozaki 
    151  1.1  ozaki setup6()
    152  1.1  ozaki {
    153  1.1  ozaki 	atf_check -s exit:0 ${inet6server} $SOCK1
    154  1.1  ozaki 	atf_check -s exit:0 ${inet6server} $SOCK2
    155  1.1  ozaki 	atf_check -s exit:0 ${inet6server} $SOCK3
    156  1.1  ozaki 
    157  1.1  ozaki 	setup_endpoint $SOCK1 $IP61 bus1 ipv6
    158  1.1  ozaki 	setup_endpoint $SOCK3 $IP62 bus2 ipv6
    159  1.1  ozaki 	setup_bridge_server
    160  1.1  ozaki }
    161  1.1  ozaki 
    162  1.1  ozaki setup_bridge()
    163  1.1  ozaki {
    164  1.1  ozaki 	export RUMP_SERVER=$SOCK2
    165  1.1  ozaki 	atf_check -s exit:0 rump.ifconfig bridge0 create
    166  1.1  ozaki 	atf_check -s exit:0 rump.ifconfig bridge0 up
    167  1.1  ozaki 
    168  1.1  ozaki 	export LD_PRELOAD=/usr/lib/librumphijack.so
    169  1.1  ozaki 	atf_check -s exit:0 /sbin/brconfig bridge0 add shmif0
    170  1.1  ozaki 	atf_check -s exit:0 /sbin/brconfig bridge0 add shmif1
    171  1.1  ozaki 	/sbin/brconfig bridge0
    172  1.1  ozaki 	unset LD_PRELOAD
    173  1.1  ozaki 	rump.ifconfig shmif0
    174  1.1  ozaki 	rump.ifconfig shmif1
    175  1.1  ozaki }
    176  1.1  ozaki 
    177  1.1  ozaki teardown_bridge()
    178  1.1  ozaki {
    179  1.1  ozaki 	export RUMP_SERVER=$SOCK2
    180  1.1  ozaki 	export LD_PRELOAD=/usr/lib/librumphijack.so
    181  1.1  ozaki 	/sbin/brconfig bridge0
    182  1.1  ozaki 	atf_check -s exit:0 /sbin/brconfig bridge0 delete shmif0
    183  1.1  ozaki 	atf_check -s exit:0 /sbin/brconfig bridge0 delete shmif1
    184  1.1  ozaki 	/sbin/brconfig bridge0
    185  1.1  ozaki 	unset LD_PRELOAD
    186  1.1  ozaki 	rump.ifconfig shmif0
    187  1.1  ozaki 	rump.ifconfig shmif1
    188  1.1  ozaki }
    189  1.1  ozaki 
    190  1.1  ozaki test_setup_bridge()
    191  1.1  ozaki {
    192  1.1  ozaki 	export RUMP_SERVER=$SOCK2
    193  1.1  ozaki 	export LD_PRELOAD=/usr/lib/librumphijack.so
    194  1.1  ozaki 	atf_check -s exit:0 -o match:shmif0 /sbin/brconfig bridge0
    195  1.1  ozaki 	atf_check -s exit:0 -o match:shmif1 /sbin/brconfig bridge0
    196  1.1  ozaki 	/sbin/brconfig bridge0
    197  1.1  ozaki 	unset LD_PRELOAD
    198  1.1  ozaki }
    199  1.1  ozaki 
    200  1.1  ozaki cleanup()
    201  1.1  ozaki {
    202  1.1  ozaki 	env RUMP_SERVER=$SOCK1 rump.halt
    203  1.1  ozaki 	env RUMP_SERVER=$SOCK2 rump.halt
    204  1.1  ozaki 	env RUMP_SERVER=$SOCK3 rump.halt
    205  1.1  ozaki }
    206  1.1  ozaki 
    207  1.1  ozaki dump_bus()
    208  1.1  ozaki {
    209  1.1  ozaki 	/usr/bin/shmif_dumpbus -p - bus1 2>/dev/null| /usr/sbin/tcpdump -n -e -r -
    210  1.1  ozaki 	/usr/bin/shmif_dumpbus -p - bus2 2>/dev/null| /usr/sbin/tcpdump -n -e -r -
    211  1.1  ozaki }
    212  1.1  ozaki 
    213  1.1  ozaki down_up_interfaces()
    214  1.1  ozaki {
    215  1.1  ozaki 	export RUMP_SERVER=$SOCK1
    216  1.1  ozaki 	rump.ifconfig shmif0 down
    217  1.1  ozaki 	rump.ifconfig shmif0 up
    218  1.1  ozaki 	export RUMP_SERVER=$SOCK3
    219  1.1  ozaki 	rump.ifconfig shmif0 down
    220  1.1  ozaki 	rump.ifconfig shmif0 up
    221  1.1  ozaki }
    222  1.1  ozaki 
    223  1.1  ozaki test_ping_failure()
    224  1.1  ozaki {
    225  1.1  ozaki 	export RUMP_SERVER=$SOCK1
    226  1.1  ozaki 	atf_check -s not-exit:0 -o ignore rump.ping -q -n -w 1 -c 1 $IP2
    227  1.1  ozaki 	export RUMP_SERVER=$SOCK3
    228  1.1  ozaki 	atf_check -s not-exit:0 -o ignore rump.ping -q -n -w 1 -c 1 $IP1
    229  1.1  ozaki }
    230  1.1  ozaki 
    231  1.1  ozaki test_ping_success()
    232  1.1  ozaki {
    233  1.1  ozaki 	export RUMP_SERVER=$SOCK1
    234  1.1  ozaki 	rump.ifconfig -v shmif0
    235  1.1  ozaki 	atf_check -s exit:0 -o ignore rump.ping -q -n -w 1 -c 1 $IP2
    236  1.1  ozaki 	rump.ifconfig -v shmif0
    237  1.1  ozaki 
    238  1.1  ozaki 	export RUMP_SERVER=$SOCK3
    239  1.1  ozaki 	rump.ifconfig -v shmif0
    240  1.1  ozaki 	atf_check -s exit:0 -o ignore rump.ping -q -n -w 1 -c 1 $IP1
    241  1.1  ozaki 	rump.ifconfig -v shmif0
    242  1.1  ozaki }
    243  1.1  ozaki 
    244  1.1  ozaki test_ping6_failure()
    245  1.1  ozaki {
    246  1.1  ozaki 	export LD_PRELOAD=/usr/lib/librumphijack.so
    247  1.1  ozaki 	export RUMP_SERVER=$SOCK1
    248  1.1  ozaki 	atf_check -s not-exit:0 -o ignore ping6 -q -n -c 1 $IP62
    249  1.1  ozaki 	export RUMP_SERVER=$SOCK3
    250  1.1  ozaki 	atf_check -s not-exit:0 -o ignore ping6 -q -n -c 1 $IP61
    251  1.1  ozaki 	unset LD_PRELOAD
    252  1.1  ozaki }
    253  1.1  ozaki 
    254  1.1  ozaki test_ping6_success()
    255  1.1  ozaki {
    256  1.1  ozaki 	export RUMP_SERVER=$SOCK1
    257  1.1  ozaki 	rump.ifconfig -v shmif0
    258  1.1  ozaki 	export LD_PRELOAD=/usr/lib/librumphijack.so
    259  1.1  ozaki 	atf_check -s exit:0 -o ignore ping6 -q -n -c 1 $IP62
    260  1.1  ozaki 	unset LD_PRELOAD
    261  1.1  ozaki 	rump.ifconfig -v shmif0
    262  1.1  ozaki 
    263  1.1  ozaki 	export RUMP_SERVER=$SOCK3
    264  1.1  ozaki 	rump.ifconfig -v shmif0
    265  1.1  ozaki 	export LD_PRELOAD=/usr/lib/librumphijack.so
    266  1.1  ozaki 	atf_check -s exit:0 -o ignore ping6 -q -n -c 1 $IP61
    267  1.1  ozaki 	unset LD_PRELOAD
    268  1.1  ozaki 	rump.ifconfig -v shmif0
    269  1.1  ozaki }
    270  1.1  ozaki 
    271  1.1  ozaki basic_body()
    272  1.1  ozaki {
    273  1.1  ozaki 	setup
    274  1.1  ozaki 	test_setup
    275  1.1  ozaki 
    276  1.1  ozaki 	setup_bridge
    277  1.1  ozaki 	test_setup_bridge
    278  1.1  ozaki 
    279  1.1  ozaki 	test_ping_success
    280  1.1  ozaki 
    281  1.1  ozaki 	teardown_bridge
    282  1.1  ozaki 	test_ping_failure
    283  1.1  ozaki }
    284  1.1  ozaki 
    285  1.1  ozaki basic6_body()
    286  1.1  ozaki {
    287  1.1  ozaki 	setup6
    288  1.1  ozaki 	test_setup6
    289  1.1  ozaki 
    290  1.1  ozaki 	# TODO: enable once ping6 implements timeout feature
    291  1.1  ozaki 	#test_ping6_failure
    292  1.1  ozaki 
    293  1.1  ozaki 	setup_bridge
    294  1.1  ozaki 	test_setup_bridge
    295  1.1  ozaki 
    296  1.1  ozaki 	test_ping6_success
    297  1.1  ozaki 
    298  1.1  ozaki 	teardown_bridge
    299  1.1  ozaki 	# TODO: enable once ping6 implements timeout feature
    300  1.1  ozaki 	#test_ping6_failure
    301  1.1  ozaki }
    302  1.1  ozaki 
    303  1.2  ozaki rtable_body()
    304  1.2  ozaki {
    305  1.2  ozaki 	addr1= addr3=
    306  1.2  ozaki 
    307  1.2  ozaki 	setup
    308  1.2  ozaki 	setup_bridge
    309  1.2  ozaki 
    310  1.2  ozaki 	# Get MAC addresses of the endpoints.
    311  1.2  ozaki 	export RUMP_SERVER=$SOCK1
    312  1.2  ozaki 	addr1=$(rump.ifconfig shmif0 |awk '/address:/ { print $2;}')
    313  1.2  ozaki 	export RUMP_SERVER=$SOCK3
    314  1.2  ozaki 	addr3=$(rump.ifconfig shmif0 |awk '/address:/ { print $2;}')
    315  1.2  ozaki 	unset RUMP_SERVER
    316  1.2  ozaki 
    317  1.2  ozaki 	# Confirm there is no MAC address caches.
    318  1.2  ozaki 	export RUMP_SERVER=$SOCK2
    319  1.2  ozaki 	export LD_PRELOAD=/usr/lib/librumphijack.so
    320  1.2  ozaki 	/sbin/brconfig bridge0
    321  1.2  ozaki 	atf_check -s exit:0 -o not-match:"$addr1" /sbin/brconfig bridge0
    322  1.2  ozaki 	atf_check -s exit:0 -o not-match:"$addr3" /sbin/brconfig bridge0
    323  1.2  ozaki 	unset LD_PRELOAD
    324  1.2  ozaki 
    325  1.2  ozaki 	# Make the bridge learn the MAC addresses of the endpoints.
    326  1.2  ozaki 	export RUMP_SERVER=$SOCK1
    327  1.2  ozaki 	atf_check -s exit:0 -o ignore rump.ping -n -w 1 -c 1 $IP2
    328  1.2  ozaki 	unset RUMP_SERVER
    329  1.2  ozaki 
    330  1.2  ozaki 	# Tests the addresses are in the cache.
    331  1.2  ozaki 	export RUMP_SERVER=$SOCK2
    332  1.2  ozaki 	export LD_PRELOAD=/usr/lib/librumphijack.so
    333  1.2  ozaki 	/sbin/brconfig bridge0
    334  1.2  ozaki 	atf_check -s exit:0 -o match:"$addr1 shmif0" /sbin/brconfig bridge0
    335  1.2  ozaki 	atf_check -s exit:0 -o match:"$addr3 shmif1" /sbin/brconfig bridge0
    336  1.2  ozaki 
    337  1.2  ozaki 	# Tests brconfig deladdr
    338  1.2  ozaki 	atf_check -s exit:0 -o ignore /sbin/brconfig bridge0 deladdr "$addr1"
    339  1.2  ozaki 	atf_check -s exit:0 -o not-match:"$addr1 shmif0" /sbin/brconfig bridge0
    340  1.2  ozaki 	atf_check -s exit:0 -o ignore /sbin/brconfig bridge0 deladdr "$addr3"
    341  1.2  ozaki 	atf_check -s exit:0 -o not-match:"$addr3 shmif1" /sbin/brconfig bridge0
    342  1.2  ozaki 	unset LD_PRELOAD
    343  1.2  ozaki 
    344  1.2  ozaki 	# Refill the MAC addresses of the endpoints.
    345  1.2  ozaki 	export RUMP_SERVER=$SOCK1
    346  1.2  ozaki 	atf_check -s exit:0 -o ignore rump.ping -n -w 1 -c 1 $IP2
    347  1.2  ozaki 	unset RUMP_SERVER
    348  1.2  ozaki 	export RUMP_SERVER=$SOCK2
    349  1.2  ozaki 	export LD_PRELOAD=/usr/lib/librumphijack.so
    350  1.2  ozaki 	/sbin/brconfig bridge0
    351  1.2  ozaki 	atf_check -s exit:0 -o match:"$addr1 shmif0" /sbin/brconfig bridge0
    352  1.2  ozaki 	atf_check -s exit:0 -o match:"$addr3 shmif1" /sbin/brconfig bridge0
    353  1.2  ozaki 
    354  1.2  ozaki 	# Tests brconfig flush.
    355  1.2  ozaki 	atf_check -s exit:0 -o ignore /sbin/brconfig bridge0 flush
    356  1.2  ozaki 	atf_check -s exit:0 -o not-match:"$addr1 shmif0" /sbin/brconfig bridge0
    357  1.2  ozaki 	atf_check -s exit:0 -o not-match:"$addr3 shmif1" /sbin/brconfig bridge0
    358  1.2  ozaki 	unset LD_PRELOAD
    359  1.2  ozaki 
    360  1.2  ozaki 	# Tests brconfig timeout.
    361  1.2  ozaki 	export RUMP_SERVER=$SOCK2
    362  1.2  ozaki 	export LD_PRELOAD=/usr/lib/librumphijack.so
    363  1.2  ozaki 	atf_check -s exit:0 -o match:"timeout: 1200" /sbin/brconfig bridge0
    364  1.2  ozaki 	atf_check -s exit:0 -o ignore /sbin/brconfig bridge0 timeout 10
    365  1.2  ozaki 	atf_check -s exit:0 -o match:"timeout: 10" /sbin/brconfig bridge0
    366  1.2  ozaki 	unset LD_PRELOAD
    367  1.2  ozaki 
    368  1.2  ozaki 	# TODO: brconfig static/flushall/discover/learn
    369  1.2  ozaki 	# TODO: cache expiration; it takes 5 minutes at least and we want to
    370  1.2  ozaki 	#       wait here so long. Should we have a sysctl to change the period?
    371  1.2  ozaki }
    372  1.2  ozaki 
    373  1.1  ozaki basic_cleanup()
    374  1.1  ozaki {
    375  1.1  ozaki 	dump_bus
    376  1.1  ozaki 	cleanup
    377  1.1  ozaki }
    378  1.1  ozaki 
    379  1.1  ozaki basic6_cleanup()
    380  1.1  ozaki {
    381  1.1  ozaki 	dump_bus
    382  1.1  ozaki 	cleanup
    383  1.1  ozaki }
    384  1.1  ozaki 
    385  1.2  ozaki rtable_cleanup()
    386  1.2  ozaki {
    387  1.2  ozaki 	dump_bus
    388  1.2  ozaki 	cleanup
    389  1.2  ozaki }
    390  1.2  ozaki 
    391  1.1  ozaki atf_init_test_cases()
    392  1.1  ozaki {
    393  1.1  ozaki 	atf_add_test_case basic
    394  1.1  ozaki 	atf_add_test_case basic6
    395  1.2  ozaki 	atf_add_test_case rtable
    396  1.1  ozaki }
    397