xref: /netbsd-src/tests/kernel/t_lock.c (revision c54cb81102ced2313cb40993fe05548aca9933a1)
1*c54cb811Schristos /* $NetBSD: t_lock.c,v 1.2 2017/01/13 21:30:41 christos Exp $ */
299635d94Sjmmv 
399635d94Sjmmv /*-
499635d94Sjmmv  * Copyright (c) 2002, 2008 The NetBSD Foundation, Inc.
599635d94Sjmmv  * All rights reserved.
699635d94Sjmmv  *
799635d94Sjmmv  * Redistribution and use in source and binary forms, with or without
899635d94Sjmmv  * modification, are permitted provided that the following conditions
999635d94Sjmmv  * are met:
1099635d94Sjmmv  * 1. Redistributions of source code must retain the above copyright
1199635d94Sjmmv  *    notice, this list of conditions and the following disclaimer.
1299635d94Sjmmv  * 2. Redistributions in binary form must reproduce the above copyright
1399635d94Sjmmv  *    notice, this list of conditions and the following disclaimer in the
1499635d94Sjmmv  *    documentation and/or other materials provided with the distribution.
1599635d94Sjmmv  *
1699635d94Sjmmv  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
1799635d94Sjmmv  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
1899635d94Sjmmv  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
1999635d94Sjmmv  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
2099635d94Sjmmv  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
2199635d94Sjmmv  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
2299635d94Sjmmv  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
2399635d94Sjmmv  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
2499635d94Sjmmv  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
2599635d94Sjmmv  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
2699635d94Sjmmv  * POSSIBILITY OF SUCH DAMAGE.
2799635d94Sjmmv  */
2899635d94Sjmmv 
2999635d94Sjmmv #include <sys/cdefs.h>
3099635d94Sjmmv __COPYRIGHT("@(#) Copyright (c) 2008\
3199635d94Sjmmv  The NetBSD Foundation, inc. All rights reserved.");
32*c54cb811Schristos __RCSID("$NetBSD: t_lock.c,v 1.2 2017/01/13 21:30:41 christos Exp $");
3399635d94Sjmmv 
3499635d94Sjmmv #include <sys/time.h>
3599635d94Sjmmv 
3699635d94Sjmmv #include <machine/lock.h>
3799635d94Sjmmv #include <signal.h>
3899635d94Sjmmv 
3999635d94Sjmmv #include <atf-c.h>
4099635d94Sjmmv 
41*c54cb811Schristos #include "h_macros.h"
4299635d94Sjmmv 
4399635d94Sjmmv __cpu_simple_lock_t lk;
4499635d94Sjmmv volatile int handled = 0;
4599635d94Sjmmv 
4699635d94Sjmmv static void
handler(int sig)4799635d94Sjmmv handler(int sig)
4899635d94Sjmmv {
4999635d94Sjmmv 	handled = 1;
5099635d94Sjmmv 	__cpu_simple_unlock(&lk);
5199635d94Sjmmv }
5299635d94Sjmmv 
5399635d94Sjmmv ATF_TC(lock);
ATF_TC_HEAD(lock,tc)5499635d94Sjmmv ATF_TC_HEAD(lock, tc)
5599635d94Sjmmv {
5699635d94Sjmmv 	atf_tc_set_md_var(tc, "timeout", "3");
5799635d94Sjmmv 	atf_tc_set_md_var(tc, "descr",
5899635d94Sjmmv 	    "Checks __cpu_simple_lock()/__cpu_simple_unlock()");
5999635d94Sjmmv }
ATF_TC_BODY(lock,tc)6099635d94Sjmmv ATF_TC_BODY(lock, tc)
6199635d94Sjmmv {
6299635d94Sjmmv 	struct itimerval itv;
6399635d94Sjmmv 
6499635d94Sjmmv 	__cpu_simple_lock_init(&lk);
6599635d94Sjmmv 
6699635d94Sjmmv 	REQUIRE_LIBC(signal(SIGVTALRM, handler), SIG_ERR);
6799635d94Sjmmv 
6899635d94Sjmmv 	itv.it_interval.tv_sec = 0;
6999635d94Sjmmv 	itv.it_interval.tv_usec = 0;
7099635d94Sjmmv 	itv.it_value.tv_sec = 1;
7199635d94Sjmmv 	itv.it_value.tv_usec = 0;
7299635d94Sjmmv 	RL(setitimer(ITIMER_VIRTUAL, &itv, NULL));
7399635d94Sjmmv 
7499635d94Sjmmv 	__cpu_simple_lock(&lk);
7599635d94Sjmmv 	__cpu_simple_lock(&lk);
7699635d94Sjmmv 
7799635d94Sjmmv 	ATF_REQUIRE(handled);
7899635d94Sjmmv 
7999635d94Sjmmv 	__cpu_simple_unlock(&lk);
8099635d94Sjmmv }
8199635d94Sjmmv 
ATF_TP_ADD_TCS(tp)8299635d94Sjmmv ATF_TP_ADD_TCS(tp)
8399635d94Sjmmv {
8499635d94Sjmmv 	ATF_TP_ADD_TC(tp, lock);
8599635d94Sjmmv 
8699635d94Sjmmv 	return atf_no_error();
8799635d94Sjmmv }
88