fio.git
9 years agoFio 2.2.6 fio-2.2.6
Jens Axboe [Fri, 27 Feb 2015 15:30:04 +0000 (08:30 -0700)]
Fio 2.2.6

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agofio: fix cycles_start build issue
Christian Ehrhardt [Fri, 27 Feb 2015 15:20:46 +0000 (08:20 -0700)]
fio: fix cycles_start build issue

There is an issue introduced with "commit 73df3e07 gettime: offset CPU cycle
counter by initial value". For architectures which define
ARCH_CPU_CLOCK_CYCLES_PER_USEC (currently only s390) this causes a build
error

gettime.c:174:11: error: â€˜cycles_start’ undeclared (first use in this
function)
    if (t < cycles_start && !cycles_wrap)

To make sure variables and code are only compiled in the same cases I
added a
clock definition called ARCH_CPU_CLOCK_WRAPS. We could merge
ARCH_CPU_CLOCK_WRAPS and the existing ARCH_CPU_CLOCK_CYCLES_PER_USEC
into one
if you prefer, so far nobody else uses it.

To avoid cluttering all architecture headers I enabled it by default in
arch-generic.h, so any arch not needing the wrap handling can undef
ARCH_CPU_CLOCK_WRAPS later in their headers.

Signed-off-by: Christian Ehrhardt <ehrhardt@linux.vnet.ibm.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoPatch to make per-thread IOPS more accurate
Ben England [Fri, 27 Feb 2015 15:14:49 +0000 (08:14 -0700)]
Patch to make per-thread IOPS more accurate

