Change iolog overlap assert to a debug dump
[fio.git] / fio.c
1 /*
2  * fio - the flexible io tester
3  *
4  * Copyright (C) 2005 Jens Axboe <axboe@suse.de>
5  * Copyright (C) 2006-2012 Jens Axboe <axboe@kernel.dk>
6  *
7  * The license below covers all files distributed with fio unless otherwise
8  * noted in the file itself.
9  *
10  *  This program is free software; you can redistribute it and/or modify
11  *  it under the terms of the GNU General Public License version 2 as
12  *  published by the Free Software Foundation.
13  *
14  *  This program is distributed in the hope that it will be useful,
15  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
16  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  *  GNU General Public License for more details.
18  *
19  *  You should have received a copy of the GNU General Public License
20  *  along with this program; if not, write to the Free Software
21  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
22  *
23  */
24 #include <unistd.h>
25 #include <fcntl.h>
26 #include <string.h>
27 #include <limits.h>
28 #include <signal.h>
29 #include <time.h>
30 #include <locale.h>
31 #include <assert.h>
32 #include <time.h>
33 #include <sys/stat.h>
34 #include <sys/wait.h>
35 #include <sys/ipc.h>
36 #include <sys/shm.h>
37 #include <sys/mman.h>
38
39 #include "fio.h"
40 #include "hash.h"
41 #include "smalloc.h"
42 #include "verify.h"
43 #include "trim.h"
44 #include "diskutil.h"
45 #include "cgroup.h"
46 #include "profile.h"
47 #include "lib/rand.h"
48 #include "memalign.h"
49 #include "server.h"
50
51 unsigned long page_mask;
52 unsigned long page_size;
53
54 static int endian_check(void)
55 {
56         union {
57                 uint8_t c[8];
58                 uint64_t v;
59         } u;
60         int le = 0, be = 0;
61
62         u.v = 0x12;
63         if (u.c[7] == 0x12)
64                 be = 1;
65         else if (u.c[0] == 0x12)
66                 le = 1;
67
68 #if defined(FIO_LITTLE_ENDIAN)
69         if (be)
70                 return 1;
71 #elif defined(FIO_BIG_ENDIAN)
72         if (le)
73                 return 1;
74 #else
75         return 1;
76 #endif
77
78         if (!le && !be)
79                 return 1;
80
81         return 0;
82 }
83
84 int main(int argc, char *argv[], char *envp[])
85 {
86         long ps;
87
88         if (endian_check()) {
89                 log_err("fio: endianness settings appear wrong.\n");
90                 log_err("fio: please report this to fio@vger.kernel.org\n");
91                 return 1;
92         }
93
94         arch_init(envp);
95
96         sinit();
97
98         /*
99          * We need locale for number printing, if it isn't set then just
100          * go with the US format.
101          */
102         if (!getenv("LC_NUMERIC"))
103                 setlocale(LC_NUMERIC, "en_US");
104
105         ps = sysconf(_SC_PAGESIZE);
106         if (ps < 0) {
107                 log_err("Failed to get page size\n");
108                 return 1;
109         }
110
111         page_size = ps;
112         page_mask = ps - 1;
113
114         fio_keywords_init();
115
116         if (parse_options(argc, argv))
117                 return 1;
118
119         if (nr_clients)
120                 return fio_handle_clients();
121         else
122                 return fio_backend();
123 }