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