X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=zbd.c;h=9c3092ab2424dae64c6f19646ff8ae85cbda9515;hp=0f3636a525d835a1514de71a9f652729105cfaff;hb=a0c84dd4354eaf0a84b8bf0a3126f65301f2206f;hpb=0f9f1921197d79fe5069473b9d85ca4559ef8c42 diff --git a/zbd.c b/zbd.c index 0f3636a5..9c3092ab 100644 --- a/zbd.c +++ b/zbd.c @@ -128,9 +128,9 @@ static bool zbd_verify_sizes(void) f->file_name); return false; } - log_info("%s: rounded up offset from %lu to %lu\n", - f->file_name, f->file_offset, - new_offset); + log_info("%s: rounded up offset from %llu to %llu\n", + f->file_name, (unsigned long long) f->file_offset, + (unsigned long long) new_offset); f->io_size -= (new_offset - f->file_offset); f->file_offset = new_offset; } @@ -143,9 +143,9 @@ static bool zbd_verify_sizes(void) f->file_name); return false; } - log_info("%s: rounded down io_size from %lu to %lu\n", - f->file_name, f->io_size, - new_end - f->file_offset); + log_info("%s: rounded down io_size from %llu to %llu\n", + f->file_name, (unsigned long long) f->io_size, + (unsigned long long) new_end - f->file_offset); f->io_size = new_end - f->file_offset; } } @@ -357,14 +357,15 @@ static int parse_zone_info(struct thread_data *td, struct fio_file *f) if (td->o.zone_size == 0) { td->o.zone_size = zone_size; } else if (td->o.zone_size != zone_size) { - log_info("fio: %s job parameter zonesize %lld does not match disk zone size %ld.\n", - f->file_name, td->o.zone_size, zone_size); + log_info("fio: %s job parameter zonesize %llu does not match disk zone size %llu.\n", + f->file_name, (unsigned long long) td->o.zone_size, + (unsigned long long) zone_size); ret = -EINVAL; goto close; } - dprint(FD_ZBD, "Device %s has %d zones of size %lu KB\n", f->file_name, - nr_zones, zone_size / 1024); + dprint(FD_ZBD, "Device %s has %d zones of size %llu KB\n", f->file_name, + nr_zones, (unsigned long long) zone_size / 1024); zbd_info = scalloc(1, sizeof(*zbd_info) + (nr_zones + 1) * sizeof(zbd_info->zone_info[0])); @@ -407,8 +408,8 @@ static int parse_zone_info(struct thread_data *td, struct fio_file *f) break; ret = read_zone_info(fd, start_sector, buf, bufsz); if (ret < 0) { - log_info("fio: BLKREPORTZONE(%lu) failed for %s (%d).\n", - start_sector, f->file_name, -ret); + log_info("fio: BLKREPORTZONE(%llu) failed for %s (%d).\n", + (unsigned long long) start_sector, f->file_name, -ret); goto close; } } @@ -602,6 +603,12 @@ static int zbd_reset_range(struct thread_data *td, const struct fio_file *f, return ret; } +static unsigned int zbd_zone_nr(struct zoned_block_device_info *zbd_info, + struct fio_zone_info *zone) +{ + return (uintptr_t) zone - (uintptr_t) zbd_info->zone_info; +} + /** * zbd_reset_zone - reset the write pointer of a single zone * @td: FIO thread data. @@ -615,8 +622,8 @@ static int zbd_reset_zone(struct thread_data *td, const struct fio_file *f, { int ret; - dprint(FD_ZBD, "%s: resetting wp of zone %lu.\n", f->file_name, - z - f->zbd_info->zone_info); + dprint(FD_ZBD, "%s: resetting wp of zone %u.\n", f->file_name, + zbd_zone_nr(f->zbd_info, z)); ret = zbd_reset_range(td, f, z->start, (z+1)->start - z->start); return ret; } @@ -639,8 +646,8 @@ static int zbd_reset_zones(struct thread_data *td, struct fio_file *f, bool reset_wp; int res = 0; - dprint(FD_ZBD, "%s: examining zones %lu .. %lu\n", f->file_name, - zb - f->zbd_info->zone_info, ze - f->zbd_info->zone_info); + dprint(FD_ZBD, "%s: examining zones %u .. %u\n", f->file_name, + zbd_zone_nr(f->zbd_info, zb), zbd_zone_nr(f->zbd_info, ze)); assert(f->fd != -1); for (z = zb; z < ze; z++) { pthread_mutex_lock(&z->mutex); @@ -653,10 +660,10 @@ static int zbd_reset_zones(struct thread_data *td, struct fio_file *f, start_z = z; } else if (start_z < ze && !reset_wp) { dprint(FD_ZBD, - "%s: resetting zones %lu .. %lu\n", + "%s: resetting zones %u .. %u\n", f->file_name, - start_z - f->zbd_info->zone_info, - z - f->zbd_info->zone_info); + zbd_zone_nr(f->zbd_info, start_z), + zbd_zone_nr(f->zbd_info, z)); if (zbd_reset_range(td, f, start_z->start, z->start - start_z->start) < 0) res = 1; @@ -666,9 +673,9 @@ static int zbd_reset_zones(struct thread_data *td, struct fio_file *f, default: if (start_z == ze) break; - dprint(FD_ZBD, "%s: resetting zones %lu .. %lu\n", - f->file_name, start_z - f->zbd_info->zone_info, - z - f->zbd_info->zone_info); + dprint(FD_ZBD, "%s: resetting zones %u .. %u\n", + f->file_name, zbd_zone_nr(f->zbd_info, start_z), + zbd_zone_nr(f->zbd_info, z)); if (zbd_reset_range(td, f, start_z->start, z->start - start_z->start) < 0) res = 1; @@ -677,9 +684,9 @@ static int zbd_reset_zones(struct thread_data *td, struct fio_file *f, } } if (start_z < ze) { - dprint(FD_ZBD, "%s: resetting zones %lu .. %lu\n", f->file_name, - start_z - f->zbd_info->zone_info, - z - f->zbd_info->zone_info); + dprint(FD_ZBD, "%s: resetting zones %u .. %u\n", f->file_name, + zbd_zone_nr(f->zbd_info, start_z), + zbd_zone_nr(f->zbd_info, z)); if (zbd_reset_range(td, f, start_z->start, z->start - start_z->start) < 0) res = 1; @@ -765,7 +772,8 @@ void zbd_file_reset(struct thread_data *td, struct fio_file *f) pthread_mutex_unlock(&f->zbd_info->mutex); for (z = zb ; z < ze; z++) pthread_mutex_unlock(&z->mutex); - dprint(FD_ZBD, "%s(%s): swd = %ld\n", __func__, f->file_name, swd); + dprint(FD_ZBD, "%s(%s): swd = %llu\n", __func__, f->file_name, + (unsigned long long) swd); /* * If data verification is enabled reset the affected zones before * writing any data to avoid that a zone reset has to be issued while @@ -995,8 +1003,8 @@ static struct fio_zone_info *zbd_replay_write_order(struct thread_data *td, } if (z->verify_block * min_bs >= f->zbd_info->zone_size) - log_err("%s: %d * %d >= %ld\n", f->file_name, z->verify_block, - min_bs, f->zbd_info->zone_size); + log_err("%s: %d * %d >= %llu\n", f->file_name, z->verify_block, + min_bs, (unsigned long long) f->zbd_info->zone_size); io_u->offset = z->start + z->verify_block++ * min_bs; return z; } @@ -1301,7 +1309,7 @@ char *zbd_write_status(const struct thread_stat *ts) { char *res; - if (asprintf(&res, "; %ld zone resets", ts->nr_zone_resets) < 0) + if (asprintf(&res, "; %llu zone resets", (unsigned long long) ts->nr_zone_resets) < 0) return NULL; return res; }