A
lgorithmique
N
umérique
D
istribuée
Public GIT Repository
projects
/
simgrid.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
| inline |
side by side
Please codacy (avoid C-style pointer casting).
[simgrid.git]
/
src
/
kernel
/
context
/
ContextThread.cpp
diff --git
a/src/kernel/context/ContextThread.cpp
b/src/kernel/context/ContextThread.cpp
index
012fbcc
..
4ed2f29
100644
(file)
--- a/
src/kernel/context/ContextThread.cpp
+++ b/
src/kernel/context/ContextThread.cpp
@@
-58,9
+58,7
@@
void ThreadContextFactory::run_all()
{
if (smx_ctx_thread_sem == nullptr) {
// Serial execution
- smx_actor_t process;
- unsigned int cursor;
- xbt_dynar_foreach(simix_global->process_to_run, cursor, process) {
+ for (smx_actor_t process : simix_global->process_to_run) {
XBT_DEBUG("Handling %p",process);
ThreadContext* context = static_cast<ThreadContext*>(process->context);
xbt_os_sem_release(context->begin_);
@@
-68,12
+66,10
@@
void ThreadContextFactory::run_all()
}
} else {
// Parallel execution
- unsigned int index;
- smx_actor_t process;
- xbt_dynar_foreach(simix_global->process_to_run, index, process)
+ for (smx_actor_t process : simix_global->process_to_run)
xbt_os_sem_release(static_cast<ThreadContext*>(process->context)->begin_);
-
xbt_dynar_foreach(simix_global->process_to_run, index, process
)
-
xbt_os_sem_acquire(static_cast<ThreadContext*>(process->context)->end_);
+
for (smx_actor_t process : simix_global->process_to_run
)
+ xbt_os_sem_acquire(static_cast<ThreadContext*>(process->context)->end_);
}
}
@@
-200,9
+196,9
@@
void ThreadContext::stop()
xbt_os_sem_release(smx_ctx_thread_sem);
// Signal to the maestro that it has finished:
- xbt_os_thread_cleanup_push((void (*)(void*))xbt_os_sem_release, this->end_);
+ xbt_os_sem_release(this->end_);
+
xbt_os_thread_exit(nullptr);
- xbt_os_thread_cleanup_pop(0);
}
void ThreadContext::suspend()