The following small patch to stat.c (using fio 2.2.4 from github)
outputs IOPS field in JSON format as a floating point number instead of
an integer.  This improves accuracy in case where fio --client runs use
lots of threads with single-digit IOPS per thread.  It seems to work,
here's a snippet of output from a short fio run with rate_iops=10 in the
job file.

     "write" : {
        "io_bytes" : 6464,
        "bw" : 646,
        "iops" : 10.10,
        "runtime" : 10000,

Why the patch: IOPS number is rounded to integer in stats.c calls to
num2str().  This doesn't sound like much of a problem because in many
use cases, with large IOPS number the error is negligible.  But in this
use case where we have many threads (we would like to get into the
thousands eventually), the IOPS/thread may be quite low and integer
rounding can introduce significant error.  For example, if we are doing
5,000 IOPS over 1,000 threads, average throughput is 5 IOPS and
potential error is ~20%, but some threads could have much higher error
in IOPS because of integer format.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoFix segfault due to bad munmap()
Jens Axboe [Thu, 26 Feb 2015 22:38:42 +0000 (15:38 -0700)]
Fix segfault due to bad munmap()

Bruce reports:

The latest code from git (built using clang) causes a segfault after printing the usage text when "./fio" is run:

[New LWP 100111]
No jobs(s) defined

fio-2.2.5-28-g93eeb
[usage text]
[New Thread 801c06400 (LWP 100111/fio)]

Program received signal SIGSEGV, Segmentation fault.
[Switching to Thread 801c06400 (LWP 100111/fio)]
flist_empty (head=0x802000040) at flist.h:119
119             return head->next == head;
Current language:  auto; currently minimal
(gdb) p head
$1 = (const struct flist_head *) 0x802000040

which is due to a bug in the filelock code, that uses
fio_mutex_remove() to remove the mutex. But that mutex is embedded
inside another mmap'ed region, hence we then segfault on later
deferencing pointers.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoMerge branch 'master' of ssh://git.kernel.dk/data/git/fio
Jens Axboe [Thu, 26 Feb 2015 15:42:31 +0000 (08:42 -0700)]
Merge branch 'master' of ssh://git.kernel.dk/data/git/fio

9 years agoTypo fix in man page.
Lars Marowsky-Bree [Thu, 26 Feb 2015 09:48:31 +0000 (10:48 +0100)]
Typo fix in man page.

josn should be json, of course.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoFix implicit function declaration on Android
enh [Wed, 25 Feb 2015 21:00:01 +0000 (14:00 -0700)]
Fix implicit function declaration on Android

there's no fio_set_sched_idle in os/os-android.h. copy the one from
os/os-linux.h.

current Android also has posix_madvise.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoAdd missing pre-defined ARM arch compiler macro
Raphael Silva [Wed, 25 Feb 2015 13:57:40 +0000 (10:57 -0300)]
Add missing pre-defined ARM arch compiler macro

Signed-off-by: Raphael Silva <raphael.philipe@ossystems.com.br>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoAdd --output-format option to manpage.
Lars Marowsky-Bree [Wed, 25 Feb 2015 15:26:19 +0000 (16:26 +0100)]
Add --output-format option to manpage.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoMake 'loops' honor full write+verify loops
Jens Axboe [Tue, 24 Feb 2015 22:50:57 +0000 (14:50 -0800)]
Make 'loops' honor full write+verify loops

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoFixup whitespace damage in the two previous commits
Jens Axboe [Thu, 19 Feb 2015 16:47:34 +0000 (08:47 -0800)]
Fixup whitespace damage in the two previous commits

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoaxmap: Avoid memory leak if axmap_new() failed
Erwan Velu [Thu, 19 Feb 2015 12:09:09 +0000 (13:09 +0100)]
axmap: Avoid memory leak if axmap_new() failed

The axmap_new() function implements an exit path using the label "err"
to free the alloced memory.

That cleanup code was cleaning all the sub malloc structures but not the
main structure (axmap) itself resulting in a memory leak of
sizeof(struct axmap) bytes.

This simple patch just free axmap at the end of the cleanup code.

9 years agoiolog: Don't leak memory if fread fails in iolog_file_inflate
Erwan Velu [Thu, 19 Feb 2015 12:04:08 +0000 (13:04 +0100)]
iolog: Don't leak memory if fread fails in iolog_file_inflate

If fread fails in iolog_file_inflate(), the current code was closing the
file descriptor and return 1. But it was missing freeing the previously
malloced buffer (buf).

This patch does add a memory free of 'buf' before returning to avoid the
memory leak.

9 years agoAllow verify w/norandommap and bsrange
Justin Eno [Thu, 29 Jan 2015 22:28:38 +0000 (14:28 -0800)]
Allow verify w/norandommap and bsrange

Only intact blocks are verified; partially-overwritten blocks
are ignored
Signed-off-by: Justin Eno <jeno@micron.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoAllow verification of random overwrites w/ba < bs
Justin Eno [Thu, 29 Jan 2015 20:59:22 +0000 (12:59 -0800)]
Allow verification of random overwrites w/ba < bs

When blockalign is less than blocksize, random overwrite
workloads may partially overwrite blocks.  This change
evicts partially-overwritten blocks from the iolog tree
so subsequent verification targets only intact blocks.

This change also allows verification with norandommap
and bsrange, though that is left disabled.
Signed-off-by: Justin Eno <jeno@micron.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoexamples/ssd-test.fio: bump size to 10G
Jens Axboe [Mon, 16 Feb 2015 22:04:11 +0000 (15:04 -0700)]
examples/ssd-test.fio: bump size to 10G

1G is a bit too tiny for most devices today, bump it to 10G.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoAllow random overwrite workloads to write io_limit
Justin Eno [Thu, 29 Jan 2015 20:27:58 +0000 (12:27 -0800)]
Allow random overwrite workloads to write io_limit

Limiting the write phase of (random) overwrite workloads to 'size'
before the verify phase doesn't make sense, so allow them to write
up to io_limit.  This better matches verify_only behavior, and
allows the [verify-job] below to succeed:

[global]
thread=1
direct=1
ioengine=sync
verify=meta
bs=1k
offset=0
size=5M
io_limit=6M
norandommap=1
verify_fatal=1
randseed=42

[write-job]
filename=datafile.tmp
rw=randwrite
do_verify=0

[verify-job]
stonewall
create_serialize=0
filename=datafile.tmp
rw=randwrite
do_verify=1
verify_only=1

Signed-off-by: Justin Eno <jeno@micron.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime.h: use time_t instead of size_t for copy of tv_sec
Castor Fu [Fri, 13 Feb 2015 14:46:04 +0000 (06:46 -0800)]
gettime.h: use time_t instead of size_t for copy of tv_sec

This addresses a small nit that our compiler was complaining about.
Thanks!

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoverify: Fix latency log for verify commands.
Gwendal Grignou [Mon, 9 Feb 2015 03:53:20 +0000 (19:53 -0800)]
verify: Fix latency log for verify commands.

When commands when requeued for the verify operation,
their start time was not reset, resulting in bogus latency graphs.

Signed-off-by: Gwendal Grignou <gwendal@chromium.org>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoFix for verify_only (do_dry_run()) broken by 74d6277f
Justin Eno [Wed, 28 Jan 2015 22:13:28 +0000 (14:13 -0800)]
Fix for verify_only (do_dry_run()) broken by 74d6277f

Previous commit to backend.c tracks io_limit more closely by
counting submitted (in-flight) I/O instead of completed I/O.
do_dry_run() does not submit I/O, so its I/O is not counted,
and it loops forever.
Signed-off-by: Justin Eno <jeno@micron.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoconfigure: fix libnuma_v2 probe to work with -Werror
Castor Fu [Thu, 29 Jan 2015 18:07:36 +0000 (10:07 -0800)]
configure: fix libnuma_v2 probe to work with -Werror

I noticed that libnuma_v2 wasn't getting detected in our build
environment because we would get an error that mask was unused.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoMoral license update
Jens Axboe [Fri, 6 Feb 2015 16:09:29 +0000 (09:09 -0700)]
Moral license update

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoUpdate the moral license
Jens Axboe [Fri, 30 Jan 2015 17:38:20 +0000 (09:38 -0800)]
Update the moral license

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: remember to tear down clock cpumask on normal exit
Jens Axboe [Thu, 29 Jan 2015 17:23:39 +0000 (09:23 -0800)]
gettime: remember to tear down clock cpumask on normal exit

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: fix unitialized variable on Solaris
Jens Axboe [Thu, 29 Jan 2015 16:32:28 +0000 (08:32 -0800)]
gettime: fix unitialized variable on Solaris

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoidletime: maintain cpuset over lifetime of idle thread
Jens Axboe [Wed, 28 Jan 2015 21:47:48 +0000 (14:47 -0700)]
idletime: maintain cpuset over lifetime of idle thread

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: initialize cpusets properly
Jens Axboe [Wed, 28 Jan 2015 21:42:10 +0000 (14:42 -0700)]
gettime: initialize cpusets properly

We can't just use memset(), some platforms have specific init/exit
routines for cpusets/masks.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: if setaffinity fails, print the errno error
Jens Axboe [Wed, 28 Jan 2015 21:34:10 +0000 (14:34 -0700)]
gettime: if setaffinity fails, print the errno error

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoFixing typo
Felipe Franciosi [Wed, 28 Jan 2015 19:06:32 +0000 (19:06 +0000)]
Fixing typo

9 years agodedupe_percentage should work even if compress_percentage is not set
Vasily Tarasov [Wed, 28 Jan 2015 16:10:30 +0000 (09:10 -0700)]
dedupe_percentage should work even if compress_percentage is not set

Currently dedupe_percentage option does not work properly if
compress_percentage is not set. This can be easily demonstrated using
the following job file:

[job-/dev/dm-0]
filename=/dev/dm-0
rw=randwrite
blocksize=4096
direct=1
ioengine=libaio
iodepth=32
dedupe_percentage=50
time_based=1
runtime=5
numjobs=1

All writes will contain zeroes for the above job file.

The problem is in fill_io_buffer() function that switches dedupe random
state only if o->compress_percentage is set.

This patch updates the condition appropriately in fill_io_buffer()
appropriately.

Signed-off-by: Vasily Tarasov <tarasov@vasily.name>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoBetter accommodate random writes larger than blockalign
Justin Eno [Tue, 27 Jan 2015 22:23:20 +0000 (14:23 -0800)]
Better accommodate random writes larger than blockalign

fill_io_u() fails prematurely if the randomly-chosen offset satisfies
blockalign but not min_bs, i.e., the offset lies too near the end of
the target region.  This change honors both parameters.

Signed-off-by: Justin Eno <jeno@micron.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoparse: ensure strings are pre-terminated when using strncpy()
Jens Axboe [Thu, 22 Jan 2015 21:51:56 +0000 (14:51 -0700)]
parse: ensure strings are pre-terminated when using strncpy()

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoMerge branch 'master' of ssh://git.kernel.dk/data/git/fio
Jens Axboe [Wed, 21 Jan 2015 23:57:00 +0000 (00:57 +0100)]
Merge branch 'master' of ssh://git.kernel.dk/data/git/fio

9 years agoFio 2.2.5 fio-2.2.5
Jens Axboe [Wed, 21 Jan 2015 20:07:43 +0000 (13:07 -0700)]
Fio 2.2.5

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoshm: disable iomem=shm* for shm disabled
Jens Axboe [Wed, 21 Jan 2015 01:38:11 +0000 (18:38 -0700)]
shm: disable iomem=shm* for shm disabled

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoconfigure: add --disable-shm to disable use of shm
Jens Axboe [Tue, 20 Jan 2015 23:29:33 +0000 (16:29 -0700)]
configure: add --disable-shm to disable use of shm

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agonet: don't record/verify UDP sequence numbers if buffer is too small
Steven Noonan [Sat, 17 Jan 2015 00:46:11 +0000 (16:46 -0800)]
net: don't record/verify UDP sequence numbers if buffer is too small

This causes a bunch of out-of-bounds accesses if you have really small buffer
sizes (i.e. 16 bytes will crash).

Signed-off-by: Steven Noonan <steven@uplinklabs.net>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agocrc/test: sha1 should do _final() after _update()
Jens Axboe [Fri, 16 Jan 2015 23:10:43 +0000 (16:10 -0700)]
crc/test: sha1 should do _final() after _update()

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoFix segfault with client/server and minimal output
Jens Axboe [Fri, 16 Jan 2015 21:25:47 +0000 (14:25 -0700)]
Fix segfault with client/server and minimal output

Fixes: bf2921f02651
Reported-by: Ben England <bengland@redhat.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agosha256: fix verify failure
Jens Axboe [Fri, 16 Jan 2015 21:25:15 +0000 (14:25 -0700)]
sha256: fix verify failure

After the checksumming update, it's required that we call the
_final() to get consistent checksums between data generation
and data verification. Seems to only affect sha256, but we should
do it for sha1 and md5 too.

Fixes: f99d67f932ab
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agosha256: fix verify failure
Jens Axboe [Fri, 16 Jan 2015 20:12:53 +0000 (21:12 +0100)]
sha256: fix verify failure

After the checksumming update, it's required that we call the
_final() to get consistent checksums between data generation
and data verification. Seems to only affect sha256, but we should
do it for sha1 and md5 too.

Fixes: f99d67f932ab
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoverify: always check completion list for low depth verifies
Jens Axboe [Fri, 16 Jan 2015 17:25:05 +0000 (10:25 -0700)]
verify: always check completion list for low depth verifies

If we have done less IO than the depth, we need to check the
pending list.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoioengine: if we get BUSY in queuing, adjust accounting
Jens Axboe [Fri, 16 Jan 2015 17:06:02 +0000 (10:06 -0700)]
ioengine: if we get BUSY in queuing, adjust accounting

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoImprove precision of the io_limit setting
Jens Axboe [Fri, 16 Jan 2015 17:03:11 +0000 (10:03 -0700)]
Improve precision of the io_limit setting

For async engines, we look only at completions. But we could have
a bunch inflight with a high queue depth, making us go higher than
we should.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoImprove rate limiting
Jens Axboe [Thu, 15 Jan 2015 17:39:12 +0000 (10:39 -0700)]
Improve rate limiting

If we have pending IO, we should commit it before going to sleep,
not just wait for IO that has already been issued.

Also improve the delay functions to return the time spent, so
that users don't have to track tha separately if they care about
the precision.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agorbd example: 'invalidate=false' no longer necessary
Jens Axboe [Wed, 14 Jan 2015 16:31:35 +0000 (09:31 -0700)]
rbd example: 'invalidate=false' no longer necessary

As of commit 903b2812e9c7, rbd does support cache invalidation.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoclient: take better care to return failure from fio_handle_clients()
Jens Axboe [Wed, 14 Jan 2015 04:47:43 +0000 (21:47 -0700)]
client: take better care to return failure from fio_handle_clients()

If any error has been noted in the ->error field, we need to pass
back a non-zero return from fio_handle_clients().

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agosmalloc: limit to 1 pool, and bump size to 16MB
Jens Axboe [Wed, 14 Jan 2015 04:35:31 +0000 (21:35 -0700)]
smalloc: limit to 1 pool, and bump size to 16MB

We can easily add new pools, but if we do this after jobs have been
forked off, then it wont really be shared storage as the new mmap
mappings will only apply to the process that instantiated them.
Since we moved the randommap mappings to private storage, we should
not need a lot of room for shared allocations. Hence I hope the 16MB
will suffice.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoaxmap: random maps are private, don't get them from smalloc
Jens Axboe [Wed, 14 Jan 2015 04:33:53 +0000 (21:33 -0700)]
axmap: random maps are private, don't get them from smalloc

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agofilelock: fix segfault on some use cases of log file locking
Jens Axboe [Wed, 14 Jan 2015 04:06:45 +0000 (21:06 -0700)]
filelock: fix segfault on some use cases of log file locking

If we end up diving into a new smalloc pool, we could add
file lock references that meant nothing to other processes.

Fixes: 243bfe190245
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agommap backend invalidate fix
Yoshinori Sato [Wed, 7 Jan 2015 03:16:36 +0000 (12:16 +0900)]
mmap backend invalidate fix

madvice before mmap. moved later.

Signed-off-by Yoshinori Sato <yo-satoh@sios.com>

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoFix disk utils being updated too often
Jens Axboe [Wed, 7 Jan 2015 22:04:39 +0000 (15:04 -0700)]
Fix disk utils being updated too often

Fixes: f893b76d5745
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoAdjust ctime_r buf down to 32
Jens Axboe [Tue, 6 Jan 2015 19:03:09 +0000 (12:03 -0700)]
Adjust ctime_r buf down to 32

We need 'at least 26 bytes', but not all 64.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoAdd timestamp to json output
Steve ODriscoll [Tue, 6 Jan 2015 19:00:27 +0000 (12:00 -0700)]
Add timestamp to json output

Modified by Jens to add humanly readable time as well.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: include min/max cycle counts for CPU clock
Jens Axboe [Tue, 6 Jan 2015 16:36:25 +0000 (09:36 -0700)]
gettime: include min/max cycle counts for CPU clock

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoserver: use fio_gettime() for timeout variables
Jens Axboe [Mon, 5 Jan 2015 20:51:22 +0000 (13:51 -0700)]
server: use fio_gettime() for timeout variables

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoverify: fix potentially unterminated name
Jens Axboe [Mon, 5 Jan 2015 15:52:37 +0000 (08:52 -0700)]
verify: fix potentially unterminated name

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agomemory: double check that mmapfd isn't -1 before closing
Jens Axboe [Mon, 5 Jan 2015 15:50:41 +0000 (08:50 -0700)]
memory: double check that mmapfd isn't -1 before closing

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogluster: io_u->error should be a positive error value
Jens Axboe [Mon, 5 Jan 2015 15:50:26 +0000 (08:50 -0700)]
gluster: io_u->error should be a positive error value

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoclient: fix potential buffer overrun in server name copy
Jens Axboe [Mon, 5 Jan 2015 15:47:01 +0000 (08:47 -0700)]
client: fix potential buffer overrun in server name copy

Not an issue right now since pdu.server is larger than the buffer,
but that could change at some point. Better be safe.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoinit: fix potential mem leak on multiple trigger options
Jens Axboe [Mon, 5 Jan 2015 15:46:35 +0000 (08:46 -0700)]
init: fix potential mem leak on multiple trigger options

Free the ones we already set, if any.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoAvoid potential buffer overflow in make_filename()
Jens Axboe [Sun, 4 Jan 2015 20:33:37 +0000 (13:33 -0700)]
Avoid potential buffer overflow in make_filename()

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agocleanup: add defines for default pareto or zipf values
Jens Axboe [Sun, 4 Jan 2015 17:02:34 +0000 (10:02 -0700)]
cleanup: add defines for default pareto or zipf values

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoFio 2.2.4 fio-2.2.4
Jens Axboe [Sun, 4 Jan 2015 02:46:55 +0000 (19:46 -0700)]
Fio 2.2.4

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agobloom: kill unused function
Jens Axboe [Sat, 3 Jan 2015 20:48:30 +0000 (13:48 -0700)]
bloom: kill unused function

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoaxmap: make axmap_first_free() static
Ming Lei [Sat, 3 Jan 2015 20:41:32 +0000 (13:41 -0700)]
axmap: make axmap_first_free() static

Pulled from an earlier patch from Ming, that we no longer need.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoRevert "axmap: ensure we lock down the maps for shared access"
Jens Axboe [Sat, 3 Jan 2015 20:40:24 +0000 (13:40 -0700)]
Revert "axmap: ensure we lock down the maps for shared access"

This reverts commit 12bde3697fc230d7af560cecc8ac469ab47643f8.

9 years agoRevert "axmap: fix deadlock"
Jens Axboe [Sat, 3 Jan 2015 20:40:16 +0000 (13:40 -0700)]
Revert "axmap: fix deadlock"

This reverts commit d555a23db84364ab942361a719a4379605bdbc41.

9 years agoGet rid of lockfile callback
Jens Axboe [Sat, 3 Jan 2015 19:15:57 +0000 (12:15 -0700)]
Get rid of lockfile callback

We don't need it, since the option priorities take care of
ordering.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoaxmap: fix deadlock
Ming Lei [Sat, 3 Jan 2015 14:21:09 +0000 (22:21 +0800)]
axmap: fix deadlock

axmap_first_free() is always called with axmap->lock held,
so needn't to acquire the lock inside the function.

The deadlock is introduced in commit 12bde3697fc230d7a(axmap:
ensure we lock down the maps for shared access).

Given axmap_first_free() is only called inside lib/axmap.c,
this patch declares the function as static. In the future,
if external users need the function, axmap lock can be
considered at that time.

Reported-by: Sedat Dilek <sedat.dilek@gmail.com>
Signed-off-by: Ming Lei <ming.lei@canonical.com>
Tested-by: Sedat Dilek <sedat.dilek@gmail.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: add basic init cpuclock test
Jens Axboe [Tue, 23 Dec 2014 17:41:34 +0000 (10:41 -0700)]
gettime: add basic init cpuclock test

Some systems claim to have a synced and constant rate tsc, even if
they don't. So add the basic cpuclock-test test as part of fio
trusting the CPU clock, to avoid using the CPU clock on a system
where the TSC truly isn't synced between CPUs.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoFio 2.2.3 fio-2.2.3
Jens Axboe [Tue, 23 Dec 2014 03:06:45 +0000 (20:06 -0700)]
Fio 2.2.3

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agooptions: ensure that we check all candidates on is_set check
Jens Axboe [Tue, 23 Dec 2014 03:03:50 +0000 (20:03 -0700)]
options: ensure that we check all candidates on is_set check

We can have multiple options that touch the same variable. One
example is cpus_allowed or cpumask, both will set the same
backend variable. But if we set cpumask= and later check if
cpus_allowed is set, then we want that to report true.

This breaks certain options since b2a9e6496494.

Reported-by: Vincent Fu <Vincent.Fu@sandisk.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoFio 2.2.2 fio-2.2.2
Jens Axboe [Mon, 22 Dec 2014 16:03:50 +0000 (09:03 -0700)]
Fio 2.2.2

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoFix default scrambling of buffers
Jens Axboe [Sat, 20 Dec 2014 21:42:56 +0000 (14:42 -0700)]
Fix default scrambling of buffers

Commit 1bf2498d3111 inadvertently made us not scramble by default.
The logic was a bit convoluted, so clear it up and scramble if:

- Asked so by adding scramble_buffers=1
- Or, if not asked to explicitly, but zero_buffers not set to 1.

Reported-by: Chris Wilson <Chris.Wilson@nutanix.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: hide fio_gtod_cpumask if not used
Jens Axboe [Fri, 19 Dec 2014 22:04:10 +0000 (15:04 -0700)]
gettime: hide fio_gtod_cpumask if not used

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: only use CPU affinity if available
Jens Axboe [Fri, 19 Dec 2014 22:03:15 +0000 (15:03 -0700)]
gettime: only use CPU affinity if available

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoFio 2.2.1 fio-2.2.1
Jens Axboe [Fri, 19 Dec 2014 19:27:49 +0000 (12:27 -0700)]
Fio 2.2.1

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoaxmap: ensure we lock down the maps for shared access
Jens Axboe [Fri, 19 Dec 2014 15:15:55 +0000 (08:15 -0700)]
axmap: ensure we lock down the maps for shared access

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agooptions: turn missing options into debug parse messages
Jens Axboe [Fri, 19 Dec 2014 15:04:48 +0000 (08:04 -0700)]
options: turn missing options into debug parse messages

It's not an error, we expect it to happen if we try and check
for set options that aren't available (due to being platform
specific, libraries missing, etc).

