/* synchro_crashtest -- tries to crash the logging mechanism by doing parallel logs*/
-/* Copyright (c) 2007-2018. The SimGrid Team. All rights reserved. */
+/* Copyright (c) 2007-2020. The SimGrid Team. All rights reserved. */
/* This program is free software; you can redistribute it and/or modify it
* under the terms of the license (GNU LGPL) which comes with this package. */
-#include "simgrid/msg.h"
+#include "simgrid/s4u/Engine.hpp"
#include <thread>
XBT_LOG_NEW_DEFAULT_CATEGORY(synchro_crashtest, "Logs of this example");
int more_info = 0; /* SET IT TO TRUE TO GET MORE INFO */
/* Code ran by each thread */
-static void* crasher_thread(void* arg)
+static void crasher_thread(int id)
{
- int id = *(int*)arg;
-
for (int i = 0; i < test_amount; i++) {
if (more_info)
XBT_INFO("%03d (%02d|%02d|%02d|%02d|%02d|%02d|%02d|%02d|%02d)", test_amount - i, id, id, id, id, id, id, id, id,
else
XBT_INFO("XXX (XX|XX|XX|XX|XX|XX|XX|XX|XX)");
}
- return NULL;
}
int main(int argc, char* argv[])
{
- MSG_init(&argc, argv);
+ simgrid::s4u::Engine e(&argc, argv);
- int id[crasher_amount];
std::thread crashers[crasher_amount];
/* spawn threads */
for (int i = 0; i < crasher_amount; i++) {
- id[i] = i;
- crashers[i] = std::thread(crasher_thread, &id[i]);
+ crashers[i] = std::thread(crasher_thread, i);
}
/* wait for them */