1 /******************************************************************************/
2 /*                                                                            */
3 /* Copyright (c) 2009 FUJITSU LIMITED                                         */
4 /*                                                                            */
5 /* This program is free software;  you can redistribute it and/or modify      */
6 /* it under the terms of the GNU General Public License as published by       */
7 /* the Free Software Foundation; either version 2 of the License, or          */
8 /* (at your option) any later version.                                        */
9 /*                                                                            */
10 /* This program is distributed in the hope that it will be useful,            */
11 /* but WITHOUT ANY WARRANTY;  without even the implied warranty of            */
12 /* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See                  */
13 /* the GNU General Public License for more details.                           */
14 /*                                                                            */
15 /* You should have received a copy of the GNU General Public License          */
16 /* along with this program;  if not, write to the Free Software               */
17 /* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA    */
18 /*                                                                            */
19 /* Author: Li Zefan <lizf@cn.fujitsu.com>                                     */
20 /*                                                                            */
21 /******************************************************************************/
22 
23 #include <sys/mman.h>
24 #include <err.h>
25 #include <math.h>
26 #include <signal.h>
27 #include <stdlib.h>
28 #include <string.h>
29 #include <unistd.h>
30 
31 int flag_exit;
32 int flag_ready;
33 
34 int interval;
35 unsigned long memsize;
36 
37 char **pages;
38 int nr_page;
39 
touch_memory(void)40 void touch_memory(void)
41 {
42 	int i;
43 
44 	for (i = 0; i < nr_page; i++)
45 		pages[i][0] = 0xef;
46 }
47 
sigusr_handler(int signo)48 void sigusr_handler(int __attribute__ ((unused)) signo)
49 {
50 	int i;
51 	int pagesize;
52 
53 	pagesize = getpagesize();
54 
55 	nr_page = ceil((double)memsize / pagesize);
56 
57 	pages = calloc(nr_page, sizeof(char *));
58 	if (pages == NULL)
59 		errx(1, "calloc failed");
60 
61 	for (i = 0; i < nr_page; i++) {
62 		pages[i] = mmap(NULL, pagesize, PROT_WRITE | PROT_READ,
63 				MAP_PRIVATE | MAP_ANONYMOUS, 0, 0);
64 		if (pages[i] == MAP_FAILED)
65 			err(1, "map failed\n");
66 	}
67 
68 	flag_ready = 1;
69 }
70 
sigint_handler(int signo)71 void sigint_handler(int __attribute__ ((unused)) signo)
72 {
73 	flag_exit = 1;
74 }
75 
main(int argc,char * argv[])76 int main(int argc, char *argv[])
77 {
78 	char *end;
79 	struct sigaction sigint_action;
80 	struct sigaction sigusr_action;
81 
82 	if (argc != 3)
83 		errx(1, "wrong argument num");
84 
85 	memsize = strtoul(argv[1], &end, 10);
86 	if (*end != '\0')
87 		errx(1, "wrong memsize");
88 	memsize = memsize * 1024 * 1024;
89 
90 	interval = atoi(argv[2]);
91 	if (interval <= 0)
92 		interval = 1;
93 
94 	/* TODO (garrcoop): add error handling. */
95 	memset(&sigint_action, 0, sizeof(sigint_action));
96 	sigint_action.sa_handler = &sigint_handler;
97 	sigaction(SIGINT, &sigint_action, NULL);
98 
99 	memset(&sigusr_action, 0, sizeof(sigusr_action));
100 	sigusr_action.sa_handler = &sigusr_handler;
101 	sigaction(SIGUSR1, &sigusr_action, NULL);
102 
103 	while (!flag_exit) {
104 		sleep(interval);
105 
106 		if (flag_ready)
107 			touch_memory();
108 	}
109 
110 	return 0;
111 }
112