From: Bruce Cran Date: Mon, 20 Feb 2012 17:01:46 +0000 (+0000) Subject: Add OS_PATH_SEPARATOR for platforms which have different path separator characters... X-Git-Tag: fio-2.0.4~18 X-Git-Url: https://git.kernel.dk/?p=fio.git;a=commitdiff_plain;h=b9fd788f0e8adacc33316107594e9eb0463743d7;hp=9e684a4976b7934f5ce011ea281dfef3352e5738 Add OS_PATH_SEPARATOR for platforms which have different path separator characters (e.g. Windows and 'classic' MacOS). Signed-off-by: Jens Axboe --- diff --git a/blktrace.c b/blktrace.c index 297a8a94..1b9bf3b8 100644 --- a/blktrace.c +++ b/blktrace.c @@ -115,7 +115,7 @@ static int lookup_device(struct thread_data *td, char *path, unsigned int maj, if (!strcmp(dir->d_name, ".") || !strcmp(dir->d_name, "..")) continue; - sprintf(full_path, "%s/%s", path, dir->d_name); + sprintf(full_path, "%s%s%s", path, FIO_OS_PATH_SEPARATOR, dir->d_name); if (lstat(full_path, &st) == -1) { perror("lstat"); break; diff --git a/cgroup.c b/cgroup.c index de00d986..ea6bbd69 100644 --- a/cgroup.c +++ b/cgroup.c @@ -86,9 +86,9 @@ static char *get_cgroup_root(struct thread_data *td, char *mnt) char *str = malloc(64); if (td->o.cgroup) - sprintf(str, "%s/%s", mnt, td->o.cgroup); + sprintf(str, "%s%s%s", mnt, FIO_OS_PATH_SEPARATOR, td->o.cgroup); else - sprintf(str, "%s/%s", mnt, td->o.name); + sprintf(str, "%s%s%s", mnt, FIO_OS_PATH_SEPARATOR, td->o.name); return str; } @@ -99,8 +99,8 @@ static int write_int_to_file(struct thread_data *td, const char *path, { char tmp[256]; FILE *f; - - sprintf(tmp, "%s/%s", path, filename); + + sprintf(tmp, "%s%s%s", path, FIO_OS_PATH_SEPARATOR, filename); f = fopen(tmp, "w"); if (!f) { td_verror(td, errno, onerr); diff --git a/diskutil.c b/diskutil.c index e4b4b8a5..47d739bb 100644 --- a/diskutil.c +++ b/diskutil.c @@ -215,7 +215,7 @@ static void find_add_disk_slaves(struct thread_data *td, char *path, !strcmp(dirent->d_name, "..")) continue; - sprintf(temppath, "%s/%s", slavesdir, dirent->d_name); + sprintf(temppath, "%s%s%s", slavesdir, FIO_OS_PATH_SEPARATOR, dirent->d_name); /* Can we always assume that the slaves device entries * are links to the real directories for the slave * devices? @@ -240,7 +240,7 @@ static void find_add_disk_slaves(struct thread_data *td, char *path, if (slavedu) continue; - sprintf(temppath, "%s/%s", slavesdir, slavepath); + sprintf(temppath, "%s%s%s", slavesdir, FIO_OS_PATH_SEPARATOR, slavepath); __init_per_file_disk_util(td, majdev, mindev, temppath); slavedu = disk_util_exists(majdev, mindev); @@ -327,7 +327,7 @@ static int find_block_dir(int majdev, int mindev, char *path, int link_ok) if (!strcmp(dir->d_name, ".") || !strcmp(dir->d_name, "..")) continue; - sprintf(full_path, "%s/%s", path, dir->d_name); + sprintf(full_path, "%s%s%s", path, FIO_OS_PATH_SEPARATOR, dir->d_name); if (!strcmp(dir->d_name, "dev")) { if (!check_dev_match(majdev, mindev, full_path)) { diff --git a/filesetup.c b/filesetup.c index d55af454..cf5ec8e9 100644 --- a/filesetup.c +++ b/filesetup.c @@ -1138,7 +1138,7 @@ static int recurse_dir(struct thread_data *td, const char *dirname) if (!strcmp(dir->d_name, ".") || !strcmp(dir->d_name, "..")) continue; - sprintf(full_path, "%s/%s", dirname, dir->d_name); + sprintf(full_path, "%s%s%s", dirname, FIO_OS_PATH_SEPARATOR, dir->d_name); if (lstat(full_path, &sb) == -1) { if (errno != ENOENT) { diff --git a/os/os.h b/os/os.h index d6ce9a77..cbb476fe 100644 --- a/os/os.h +++ b/os/os.h @@ -125,6 +125,10 @@ typedef unsigned long os_cpu_mask_t; #define FIO_PREFERRED_ENGINE "sync" #endif +#ifndef FIO_OS_PATH_SEPARATOR +#define FIO_OS_PATH_SEPARATOR "/" +#endif + #ifndef FIO_MAX_JOBS #define FIO_MAX_JOBS 2048 #endif