examples/smpi/trace_call_location/smpi_trace_call_location
examples/smpi/trace_simple/smpi_trace_simple
examples/smpi/trace/smpi_trace
+teshsuite/kernel/context-defaults/context-defaults
+teshsuite/kernel/context-stacksize/context-stacksize
teshsuite/java/semaphoregc/java-semaphoregc_compiled
teshsuite/java/sleephostoff/java-sleephostoff_compiled
teshsuite/mc/dwarf/dwarf
teshsuite/simdag/comp-only-seq/comp-only-seq
teshsuite/simdag/flatifier/flatifier
teshsuite/simdag/incomplete/incomplete
-teshsuite/simix/check-defaults/check-defaults
teshsuite/simix/generic-simcalls/generic-simcalls
teshsuite/simix/stack-overflow/stack-overflow
teshsuite/smpi/bug-17132/bug-17132
-foreach(x context-stacksize)
+foreach(x context-defaults context-stacksize)
add_executable (${x} EXCLUDE_FROM_ALL ${x}/${x}.cpp)
target_link_libraries(${x} simgrid)
set_target_properties(${x} PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/${x})
set(teshsuite_src ${teshsuite_src} ${CMAKE_CURRENT_SOURCE_DIR}/${x}/${x}.cpp)
endforeach()
+foreach (factory raw thread boost ucontext)
+ set(tesh_files ${tesh_files} ${CMAKE_CURRENT_SOURCE_DIR}/context-defaults/factory_${factory}.tesh)
+endforeach()
+
## Add the tests.
## Some need to be run with all factories, some don't need tesh to run
# This test should not be executed with thread contexts, as they ignore stack size changes
-ADD_TESH_FACTORIES(tesh-kern-context-stacksize "raw;boost;ucontext" --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/kernel/context-stacksize --setenv srcdir=${CMAKE_HOME_DIRECTORY}/teshsuite/kernel/context-stacksize --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --cd ${CMAKE_BINARY_DIR}/teshsuite/kernel/context-stacksize ${CMAKE_HOME_DIRECTORY}/teshsuite/kernel/context-stacksize/context-stacksize.tesh)
+ADD_TESH_FACTORIES(tesh-kernel-context-stacksize "raw;boost;ucontext" --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/kernel/context-stacksize --setenv srcdir=${CMAKE_HOME_DIRECTORY}/teshsuite/kernel/context-stacksize --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms --cd ${CMAKE_BINARY_DIR}/teshsuite/kernel/context-stacksize ${CMAKE_HOME_DIRECTORY}/teshsuite/kernel/context-stacksize/context-stacksize.tesh)
set(tesh_files ${tesh_files} ${CMAKE_CURRENT_SOURCE_DIR}/context-stacksize/context-stacksize.tesh)
+# Ensure that we have the right default setting for the context factory
+IF(HAVE_RAW_CONTEXTS)
+ ADD_TESH(tesh-kernel-context-default --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/kernel/context-defaults --cd ${CMAKE_HOME_DIRECTORY}/teshsuite/kernel/context-defaults factory_raw.tesh)
+ELSEIF(HAVE_UCONTEXT_CONTEXTS)
+ ADD_TESH(tesh-kernel-context-default --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/kernel/context-defaults --cd ${CMAKE_HOME_DIRECTORY}/teshsuite/kernel/context-defaults factory_ucontext.tesh)
+ELSEIF(HAVE_BOOST_CONTEXTS)
+ ADD_TESH(tesh-kernel-context-default --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/kernel/context-defaults --cd ${CMAKE_HOME_DIRECTORY}/teshsuite/kernel/context-defaults factory_boost.tesh)
+ELSE()
+ ADD_TESH(tesh-kernel-context-default --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/kernel/context-defaults --cd ${CMAKE_HOME_DIRECTORY}/teshsuite/kernel/context-defaults factory_thread.tesh)
+ENDIF()
+# Ensure that we get what we want when specifying the context factory on the command line
+foreach (factory raw thread boost ucontext)
+ string (TOUPPER have_${factory}_contexts VARNAME)
+ if (${factory} STREQUAL "thread" OR ${VARNAME})
+ # Cannot use ADD_TESH() here since ${factory} is part of the tesh filename
+ ADD_TESH(tesh-kernel-factory-${factory} --cfg contexts/factory:${factory} --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/kernel/context-defaults --cd ${CMAKE_HOME_DIRECTORY}/teshsuite/kernel/context-defaults factory_${factory}.tesh)
+ endif()
+endforeach()
# Pack the files in the archive
--- /dev/null
+$ ${bindir:=.}/context-defaults
+> [simix_context/VERBOSE] Using Boost contexts. Welcome to the 21th century.
+> [simix_context/VERBOSE] Creating a context of stack 8Mb
-$ ${bindir:=.}/check-defaults
+$ ${bindir:=.}/context-defaults
> [simix_context/VERBOSE] Using raw contexts. Because the glibc is just not good enough for us.
+> [simix_context/VERBOSE] Creating a context of stack 8Mb
\ No newline at end of file
-$ ${bindir:=.}/check-defaults
+$ ${bindir:=.}/context-defaults
> [simix_context/VERBOSE] Activating thread context factory
--- /dev/null
+$ ${bindir:=.}/context-defaults
+> [simix_context/VERBOSE] Activating SYSV context factory
+> [simix_context/VERBOSE] Creating a context of stack 8Mb
+
-foreach(x check-defaults generic-simcalls stack-overflow)
+foreach(x generic-simcalls stack-overflow)
add_executable (${x} EXCLUDE_FROM_ALL ${x}/${x}.cpp)
target_link_libraries(${x} simgrid)
set_target_properties(${x} PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/${x})
add_dependencies(tests ${x})
endforeach()
-foreach (factory raw thread boost ucontext)
- set(tesh_files ${tesh_files} ${CMAKE_CURRENT_SOURCE_DIR}/check-defaults/factory_${factory}.tesh)
-endforeach()
-
set(teshsuite_src ${teshsuite_src} PARENT_SCOPE)
set(tesh_files ${tesh_files}
${CMAKE_CURRENT_SOURCE_DIR}/stack-overflow/stack-overflow.tesh
${CMAKE_CURRENT_SOURCE_DIR}/generic-simcalls/generic-simcalls.tesh
PARENT_SCOPE)
-IF(HAVE_RAW_CONTEXTS)
- ADD_TESH(tesh-simix-factory-default --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/simix/check-defaults --cd ${CMAKE_HOME_DIRECTORY}/teshsuite/simix/check-defaults factory_raw.tesh)
-ELSEIF(HAVE_UCONTEXT_CONTEXTS)
- ADD_TESH(tesh-simix-factory-default --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/simix/check-defaults --cd ${CMAKE_HOME_DIRECTORY}/teshsuite/simix/check-defaults factory_ucontext.tesh)
-ELSEIF(HAVE_BOOST_CONTEXTS)
- ADD_TESH(tesh-simix-factory-default --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/simix/check-defaults --cd ${CMAKE_HOME_DIRECTORY}/teshsuite/simix/check-defaults factory_boost.tesh)
-ELSE()
- ADD_TESH(tesh-simix-factory-default --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/simix/check-defaults --cd ${CMAKE_HOME_DIRECTORY}/teshsuite/simix/check-defaults factory_thread.tesh)
-ENDIF()
-
if (NOT enable_memcheck AND NOT enable_address_sanitizer AND NOT enable_thread_sanitizer)
ADD_TESH_FACTORIES(stack-overflow "ucontext;raw;boost" --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/simix/stack-overflow --setenv srcdir=${CMAKE_HOME_DIRECTORY} --cd ${CMAKE_HOME_DIRECTORY}/teshsuite/simix/stack-overflow stack-overflow.tesh)
if (WIN32)
endif()
ADD_TESH_FACTORIES(generic-simcalls "thread;ucontext;raw;boost" --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/simix/generic-simcalls --setenv srcdir=${CMAKE_HOME_DIRECTORY} --cd ${CMAKE_HOME_DIRECTORY}/teshsuite/simix/generic-simcalls generic-simcalls.tesh)
-foreach (factory raw thread boost ucontext)
- string (TOUPPER have_${factory}_contexts VARNAME)
- if (${factory} STREQUAL "thread" OR ${VARNAME})
- # Cannot use ADD_TESH() here since ${factory} is part of the tesh filename
- ADD_TESH(tesh-simix-factory-${factory} --cfg contexts/factory:${factory} --setenv bindir=${CMAKE_BINARY_DIR}/teshsuite/simix/check-defaults --cd ${CMAKE_HOME_DIRECTORY}/teshsuite/simix/check-defaults factory_${factory}.tesh)
- endif()
-endforeach()
+++ /dev/null
-$ ${bindir:=.}/check-defaults
-> [simix_context/VERBOSE] Using Boost contexts. Welcome to the 21th century.
+++ /dev/null
-$ ${bindir:=.}/check-defaults
-> [simix_context/VERBOSE] Activating SYSV context factory