pause01.c revision 4bb656a129f7507823e9e6d6b98b1a02fd80ef89
1/*
2 * Copyright (c) 2000 Silicon Graphics, Inc.  All Rights Reserved.
3 *
4 * This program is free software; you can redistribute it and/or modify it
5 * under the terms of version 2 of the GNU General Public License as
6 * published by the Free Software Foundation.
7 *
8 * This program is distributed in the hope that it would be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
11 *
12 * Further, this software is distributed without any warranty that it is
13 * free of the rightful claim of any third person regarding infringement
14 * or the like.  Any license provided herein, whether implied or
15 * otherwise, applies only to this software file.  Patent licenses, if
16 * any, provided herein do not apply to combinations of this program with
17 * other software, or any other product whatsoever.
18 *
19 * You should have received a copy of the GNU General Public License along
20 * with this program; if not, write the Free Software Foundation, Inc., 59
21 * Temple Place - Suite 330, Boston MA 02111-1307, USA.
22 *
23 * Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
24 * Mountain View, CA  94043, or:
25 *
26 * http://www.sgi.com
27 *
28 * For further information regarding this notice, see:
29 *
30 * http://oss.sgi.com/projects/GenInfo/NoticeExplan/
31 *
32 */
33/* $Id: pause01.c,v 1.3 2009/02/26 12:04:40 subrata_modak Exp $ */
34/**********************************************************
35 *
36 *    OS Test - Silicon Graphics, Inc.
37 *
38 *    TEST IDENTIFIER	: pause01
39 *
40 *    EXECUTED BY	: anyone
41 *
42 *    TEST TITLE	: Basic test for pause(2)
43 *
44 *    PARENT DOCUMENT	: xxxtds01
45 *
46 *    TEST CASE TOTAL	: 1
47 *
48 *    WALL CLOCK TIME	: 2
49 *
50 *    CPU TYPES		: ALL
51 *
52 *    AUTHOR		: William Roske
53 *
54 *    CO-PILOT		: Dave Fenner
55 *
56 *    DATE STARTED	: 03/30/92
57 *
58 *    INITIAL RELEASE	: UNICOS 7.0
59 *
60 *    TEST CASES
61 *
62 * 	1.) pause(2) returns...(See Description)
63 *
64 *    INPUT SPECIFICATIONS
65 * 	The standard options for system call tests are accepted.
66 *	(See the parse_opts(3) man page).
67 *
68 *    OUTPUT SPECIFICATIONS
69 *
70 *    DURATION
71 * 	Terminates - with frequency and infinite modes.
72 *
73 *    SIGNALS
74 * 	Uses SIGUSR1 to pause before test if option set.
75 * 	(See the parse_opts(3) man page).
76 *
77 *    RESOURCES
78 * 	None
79 *
80 *    ENVIRONMENTAL NEEDS
81 *      No run-time environmental needs.
82 *
83 *    SPECIAL PROCEDURAL REQUIREMENTS
84 * 	None
85 *
86 *    INTERCASE DEPENDENCIES
87 * 	None
88 *
89 *    DETAILED DESCRIPTION
90 *	This is a Phase I test for the pause(2) system call.  It is intended
91 *	to provide a limited exposure of the system call, for now.  It
92 *	should/will be extended when full functional tests are written for
93 *	pause(2).
94 *
95 * 	Setup:
96 * 	  Setup signal handling.
97 *	  Pause for SIGUSR1 if option specified.
98 *
99 * 	Test:
100 *	 Loop if the proper options are given.
101 * 	  Execute system call
102 *	  Check return code, if system call failed (return=-1)
103 *		Log the errno and Issue a FAIL message.
104 *	  Otherwise, Issue a PASS message.
105 *
106 * 	Cleanup:
107 * 	  Print errno log and/or timing stats if options given
108 *
109 *
110 *#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#**/
111
112#include <errno.h>
113#include <signal.h>
114#include "test.h"
115#include "usctest.h"
116
117void setup();
118void cleanup();
119
120
121
122char *TCID="pause01"; 		/* Test program identifier.    */
123int TST_TOTAL=1;    		/* Total number of test cases. */
124extern int Tst_count;		/* Test Case counter for tst_* routines */
125
126int exp_enos[]={EINTR, 0};
127void go();
128
129int
130main(int ac, char **av)
131{
132    int lc;		/* loop counter */
133    char *msg;		/* message returned from parse_opts */
134
135    /***************************************************************
136     * parse standard options
137     ***************************************************************/
138    if ( (msg=parse_opts(ac, av, (option_t *) NULL, NULL)) != (char *) NULL )
139	tst_brkm(TBROK, cleanup, "OPTION PARSING ERROR - %s", msg);
140
141    /***************************************************************
142     * perform global setup for test
143     ***************************************************************/
144    setup();
145
146    /* set the expected errnos... */
147    TEST_EXP_ENOS(exp_enos);
148
149    /***************************************************************
150     * check looping state if -c option given
151     ***************************************************************/
152    for (lc=0; TEST_LOOPING(lc); lc++) {
153
154	/* reset Tst_count in case we are looping. */
155	Tst_count=0;
156
157        (void) signal(SIGALRM, go);
158        alarm(1);
159	/*
160	 * Call pause(2)
161	 */
162	TEST(pause());
163
164	/* check return code.  Pause returns -1 and EINTR errno */
165	if (TEST_RETURN != -1) {
166	    tst_resm(TFAIL,
167		     "pause() returned WITHOUT an error return code : %d",
168		     TEST_ERRNO);
169	} else {
170	    /* log the errno */
171	    TEST_ERROR_LOG(TEST_ERRNO);
172	    /***************************************************************
173	     * only perform functional verification if flag set (-f not given)
174	     ***************************************************************/
175	    if ( STD_FUNCTIONAL_TEST ) {
176		/* check the errno */
177		if (TEST_ERRNO == EINTR)
178		    tst_resm(TPASS, "pause() returned %d", TEST_RETURN);
179		else
180		    tst_resm(TFAIL, "pause() returned %d. Expected %d (EINTR)",
181			     TEST_RETURN, EINTR);
182	    }
183	}
184    }	/* End for TEST_LOOPING */
185
186    /***************************************************************
187     * cleanup and exit
188     ***************************************************************/
189    cleanup();
190
191    return 0;
192}	/* End main */
193
194/***************************************************************
195 * setup() - performs all ONE TIME setup for this test.
196 ***************************************************************/
197void
198setup()
199{
200    /* capture signals */
201    tst_sig(NOFORK, DEF_HANDLER, cleanup);
202
203    /* Pause if that option was specified */
204    TEST_PAUSE;
205}	/* End setup() */
206
207
208/***************************************************************
209 * cleanup() - performs all ONE TIME cleanup for this test at
210 *		completion or premature exit.
211 ***************************************************************/
212void
213cleanup()
214{
215    /*
216     * print timing stats if that option was specified.
217     * print errno log if that option was specified.
218     */
219    TEST_CLEANUP;
220
221    /* exit with return code appropriate for results */
222    tst_exit();
223}	/* End cleanup() */
224
225/* routine to catch the alarm signal */
226void
227go()
228{
229}
230