t_lock.c revision 1.1 1 1.1 jmmv /* $NetBSD: t_lock.c,v 1.1 2009/02/20 21:39:57 jmmv Exp $ */
2 1.1 jmmv
3 1.1 jmmv /*-
4 1.1 jmmv * Copyright (c) 2002, 2008 The NetBSD Foundation, Inc.
5 1.1 jmmv * All rights reserved.
6 1.1 jmmv *
7 1.1 jmmv * Redistribution and use in source and binary forms, with or without
8 1.1 jmmv * modification, are permitted provided that the following conditions
9 1.1 jmmv * are met:
10 1.1 jmmv * 1. Redistributions of source code must retain the above copyright
11 1.1 jmmv * notice, this list of conditions and the following disclaimer.
12 1.1 jmmv * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 jmmv * notice, this list of conditions and the following disclaimer in the
14 1.1 jmmv * documentation and/or other materials provided with the distribution.
15 1.1 jmmv *
16 1.1 jmmv * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
17 1.1 jmmv * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
18 1.1 jmmv * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 1.1 jmmv * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
20 1.1 jmmv * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 1.1 jmmv * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 1.1 jmmv * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23 1.1 jmmv * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24 1.1 jmmv * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25 1.1 jmmv * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26 1.1 jmmv * POSSIBILITY OF SUCH DAMAGE.
27 1.1 jmmv */
28 1.1 jmmv
29 1.1 jmmv #include <sys/cdefs.h>
30 1.1 jmmv __COPYRIGHT("@(#) Copyright (c) 2008\
31 1.1 jmmv The NetBSD Foundation, inc. All rights reserved.");
32 1.1 jmmv __RCSID("$NetBSD: t_lock.c,v 1.1 2009/02/20 21:39:57 jmmv Exp $");
33 1.1 jmmv
34 1.1 jmmv #include <sys/time.h>
35 1.1 jmmv
36 1.1 jmmv #include <machine/lock.h>
37 1.1 jmmv #include <signal.h>
38 1.1 jmmv
39 1.1 jmmv #include <atf-c.h>
40 1.1 jmmv
41 1.1 jmmv #include "../h_macros.h"
42 1.1 jmmv
43 1.1 jmmv __cpu_simple_lock_t lk;
44 1.1 jmmv volatile int handled = 0;
45 1.1 jmmv
46 1.1 jmmv static void
47 1.1 jmmv handler(int sig)
48 1.1 jmmv {
49 1.1 jmmv handled = 1;
50 1.1 jmmv __cpu_simple_unlock(&lk);
51 1.1 jmmv }
52 1.1 jmmv
53 1.1 jmmv ATF_TC(lock);
54 1.1 jmmv ATF_TC_HEAD(lock, tc)
55 1.1 jmmv {
56 1.1 jmmv atf_tc_set_md_var(tc, "timeout", "3");
57 1.1 jmmv atf_tc_set_md_var(tc, "descr",
58 1.1 jmmv "Checks __cpu_simple_lock()/__cpu_simple_unlock()");
59 1.1 jmmv }
60 1.1 jmmv ATF_TC_BODY(lock, tc)
61 1.1 jmmv {
62 1.1 jmmv struct itimerval itv;
63 1.1 jmmv
64 1.1 jmmv __cpu_simple_lock_init(&lk);
65 1.1 jmmv
66 1.1 jmmv REQUIRE_LIBC(signal(SIGVTALRM, handler), SIG_ERR);
67 1.1 jmmv
68 1.1 jmmv itv.it_interval.tv_sec = 0;
69 1.1 jmmv itv.it_interval.tv_usec = 0;
70 1.1 jmmv itv.it_value.tv_sec = 1;
71 1.1 jmmv itv.it_value.tv_usec = 0;
72 1.1 jmmv RL(setitimer(ITIMER_VIRTUAL, &itv, NULL));
73 1.1 jmmv
74 1.1 jmmv __cpu_simple_lock(&lk);
75 1.1 jmmv __cpu_simple_lock(&lk);
76 1.1 jmmv
77 1.1 jmmv ATF_REQUIRE(handled);
78 1.1 jmmv
79 1.1 jmmv __cpu_simple_unlock(&lk);
80 1.1 jmmv }
81 1.1 jmmv
82 1.1 jmmv ATF_TP_ADD_TCS(tp)
83 1.1 jmmv {
84 1.1 jmmv ATF_TP_ADD_TC(tp, lock);
85 1.1 jmmv
86 1.1 jmmv return atf_no_error();
87 1.1 jmmv }
88