1 /******************************************************************************/
2 /* Copyright (c) Crackerjack Project., 2007				   */
3 /*									    */
4 /* This program is free software;  you can redistribute it and/or modify      */
5 /* it under the terms of the GNU General Public License as published by       */
6 /* the Free Software Foundation; either version 2 of the License, or	  */
7 /* (at your option) any later version.					*/
8 /*									    */
9 /* This program is distributed in the hope that it will be useful,	    */
10 /* but WITHOUT ANY WARRANTY;  without even the implied warranty of	    */
11 /* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See		  */
12 /* the GNU General Public License for more details.			   */
13 /*									    */
14 /* You should have received a copy of the GNU General Public License	  */
15 /* along with this program;  if not, write to the Free Software	       */
16 /* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA    */
17 /*									    */
18 /******************************************************************************/
19 /******************************************************************************/
20 /*									    */
21 /* File:	bdflush01.c					    */
22 /*									    */
23 /* Description: bdflush() starts, flushes, or tunes the buffer-dirty-flush    */
24 /*		daemon. Only a privileged process (one with the CAP_SYS_ADMIN */
25 /*		capability) may call bdflush().				      */
26 /*									      */
27 /*		If func is negative or 0, and no daemon has been started,     */
28 /*		then bdflush() enters the daemon code and never returns.      */
29 /*									      */
30 /*		If func is 1, some dirty buffers are written to disk.	      */
31 /*		If func is 2 or more and is even (low bit is 0), then address */
32 /*		is the address of a long word, and the tuning parameter       */
33 /*		numbered (func-2)/2 is returned to the caller in that address.*/
34 /*									      */
35 /*		If func is 3 or more and is odd (low bit is 1), then data is  */
36 /*		a long word, and the kernel sets tuning parameter numbered    */
37 /*		(func-3)/2 to that value.				      */
38 /*		    							      */
39 /*		The set of parameters, their values, and their legal ranges   */
40 /*		are defined in the kernel source file fs/buffer.c. 	      */
41 /*									      */
42 /*		Return Value:						      */
43 /*		If func is negative or 0 and the daemon successfully starts,  */
44 /*		bdflush() never returns. Otherwise, the return value is 0 on  */
45 /*		success and -1 on failure, with errno set to indicate the     */
46 /*		error.							      */
47 /*									      */
48 /*		Errors:							      */
49 /*			EBUSY						      */
50 /*			    An attempt was made to enter the daemon code after*/
51 /*			    another process has already entered. 	      */
52 /*			EFAULT						      */
53 /*			   address points outside your accessible address     */
54 /*			   space. 					      */
55 /*			EINVAL						      */
56 /*			    An attempt was made to read or write an invalid   */
57 /*			    parameter number, or to write an invalid value to */
58 /*			    a parameter. 				      */
59 /*			EPERM						      */
60 /*			    Caller does not have the CAP_SYS_ADMIN capability.*/
61 /*									      */
62 /* Usage:  <for command-line>						 */
63 /* bdflush01 [-c n] [-e][-i n] [-I x] [-p x] [-t]		      */
64 /*      where,  -c n : Run n copies concurrently.			     */
65 /*	      -e   : Turn on errno logging.				 */
66 /*	      -i n : Execute test n times.				  */
67 /*	      -I x : Execute test for x seconds.			    */
68 /*	      -P x : Pause for x seconds between iterations.		*/
69 /*	      -t   : Turn on syscall timing.				*/
70 /*									    */
71 /* Total Tests: 1							     */
72 /*									    */
73 /* Test Name:   bdflush01					      */
74 /* History:     Porting from Crackerjack to LTP is done by		    */
75 /*	      Manas Kumar Nayak maknayak@in.ibm.com>			*/
76 /******************************************************************************/
77 #include <stdio.h>
78 #include <stdlib.h>
79 #include <sys/wait.h>
80 #include <sys/types.h>
81 #include <unistd.h>
82 #include <errno.h>
83 #include <sys/stat.h>
84 
85 #include "test.h"
86 #include "linux_syscall_numbers.h"
87 
88 char *TCID = "bdflush01";
89 int testno;
90 int TST_TOTAL = 1;
91 
cleanup(void)92 void cleanup(void)
93 {
94 	tst_rmdir();
95 }
96 
setup(void)97 void setup(void)
98 {
99 	TEST_PAUSE;
100 	tst_tmpdir();
101 }
102 
main(int ac,char ** av)103 int main(int ac, char **av)
104 {
105 	long data;
106 
107 	tst_parse_opts(ac, av, NULL, NULL);
108 
109 	setup();
110 
111 	/*
112 	 * TODO (garrcoop): add more functional testcases; there are a ton
113 	 * missing.
114 	 */
115 	data = 0;
116 	tst_count = 1;
117 	for (testno = 0; testno < TST_TOTAL; ++testno) {
118 		TEST(ltp_syscall(__NR_bdflush, 3, data));
119 		if (TEST_RETURN == -1)
120 			tst_brkm(TFAIL | TTERRNO, cleanup, "bdflush failed");
121 		else
122 			tst_resm(TPASS, "bdflush() = %ld", TEST_RETURN);
123 	}
124 	cleanup();
125 	tst_exit();
126 }
127