Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Signal handling - SIGTERM will stop calculation and force file saving #2110

Merged
merged 23 commits into from
Sep 15, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
63270c4
first commit, proof of concept
bigfooted Aug 15, 2023
56411f7
Merge branch 'develop' into feature_signal_handling
bigfooted Aug 15, 2023
7be05ed
move signal handler to coutput
bigfooted Aug 16, 2023
bdfb8fb
Merge branch 'feature_signal_handling' of https://github.com/su2code/…
bigfooted Aug 16, 2023
4d5673d
Merge branch 'develop' into feature_signal_handling
bigfooted Aug 17, 2023
5a7d62d
Merge branch 'develop' into feature_signal_handling
bigfooted Aug 21, 2023
84beef6
Merge branch 'develop' into feature_signal_handling
bigfooted Aug 22, 2023
a3ef34d
Merge branch 'develop' into feature_signal_handling
bigfooted Aug 26, 2023
38f3162
Merge branch 'develop' into feature_signal_handling
bigfooted Sep 4, 2023
16bf9cd
Merge branch 'develop' into feature_signal_handling
bigfooted Sep 15, 2023
8932eed
Merge branch 'develop' into feature_signal_handling
bigfooted Oct 26, 2023
4f4c3ae
Merge branch 'develop' into feature_signal_handling
bigfooted Nov 12, 2023
49324e9
Merge branch 'develop' into feature_signal_handling
bigfooted Nov 17, 2023
2ffc16f
Merge branch 'develop' into feature_signal_handling
bigfooted Feb 7, 2024
f42e22a
Merge branch 'develop' into feature_signal_handling
bigfooted Feb 15, 2024
005dc9b
Merge branch 'develop' into feature_signal_handling
bigfooted Feb 27, 2024
6291179
Merge branch 'develop' into feature_signal_handling
bigfooted Mar 5, 2024
d77d475
Merge branch 'develop' into feature_signal_handling
bigfooted Apr 4, 2024
28b9769
Merge branch 'develop' into feature_signal_handling
bigfooted Apr 24, 2024
ef316f2
Merge branch 'develop' into feature_signal_handling
bigfooted Jun 4, 2024
5da85c6
Merge branch 'develop' into feature_signal_handling
bigfooted Jul 10, 2024
213a947
cleanup
pcarruscag Sep 15, 2024
cd80746
Merge remote-tracking branch 'upstream/develop' into feature_signal_h…
pcarruscag Sep 15, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions SU2_CFD/src/drivers/CSinglezoneDriver.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -66,8 +66,8 @@ void CSinglezoneDriver::StartSolver() {
TimeIter = config_container[ZONE_0]->GetRestart_Iter();

/*--- Run the problem until the number of time iterations required is reached. ---*/
while ( TimeIter < config_container[ZONE_0]->GetnTime_Iter() ) {

/*--- or until a SIGTERM signal stops the loop. We catch SIGTERM and exit gracefully ---*/
while ( TimeIter < config_container[ZONE_0]->GetnTime_Iter()) {
/*--- Perform some preprocessing before starting the time-step simulation. ---*/

Preprocess(TimeIter);
Expand Down
24 changes: 22 additions & 2 deletions SU2_CFD/src/output/COutput.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,9 @@
* License along with SU2. If not, see <http://www.gnu.org/licenses/>.
*/

#include <iostream>
#include <csignal>

#include "../../../Common/include/geometry/CGeometry.hpp"
#include "../../include/solvers/CSolver.hpp"

Expand All @@ -47,6 +50,15 @@
#include "../../include/output/filewriter/CSU2BinaryFileWriter.hpp"
#include "../../include/output/filewriter/CSU2MeshFileWriter.hpp"

namespace {
volatile sig_atomic_t STOP;

void signalHandler(int signum) {
std::cout << "Interrupt signal (" << signum << ") received, saving files and exiting.\n";
STOP = 1;
}
}

COutput::COutput(const CConfig *config, unsigned short ndim, bool fem_output):
rank(SU2_MPI::GetRank()),
size(SU2_MPI::GetSize()),
Expand Down Expand Up @@ -169,7 +181,11 @@ COutput::COutput(const CConfig *config, unsigned short ndim, bool fem_output):
volumeDataSorter = nullptr;
surfaceDataSorter = nullptr;

headerNeeded = false;
headerNeeded = false;

/*--- Setup a signal handler for SIGTERM. ---*/

signal(SIGTERM, signalHandler);
}

COutput::~COutput() {
Expand Down Expand Up @@ -233,7 +249,7 @@ void COutput::SetHistoryOutput(CGeometry ****geometry, CSolver *****solver, CCon

if (config[ZONE_0]->GetMultizone_Problem())
Iter = OuterIter;

/*--- Turbomachinery Performance Screen summary output---*/
if (Iter%100 == 0 && rank == MASTER_NODE) {
SetTurboPerformance_Output(TurboPerf, config[val_iZone], TimeIter, OuterIter, InnerIter);
Expand Down Expand Up @@ -946,9 +962,13 @@ bool COutput::ConvergenceMonitoring(CConfig *config, unsigned long Iteration) {

if (convFields.empty() || Iteration < config->GetStartConv_Iter()) convergence = false;

/*--- If a SIGTERM signal is sent to one of the processes, we set convergence to true. ---*/
if (STOP) convergence = true;

/*--- Apply the same convergence criteria to all processors. ---*/

unsigned short local = convergence, global = 0;

SU2_MPI::Allreduce(&local, &global, 1, MPI_UNSIGNED_SHORT, MPI_MAX, SU2_MPI::GetComm());
convergence = global > 0;

Expand Down
Loading