This fixes cases where fio would spew:

fio: no option found at offset 1240

and other offsets.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agooptions: add debug code for failure to lookup option names
Jens Axboe [Fri, 19 Dec 2014 04:51:21 +0000 (21:51 -0700)]
options: add debug code for failure to lookup option names

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agomutex: add __fio_mutex_remove()
Jens Axboe [Fri, 19 Dec 2014 02:44:18 +0000 (19:44 -0700)]
mutex: add __fio_mutex_remove()

We have to remember to free the condvar, so add a __fio_mutex_remove()
for cases that init a mutex inside an smalloc'ed region with
__fio_mutex_init().

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoMerge branch 'master' of ssh://git.kernel.dk/data/git/fio
Jens Axboe [Thu, 18 Dec 2014 17:20:38 +0000 (10:20 -0700)]
Merge branch 'master' of ssh://git.kernel.dk/data/git/fio

9 years agot/btrace2fio: add ability to add specific options through -a
Jens Axboe [Thu, 18 Dec 2014 17:18:30 +0000 (10:18 -0700)]
t/btrace2fio: add ability to add specific options through -a

Can be used multiple times to add more options.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoparse: remove the arithmetic parser checking
Jens Axboe [Wed, 17 Dec 2014 20:27:32 +0000 (13:27 -0700)]
parse: remove the arithmetic parser checking

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoFio 2.2.0 fio-2.2.0
Jens Axboe [Wed, 17 Dec 2014 17:46:46 +0000 (10:46 -0700)]
Fio 2.2.0

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: fix compile warning for !ARCH_HAVE_CPU_CLOCK
Jens Axboe [Wed, 17 Dec 2014 16:08:01 +0000 (09:08 -0700)]
gettime: fix compile warning for !ARCH_HAVE_CPU_CLOCK

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: offset CPU cycle counter by initial value
Jens Axboe [Wed, 17 Dec 2014 15:51:23 +0000 (08:51 -0700)]
gettime: offset CPU cycle counter by initial value

