2001-11-16 06:46:32 +08:00
|
|
|
/*
|
2002-01-11 02:45:34 +08:00
|
|
|
* Copyright (C) 2001, 2002
|
2001-11-16 06:46:32 +08:00
|
|
|
* National Center for Supercomputing Applications
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
2001-11-07 23:28:33 +08:00
|
|
|
* Author: Albert Cheng of NCSA, Oct 24, 2001.
|
|
|
|
*/
|
|
|
|
|
2001-12-11 00:24:58 +08:00
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/stat.h>
|
2001-11-07 23:28:33 +08:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <fcntl.h>
|
2001-12-11 00:24:58 +08:00
|
|
|
#include <unistd.h>
|
|
|
|
#include <errno.h>
|
2001-11-16 06:46:32 +08:00
|
|
|
|
|
|
|
#include "hdf5.h"
|
|
|
|
|
|
|
|
#ifdef H5_HAVE_PARALLEL
|
|
|
|
|
2001-11-07 23:28:33 +08:00
|
|
|
#include <mpi.h>
|
2001-11-16 06:46:32 +08:00
|
|
|
|
2001-11-07 23:28:33 +08:00
|
|
|
#ifndef MPI_FILE_NULL /*MPIO may be defined in mpi.h already */
|
|
|
|
# include <mpio.h>
|
2001-11-16 06:46:32 +08:00
|
|
|
#endif /* !MPI_FILE_NULL */
|
2001-11-07 23:28:33 +08:00
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
#include "pio_perf.h"
|
|
|
|
#include "pio_timer.h"
|
2001-11-07 23:28:33 +08:00
|
|
|
|
|
|
|
/* Macro definitions */
|
2001-11-16 06:46:32 +08:00
|
|
|
|
|
|
|
/* sizes of various items. these sizes won't change during program execution */
|
2001-12-20 06:10:15 +08:00
|
|
|
#define ELMT_SIZE ((int)sizeof(int)) /* we're doing ints */
|
2001-11-16 06:46:32 +08:00
|
|
|
|
|
|
|
#define GOTOERROR(errcode) { ret_code = errcode; goto done; }
|
|
|
|
#define GOTODONE { goto done; }
|
|
|
|
#define ERRMSG(mesg) { \
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
fprintf(stderr, "Proc %d: ", pio_mpi_rank_g); \
|
2001-11-16 06:46:32 +08:00
|
|
|
fprintf(stderr, "*** Assertion failed (%s) at line %4d in %s\n", \
|
|
|
|
mesg, (int)__LINE__, __FILE__); \
|
2001-11-07 23:28:33 +08:00
|
|
|
}
|
2001-11-16 06:46:32 +08:00
|
|
|
|
|
|
|
#define MSG(mesg) { \
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
fprintf(stderr, "Proc %d: ", pio_mpi_rank_g); \
|
2001-11-16 06:46:32 +08:00
|
|
|
fprintf(stderr, "(%s) at line %4d in %s\n", \
|
|
|
|
mesg, (int)__LINE__, __FILE__); \
|
2001-11-07 23:28:33 +08:00
|
|
|
}
|
2001-11-16 06:46:32 +08:00
|
|
|
|
|
|
|
/* verify: if val is false (0), print mesg. */
|
|
|
|
#define VRFY(val, mesg) do { \
|
|
|
|
if (!val) { \
|
|
|
|
ERRMSG(mesg); \
|
|
|
|
GOTOERROR(FAIL); \
|
|
|
|
} \
|
2001-11-07 23:28:33 +08:00
|
|
|
} while(0)
|
|
|
|
|
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
/* POSIX I/O macros */
|
|
|
|
#define POSIXCREATE(fn) HDopen(fn, O_CREAT|O_TRUNC|O_RDWR, 0600)
|
|
|
|
#define POSIXOPEN(fn, F) HDopen(fn, F, 0600)
|
|
|
|
#define POSIXCLOSE(F) HDclose(F)
|
|
|
|
#define POSIXSEEK(F,L) HDlseek(F, L, SEEK_SET)
|
|
|
|
#define POSIXWRITE(F,B,S) HDwrite(F,B,S)
|
|
|
|
#define POSIXREAD(F,B,S) HDread(F,B,S)
|
2001-11-16 06:46:32 +08:00
|
|
|
|
|
|
|
enum {
|
|
|
|
PIO_CREATE = 1,
|
|
|
|
PIO_WRITE = 2,
|
|
|
|
PIO_READ = 4
|
|
|
|
};
|
|
|
|
|
2001-12-13 03:55:21 +08:00
|
|
|
/* Global variables */
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
static int clean_file_g = -1; /*whether to cleanup temporary test */
|
|
|
|
/*files. -1 is not defined; */
|
|
|
|
/*0 is no cleanup; 1 is do cleanup */
|
2001-12-13 03:55:21 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
2001-12-05 06:23:54 +08:00
|
|
|
/*
|
|
|
|
* In a parallel machine, the filesystem suitable for compiling is
|
|
|
|
* unlikely a parallel file system that is suitable for parallel I/O.
|
|
|
|
* There is no standard pathname for the parallel file system. /tmp
|
|
|
|
* is about the best guess.
|
|
|
|
*/
|
|
|
|
#ifndef HDF5_PARAPREFIX
|
|
|
|
# ifdef __PUMAGON__
|
|
|
|
/* For the PFS of TFLOPS */
|
2001-12-11 06:07:58 +08:00
|
|
|
# define HDF5_PARAPREFIX "pfs:/pfs_grande/multi/tmp_1"
|
2001-12-05 06:23:54 +08:00
|
|
|
# else
|
2001-12-11 06:07:58 +08:00
|
|
|
# define HDF5_PARAPREFIX "/tmp"
|
2001-12-05 06:23:54 +08:00
|
|
|
# endif /* __PUMAGON__ */
|
|
|
|
#endif /* !HDF5_PARAPREFIX */
|
2001-12-11 06:07:58 +08:00
|
|
|
|
|
|
|
#ifndef MIN
|
2001-12-11 00:24:58 +08:00
|
|
|
#define MIN(a,b) (a < b ? a : b)
|
2001-12-11 06:07:58 +08:00
|
|
|
#endif /* !MIN */
|
2001-12-05 06:23:54 +08:00
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
/* the different types of file descriptors we can expect */
|
|
|
|
typedef union _file_descr {
|
2002-05-23 07:22:46 +08:00
|
|
|
int posixfd; /* POSIX file handle*/
|
2001-11-16 06:46:32 +08:00
|
|
|
MPI_File mpifd; /* MPI file */
|
|
|
|
hid_t h5fd; /* HDF5 file */
|
|
|
|
} file_descr;
|
|
|
|
|
|
|
|
/* local functions */
|
2001-12-05 06:23:54 +08:00
|
|
|
static char *pio_create_filename(iotype iot, const char *base_name,
|
|
|
|
char *fullname, size_t size);
|
2002-05-23 07:22:46 +08:00
|
|
|
static herr_t do_write(results *res, file_descr *fd, parameters *parms,
|
|
|
|
long ndsets, off_t nelmts, size_t buf_size, void *buffer);
|
|
|
|
static herr_t do_read(results *res, file_descr *fd, parameters *parms,
|
|
|
|
long ndsets, off_t nelmts, size_t buf_size, void *buffer /*out*/);
|
|
|
|
static herr_t do_fopen(parameters *param, char *fname, file_descr *fd /*out*/,
|
2001-12-13 03:55:21 +08:00
|
|
|
int flags);
|
2001-12-12 05:45:29 +08:00
|
|
|
static herr_t do_fclose(iotype iot, file_descr *fd);
|
2001-12-14 04:14:32 +08:00
|
|
|
static void do_cleanupfile(iotype iot, char *fname);
|
2001-11-16 06:46:32 +08:00
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
/*
|
|
|
|
* Function: do_pio
|
|
|
|
* Purpose: PIO Engine where Parallel IO are executed.
|
|
|
|
* Return: results
|
|
|
|
* Programmer: Albert Cheng, Bill Wendling 2001/12/12
|
|
|
|
* Modifications:
|
|
|
|
*/
|
2001-12-11 06:07:58 +08:00
|
|
|
results
|
2002-05-07 07:58:57 +08:00
|
|
|
do_pio(parameters param)
|
2001-11-07 23:28:33 +08:00
|
|
|
{
|
2001-11-16 06:46:32 +08:00
|
|
|
/* return codes */
|
2001-12-12 05:45:29 +08:00
|
|
|
herr_t ret_code = 0; /*return code */
|
|
|
|
results res;
|
|
|
|
|
|
|
|
file_descr fd;
|
|
|
|
iotype iot;
|
|
|
|
|
|
|
|
char fname[FILENAME_MAX];
|
2001-12-18 07:02:20 +08:00
|
|
|
int maxprocs;
|
|
|
|
int nfiles, nf;
|
2002-05-14 03:55:33 +08:00
|
|
|
long ndsets;
|
2002-05-23 07:22:46 +08:00
|
|
|
off_t nelmts;
|
2001-12-12 05:45:29 +08:00
|
|
|
char *buffer = NULL; /*data buffer pointer */
|
2002-05-14 03:55:33 +08:00
|
|
|
size_t buf_size; /*data buffer size in bytes */
|
2001-11-16 06:46:32 +08:00
|
|
|
|
|
|
|
/* HDF5 variables */
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
herr_t hrc; /*HDF5 return code */
|
2001-11-16 06:46:32 +08:00
|
|
|
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
/* Sanity check parameters */
|
|
|
|
|
2002-05-16 21:51:48 +08:00
|
|
|
/* debug */
|
|
|
|
if (pio_debug_level>=4) {
|
2002-05-22 02:49:44 +08:00
|
|
|
h5_dump_info_object(pio_info_g);
|
2002-05-16 21:51:48 +08:00
|
|
|
}
|
|
|
|
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
/* IO type */
|
2001-11-07 23:28:33 +08:00
|
|
|
iot = param.io_type;
|
2001-11-16 06:46:32 +08:00
|
|
|
|
2001-11-07 23:28:33 +08:00
|
|
|
switch (iot) {
|
|
|
|
case MPIO:
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
fd.mpifd = MPI_FILE_NULL;
|
2001-12-11 06:07:58 +08:00
|
|
|
res.timers = pio_time_new(MPI_TIMER);
|
2001-12-05 06:23:54 +08:00
|
|
|
break;
|
2002-05-23 07:22:46 +08:00
|
|
|
case POSIXIO:
|
|
|
|
fd.posixfd = -1;
|
2002-05-08 01:33:56 +08:00
|
|
|
res.timers = pio_time_new(MPI_TIMER);
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
break;
|
2001-11-07 23:28:33 +08:00
|
|
|
case PHDF5:
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
fd.h5fd = -1;
|
2002-05-08 01:33:56 +08:00
|
|
|
res.timers = pio_time_new(MPI_TIMER);
|
2001-12-05 06:23:54 +08:00
|
|
|
break;
|
2001-11-07 23:28:33 +08:00
|
|
|
default:
|
2001-12-05 06:23:54 +08:00
|
|
|
/* unknown request */
|
|
|
|
fprintf(stderr, "Unknown IO type request (%d)\n", iot);
|
|
|
|
GOTOERROR(FAIL);
|
2001-11-07 23:28:33 +08:00
|
|
|
}
|
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
nfiles = param.num_files; /* number of files */
|
|
|
|
ndsets = param.num_dsets; /* number of datasets per file */
|
|
|
|
nelmts = param.num_elmts; /* number of elements per dataset */
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
maxprocs = param.num_procs; /* max number of mpi-processes to use */
|
2001-12-12 05:45:29 +08:00
|
|
|
buf_size = param.buf_size;
|
2001-11-07 23:28:33 +08:00
|
|
|
|
2001-12-18 07:02:20 +08:00
|
|
|
if (nfiles < 0 ) {
|
|
|
|
fprintf(stderr,
|
|
|
|
"number of files must be >= 0 (%d)\n",
|
|
|
|
nfiles);
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (ndsets < 0 ) {
|
|
|
|
fprintf(stderr,
|
|
|
|
"number of datasets per file must be >= 0 (%ld)\n",
|
|
|
|
ndsets);
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
2001-12-11 00:24:58 +08:00
|
|
|
if (maxprocs <= 0 ) {
|
2001-11-16 06:46:32 +08:00
|
|
|
fprintf(stderr,
|
2001-12-12 05:45:29 +08:00
|
|
|
"maximum number of process to use must be > 0 (%d)\n",
|
2001-11-16 06:46:32 +08:00
|
|
|
maxprocs);
|
|
|
|
GOTOERROR(FAIL);
|
2001-11-07 23:28:33 +08:00
|
|
|
}
|
2001-11-16 06:46:32 +08:00
|
|
|
|
2001-12-12 05:45:29 +08:00
|
|
|
|
2002-05-07 23:22:31 +08:00
|
|
|
#if akcdebug
|
|
|
|
/* debug*/
|
2001-12-12 05:45:29 +08:00
|
|
|
fprintf(stderr, "nfiles=%d\n", nfiles);
|
|
|
|
fprintf(stderr, "ndsets=%ld\n", ndsets);
|
|
|
|
fprintf(stderr, "nelmts=%ld\n", nelmts);
|
|
|
|
fprintf(stderr, "maxprocs=%d\n", maxprocs);
|
|
|
|
fprintf(stderr, "buffer size=%ld\n", buf_size);
|
2001-12-13 23:29:47 +08:00
|
|
|
fprintf(stderr, "total data size=%ld\n", ndsets*nelmts*sizeof(int));
|
2001-12-12 07:02:07 +08:00
|
|
|
nfiles=MIN(3, nfiles);
|
2001-12-13 23:29:47 +08:00
|
|
|
/*ndsets=MIN(5, ndsets);*/
|
2001-12-13 03:55:21 +08:00
|
|
|
/*nelmts=MIN(1000, nelmts);*/
|
|
|
|
buf_size=MIN(1024*1024, buf_size);
|
2001-12-12 07:02:07 +08:00
|
|
|
/* DEBUG END */
|
|
|
|
#endif
|
2001-12-12 05:45:29 +08:00
|
|
|
|
2001-11-07 23:28:33 +08:00
|
|
|
/* allocate data buffer */
|
2002-05-23 07:22:46 +08:00
|
|
|
if(buf_size>0) {
|
|
|
|
buffer = malloc(buf_size);
|
2001-11-16 06:46:32 +08:00
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
if (buffer == NULL){
|
|
|
|
fprintf(stderr, "malloc for data buffer size (%ld) failed\n",
|
|
|
|
buf_size);
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
2001-11-07 23:28:33 +08:00
|
|
|
}
|
|
|
|
|
2002-05-07 07:58:57 +08:00
|
|
|
if (pio_debug_level >= 4) {
|
|
|
|
int myrank;
|
|
|
|
|
|
|
|
MPI_Comm_rank(pio_comm_g, &myrank);
|
|
|
|
|
2002-05-03 05:19:19 +08:00
|
|
|
/* output all of the times for all iterations */
|
2002-05-04 05:09:52 +08:00
|
|
|
if (myrank == 0)
|
|
|
|
fprintf(output, "Timer details:\n");
|
2002-05-07 07:58:57 +08:00
|
|
|
}
|
2002-05-03 05:19:19 +08:00
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
for (nf = 1; nf <= nfiles; nf++) {
|
2001-12-12 05:45:29 +08:00
|
|
|
/*
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
* Write performance measurement
|
2001-12-12 05:45:29 +08:00
|
|
|
*/
|
2001-11-16 06:46:32 +08:00
|
|
|
/* Open file for write */
|
2001-12-05 06:23:54 +08:00
|
|
|
char base_name[256];
|
2001-11-16 06:46:32 +08:00
|
|
|
|
2002-01-12 03:44:51 +08:00
|
|
|
MPI_Barrier(pio_comm_g);
|
|
|
|
|
2001-12-05 06:23:54 +08:00
|
|
|
sprintf(base_name, "#pio_tmp_%u", nf);
|
|
|
|
pio_create_filename(iot, base_name, fname, sizeof(fname));
|
2001-12-13 23:29:47 +08:00
|
|
|
#if AKCDEBUG
|
2001-12-12 07:02:07 +08:00
|
|
|
fprintf(stderr, "filename=%s\n", fname);
|
2001-12-13 23:29:47 +08:00
|
|
|
#endif
|
2001-11-16 06:46:32 +08:00
|
|
|
|
2001-12-20 06:10:15 +08:00
|
|
|
set_time(res.timers, HDF5_GROSS_WRITE_FIXED_DIMS, START);
|
2002-05-23 07:22:46 +08:00
|
|
|
hrc = do_fopen(¶m, fname, &fd, PIO_CREATE | PIO_WRITE);
|
2001-12-11 06:07:58 +08:00
|
|
|
|
2001-12-12 05:45:29 +08:00
|
|
|
VRFY((hrc == SUCCESS), "do_fopen failed");
|
2001-12-11 06:07:58 +08:00
|
|
|
|
2001-12-20 06:10:15 +08:00
|
|
|
set_time(res.timers, HDF5_FINE_WRITE_FIXED_DIMS, START);
|
2002-05-23 07:22:46 +08:00
|
|
|
hrc = do_write(&res, &fd, ¶m, ndsets, nelmts, buf_size, buffer);
|
2001-12-20 06:10:15 +08:00
|
|
|
set_time(res.timers, HDF5_FINE_WRITE_FIXED_DIMS, STOP);
|
2001-12-11 06:07:58 +08:00
|
|
|
|
2001-12-12 05:45:29 +08:00
|
|
|
VRFY((hrc == SUCCESS), "do_write failed");
|
2001-11-07 23:28:33 +08:00
|
|
|
|
2001-12-11 06:07:58 +08:00
|
|
|
/* Close file for write */
|
2001-12-12 05:45:29 +08:00
|
|
|
hrc = do_fclose(iot, &fd);
|
2001-12-11 06:07:58 +08:00
|
|
|
|
2001-12-20 06:10:15 +08:00
|
|
|
set_time(res.timers, HDF5_GROSS_WRITE_FIXED_DIMS, STOP);
|
2001-12-12 05:45:29 +08:00
|
|
|
VRFY((hrc == SUCCESS), "do_fclose failed");
|
2001-11-16 06:46:32 +08:00
|
|
|
|
2002-01-12 03:44:51 +08:00
|
|
|
MPI_Barrier(pio_comm_g);
|
|
|
|
|
2001-12-12 05:45:29 +08:00
|
|
|
/*
|
|
|
|
* Read performance measurement
|
|
|
|
*/
|
2001-11-16 06:46:32 +08:00
|
|
|
/* Open file for read */
|
2001-12-20 06:10:15 +08:00
|
|
|
set_time(res.timers, HDF5_GROSS_READ_FIXED_DIMS, START);
|
2002-05-23 07:22:46 +08:00
|
|
|
hrc = do_fopen(¶m, fname, &fd, PIO_READ);
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
2001-12-12 05:45:29 +08:00
|
|
|
VRFY((hrc == SUCCESS), "do_fopen failed");
|
2001-11-07 23:28:33 +08:00
|
|
|
|
2001-12-20 06:10:15 +08:00
|
|
|
set_time(res.timers, HDF5_FINE_READ_FIXED_DIMS, START);
|
2002-05-23 07:22:46 +08:00
|
|
|
hrc = do_read(&res, &fd, ¶m, ndsets, nelmts, buf_size, buffer);
|
2001-12-20 06:10:15 +08:00
|
|
|
set_time(res.timers, HDF5_FINE_READ_FIXED_DIMS, STOP);
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
VRFY((hrc == SUCCESS), "do_read failed");
|
2001-11-07 23:28:33 +08:00
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
/* Close file for read */
|
2001-12-12 05:45:29 +08:00
|
|
|
hrc = do_fclose(iot, &fd);
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
2001-12-20 06:10:15 +08:00
|
|
|
set_time(res.timers, HDF5_GROSS_READ_FIXED_DIMS, STOP);
|
2001-12-12 05:45:29 +08:00
|
|
|
VRFY((hrc == SUCCESS), "do_fclose failed");
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
2002-01-12 03:44:51 +08:00
|
|
|
MPI_Barrier(pio_comm_g);
|
|
|
|
|
2001-12-14 04:14:32 +08:00
|
|
|
do_cleanupfile(iot, fname);
|
2001-11-07 23:28:33 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
done:
|
|
|
|
/* clean up */
|
|
|
|
/* release HDF5 objects */
|
2001-11-16 06:46:32 +08:00
|
|
|
|
2001-12-12 05:45:29 +08:00
|
|
|
/* close any opened files */
|
|
|
|
/* no remove(fname) because that should have happened normally. */
|
|
|
|
switch (iot) {
|
2002-05-23 07:22:46 +08:00
|
|
|
case POSIXIO:
|
|
|
|
if (fd.posixfd != -1)
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
hrc = do_fclose(iot, &fd);
|
2001-12-12 05:45:29 +08:00
|
|
|
break;
|
|
|
|
case MPIO:
|
|
|
|
if (fd.mpifd != MPI_FILE_NULL)
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
hrc = do_fclose(iot, &fd);
|
2001-12-12 05:45:29 +08:00
|
|
|
break;
|
|
|
|
case PHDF5:
|
|
|
|
if (fd.h5fd != -1)
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
hrc = do_fclose(iot, &fd);
|
2001-12-12 05:45:29 +08:00
|
|
|
break;
|
2001-11-07 23:28:33 +08:00
|
|
|
}
|
2001-11-16 06:46:32 +08:00
|
|
|
|
2001-11-07 23:28:33 +08:00
|
|
|
/* release generic resources */
|
2002-05-23 07:22:46 +08:00
|
|
|
if(buffer)
|
|
|
|
free(buffer);
|
2001-12-11 06:07:58 +08:00
|
|
|
res.ret_code = ret_code;
|
|
|
|
return res;
|
2001-11-07 23:28:33 +08:00
|
|
|
}
|
|
|
|
|
2001-12-05 06:23:54 +08:00
|
|
|
/*
|
|
|
|
* Function: pio_create_filename
|
|
|
|
* Purpose: Create a new filename to write to. Determine the correct
|
|
|
|
* suffix to append to the filename by the type of I/O we're
|
|
|
|
* doing. Also, place in the /tmp/{$USER,$LOGIN} directory if
|
|
|
|
* USER or LOGIN are specified in the environment.
|
|
|
|
* Return: Pointer to filename or NULL
|
|
|
|
* Programmer: Bill Wendling, 21. November 2001
|
|
|
|
* Modifications:
|
|
|
|
*/
|
|
|
|
static char *
|
|
|
|
pio_create_filename(iotype iot, const char *base_name, char *fullname, size_t size)
|
|
|
|
{
|
|
|
|
const char *prefix, *suffix;
|
|
|
|
char *ptr, last = '\0';
|
|
|
|
size_t i, j;
|
|
|
|
|
|
|
|
if (!base_name || !fullname || size < 1)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
memset(fullname, 0, size);
|
|
|
|
|
|
|
|
switch (iot) {
|
2002-05-23 07:22:46 +08:00
|
|
|
case POSIXIO:
|
|
|
|
suffix = ".posix";
|
2001-12-05 06:23:54 +08:00
|
|
|
break;
|
|
|
|
case MPIO:
|
|
|
|
suffix = ".mpio";
|
|
|
|
break;
|
|
|
|
case PHDF5:
|
|
|
|
suffix = ".h5";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* First use the environment variable and then try the constant */
|
|
|
|
prefix = getenv("HDF5_PARAPREFIX");
|
|
|
|
|
|
|
|
#ifdef HDF5_PARAPREFIX
|
|
|
|
if (!prefix)
|
|
|
|
prefix = HDF5_PARAPREFIX;
|
|
|
|
#endif /* HDF5_PARAPREFIX */
|
|
|
|
|
|
|
|
/* Prepend the prefix value to the base name */
|
|
|
|
if (prefix && *prefix) {
|
|
|
|
/* If the prefix specifies the HDF5_PARAPREFIX directory, then
|
|
|
|
* default to using the "/tmp/$USER" or "/tmp/$LOGIN"
|
|
|
|
* directory instead. */
|
|
|
|
register char *user, *login, *subdir;
|
|
|
|
|
|
|
|
user = getenv("USER");
|
|
|
|
login = getenv("LOGIN");
|
|
|
|
subdir = (user ? user : login);
|
|
|
|
|
|
|
|
if (subdir) {
|
|
|
|
for (i = 0; i < size && prefix[i]; i++)
|
|
|
|
fullname[i] = prefix[i];
|
|
|
|
|
|
|
|
fullname[i++] = '/';
|
|
|
|
|
|
|
|
for (j = 0; i < size && subdir[j]; i++, j++)
|
|
|
|
fullname[i] = subdir[j];
|
|
|
|
} else {
|
|
|
|
/* We didn't append the prefix yet */
|
|
|
|
strncpy(fullname, prefix, MIN(strlen(prefix), size));
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((strlen(fullname) + strlen(base_name) + 1) < size) {
|
|
|
|
/* Append the base_name with a slash first. Multiple slashes are
|
|
|
|
* handled below. */
|
2002-04-19 15:20:41 +08:00
|
|
|
h5_stat_t buf;
|
2001-12-05 06:23:54 +08:00
|
|
|
|
2002-04-20 05:54:35 +08:00
|
|
|
if (HDstat(fullname, &buf) < 0)
|
2001-12-05 06:23:54 +08:00
|
|
|
/* The directory doesn't exist just yet */
|
|
|
|
if (mkdir(fullname, (mode_t)0755) < 0 && errno != EEXIST) {
|
|
|
|
/* We couldn't make the "/tmp/${USER,LOGIN}" subdirectory.
|
|
|
|
* Default to PREFIX's original prefix value. */
|
|
|
|
strcpy(fullname, prefix);
|
|
|
|
}
|
|
|
|
|
|
|
|
strcat(fullname, "/");
|
|
|
|
strcat(fullname, base_name);
|
|
|
|
} else {
|
|
|
|
/* Buffer is too small */
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
} else if (strlen(base_name) >= size) {
|
|
|
|
/* Buffer is too small */
|
|
|
|
return NULL;
|
|
|
|
} else {
|
|
|
|
strcpy(fullname, base_name);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Append a suffix */
|
|
|
|
if (suffix) {
|
|
|
|
if (strlen(fullname) + strlen(suffix) >= size)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
strcat(fullname, suffix);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Remove any double slashes in the filename */
|
|
|
|
for (ptr = fullname, i = j = 0; ptr && i < size; i++, ptr++) {
|
|
|
|
if (*ptr != '/' || last != '/')
|
|
|
|
fullname[j++] = *ptr;
|
|
|
|
|
|
|
|
last = *ptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
return fullname;
|
|
|
|
}
|
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
/*
|
|
|
|
* Function: do_write
|
2001-12-05 06:23:54 +08:00
|
|
|
* Purpose: Write the required amount of data to the file.
|
2001-11-16 06:46:32 +08:00
|
|
|
* Return: SUCCESS or FAIL
|
2001-12-13 23:29:47 +08:00
|
|
|
* Programmer: Albert Cheng, Bill Wendling, 2001/12/13
|
2001-11-16 06:46:32 +08:00
|
|
|
* Modifications:
|
|
|
|
*/
|
|
|
|
static herr_t
|
2002-05-23 07:22:46 +08:00
|
|
|
do_write(results *res, file_descr *fd, parameters *parms, long ndsets,
|
|
|
|
off_t nelmts, size_t buf_size, void *buffer)
|
2001-11-07 23:28:33 +08:00
|
|
|
{
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
int ret_code = SUCCESS;
|
2002-05-23 07:22:46 +08:00
|
|
|
long rc; /*routine return code */
|
2001-12-12 07:02:07 +08:00
|
|
|
int mrc; /*MPI return code */
|
|
|
|
MPI_Offset mpi_offset;
|
|
|
|
MPI_Status mpi_status;
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
long ndset;
|
2002-05-23 07:22:46 +08:00
|
|
|
off_t nelmts_written;
|
|
|
|
size_t nelmts_towrite;
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
char dname[64];
|
|
|
|
off_t dset_offset; /*dataset offset in a file */
|
|
|
|
off_t file_offset; /*file offset of the next transfer */
|
2002-05-14 03:55:33 +08:00
|
|
|
off_t dset_size; /*one dataset size in bytes */
|
2002-05-23 07:22:46 +08:00
|
|
|
size_t nelmts_in_buf;
|
|
|
|
off_t elmts_begin; /*first elmt this process transfer */
|
|
|
|
off_t elmts_count; /*number of elmts this process transfer */
|
|
|
|
hid_t dcpl = -1; /* Dataset creation property list */
|
2001-12-12 05:45:29 +08:00
|
|
|
|
|
|
|
/* HDF5 variables */
|
|
|
|
herr_t hrc; /*HDF5 return code */
|
|
|
|
hsize_t h5dims[1]; /*dataset dim sizes */
|
|
|
|
hid_t h5dset_space_id = -1; /*dataset space ID */
|
|
|
|
hid_t h5mem_space_id = -1; /*memory dataspace ID */
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
hid_t h5ds_id = -1; /*dataset handle */
|
2001-12-12 05:45:29 +08:00
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
#if AKCDEBUG
|
|
|
|
fprintf(stderr, "In do_write\n");
|
|
|
|
fprintf(stderr, "ndsets=%ld\n", ndsets);
|
|
|
|
fprintf(stderr, "nelmts=%ld\n", nelmts);
|
|
|
|
fprintf(stderr, "buffer size=%ld\n", buf_size);
|
|
|
|
#endif
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
/* calculate dataset parameters. data type is always native C int */
|
|
|
|
dset_size = nelmts * ELMT_SIZE;
|
2001-12-12 05:45:29 +08:00
|
|
|
nelmts_in_buf = buf_size/ELMT_SIZE;
|
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
/* hdf5 data space setup */
|
2002-05-23 07:22:46 +08:00
|
|
|
if (parms->io_type == PHDF5){
|
|
|
|
if(nelmts>0) {
|
|
|
|
/* define a contiquous dataset of nelmts native ints */
|
|
|
|
h5dims[0] = nelmts;
|
|
|
|
h5dset_space_id = H5Screate_simple(1, h5dims, NULL);
|
|
|
|
VRFY((h5dset_space_id >= 0), "H5Screate_simple");
|
|
|
|
} /* end if */
|
|
|
|
else {
|
|
|
|
h5dset_space_id = H5Screate(H5S_SCALAR);
|
|
|
|
VRFY((h5dset_space_id >= 0), "H5Screate");
|
|
|
|
} /* end else */
|
2001-12-12 05:45:29 +08:00
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
/* create the memory dataspace that corresponds to the xfer buffer */
|
2002-05-23 07:22:46 +08:00
|
|
|
if(nelmts_in_buf>0) {
|
|
|
|
h5dims[0] = nelmts_in_buf;
|
|
|
|
h5mem_space_id = H5Screate_simple(1, h5dims, NULL);
|
|
|
|
VRFY((h5mem_space_id >= 0), "H5Screate_simple");
|
|
|
|
} /* end if */
|
|
|
|
else {
|
|
|
|
h5mem_space_id = H5Screate(H5S_SCALAR);
|
|
|
|
VRFY((h5mem_space_id >= 0), "H5Screate");
|
|
|
|
} /* end else */
|
2001-12-12 05:45:29 +08:00
|
|
|
}
|
2001-11-16 06:46:32 +08:00
|
|
|
|
|
|
|
for (ndset = 1; ndset <= ndsets; ++ndset) {
|
|
|
|
|
|
|
|
/* Calculate dataset offset within a file */
|
|
|
|
|
|
|
|
/* create dataset */
|
2002-05-23 07:22:46 +08:00
|
|
|
switch (parms->io_type) {
|
|
|
|
case POSIXIO:
|
2001-11-16 06:46:32 +08:00
|
|
|
case MPIO:
|
2002-05-23 07:22:46 +08:00
|
|
|
/* both posix and mpi io just need dataset offset in file*/
|
2001-11-16 06:46:32 +08:00
|
|
|
dset_offset = (ndset - 1) * dset_size;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case PHDF5:
|
2002-05-23 07:22:46 +08:00
|
|
|
dcpl = H5Pcreate(H5P_DATASET_CREATE);
|
|
|
|
if (dcpl < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Property List Create failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Make the dataset chunked if asked */
|
|
|
|
if(parms->h5_use_chunks) {
|
|
|
|
/* Set the chunk size to be the same as the buffer size */
|
|
|
|
h5dims[0] = nelmts_in_buf;
|
|
|
|
hrc = H5Pset_chunk(dcpl, 1, h5dims);
|
|
|
|
if (hrc < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Property List Set failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
} /* end if */
|
|
|
|
} /* end if */
|
|
|
|
|
|
|
|
#if H5_VERS_MAJOR > 1 || H5_VERS_MINOR > 4
|
|
|
|
/* Disable writing fill values if asked */
|
|
|
|
if(parms->h5_no_fill) {
|
|
|
|
hrc = H5Pset_fill_time(dcpl, H5D_FILL_TIME_NEVER);
|
|
|
|
if (hrc < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Property List Set failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
} /* end if */
|
|
|
|
} /* end if */
|
|
|
|
#endif
|
|
|
|
|
2001-12-12 07:02:07 +08:00
|
|
|
sprintf(dname, "Dataset_%ld", ndset);
|
2001-12-12 05:45:29 +08:00
|
|
|
h5ds_id = H5Dcreate(fd->h5fd, dname, H5T_NATIVE_INT,
|
2002-05-23 07:22:46 +08:00
|
|
|
h5dset_space_id, dcpl);
|
2001-12-05 06:23:54 +08:00
|
|
|
|
|
|
|
if (h5ds_id < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Dataset Create failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
hrc = H5Pclose(dcpl);
|
|
|
|
/* verifying the close of the dcpl */
|
|
|
|
if (hrc < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Property List Close failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
/* Calculate the first element and how many elements this process
|
|
|
|
* transfer. First calculate the beginning element of this process
|
|
|
|
* and the next process. Count of elements is the difference between
|
|
|
|
* these two beginnings. This way, it avoids any rounding errors.
|
|
|
|
*/
|
2002-05-23 07:22:46 +08:00
|
|
|
elmts_begin = (long)(((double)nelmts)/pio_mpi_nprocs_g*pio_mpi_rank_g);
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
|
|
|
if (pio_mpi_rank_g < (pio_mpi_nprocs_g - 1))
|
2002-05-23 07:22:46 +08:00
|
|
|
elmts_count = (long)((((double)nelmts) / pio_mpi_nprocs_g * (pio_mpi_rank_g + 1))
|
|
|
|
- (double)elmts_begin);
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
else
|
|
|
|
/* last process. Take whatever are left */
|
|
|
|
elmts_count = nelmts - elmts_begin;
|
2001-12-13 23:29:47 +08:00
|
|
|
|
|
|
|
#if AKCDEBUG
|
2001-12-13 03:55:21 +08:00
|
|
|
fprintf(stderr, "proc %d: elmts_begin=%ld, elmts_count=%ld\n",
|
|
|
|
pio_mpi_rank_g, elmts_begin, elmts_count);
|
2001-12-13 23:29:47 +08:00
|
|
|
#endif
|
2001-12-13 03:55:21 +08:00
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
nelmts_written = 0 ;
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
/* Start "raw data" write timer */
|
|
|
|
set_time(res->timers, HDF5_RAW_WRITE_FIXED_DIMS, START);
|
|
|
|
|
2001-12-13 03:55:21 +08:00
|
|
|
while (nelmts_written < elmts_count){
|
|
|
|
nelmts_towrite = elmts_count - nelmts_written;
|
2001-11-16 06:46:32 +08:00
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
if ((elmts_count - nelmts_written) >= nelmts_in_buf) {
|
2001-12-12 05:45:29 +08:00
|
|
|
nelmts_towrite = nelmts_in_buf;
|
2001-11-16 06:46:32 +08:00
|
|
|
} else {
|
|
|
|
/* last write of a partial buffer */
|
2001-12-13 03:55:21 +08:00
|
|
|
nelmts_towrite = elmts_count - nelmts_written;
|
2001-11-16 06:46:32 +08:00
|
|
|
}
|
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
#if AKCDEBUG
|
2001-11-16 06:46:32 +08:00
|
|
|
/*Prepare write data*/
|
|
|
|
{
|
2001-12-05 06:23:54 +08:00
|
|
|
int *intptr = (int *)buffer;
|
2001-11-16 06:46:32 +08:00
|
|
|
register int i;
|
|
|
|
|
|
|
|
for (i = 0; i < nelmts_towrite; ++i)
|
|
|
|
*intptr++ = nelmts_towrite + i;
|
|
|
|
}
|
2001-12-13 23:29:47 +08:00
|
|
|
#endif
|
2001-11-16 06:46:32 +08:00
|
|
|
|
|
|
|
/* Write */
|
|
|
|
/* Calculate offset of write within a dataset/file */
|
2002-05-23 07:22:46 +08:00
|
|
|
switch (parms->io_type) {
|
|
|
|
case POSIXIO:
|
2002-05-14 03:55:33 +08:00
|
|
|
/* need to (off_t) the elmnts_begin expression because they */
|
|
|
|
/* may be of smaller sized integer types */
|
|
|
|
file_offset = dset_offset + (off_t)(elmts_begin + nelmts_written)*ELMT_SIZE;
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
#if AKCDEBUG
|
|
|
|
fprintf(stderr, "proc %d: writes %ld bytes at file-offset %ld\n",
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
pio_mpi_rank_g, nelmts_towrite*ELMT_SIZE, file_offset);
|
2001-12-13 23:29:47 +08:00
|
|
|
#endif
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
rc = POSIXSEEK(fd->posixfd, file_offset);
|
|
|
|
VRFY((rc>=0), "POSIXSEEK");
|
|
|
|
rc = POSIXWRITE(fd->posixfd, buffer, (size_t)(nelmts_towrite * ELMT_SIZE));
|
|
|
|
VRFY((rc == (nelmts_towrite*ELMT_SIZE)), "POSIXWRITE");
|
2001-11-16 06:46:32 +08:00
|
|
|
break;
|
|
|
|
|
|
|
|
case MPIO:
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
mpi_offset = dset_offset + (elmts_begin + nelmts_written)*ELMT_SIZE;
|
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
#if AKCDEBUG
|
|
|
|
fprintf(stderr, "proc %d: writes %ld bytes at mpi-offset %ld\n",
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
pio_mpi_rank_g, nelmts_towrite*ELMT_SIZE, mpi_offset);
|
2001-12-13 23:29:47 +08:00
|
|
|
#endif
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
|
|
|
mrc = MPI_File_write_at(fd->mpifd, mpi_offset, buffer,
|
2002-05-23 07:22:46 +08:00
|
|
|
(int)(nelmts_towrite*ELMT_SIZE), MPI_CHAR,
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
&mpi_status);
|
|
|
|
VRFY((mrc==MPI_SUCCESS), "MPIO_WRITE");
|
|
|
|
break;
|
2001-11-16 06:46:32 +08:00
|
|
|
case PHDF5:
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
/*set up the dset space id to select the segment to process */
|
|
|
|
{
|
|
|
|
hsize_t block[1], stride[1], count[1];
|
|
|
|
hssize_t start[1];
|
|
|
|
|
|
|
|
start[0] = elmts_begin + nelmts_written;
|
|
|
|
stride[0] = block[0] = nelmts_towrite;
|
|
|
|
count[0] = 1;
|
|
|
|
hrc = H5Sselect_hyperslab(h5dset_space_id, H5S_SELECT_SET,
|
|
|
|
start, stride, count, block);
|
|
|
|
VRFY((hrc >= 0), "H5Sset_hyperslab");
|
|
|
|
|
|
|
|
/*setup the memory space id too. Only start is different */
|
|
|
|
start[0] = 0;
|
|
|
|
hrc = H5Sselect_hyperslab(h5mem_space_id, H5S_SELECT_SET,
|
|
|
|
start, stride, count, block);
|
|
|
|
VRFY((hrc >= 0), "H5Sset_hyperslab");
|
|
|
|
}
|
|
|
|
|
|
|
|
/* set write time here */
|
|
|
|
hrc = H5Dwrite(h5ds_id, H5T_NATIVE_INT, h5mem_space_id,
|
|
|
|
h5dset_space_id, H5P_DEFAULT, buffer);
|
|
|
|
VRFY((hrc >= 0), "H5Dwrite");
|
2001-11-16 06:46:32 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
nelmts_written += nelmts_towrite;
|
|
|
|
}
|
2001-11-07 23:28:33 +08:00
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
/* Stop "raw data" write timer */
|
|
|
|
set_time(res->timers, HDF5_RAW_WRITE_FIXED_DIMS, STOP);
|
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
/* Calculate write time */
|
2001-11-07 23:28:33 +08:00
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
/* Close dataset. Only HDF5 needs to do an explicit close. */
|
2002-05-23 07:22:46 +08:00
|
|
|
if (parms->io_type == PHDF5){
|
2001-12-12 05:45:29 +08:00
|
|
|
hrc = H5Dclose(h5ds_id);
|
2001-11-07 23:28:33 +08:00
|
|
|
|
2001-12-05 06:23:54 +08:00
|
|
|
if (hrc < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Dataset Close failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
h5ds_id = -1;
|
|
|
|
}
|
|
|
|
}
|
2001-11-07 23:28:33 +08:00
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
done:
|
2001-12-12 05:45:29 +08:00
|
|
|
/* release HDF5 objects */
|
|
|
|
if (h5dset_space_id != -1) {
|
|
|
|
hrc = H5Sclose(h5dset_space_id);
|
|
|
|
if (hrc < 0){
|
|
|
|
fprintf(stderr, "HDF5 Dataset Space Close failed\n");
|
|
|
|
ret_code = FAIL;
|
|
|
|
} else {
|
|
|
|
h5dset_space_id = -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (h5mem_space_id != -1) {
|
|
|
|
hrc = H5Sclose(h5mem_space_id);
|
|
|
|
if (hrc < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Memory Space Close failed\n");
|
|
|
|
ret_code = FAIL;
|
|
|
|
} else {
|
|
|
|
h5mem_space_id = -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
return ret_code;
|
2001-11-07 23:28:33 +08:00
|
|
|
}
|
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
/*
|
|
|
|
* Function: do_read
|
|
|
|
* Purpose: read the required amount of data from the file.
|
|
|
|
* Return: SUCCESS or FAIL
|
|
|
|
* Programmer: Albert Cheng 2001/12/13
|
|
|
|
* Modifications:
|
|
|
|
*/
|
|
|
|
static herr_t
|
2002-05-23 07:22:46 +08:00
|
|
|
do_read(results *res, file_descr *fd, parameters *parms, long ndsets,
|
|
|
|
off_t nelmts, size_t buf_size, void *buffer /*out*/)
|
2001-12-13 23:29:47 +08:00
|
|
|
{
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
int ret_code = SUCCESS;
|
2002-05-23 07:22:46 +08:00
|
|
|
long rc; /*routine return code */
|
2001-12-13 23:29:47 +08:00
|
|
|
int mrc; /*MPI return code */
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
MPI_Offset mpi_offset;
|
|
|
|
MPI_Status mpi_status;
|
|
|
|
long ndset;
|
2002-05-23 07:22:46 +08:00
|
|
|
size_t nelmts_toread;
|
|
|
|
off_t nelmts_read;
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
char dname[64];
|
|
|
|
off_t dset_offset; /*dataset offset in a file */
|
|
|
|
off_t file_offset; /*file offset of the next transfer */
|
2002-05-14 03:55:33 +08:00
|
|
|
off_t dset_size; /*one dataset size in bytes */
|
2002-05-23 07:22:46 +08:00
|
|
|
size_t nelmts_in_buf;
|
|
|
|
off_t elmts_begin; /*first elmt this process transfer */
|
|
|
|
off_t elmts_count; /*number of elmts this process transfer */
|
2001-12-13 23:29:47 +08:00
|
|
|
|
|
|
|
/* HDF5 variables */
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
herr_t hrc; /*HDF5 return code */
|
|
|
|
hsize_t h5dims[1]; /*dataset dim sizes */
|
|
|
|
hid_t h5dset_space_id = -1; /*dataset space ID */
|
|
|
|
hid_t h5mem_space_id = -1; /*memory dataspace ID */
|
|
|
|
hid_t h5ds_id = -1; /*dataset handle */
|
2001-12-13 23:29:47 +08:00
|
|
|
|
|
|
|
#if AKCDEBUG
|
|
|
|
fprintf(stderr, "In do_read\n");
|
|
|
|
fprintf(stderr, "ndsets=%ld\n", ndsets);
|
|
|
|
fprintf(stderr, "nelmts=%ld\n", nelmts);
|
|
|
|
fprintf(stderr, "buffer size=%ld\n", buf_size);
|
|
|
|
#endif
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
/* calculate dataset parameters. data type is always native C int */
|
|
|
|
dset_size = nelmts * ELMT_SIZE;
|
|
|
|
nelmts_in_buf = buf_size/ELMT_SIZE;
|
|
|
|
|
|
|
|
/* hdf5 data space setup */
|
2002-05-23 07:22:46 +08:00
|
|
|
if (parms->io_type == PHDF5){
|
|
|
|
if(nelmts>0) {
|
|
|
|
/* define a contiquous dataset of nelmts native ints */
|
|
|
|
h5dims[0] = nelmts;
|
|
|
|
h5dset_space_id = H5Screate_simple(1, h5dims, NULL);
|
|
|
|
VRFY((h5dset_space_id >= 0), "H5Screate_simple");
|
|
|
|
} /* end if */
|
|
|
|
else {
|
|
|
|
h5dset_space_id = H5Screate(H5S_SCALAR);
|
|
|
|
VRFY((h5dset_space_id >= 0), "H5Screate");
|
|
|
|
} /* end else */
|
2001-12-13 23:29:47 +08:00
|
|
|
|
|
|
|
/* create the memory dataspace that corresponds to the xfer buffer */
|
2002-05-23 07:22:46 +08:00
|
|
|
if(nelmts_in_buf>0) {
|
|
|
|
h5dims[0] = nelmts_in_buf;
|
|
|
|
h5mem_space_id = H5Screate_simple(1, h5dims, NULL);
|
|
|
|
VRFY((h5mem_space_id >= 0), "H5Screate_simple");
|
|
|
|
} /* end if */
|
|
|
|
else {
|
|
|
|
h5mem_space_id = H5Screate(H5S_SCALAR);
|
|
|
|
VRFY((h5mem_space_id >= 0), "H5Screate");
|
|
|
|
} /* end else */
|
2001-12-13 23:29:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
for (ndset = 1; ndset <= ndsets; ++ndset) {
|
|
|
|
/* Calculate dataset offset within a file */
|
|
|
|
|
|
|
|
/* create dataset */
|
2002-05-23 07:22:46 +08:00
|
|
|
switch (parms->io_type) {
|
|
|
|
case POSIXIO:
|
2001-12-13 23:29:47 +08:00
|
|
|
case MPIO:
|
2002-05-23 07:22:46 +08:00
|
|
|
/* both posix and mpi io just need dataset offset in file*/
|
2001-12-13 23:29:47 +08:00
|
|
|
dset_offset = (ndset - 1) * dset_size;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case PHDF5:
|
|
|
|
sprintf(dname, "Dataset_%ld", ndset);
|
|
|
|
h5ds_id = H5Dopen(fd->h5fd, dname);
|
|
|
|
if (h5ds_id < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Dataset open failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
/*
|
|
|
|
* Calculate the first element and how many elements this process
|
|
|
|
* transfer. First calculate the beginning element of this process
|
|
|
|
* and the next process. Count of elements is the difference between
|
|
|
|
* these two beginnings. This way, it avoids any rounding errors.
|
|
|
|
*/
|
2002-05-23 07:22:46 +08:00
|
|
|
elmts_begin = (long)(((double)nelmts)/pio_mpi_nprocs_g*pio_mpi_rank_g);
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
|
|
|
if (pio_mpi_rank_g < (pio_mpi_nprocs_g - 1))
|
2002-05-23 07:22:46 +08:00
|
|
|
elmts_count = (long)((((double)nelmts) / pio_mpi_nprocs_g * (pio_mpi_rank_g + 1)) -
|
|
|
|
(double)elmts_begin);
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
else
|
|
|
|
/* last process. Take whatever are left */
|
|
|
|
elmts_count = nelmts - elmts_begin;
|
2001-12-13 23:29:47 +08:00
|
|
|
|
|
|
|
#if AKCDEBUG
|
|
|
|
fprintf(stderr, "proc %d: elmts_begin=%ld, elmts_count=%ld\n",
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
pio_mpi_rank_g, elmts_begin, elmts_count);
|
2001-12-13 23:29:47 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
nelmts_read = 0 ;
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
/* Start "raw data" read timer */
|
|
|
|
set_time(res->timers, HDF5_RAW_READ_FIXED_DIMS, START);
|
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
while (nelmts_read < elmts_count){
|
|
|
|
nelmts_toread = elmts_count - nelmts_read;
|
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
if ((elmts_count - nelmts_read) >= nelmts_in_buf)
|
2001-12-13 23:29:47 +08:00
|
|
|
nelmts_toread = nelmts_in_buf;
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
else
|
2001-12-13 23:29:47 +08:00
|
|
|
/* last read of a partial buffer */
|
|
|
|
nelmts_toread = elmts_count - nelmts_read;
|
|
|
|
|
|
|
|
/* read */
|
|
|
|
/* Calculate offset of read within a dataset/file */
|
2002-05-23 07:22:46 +08:00
|
|
|
switch (parms->io_type){
|
|
|
|
case POSIXIO:
|
2002-05-14 03:55:33 +08:00
|
|
|
/* need to (off_t) the elmnts_begin expression because they */
|
|
|
|
/* may be of smaller sized integer types */
|
|
|
|
file_offset = dset_offset + (off_t)(elmts_begin + nelmts_read)*ELMT_SIZE;
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
#if AKCDEBUG
|
|
|
|
fprintf(stderr, "proc %d: read %ld bytes at file-offset %ld\n",
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
pio_mpi_rank_g, nelmts_toread*ELMT_SIZE, file_offset);
|
2001-12-13 23:29:47 +08:00
|
|
|
#endif
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
rc = POSIXSEEK(fd->posixfd, file_offset);
|
|
|
|
VRFY((rc>=0), "POSIXSEEK");
|
|
|
|
rc = POSIXREAD(fd->posixfd, buffer, (size_t)(nelmts_toread*ELMT_SIZE));
|
|
|
|
VRFY((rc==(nelmts_toread*ELMT_SIZE)), "POSIXREAD");
|
2001-12-13 23:29:47 +08:00
|
|
|
break;
|
|
|
|
|
|
|
|
case MPIO:
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
mpi_offset = dset_offset + (elmts_begin + nelmts_read)*ELMT_SIZE;
|
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
#if AKCDEBUG
|
|
|
|
fprintf(stderr, "proc %d: read %ld bytes at mpi-offset %ld\n",
|
2001-12-20 06:10:15 +08:00
|
|
|
pio_mpi_rank_g, nelmts_toread*ELMT_SIZE, mpi_offset);
|
2001-12-13 23:29:47 +08:00
|
|
|
#endif
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
|
|
|
mrc = MPI_File_read_at(fd->mpifd, mpi_offset, buffer,
|
2002-05-23 07:22:46 +08:00
|
|
|
(int)(nelmts_toread*ELMT_SIZE), MPI_CHAR,
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
&mpi_status);
|
|
|
|
VRFY((mrc==MPI_SUCCESS), "MPIO_read");
|
|
|
|
break;
|
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
case PHDF5:
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
/*set up the dset space id to select the segment to process */
|
|
|
|
{
|
|
|
|
hsize_t block[1], stride[1], count[1];
|
|
|
|
hssize_t start[1];
|
|
|
|
|
|
|
|
start[0] = elmts_begin + nelmts_read;
|
|
|
|
stride[0] = block[0] = nelmts_toread;
|
|
|
|
count[0] = 1;
|
|
|
|
hrc = H5Sselect_hyperslab(h5dset_space_id, H5S_SELECT_SET,
|
|
|
|
start, stride, count, block);
|
|
|
|
VRFY((hrc >= 0), "H5Sset_hyperslab");
|
|
|
|
|
|
|
|
/*setup the memory space id too. Only start is different */
|
|
|
|
start[0] = 0;
|
|
|
|
hrc = H5Sselect_hyperslab(h5mem_space_id, H5S_SELECT_SET,
|
|
|
|
start, stride, count, block);
|
|
|
|
VRFY((hrc >= 0), "H5Sset_hyperslab");
|
|
|
|
}
|
|
|
|
|
|
|
|
/* set read time here */
|
|
|
|
hrc = H5Dread(h5ds_id, H5T_NATIVE_INT, h5mem_space_id,
|
|
|
|
h5dset_space_id, H5P_DEFAULT, buffer);
|
|
|
|
VRFY((hrc >= 0), "H5Dread");
|
2001-12-13 23:29:47 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
#if AKCDEBUG & 0
|
|
|
|
/*verify read data*/
|
|
|
|
{
|
|
|
|
int *intptr = (int *)buffer;
|
|
|
|
register int i;
|
|
|
|
|
|
|
|
for (i = 0; i < nelmts_towrite; ++i)
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
/* TO BE IMPLEMENTED */
|
2001-12-13 23:29:47 +08:00
|
|
|
;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
nelmts_read += nelmts_toread;
|
|
|
|
}
|
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
/* Stop "raw data" read timer */
|
|
|
|
set_time(res->timers, HDF5_RAW_READ_FIXED_DIMS, STOP);
|
|
|
|
|
2001-12-13 23:29:47 +08:00
|
|
|
/* Calculate read time */
|
|
|
|
|
|
|
|
/* Close dataset. Only HDF5 needs to do an explicit close. */
|
2002-05-23 07:22:46 +08:00
|
|
|
if (parms->io_type == PHDF5){
|
2001-12-13 23:29:47 +08:00
|
|
|
hrc = H5Dclose(h5ds_id);
|
|
|
|
|
|
|
|
if (hrc < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Dataset Close failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
|
|
|
h5ds_id = -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
done:
|
|
|
|
/* release HDF5 objects */
|
|
|
|
if (h5dset_space_id != -1) {
|
|
|
|
hrc = H5Sclose(h5dset_space_id);
|
|
|
|
if (hrc < 0){
|
|
|
|
fprintf(stderr, "HDF5 Dataset Space Close failed\n");
|
|
|
|
ret_code = FAIL;
|
|
|
|
} else {
|
|
|
|
h5dset_space_id = -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (h5mem_space_id != -1) {
|
|
|
|
hrc = H5Sclose(h5mem_space_id);
|
|
|
|
if (hrc < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Memory Space Close failed\n");
|
|
|
|
ret_code = FAIL;
|
|
|
|
} else {
|
|
|
|
h5mem_space_id = -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return ret_code;
|
|
|
|
}
|
|
|
|
|
2001-12-05 06:23:54 +08:00
|
|
|
/*
|
2001-12-11 00:24:58 +08:00
|
|
|
* Function: do_fopen
|
2001-12-05 06:23:54 +08:00
|
|
|
* Purpose: Open the specified file.
|
|
|
|
* Return: SUCCESS or FAIL
|
2001-12-13 23:29:47 +08:00
|
|
|
* Programmer: Albert Cheng, Bill Wendling, 2001/12/13
|
2001-12-05 06:23:54 +08:00
|
|
|
* Modifications:
|
|
|
|
*/
|
2001-11-16 06:46:32 +08:00
|
|
|
static herr_t
|
2002-05-23 07:22:46 +08:00
|
|
|
do_fopen(parameters *param, char *fname, file_descr *fd /*out*/, int flags)
|
2001-11-07 23:28:33 +08:00
|
|
|
{
|
2001-11-16 06:46:32 +08:00
|
|
|
int ret_code = SUCCESS, mrc;
|
|
|
|
herr_t hrc;
|
|
|
|
hid_t acc_tpl = -1; /* file access templates */
|
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
switch (param->io_type) {
|
|
|
|
case POSIXIO:
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
if (flags & (PIO_CREATE | PIO_WRITE))
|
2002-05-23 07:22:46 +08:00
|
|
|
fd->posixfd = POSIXCREATE(fname);
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
else
|
2002-05-23 07:22:46 +08:00
|
|
|
fd->posixfd = POSIXOPEN(fname, O_RDONLY);
|
2001-11-16 06:46:32 +08:00
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
if (fd->posixfd < 0 ) {
|
|
|
|
fprintf(stderr, "POSIX File Open failed(%s)\n", fname);
|
2002-04-24 00:07:50 +08:00
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
/* The perils of POSIX I/O in a parallel environment. The problem is:
|
2002-02-21 06:35:20 +08:00
|
|
|
*
|
|
|
|
* - Process n opens a file with truncation and then starts
|
|
|
|
* writing to the file.
|
|
|
|
* - Process m also opens the file with truncation, but after
|
|
|
|
* process n has already started to write to the file. Thus,
|
|
|
|
* all of the stuff process n wrote is now lost.
|
|
|
|
*/
|
|
|
|
MPI_Barrier(pio_comm_g);
|
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
break;
|
|
|
|
|
|
|
|
case MPIO:
|
2001-12-13 03:55:21 +08:00
|
|
|
if (flags & (PIO_CREATE | PIO_WRITE)) {
|
2002-05-16 21:51:48 +08:00
|
|
|
MPI_File_delete(fname, pio_info_g);
|
2001-12-13 03:55:21 +08:00
|
|
|
mrc = MPI_File_open(pio_comm_g, fname, MPI_MODE_CREATE | MPI_MODE_RDWR,
|
2002-05-16 21:51:48 +08:00
|
|
|
pio_info_g, &fd->mpifd);
|
2001-12-14 04:14:32 +08:00
|
|
|
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
if (mrc != MPI_SUCCESS) {
|
|
|
|
fprintf(stderr, "MPI File Open failed(%s)\n", fname);
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*since MPI_File_open with MPI_MODE_CREATE does not truncate */
|
|
|
|
/*filesize , set size to 0 explicitedly. */
|
2001-12-20 06:10:15 +08:00
|
|
|
mrc = MPI_File_set_size(fd->mpifd, (MPI_Offset)0);
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
|
|
|
|
if (mrc != MPI_SUCCESS) {
|
|
|
|
fprintf(stderr, "MPI_File_set_size failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
2001-11-16 06:46:32 +08:00
|
|
|
} else {
|
2001-12-13 03:55:21 +08:00
|
|
|
mrc = MPI_File_open(pio_comm_g, fname, MPI_MODE_RDONLY,
|
2002-05-16 21:51:48 +08:00
|
|
|
pio_info_g, &fd->mpifd);
|
2001-11-07 23:28:33 +08:00
|
|
|
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
if (mrc != MPI_SUCCESS) {
|
|
|
|
fprintf(stderr, "MPI File Open failed(%s)\n", fname);
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
}
|
2001-11-07 23:28:33 +08:00
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
break;
|
|
|
|
|
|
|
|
case PHDF5:
|
|
|
|
acc_tpl = H5Pcreate(H5P_FILE_ACCESS);
|
2001-12-05 06:23:54 +08:00
|
|
|
if (acc_tpl < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Property List Create failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
/* Set the file driver to the MPI-I/O driver */
|
2002-05-16 21:51:48 +08:00
|
|
|
hrc = H5Pset_fapl_mpio(acc_tpl, pio_comm_g, pio_info_g);
|
2002-05-23 07:22:46 +08:00
|
|
|
if (hrc < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Property List Set failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
2001-12-05 06:23:54 +08:00
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
/* Set the alignment of objects in HDF5 file */
|
|
|
|
hrc = H5Pset_alignment(acc_tpl, param->h5_thresh, param->h5_align);
|
2001-12-05 06:23:54 +08:00
|
|
|
if (hrc < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Property List Set failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
2001-11-16 06:46:32 +08:00
|
|
|
|
|
|
|
/* create the parallel file */
|
2001-12-13 03:55:21 +08:00
|
|
|
if (flags & (PIO_CREATE | PIO_WRITE)) {
|
2001-12-12 04:57:53 +08:00
|
|
|
fd->h5fd = H5Fcreate(fname, H5F_ACC_TRUNC, H5P_DEFAULT, acc_tpl);
|
2001-11-16 06:46:32 +08:00
|
|
|
} else {
|
2001-12-12 04:57:53 +08:00
|
|
|
fd->h5fd = H5Fopen(fname, H5P_DEFAULT, acc_tpl);
|
2001-11-16 06:46:32 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
hrc = H5Pclose(acc_tpl);
|
|
|
|
|
2001-12-12 04:57:53 +08:00
|
|
|
if (fd->h5fd < 0) {
|
2001-12-05 06:23:54 +08:00
|
|
|
fprintf(stderr, "HDF5 File Create failed(%s)\n", fname);
|
2001-11-16 06:46:32 +08:00
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* verifying the close of the acc_tpl */
|
2001-12-05 06:23:54 +08:00
|
|
|
if (hrc < 0) {
|
|
|
|
fprintf(stderr, "HDF5 Property List Close failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
2001-11-16 06:46:32 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
done:
|
|
|
|
return ret_code;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2001-12-11 00:24:58 +08:00
|
|
|
* Function: do_fclose
|
2001-11-16 06:46:32 +08:00
|
|
|
* Purpose: Close the specified file descriptor.
|
|
|
|
* Return: SUCCESS or FAIL
|
2001-12-13 23:29:47 +08:00
|
|
|
* Programmer: Albert Cheng, Bill Wendling, 2001/12/13
|
2001-11-16 06:46:32 +08:00
|
|
|
* Modifications:
|
|
|
|
*/
|
|
|
|
static herr_t
|
2001-12-12 05:45:29 +08:00
|
|
|
do_fclose(iotype iot, file_descr *fd /*out*/)
|
2001-11-07 23:28:33 +08:00
|
|
|
{
|
2001-11-16 06:46:32 +08:00
|
|
|
herr_t ret_code = SUCCESS, hrc;
|
|
|
|
int mrc = 0, rc = 0;
|
|
|
|
|
|
|
|
switch (iot) {
|
2002-05-23 07:22:46 +08:00
|
|
|
case POSIXIO:
|
|
|
|
rc = POSIXCLOSE(fd->posixfd);
|
2001-11-16 06:46:32 +08:00
|
|
|
|
|
|
|
if (rc != 0){
|
2002-05-23 07:22:46 +08:00
|
|
|
fprintf(stderr, "POSIX File Close failed\n");
|
2001-11-16 06:46:32 +08:00
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
2002-05-23 07:22:46 +08:00
|
|
|
fd->posixfd = -1;
|
2001-11-16 06:46:32 +08:00
|
|
|
break;
|
|
|
|
|
|
|
|
case MPIO:
|
2001-12-14 04:14:32 +08:00
|
|
|
mrc = MPI_File_close(&fd->mpifd);
|
2001-11-16 06:46:32 +08:00
|
|
|
|
|
|
|
if (mrc != MPI_SUCCESS){
|
|
|
|
fprintf(stderr, "MPI File close failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
2001-12-12 05:45:29 +08:00
|
|
|
fd->mpifd = MPI_FILE_NULL;
|
2001-11-16 06:46:32 +08:00
|
|
|
break;
|
|
|
|
|
|
|
|
case PHDF5:
|
2001-12-12 05:45:29 +08:00
|
|
|
hrc = H5Fclose(fd->h5fd);
|
2001-11-16 06:46:32 +08:00
|
|
|
|
|
|
|
if (hrc < 0) {
|
|
|
|
fprintf(stderr, "HDF5 File Close failed\n");
|
|
|
|
GOTOERROR(FAIL);
|
|
|
|
}
|
|
|
|
|
2001-12-12 05:45:29 +08:00
|
|
|
fd->h5fd = -1;
|
2001-11-16 06:46:32 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
done:
|
|
|
|
return ret_code;
|
2001-11-07 23:28:33 +08:00
|
|
|
}
|
2001-11-16 06:46:32 +08:00
|
|
|
|
2001-12-13 03:55:21 +08:00
|
|
|
|
|
|
|
/*
|
2001-12-13 23:29:47 +08:00
|
|
|
* Function: do_fclose
|
|
|
|
* Purpose: Cleanup temporary file unless HDF5_NOCLEANUP is set.
|
|
|
|
* Only Proc 0 of the PIO communicator will do the cleanup.
|
|
|
|
* Other processes just return.
|
|
|
|
* Return: void
|
|
|
|
* Programmer: Albert Cheng 2001/12/12
|
|
|
|
* Modifications:
|
2001-12-13 03:55:21 +08:00
|
|
|
*/
|
2001-12-13 23:29:47 +08:00
|
|
|
static void
|
2001-12-14 04:14:32 +08:00
|
|
|
do_cleanupfile(iotype iot, char *fname)
|
2001-12-13 03:55:21 +08:00
|
|
|
{
|
|
|
|
if (pio_mpi_rank_g != 0)
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
return;
|
2001-12-13 03:55:21 +08:00
|
|
|
|
|
|
|
if (clean_file_g == -1)
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
clean_file_g = (getenv("HDF5_NOCLEANUP")==NULL) ? 1 : 0;
|
2001-12-13 03:55:21 +08:00
|
|
|
|
2001-12-14 04:14:32 +08:00
|
|
|
if (clean_file_g){
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
switch (iot){
|
2002-05-23 07:22:46 +08:00
|
|
|
case POSIXIO:
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
remove(fname);
|
|
|
|
break;
|
|
|
|
case MPIO:
|
|
|
|
case PHDF5:
|
2002-05-16 21:51:48 +08:00
|
|
|
MPI_File_delete(fname, pio_info_g);
|
[svn-r4733]
Purpose:
Feature Changes
Description:
Okay, I needed to add in more parameters so that the user can modify
how things are supposed to work with the PIO programs. Also needed
to change the algorithm a bit to make these work. And needed to add
in timing for the READ option.
Solution:
Added the above things. The parameters took a major rewrite of the
command-line parsing stuff. Here's the usage statement:
usage: pio_perf [OPTIONS]
OPTIONS
-h, --help Print a usage message and exit
-d N, --num-dsets=N Number of datasets per file [default:1]
-f S, --file-size=S Size of a single file [default: 64M]
-F N, --num-files=N Number of files [default: 1]
-H, --hdf5 Run HDF5 performance test
-i, --num-iterations Number of iterations to perform [default: 1]
-m, --mpiio Run MPI/IO performance test
-o F, --output=F Output raw data into file F [default: none]
-P N, --max-num-processes=N Maximum number of processes to use [default: 1]
-p N, --min-num-processes=N Minimum number of processes to use [default: 1]
-r, --raw Run raw (UNIX) performance test
-X S, --max-xfer-size=S Maximum transfer buffer size [default: 1M]
-x S, --min-xfer-size=S Minimum transfer buffer size [default: 1K]
F - is a filename.
N - is an integer >=0.
S - is a size specifier, an integer >=0 followed by a size indicator:
K - Kilobyte
M - Megabyte
G - Gigabyte
Example: 37M = 37 Megabytes
Platforms tested:
Linux, but not fully finished...
2001-12-19 04:12:21 +08:00
|
|
|
break;
|
|
|
|
}
|
2001-12-14 04:14:32 +08:00
|
|
|
}
|
2001-12-13 03:55:21 +08:00
|
|
|
}
|
2002-05-07 23:22:31 +08:00
|
|
|
|
|
|
|
#ifndef TIME_MPI
|
|
|
|
#define TIME_MPI
|
|
|
|
#endif
|
|
|
|
#ifdef TIME_MPI
|
|
|
|
/* instrument the MPI_File_wrirte_xxx and read_xxx calls to measure
|
|
|
|
* pure time spent in MPI_File code.
|
|
|
|
*/
|
|
|
|
int MPI_File_read_at(MPI_File fh, MPI_Offset offset, void *buf,
|
|
|
|
int count, MPI_Datatype datatype, MPI_Status *status)
|
|
|
|
{
|
|
|
|
int err;
|
|
|
|
set_time(timer_g, HDF5_MPI_READ, START);
|
|
|
|
err=PMPI_File_read_at(fh, offset, buf, count, datatype, status);
|
|
|
|
set_time(timer_g, HDF5_MPI_READ, STOP);
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int MPI_File_read_at_all(MPI_File fh, MPI_Offset offset, void *buf,
|
|
|
|
int count, MPI_Datatype datatype, MPI_Status *status)
|
|
|
|
{
|
|
|
|
int err;
|
|
|
|
set_time(timer_g, HDF5_MPI_READ, START);
|
|
|
|
err=PMPI_File_read_at_all(fh, offset, buf, count, datatype, status);
|
|
|
|
set_time(timer_g, HDF5_MPI_READ, STOP);
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
|
|
|
int MPI_File_write_at(MPI_File fh, MPI_Offset offset, void *buf,
|
|
|
|
int count, MPI_Datatype datatype, MPI_Status *status)
|
|
|
|
{
|
|
|
|
int err;
|
|
|
|
set_time(timer_g, HDF5_MPI_WRITE, START);
|
|
|
|
err=PMPI_File_write_at(fh, offset, buf, count, datatype, status);
|
|
|
|
set_time(timer_g, HDF5_MPI_WRITE, STOP);
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
|
|
|
int MPI_File_write_at_all(MPI_File fh, MPI_Offset offset, void *buf,
|
|
|
|
int count, MPI_Datatype datatype, MPI_Status *status)
|
|
|
|
{
|
|
|
|
int err;
|
|
|
|
set_time(timer_g, HDF5_MPI_WRITE, START);
|
|
|
|
err=PMPI_File_write_at_all(fh, offset, buf, count, datatype, status);
|
|
|
|
set_time(timer_g, HDF5_MPI_WRITE, STOP);
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* TIME_MPI */
|
2001-11-07 23:28:33 +08:00
|
|
|
#endif /* H5_HAVE_PARALLEL */
|