summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDana Robinson <derobins@hdfgroup.org>2021-04-09 17:05:59 (GMT)
committerDana Robinson <derobins@hdfgroup.org>2021-04-09 17:05:59 (GMT)
commita2f39152a071179ccf9d8f2e8979485eee2e8034 (patch)
tree892f8fc056d2b11629993e3ac02ebcd9d2b607d6
parentee655cf374c5f2b2f43673a9e1d925af0f231626 (diff)
parent4fc1dacf9ef476fc9e1dbcdb2b49167ea04ae31f (diff)
downloadhdf5-a2f39152a071179ccf9d8f2e8979485eee2e8034.zip
hdf5-a2f39152a071179ccf9d8f2e8979485eee2e8034.tar.gz
hdf5-a2f39152a071179ccf9d8f2e8979485eee2e8034.tar.bz2
Merge remote-tracking branch 'canonical/feature/vfd_swmr' into vfd_swmr/thg_standards
-rw-r--r--test/testvfdswmr.sh.in14
-rw-r--r--test/vfd_swmr_group_writer.c588
2 files changed, 414 insertions, 188 deletions
diff --git a/test/testvfdswmr.sh.in b/test/testvfdswmr.sh.in
index b6b2300..e8ead12 100644
--- a/test/testvfdswmr.sh.in
+++ b/test/testvfdswmr.sh.in
@@ -40,7 +40,8 @@ nsofterrors=0 # soft errors are expected to occur some of the time
# on a couple of nondeterministic tests.
###############################################################################
-## test parameters for vfd_swmr_bigset_writer.c based on HDF5TestExpress:
+## test parameters for vfd_swmr_bigset_writer.c and vfd_swmr_group_writer.c
+## based on HDF5TestExpress:
## 0: Exhaustive run: Tests take a long time to run.
## 1: Default run.
## 2+: Quick run
@@ -53,14 +54,17 @@ fi
BIGSET_n=25 # -n option: # of iterations
BIGSET_few_s=20 # -s option: # of datasets (for few_big test)
BIGSET_many_s=500 # -s option: # of datasets (for many_small test)
+GROUP_n=100 # -n option: # of groups (for vfd_swmr_group_writer.c)
if [[ "$HDF5TestExpress" -eq 0 ]] ; then # Setting for exhaustive run
BIGSET_n=50
BIGSET_few_s=40
BIGSET_many_s=1000
+ GROUP_n=400
elif [[ "$HDF5TestExpress" -gt 1 ]]; then # Setting for quick run
BIGSET_n=10
BIGSET_few_s=10
BIGSET_many_s=100
+ GROUP_n=40
fi
###############################################################################
@@ -610,17 +614,17 @@ if [ ${do_zoo:-no} = yes ]; then
fi
#
-# Make sure that we can create 10000 groups while a reader waits
-# for each to appear.
+# Make sure that we can create GROUP_n groups (40, 100, or 400 depending on the HDF5TestExpress level)
+# while a reader waits for each to appear.
#
if [ ${do_groups:-no} = yes ]; then
echo launch vfd_swmr_group_writer
catch_out_err_and_rc vfd_swmr_group_writer \
- ../vfd_swmr_group_writer -q -c 1000 -n 10000 &
+ ../vfd_swmr_group_writer -q -c 10 -n $GROUP_n &
pid_writer=$!
catch_out_err_and_rc vfd_swmr_group_reader \
- ../vfd_swmr_group_reader -q -c 1000 -n 10000 &
+ ../vfd_swmr_group_reader -q -c 10 -n $GROUP_n -u 5 &
pid_reader=$!
# Wait for the reader to finish before signalling the
diff --git a/test/vfd_swmr_group_writer.c b/test/vfd_swmr_group_writer.c
index 1c309e1..33f0f7f 100644
--- a/test/vfd_swmr_group_writer.c
+++ b/test/vfd_swmr_group_writer.c
@@ -23,85 +23,94 @@
#ifndef H5_HAVE_WIN32_API
-#include <err.h>
-#include <libgen.h>
+#define READER_WAIT_TICKS 3
typedef struct {
- hid_t file, filetype, one_by_one_sid;
- char filename[PATH_MAX];
- char progname[PATH_MAX];
- unsigned int asteps;
- unsigned int csteps;
- unsigned int nsteps;
- bool wait_for_signal;
- bool use_vfd_swmr;
+ hid_t file, filetype, one_by_one_sid;
+ char filename[PATH_MAX];
+ char progname[PATH_MAX];
+ unsigned int asteps;
+ unsigned int csteps;
+ unsigned int nsteps;
+ unsigned int update_interval;
+ bool use_vfd_swmr;
+ bool use_named_pipes;
} state_t;
#define ALL_HID_INITIALIZER \
(state_t) \
{ \
.file = H5I_INVALID_HID, .one_by_one_sid = H5I_INVALID_HID, .filename = "", \
- .filetype = H5T_NATIVE_UINT32, .asteps = 10, .csteps = 10, .nsteps = 100, .wait_for_signal = true, \
- .use_vfd_swmr = true \
+ .filetype = H5T_NATIVE_UINT32, .asteps = 10, .csteps = 10, .nsteps = 100, .update_interval = READER_WAIT_TICKS, \
+ .use_vfd_swmr = true, \
+ .use_named_pipes = true \
}
-static void state_init(state_t *, int, char **);
-
-static const hid_t badhid = H5I_INVALID_HID;
-
static void
usage(const char *progname)
{
- fprintf(stderr,
- "usage: %s [-S] [-W] [-a steps] [-b] [-c]\n"
- " [-n iterations]\n"
- "\n"
- "-S: do not use VFD SWMR\n"
- "-W: do not wait for a signal before\n"
- " exiting\n"
- "-a steps: `steps` between adding attributes\n"
- "-b: write data in big-endian byte order\n"
- "-c steps: `steps` between communication between the writer and reader\n"
- "-n ngroups: the number of groups\n"
- "\n",
- progname);
- exit(EXIT_FAILURE);
+ fprintf(stderr, "usage: %s [-S] [-a steps] [-b] [-c]\n"
+ " [-n iterations] [-N] [-q] [-u numb_ticks]\n"
+ "\n"
+ "-S: do not use VFD SWMR\n"
+ "-a steps: `steps` between adding attributes\n"
+ "-b: write data in big-endian byte order\n"
+ "-c steps: `steps` between communication between the writer and reader\n"
+ "-n ngroups: the number of groups\n"
+ "-N: do not use named pipes, mainly for running the writer and reader seperately\n"
+ "-u numb_tcks: `numb_ticks` for the reader to wait before verification\n"
+ "-q: silence printouts, few messages\n"
+ "\n",
+ progname);
+ exit(EXIT_FAILURE);
}
-static void
+static bool
state_init(state_t *s, int argc, char **argv)
{
unsigned long tmp;
int ch;
const hsize_t dims = 1;
- char tfile[PATH_MAX];
+ char *tfile = NULL;
char * end;
*s = ALL_HID_INITIALIZER;
- esnprintf(tfile, sizeof(tfile), "%s", argv[0]);
- esnprintf(s->progname, sizeof(s->progname), "%s", basename(tfile));
- while ((ch = getopt(argc, argv, "SWa:bc:n:q")) != -1) {
+ if (H5_basename(argv[0], &tfile) < 0) {
+ H5_FAILED(); AT();
+ printf("H5_basename failed\n");
+ goto error;
+ }
+
+ esnprintf(s->progname, sizeof(s->progname), "%s", tfile);
+
+ if (tfile)
+ HDfree(tfile);
+
+ while ((ch = getopt(argc, argv, "Sa:bc:n:Nqu:")) != -1) {
switch (ch) {
case 'S':
s->use_vfd_swmr = false;
break;
- case 'W':
- s->wait_for_signal = false;
- break;
case 'a':
case 'c':
case 'n':
+ case 'u':
errno = 0;
- tmp = strtoul(optarg, &end, 0);
+ tmp = strtoul(optarg, &end, 0);
if (end == optarg || *end != '\0') {
- errx(EXIT_FAILURE, "couldn't parse `-%c` argument `%s`", ch, optarg);
+ H5_FAILED(); AT();
+ printf("couldn't parse `-%c` argument `%s`\n", ch, optarg);
+ goto error;
+ } else if (errno != 0) {
+ H5_FAILED(); AT();
+ printf("couldn't parse `-%c` argument `%s`\n", ch, optarg);
+ goto error;
+ } else if (tmp > UINT_MAX) {
+ H5_FAILED(); AT();
+ printf("`-%c` argument `%lu` too large\n", ch, tmp);
+ goto error;
}
- else if (errno != 0) {
- err(EXIT_FAILURE, "couldn't parse `-%c` argument `%s`", ch, optarg);
- }
- else if (tmp > UINT_MAX)
- errx(EXIT_FAILURE, "`-%c` argument `%lu` too large", ch, tmp);
if (ch == 'a')
s->asteps = (unsigned)tmp;
@@ -109,10 +118,15 @@ state_init(state_t *s, int argc, char **argv)
s->csteps = (unsigned)tmp;
else if (ch == 'n')
s->nsteps = (unsigned)tmp;
+ else if (ch == 'u')
+ s->update_interval = (unsigned)tmp;
break;
case 'b':
s->filetype = H5T_STD_U32BE;
break;
+ case 'N':
+ s->use_named_pipes = false;
+ break;
case 'q':
verbosity = 0;
break;
@@ -126,22 +140,42 @@ state_init(state_t *s, int argc, char **argv)
argv += optind;
/* space for attributes */
- if ((s->one_by_one_sid = H5Screate_simple(1, &dims, &dims)) < 0)
- errx(EXIT_FAILURE, "H5Screate_simple failed");
+ if ((s->one_by_one_sid = H5Screate_simple(1, &dims, &dims)) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Screate_simple failed\n");
+ goto error;
+ }
- if (s->csteps < 1 || s->csteps > s->nsteps)
- errx(EXIT_FAILURE, "communication interval is out of bounds");
+ if( s->csteps < 1 || s->csteps > s->nsteps) {
+ H5_FAILED(); AT();
+ printf("communication interval is out of bounds\n");
+ goto error;
+ }
- if (s->asteps < 1 || s->asteps > s->nsteps)
- errx(EXIT_FAILURE, "attribute interval is out of bounds");
+ if( s->asteps < 1 || s->asteps > s->nsteps) {
+ H5_FAILED(); AT();
+ printf("attribute interval is out of bounds\n");
+ goto error;
+ }
- if (argc > 0)
- errx(EXIT_FAILURE, "unexpected command-line arguments");
+ if (argc > 0) {
+ H5_FAILED(); AT();
+ printf("unexpected command-line arguments\n");
+ goto error;
+ }
esnprintf(s->filename, sizeof(s->filename), "vfd_swmr_group.h5");
+
+ return true;
+
+error:
+ if (tfile)
+ HDfree(tfile);
+
+ return false;
}
-static void
+static bool
add_group_attribute(const state_t *s, hid_t g, hid_t sid, unsigned int which)
{
hid_t aid;
@@ -151,98 +185,160 @@ add_group_attribute(const state_t *s, hid_t g, hid_t sid, unsigned int which)
dbgf(1, "setting attribute %s on group %u to %u\n", name, which, which);
- if ((aid = H5Acreate2(g, name, s->filetype, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
- errx(EXIT_FAILURE, "H5Acreate2 failed");
+ if ((aid = H5Acreate2(g, name, s->filetype, sid, H5P_DEFAULT,
+ H5P_DEFAULT)) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Acreate2 failed\n");
+ goto error;
+ }
+
+ if (H5Awrite(aid, H5T_NATIVE_UINT, &which) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Awrite failed\n");
+ goto error;
+ }
+
+ if (H5Aclose(aid) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Aclose failed\n");
+ goto error;
+ }
- if (H5Awrite(aid, H5T_NATIVE_UINT, &which) < 0)
- errx(EXIT_FAILURE, "H5Awrite failed");
- if (H5Aclose(aid) < 0)
- errx(EXIT_FAILURE, "H5Aclose failed");
+ return true;
+
+error:
+ H5E_BEGIN_TRY {
+ H5Aclose(aid);
+ } H5E_END_TRY;
+
+ return false;
}
-static void
+static bool
write_group(state_t *s, unsigned int which)
{
- char name[sizeof("/group-9999999999")];
- hid_t g;
-
- assert(which < s->nsteps);
+ char name[sizeof("/group-9999999999")];
+ hid_t g = H5I_INVALID_HID;
+ bool result = true;
+
+ if (which >= s->nsteps) {
+ H5_FAILED(); AT();
+ printf("group order is out of bounds\n");
+ goto error;
+ }
esnprintf(name, sizeof(name), "/group-%d", which);
- g = H5Gcreate2(s->file, name, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT);
-
- if (g < 0)
- errx(EXIT_FAILURE, "H5Gcreate(, \"%s\", ) failed", name);
+ if ((g = H5Gcreate2(s->file, name, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Gcreate2 failed\n");
+ goto error;
+ }
if (s->asteps != 0 && which % s->asteps == 0)
- add_group_attribute(s, g, s->one_by_one_sid, which);
+ result = add_group_attribute(s, g, s->one_by_one_sid, which);
- if (H5Gclose(g) < 0)
- errx(EXIT_FAILURE, "H5Gclose failed");
+ if (H5Gclose(g) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Gclose failed\n");
+ goto error;
+ }
+
+ return result;
+
+error:
+ H5E_BEGIN_TRY {
+ H5Gclose(g);
+ } H5E_END_TRY;
+
+ return false;
}
static bool
verify_group_attribute(hid_t g, unsigned int which)
{
- estack_state_t es;
- unsigned int read_which;
- hid_t aid;
- char name[sizeof("attr-9999999999")];
+ unsigned int read_which;
+ hid_t aid;
+ char name[sizeof("attr-9999999999")];
esnprintf(name, sizeof(name), "attr-%u", which);
dbgf(1, "verifying attribute %s on group %u equals %u\n", name, which, which);
- es = disable_estack();
if ((aid = H5Aopen(g, name, H5P_DEFAULT)) < 0) {
- restore_estack(es);
- return false;
+ H5_FAILED(); AT();
+ printf("H5Aopen failed\n");
+ goto error;
}
if (H5Aread(aid, H5T_NATIVE_UINT, &read_which) < 0) {
- restore_estack(es);
- if (H5Aclose(aid) < 0)
- errx(EXIT_FAILURE, "H5Aclose failed");
- return false;
+ H5_FAILED(); AT();
+ printf("H5Aread failed\n");
+ goto error;
}
- restore_estack(es);
+ if (read_which != which) {
+ H5_FAILED(); AT();
+ printf("H5Aread wrong value\n");
+ goto error;
+ }
+
+ if (H5Aclose(aid) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Aread failed\n");
+ goto error;
+ }
- if (H5Aclose(aid) < 0)
- errx(EXIT_FAILURE, "H5Aclose failed");
+ return true;
- return read_which == which;
+error:
+ H5E_BEGIN_TRY {
+ H5Aclose(aid);
+ } H5E_END_TRY;
+
+ return false;
}
static bool
verify_group(state_t *s, unsigned int which)
{
- char name[sizeof("/group-9999999999")];
- hid_t g;
- estack_state_t es;
- bool result;
-
- assert(which < s->nsteps);
+ char name[sizeof("/group-9999999999")];
+ hid_t g = H5I_INVALID_HID;
+ bool result = true;
+
+ if (which >= s->nsteps) {
+ H5_FAILED(); AT();
+ printf("Group order is out of bounds\n");
+ goto error;
+ }
esnprintf(name, sizeof(name), "/group-%d", which);
- es = disable_estack();
- g = H5Gopen2(s->file, name, H5P_DEFAULT);
- restore_estack(es);
-
- if (g < 0)
- return false;
+ if ((g = H5Gopen(s->file, name, H5P_DEFAULT)) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Gopen failed\n");
+ goto error;
+ }
if (s->asteps != 0 && which % s->asteps == 0)
result = verify_group_attribute(g, which);
else
result = true;
- if (H5Gclose(g) < 0)
- errx(EXIT_FAILURE, "H5Gclose failed");
+ if (H5Gclose(g) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Gclose failed\n");
+ goto error;
+ }
return result;
+
+error:
+ H5E_BEGIN_TRY {
+ H5Gclose(g);
+ } H5E_END_TRY;
+
+ return false;
}
/* Sleep for `tenths` tenths of a second */
@@ -257,20 +353,23 @@ decisleep(uint32_t tenths)
int
main(int argc, char **argv)
{
- hid_t fapl, fcpl;
- herr_t ret;
- unsigned step;
- bool writer;
- state_t s;
- const char * personality;
+ hid_t fapl = H5I_INVALID_HID, fcpl = H5I_INVALID_HID;
+ unsigned step;
+ bool writer = false;
+ state_t s;
+ const char *personality;
H5F_vfd_swmr_config_t config;
- const char * fifo_writer_to_reader = "./fifo_group_writer_to_reader";
- const char * fifo_reader_to_writer = "./fifo_group_reader_to_writer";
- int fd_writer_to_reader, fd_reader_to_writer;
- int notify = 0, verify = 0;
- unsigned int i;
-
- state_init(&s, argc, argv);
+ const char *fifo_writer_to_reader = "./fifo_group_writer_to_reader";
+ const char *fifo_reader_to_writer = "./fifo_group_reader_to_writer";
+ int fd_writer_to_reader = -1, fd_reader_to_writer = -1;
+ int notify = 0, verify = 0;
+ unsigned int i;
+
+ if (!state_init(&s, argc, argv)) {
+ H5_FAILED(); AT();
+ printf("state_init failed\n");
+ goto error;
+ }
personality = strstr(s.progname, "vfd_swmr_group_");
@@ -279,81 +378,133 @@ main(int argc, char **argv)
else if (personality != NULL && strcmp(personality, "vfd_swmr_group_reader") == 0)
writer = false;
else {
- errx(EXIT_FAILURE, "unknown personality, expected vfd_swmr_group_{reader,writer}");
+ H5_FAILED(); AT();
+ printf("unknown personality, expected vfd_swmr_group_{reader,writer}\n");
+ goto error;
}
/* config, tick_len, max_lag, writer, flush_raw_data, md_pages_reserved, md_file_path */
init_vfd_swmr_config(&config, 4, 7, writer, FALSE, 128, "./group-shadow");
/* use_latest_format, use_vfd_swmr, only_meta_page, config */
- fapl = vfd_swmr_create_fapl(true, s.use_vfd_swmr, true, &config);
-
- if (fapl < 0)
- errx(EXIT_FAILURE, "vfd_swmr_create_fapl");
+ if ((fapl = vfd_swmr_create_fapl(true, s.use_vfd_swmr, true, &config)) < 0) {
+ H5_FAILED(); AT();
+ printf("vfd_swmr_create_fapl failed\n");
+ goto error;
+ }
- if ((fcpl = H5Pcreate(H5P_FILE_CREATE)) < 0)
- errx(EXIT_FAILURE, "H5Pcreate");
+ if ((fcpl = H5Pcreate(H5P_FILE_CREATE)) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Pcreate failed\n");
+ goto error;
+ }
- ret = H5Pset_file_space_strategy(fcpl, H5F_FSPACE_STRATEGY_PAGE, false, 1);
- if (ret < 0)
- errx(EXIT_FAILURE, "H5Pset_file_space_strategy");
+ if (H5Pset_file_space_strategy(fcpl, H5F_FSPACE_STRATEGY_PAGE, false, 1) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Pset_file_space_strategy failed\n");
+ goto error;
+ }
if (writer)
s.file = H5Fcreate(s.filename, H5F_ACC_TRUNC, fcpl, fapl);
else
s.file = H5Fopen(s.filename, H5F_ACC_RDONLY, fapl);
- if (s.file == badhid)
- errx(EXIT_FAILURE, writer ? "H5Fcreate" : "H5Fopen");
+ if (s.file < 0) {
+ H5_FAILED(); AT();
+ printf("H5Fcreate/open failed\n");
+ goto error;
+ }
/* Use two named pipes(FIFO) to coordinate the writer and reader for
* two-way communication so that the two sides can move forward together.
* One is for the writer to write to the reader.
* The other one is for the reader to signal the writer. */
- if (writer) {
+ if (s.use_named_pipes && writer) {
/* Writer creates two named pipes(FIFO) */
- if (HDmkfifo(fifo_writer_to_reader, 0600) < 0)
- errx(EXIT_FAILURE, "HDmkfifo");
+ if (HDmkfifo(fifo_writer_to_reader, 0600) < 0) {
+ H5_FAILED(); AT();
+ printf("HDmkfifo failed\n");
+ goto error;
+ }
+
+ if (HDmkfifo(fifo_reader_to_writer, 0600) < 0) {
+ H5_FAILED(); AT();
+ printf("HDmkfifo failed\n");
+ goto error;
+ }
- if (HDmkfifo(fifo_reader_to_writer, 0600) < 0)
- errx(EXIT_FAILURE, "HDmkfifo");
}
/* Both the writer and reader open the pipes */
- if ((fd_writer_to_reader = HDopen(fifo_writer_to_reader, O_RDWR)) < 0)
- errx(EXIT_FAILURE, "fifo_writer_to_reader open failed");
+ if (s.use_named_pipes && (fd_writer_to_reader = HDopen(fifo_writer_to_reader, O_RDWR)) < 0) {
+ H5_FAILED(); AT();
+ printf("HDopen failed\n");
+ goto error;
+ }
- if ((fd_reader_to_writer = HDopen(fifo_reader_to_writer, O_RDWR)) < 0)
- errx(EXIT_FAILURE, "fifo_reader_to_writer open failed");
+ if (s.use_named_pipes && (fd_reader_to_writer = HDopen(fifo_reader_to_writer, O_RDWR)) < 0) {
+ H5_FAILED(); AT();
+ printf("HDopen failed\n");
+ goto error;
+ }
if (writer) {
for (step = 0; step < s.nsteps; step++) {
dbgf(2, "writer: step %d\n", step);
- write_group(&s, step);
-
- /* At communication interval, notifies the reader and waits for its response */
- if (step % s.csteps == 0) {
- /* Bump up the value of notify to notice the reader to start to read */
- notify++;
- if (HDwrite(fd_writer_to_reader, &notify, sizeof(int)) < 0)
- err(EXIT_FAILURE, "write failed");
+ if (!write_group(&s, step)) {
+ H5_FAILED(); AT();
+ printf("write_group failed\n");
- /* During the wait, writer makes repeated HDF5 API calls
- * to trigger EOT at approximately the correct time */
- for (i = 0; i < config.max_lag + 1; i++) {
- decisleep(config.tick_len);
- H5Aexists(s.file, "nonexistent");
+ /* At communication interval, notifies the reader about the failture and quit */
+ if (s.use_named_pipes && (step % s.csteps == 0)) {
+ notify = -1;
+ HDwrite(fd_writer_to_reader, &notify, sizeof(int));
}
- /* Receive the same value from the reader and verify it before
- * going to the next step */
- verify++;
- if (HDread(fd_reader_to_writer, &notify, sizeof(int)) < 0)
- err(EXIT_FAILURE, "read failed");
-
- if (notify != verify)
- errx(EXIT_FAILURE, "received message %d, expecting %d", notify, verify);
+ goto error;
+ } else {
+ /* At communication interval, notifies the reader and waits for its response */
+ if (s.use_named_pipes && (step % s.csteps == 0)) {
+ /* Bump up the value of notify to notice the reader to start to read */
+ notify++;
+ if (HDwrite(fd_writer_to_reader, &notify, sizeof(int)) < 0) {
+ H5_FAILED(); AT();
+ printf("HDwrite failed\n");
+ goto error;
+ }
+
+ /* During the wait, writer makes repeated HDF5 API calls
+ * to trigger EOT at approximately the correct time */
+ for(i = 0; i < config.max_lag + 1; i++) {
+ decisleep(config.tick_len);
+ H5E_BEGIN_TRY {
+ H5Aexists(s.file, "nonexistent");
+ } H5E_END_TRY;
+ }
+
+ /* Receive the same value from the reader and verify it before
+ * going to the next step */
+ verify++;
+ if (HDread(fd_reader_to_writer, &notify, sizeof(int)) < 0) {
+ H5_FAILED(); AT();
+ printf("HDread failed\n");
+ goto error;
+ }
+
+ if (notify == -1) {
+ H5_FAILED(); AT();
+ printf("reader failed to verify group\n");
+ goto error;
+ }
+
+ if (notify != verify) {
+ H5_FAILED(); AT();
+ printf("received message %d, expecting %d\n", notify, verify);
+ goto error;
+ }
+ }
}
}
}
@@ -363,57 +514,128 @@ main(int argc, char **argv)
/* At communication interval, waits for the writer to finish creation before starting verification
*/
- if (step % s.csteps == 0) {
+ if (s.use_named_pipes && (step % s.csteps == 0)) {
/* The writer should have bumped up the value of notify.
* Do the same with verify and confirm it */
verify++;
/* Receive the notify that the writer bumped up the value */
- if (HDread(fd_writer_to_reader, &notify, sizeof(int)) < 0)
- err(EXIT_FAILURE, "read failed");
+ if (HDread(fd_writer_to_reader, &notify, sizeof(int)) < 0) {
+ H5_FAILED(); AT();
+ printf("HDread failed\n");
+ goto error;
+ }
+
+ if (notify == -1) {
+ H5_FAILED(); AT();
+ printf("writer failed to create group\n");
+ goto error;
+ }
- if (notify != verify)
- errx(EXIT_FAILURE, "received message %d, expecting %d", notify, verify);
+ if (notify != verify) {
+ H5_FAILED(); AT();
+ printf("received message %d, expecting %d\n", notify, verify);
+ goto error;
+ }
}
- while (!verify_group(&s, step))
- ;
+ /* Wait for a few ticks for the update to happen */
+ if (s.use_named_pipes)
+ decisleep(config.tick_len * s.update_interval);
+
+ /* Start to verify group */
+ if (!verify_group(&s, step)) {
+ H5_FAILED(); AT();
+ printf("verify_group failed\n");
- if (step % s.csteps == 0) {
- /* Send back the same nofity value for acknowledgement to tell the writer
- * move to the next step. */
- if (HDwrite(fd_reader_to_writer, &notify, sizeof(int)) < 0)
- err(EXIT_FAILURE, "write failed");
+ /* At communication interval, tell the writer about the failure and exit */
+ if (s.use_named_pipes && (step % s.csteps == 0)) {
+ notify = -1;
+ HDwrite(fd_reader_to_writer, &notify, sizeof(int));
+ }
+
+ goto error;
+ } else {
+ if (s.use_named_pipes && (step % s.csteps == 0)) {
+ /* Send back the same nofity value for acknowledgement to tell the writer
+ * move to the next step */
+ if (HDwrite(fd_reader_to_writer, &notify, sizeof(int)) < 0) {
+ H5_FAILED(); AT();
+ printf("HDwrite failed\n");
+ goto error;
+ }
+ }
}
}
}
- if (H5Pclose(fapl) < 0)
- errx(EXIT_FAILURE, "H5Pclose(fapl)");
+ if (H5Pclose(fapl) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Pclose failed\n");
+ goto error;
+ }
- if (H5Pclose(fcpl) < 0)
- errx(EXIT_FAILURE, "H5Pclose(fcpl)");
+ if (H5Pclose(fcpl) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Pclose failed\n");
+ goto error;
+ }
- if (H5Fclose(s.file) < 0)
- errx(EXIT_FAILURE, "H5Fclose");
+ if (H5Fclose(s.file) < 0) {
+ H5_FAILED(); AT();
+ printf("H5Fclose failed\n");
+ goto error;
+ }
/* Both the writer and reader close the named pipes */
- if (HDclose(fd_writer_to_reader) < 0)
- errx(EXIT_FAILURE, "HDclose");
+ if (s.use_named_pipes && HDclose(fd_writer_to_reader) < 0) {
+ H5_FAILED(); AT();
+ printf("HDclose failed\n");
+ goto error;
+ }
- if (HDclose(fd_reader_to_writer) < 0)
- errx(EXIT_FAILURE, "HDclose");
+ if (s.use_named_pipes && HDclose(fd_reader_to_writer) < 0) {
+ H5_FAILED(); AT();
+ printf("HDclose failed\n");
+ goto error;
+ }
/* Reader finishes last and deletes the named pipes */
- if (!writer) {
- if (HDremove(fifo_writer_to_reader) != 0)
- errx(EXIT_FAILURE, "fifo_writer_to_reader deletion failed");
+ if(s.use_named_pipes && !writer) {
+ if(HDremove(fifo_writer_to_reader) != 0) {
+ H5_FAILED(); AT();
+ printf("HDremove failed\n");
+ goto error;
+ }
- if (HDremove(fifo_reader_to_writer) != 0)
- errx(EXIT_FAILURE, "fifo_reader_to_writer deletion failed");
+ if(HDremove(fifo_reader_to_writer) != 0) {
+ H5_FAILED(); AT();
+ printf("HDremove failed\n");
+ goto error;
+ }
}
return EXIT_SUCCESS;
+
+error:
+ H5E_BEGIN_TRY {
+ H5Pclose(fapl);
+ H5Pclose(fcpl);
+ H5Fclose(s.file);
+ } H5E_END_TRY;
+
+ if (s.use_named_pipes && fd_writer_to_reader >= 0)
+ HDclose(fd_writer_to_reader);
+
+ if (s.use_named_pipes && fd_reader_to_writer >= 0)
+ HDclose(fd_reader_to_writer);
+
+ if(s.use_named_pipes && !writer) {
+ HDremove(fifo_writer_to_reader);
+ HDremove(fifo_reader_to_writer);
+ }
+
+ return EXIT_FAILURE;
}
#else /* H5_HAVE_WIN32_API */