X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=filesetup.c;h=2b690c8930d91cc39eeac8e4fb8a845409c96a86;hb=deaa1af25d75d6989d15966b4579bc158df856f0;hp=5a8105a6032e24b2e45a8a9d028c2a0b7e2552fe;hpb=49ffb4a2e1ac3026d77d9e1c03edc2753fcec41b;p=fio.git diff --git a/filesetup.c b/filesetup.c index 5a8105a6..2b690c89 100644 --- a/filesetup.c +++ b/filesetup.c @@ -11,6 +11,7 @@ #include "fio.h" #include "smalloc.h" #include "filehash.h" +#include "os/os.h" static int root_warn; @@ -77,7 +78,7 @@ static int extend_file(struct thread_data *td, struct fio_file *f) } } #endif - + if (!new_layout) goto done; @@ -209,9 +210,16 @@ static unsigned long long get_rand_file_size(struct thread_data *td) unsigned long long ret, sized; long r; - r = os_random_long(&td->file_size_state); - sized = td->o.file_size_high - td->o.file_size_low; - ret = (unsigned long long) ((double) sized * (r / (OS_RAND_MAX + 1.0))); + if (td->o.use_os_rand) { + r = os_random_long(&td->file_size_state); + sized = td->o.file_size_high - td->o.file_size_low; + ret = (unsigned long long) ((double) sized * (r / (OS_RAND_MAX + 1.0))); + } else { + r = __rand(&td->__file_size_state); + sized = td->o.file_size_high - td->o.file_size_low; + ret = (unsigned long long) ((double) sized * (r / (FRAND_MAX + 1.0))); + } + ret += td->o.file_size_low; ret -= (ret % td->o.rw_min_bs); return ret; @@ -232,7 +240,7 @@ static int file_size(struct thread_data *td, struct fio_file *f) static int bdev_size(struct thread_data *td, struct fio_file *f) { - unsigned long long bytes; + unsigned long long bytes = 0; int r; if (td->io_ops->open_file(td, f)) { @@ -241,9 +249,10 @@ static int bdev_size(struct thread_data *td, struct fio_file *f) return 1; } - r = blockdev_size(f->fd, &bytes); + r = blockdev_size(f, &bytes); if (r) { td_verror(td, r, "blockdev_size"); + printf("fd is %d\n", f->fd); goto err; } @@ -263,7 +272,7 @@ err: static int char_size(struct thread_data *td, struct fio_file *f) { #ifdef FIO_HAVE_CHARDEV_SIZE - unsigned long long bytes; + unsigned long long bytes = 0; int r; if (td->io_ops->open_file(td, f)) { @@ -272,7 +281,7 @@ static int char_size(struct thread_data *td, struct fio_file *f) return 1; } - r = chardev_size(f->fd, &bytes); + r = chardev_size(f, &bytes); if (r) { td_verror(td, r, "chardev_size"); goto err; @@ -315,7 +324,7 @@ static int get_file_size(struct thread_data *td, struct fio_file *f) return ret; if (f->file_offset > f->real_file_size) { - log_err("%s: offset extends end (%Lu > %Lu)\n", td->o.name, + log_err("%s: offset extends end (%llu > %llu)\n", td->o.name, f->file_offset, f->real_file_size); return 1; } @@ -345,14 +354,14 @@ static int __file_invalidate_cache(struct thread_data *td, struct fio_file *f, * FIXME: add blockdev flushing too */ if (f->mmap_ptr) { - ret = madvise(f->mmap_ptr, f->mmap_sz, MADV_DONTNEED); + ret = posix_madvise(f->mmap_ptr, f->mmap_sz, POSIX_MADV_DONTNEED); #ifdef FIO_MADV_FREE - (void) madvise(f->mmap_ptr, f->mmap_sz, FIO_MADV_FREE); + (void) posix_madvise(f->mmap_ptr, f->mmap_sz, FIO_MADV_FREE); #endif } else if (f->filetype == FIO_TYPE_FILE) { - ret = fadvise(f->fd, off, len, POSIX_FADV_DONTNEED); + ret = posix_fadvise(f->fd, off, len, POSIX_FADV_DONTNEED); } else if (f->filetype == FIO_TYPE_BD) { - ret = blockdev_invalidate_cache(f->fd); + ret = blockdev_invalidate_cache(f); if (ret < 0 && errno == EACCES && geteuid()) { if (!root_warn) { log_err("fio: only root may flush block " @@ -733,7 +742,7 @@ int setup_files(struct thread_data *td) temp_stall_ts = 1; if (!terse_output) log_info("%s: Laying out IO file(s) (%u file(s) /" - " %LuMB)\n", td->o.name, need_extend, + " %lluMB)\n", td->o.name, need_extend, extend_size >> 20); for_each_file(td, f, i) { @@ -810,7 +819,7 @@ int init_random_map(struct thread_data *td) (unsigned long long) td->o.rw_min_bs; num_maps = (blocks + BLOCKS_PER_MAP - 1) / (unsigned long long) BLOCKS_PER_MAP; - f->file_map = smalloc(num_maps * sizeof(int)); + f->file_map = smalloc(num_maps * sizeof(unsigned long)); if (f->file_map) { f->num_maps = num_maps; continue; @@ -884,7 +893,9 @@ static void get_file_type(struct fio_file *f) f->filetype = FIO_TYPE_FILE; if (!stat(f->file_name, &sb)) { - if (S_ISBLK(sb.st_mode)) + /* \\.\ is the device namespace in Windows, where every file is + * a block device */ + if (S_ISBLK(sb.st_mode) || strncmp(f->file_name, "\\\\.\\", 4) == 0) f->filetype = FIO_TYPE_BD; else if (S_ISCHR(sb.st_mode)) f->filetype = FIO_TYPE_CHAR;