Should then be safe for the full 2^64 cycles, and we push
the more expensive variable division to later in the run (which
is probably never).

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agostat: always show disk util in terse v3/v4
Jens Axboe [Wed, 17 Dec 2014 15:30:30 +0000 (08:30 -0700)]
stat: always show disk util in terse v3/v4

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: cleanup for FIO_DEBUG_TIME
Jens Axboe [Wed, 17 Dec 2014 06:03:54 +0000 (23:03 -0700)]
gettime: cleanup for FIO_DEBUG_TIME

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: fix overflow in cycle to usec conversion
Jens Axboe [Wed, 17 Dec 2014 05:40:37 +0000 (22:40 -0700)]
gettime: fix overflow in cycle to usec conversion

If this multiplication overflows:

usecs = (t * inv_cycles_per_usec) / 16777216UL;

then usecs is 2^64/2^24, which is 1099511627776. Divide that by
10^6 to get seconds, and that is 1099511. Since we cached the
old value previously, we'd get stuck with this amount of seconds.

To avoid turning this into an expensive division, have a check
and only divide if we have to. This avoids the overflow.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime-thread: set and allow multiple CPUs
Jens Axboe [Wed, 17 Dec 2014 03:38:53 +0000 (20:38 -0700)]
gettime-thread: set and allow multiple CPUs

