aboutsummaryrefslogtreecommitdiff
path: root/Carpet/Carpet/src/Evolve.cc
diff options
context:
space:
mode:
authorRoland Haas <roland.haas@physics.gatech.edu>2012-06-25 21:03:35 -0700
committerBarry Wardell <barry.wardell@gmail.com>2012-09-11 18:23:27 +0100
commit57fc421df81a2c583de4d75ba60cf1d19b7efba1 (patch)
treed545550688bc3dc1586f62d316f8e913a06866c2 /Carpet/Carpet/src/Evolve.cc
parent9e4a198aa26c46c7bf3e60bfbe8f8084d4c8d07a (diff)
Carpet: ensure scheduling of global-early routines in POSTREGRID
these routines would not start since they were only checked for on rl==0 which is never recomposed.
Diffstat (limited to 'Carpet/Carpet/src/Evolve.cc')
-rw-r--r--Carpet/Carpet/src/Evolve.cc22
1 files changed, 21 insertions, 1 deletions
diff --git a/Carpet/Carpet/src/Evolve.cc b/Carpet/Carpet/src/Evolve.cc
index 19e25fc9b..32a2293ac 100644
--- a/Carpet/Carpet/src/Evolve.cc
+++ b/Carpet/Carpet/src/Evolve.cc
@@ -294,6 +294,12 @@ namespace Carpet {
if (did_regrid) {
bool did_any_recompose = false;
BEGIN_META_MODE (cctkGH) {
+
+ bool have_done_global_mode = false;
+ bool have_done_early_global_mode = false;
+ bool have_done_late_global_mode = false;
+ bool have_done_anything = false;
+
for (int rl=0; rl<reflevels; ++rl) {
bool const did_recompose = Recompose (cctkGH, rl, true);
@@ -310,13 +316,22 @@ namespace Carpet {
ENTER_LEVEL_MODE (cctkGH, rl) {
BeginTimingLevel (cctkGH);
- do_early_global_mode = reflevel==0;
+ do_early_global_mode = not have_done_early_global_mode;
do_late_global_mode = reflevel==reflevels-1;
do_early_meta_mode =
do_early_global_mode and mglevel==mglevels-1;
do_late_meta_mode = do_late_global_mode and mglevel==0;
do_global_mode = do_late_global_mode;
do_meta_mode = do_late_meta_mode;
+ assert (not (have_done_global_mode and do_global_mode));
+ assert (not (have_done_early_global_mode and
+ do_early_global_mode));
+ assert (not (have_done_late_global_mode and
+ do_late_global_mode));
+ have_done_global_mode |= do_global_mode;
+ have_done_early_global_mode |= do_early_global_mode;
+ have_done_late_global_mode |= do_late_global_mode;
+ have_done_anything = true;
BEGIN_TIMELEVEL_LOOP(cctkGH) {
@@ -344,6 +359,11 @@ namespace Carpet {
} // if did_recompose
} // for rl
+
+ if (have_done_anything) assert (have_done_global_mode);
+ if (have_done_anything) assert (have_done_early_global_mode);
+ if (have_done_anything) assert (have_done_late_global_mode);
+
} END_META_MODE;
} // if did_regrid