Also use the new option checking framework instead of carrying
a flag for whether it's set or not.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime-thread: fix missing startup mutex
Jens Axboe [Wed, 17 Dec 2014 02:49:54 +0000 (19:49 -0700)]
gettime-thread: fix missing startup mutex

It'll segfault if gtod_cpu= is used, ensure we pass in the mutex.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: improve gettimeofday() offload support
Jens Axboe [Wed, 17 Dec 2014 02:43:55 +0000 (19:43 -0700)]
gettime: improve gettimeofday() offload support

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: limit warning on CPU clock
Jens Axboe [Tue, 16 Dec 2014 22:37:25 +0000 (15:37 -0700)]
gettime: limit warning on CPU clock

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agogettime: don't attempt to fixup what looks like a backwards clock
Jens Axboe [Tue, 16 Dec 2014 22:13:45 +0000 (15:13 -0700)]
gettime: don't attempt to fixup what looks like a backwards clock

It could just be a wrap. The code is buggy, kill it, we'll deal
with the wrap later.

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoengines/mmap: clear partial mmap flag on close
Jens Axboe [Tue, 16 Dec 2014 17:46:24 +0000 (10:46 -0700)]
engines/mmap: clear partial mmap flag on close

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agoengines/mmap: fix segfault on large devices and 32-bit archs
Jens Axboe [Tue, 16 Dec 2014 17:35:07 +0000 (10:35 -0700)]
engines/mmap: fix segfault on large devices and 32-bit archs

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agobackend: use monotonic clock for ETA, if we have it
Jens Axboe [Tue, 16 Dec 2014 02:54:57 +0000 (19:54 -0700)]
backend: use monotonic clock for ETA, if we have it

Signed-off-by: Jens Axboe <axboe@fb.com>
9 years agobackend: fix off-by-one in nsec calculation
Jens Axboe [Mon, 15 Dec 2014 20:45:53 +0000 (13:45 -0700)]
backend: fix off-by-one in nsec calculation

If it's equal to 10^9 we need to bump seconds and subtract 10^9
from nsec, not only if it's larger than.

Signed-off-by: Jens Axboe <axboe@fb.com>