mirror of
https://github.com/Z3Prover/z3
synced 2025-04-06 01:24:08 +00:00
Added optional synchronization for multi-thread API logs. Relates to #798.
This commit is contained in:
parent
03f8b871a1
commit
dee7c29b19
|
@ -105,6 +105,7 @@ GIT_HASH=False
|
||||||
GIT_DESCRIBE=False
|
GIT_DESCRIBE=False
|
||||||
SLOW_OPTIMIZE=False
|
SLOW_OPTIMIZE=False
|
||||||
USE_OMP=True
|
USE_OMP=True
|
||||||
|
LOG_SYNC=False
|
||||||
|
|
||||||
FPMATH="Default"
|
FPMATH="Default"
|
||||||
FPMATH_FLAGS="-mfpmath=sse -msse -msse2"
|
FPMATH_FLAGS="-mfpmath=sse -msse -msse2"
|
||||||
|
@ -652,6 +653,7 @@ def display_help(exit_code):
|
||||||
print(" --gprof enable gprof")
|
print(" --gprof enable gprof")
|
||||||
print(" -f <path> --foci2=<path> use foci2 library at path")
|
print(" -f <path> --foci2=<path> use foci2 library at path")
|
||||||
print(" --noomp disable OpenMP and all features that require it.")
|
print(" --noomp disable OpenMP and all features that require it.")
|
||||||
|
print(" --log-sync synchronize access to API log files to enable multi-thread API logging.")
|
||||||
print("")
|
print("")
|
||||||
print("Some influential environment variables:")
|
print("Some influential environment variables:")
|
||||||
if not IS_WINDOWS:
|
if not IS_WINDOWS:
|
||||||
|
@ -678,13 +680,13 @@ def display_help(exit_code):
|
||||||
def parse_options():
|
def parse_options():
|
||||||
global VERBOSE, DEBUG_MODE, IS_WINDOWS, VS_X64, ONLY_MAKEFILES, SHOW_CPPS, VS_PROJ, TRACE, VS_PAR, VS_PAR_NUM
|
global VERBOSE, DEBUG_MODE, IS_WINDOWS, VS_X64, ONLY_MAKEFILES, SHOW_CPPS, VS_PROJ, TRACE, VS_PAR, VS_PAR_NUM
|
||||||
global DOTNET_ENABLED, DOTNET_KEY_FILE, JAVA_ENABLED, ML_ENABLED, STATIC_LIB, STATIC_BIN, PREFIX, GMP, FOCI2, FOCI2LIB, PYTHON_PACKAGE_DIR, GPROF, GIT_HASH, GIT_DESCRIBE, PYTHON_INSTALL_ENABLED, PYTHON_ENABLED
|
global DOTNET_ENABLED, DOTNET_KEY_FILE, JAVA_ENABLED, ML_ENABLED, STATIC_LIB, STATIC_BIN, PREFIX, GMP, FOCI2, FOCI2LIB, PYTHON_PACKAGE_DIR, GPROF, GIT_HASH, GIT_DESCRIBE, PYTHON_INSTALL_ENABLED, PYTHON_ENABLED
|
||||||
global LINUX_X64, SLOW_OPTIMIZE, USE_OMP
|
global LINUX_X64, SLOW_OPTIMIZE, USE_OMP, LOG_SYNC
|
||||||
try:
|
try:
|
||||||
options, remainder = getopt.gnu_getopt(sys.argv[1:],
|
options, remainder = getopt.gnu_getopt(sys.argv[1:],
|
||||||
'b:df:sxhmcvtnp:gj',
|
'b:df:sxhmcvtnp:gj',
|
||||||
['build=', 'debug', 'silent', 'x64', 'help', 'makefiles', 'showcpp', 'vsproj',
|
['build=', 'debug', 'silent', 'x64', 'help', 'makefiles', 'showcpp', 'vsproj',
|
||||||
'trace', 'dotnet', 'dotnet-key=', 'staticlib', 'prefix=', 'gmp', 'foci2=', 'java', 'parallel=', 'gprof',
|
'trace', 'dotnet', 'dotnet-key=', 'staticlib', 'prefix=', 'gmp', 'foci2=', 'java', 'parallel=', 'gprof',
|
||||||
'githash=', 'git-describe', 'x86', 'ml', 'optimize', 'noomp', 'pypkgdir=', 'python', 'staticbin'])
|
'githash=', 'git-describe', 'x86', 'ml', 'optimize', 'noomp', 'pypkgdir=', 'python', 'staticbin', 'log-sync'])
|
||||||
except:
|
except:
|
||||||
print("ERROR: Invalid command line option")
|
print("ERROR: Invalid command line option")
|
||||||
display_help(1)
|
display_help(1)
|
||||||
|
@ -749,6 +751,8 @@ def parse_options():
|
||||||
ML_ENABLED = True
|
ML_ENABLED = True
|
||||||
elif opt in ('', '--noomp'):
|
elif opt in ('', '--noomp'):
|
||||||
USE_OMP = False
|
USE_OMP = False
|
||||||
|
elif opt in ('', '--log-sync'):
|
||||||
|
LOG_SYNC = True
|
||||||
elif opt in ('--python'):
|
elif opt in ('--python'):
|
||||||
PYTHON_ENABLED = True
|
PYTHON_ENABLED = True
|
||||||
PYTHON_INSTALL_ENABLED = True
|
PYTHON_INSTALL_ENABLED = True
|
||||||
|
@ -2316,7 +2320,9 @@ def mk_config():
|
||||||
if HAS_OMP:
|
if HAS_OMP:
|
||||||
extra_opt = ' /openmp'
|
extra_opt = ' /openmp'
|
||||||
else:
|
else:
|
||||||
extra_opt = ' -D_NO_OMP_'
|
extra_opt = ' /D_NO_OMP_'
|
||||||
|
if HAS_OMP and LOG_SYNC:
|
||||||
|
extra_opt = '%s /DZ3_LOG_SYNC' % extra_opt
|
||||||
if GIT_HASH:
|
if GIT_HASH:
|
||||||
extra_opt = ' %s /D Z3GITHASH=%s' % (extra_opt, GIT_HASH)
|
extra_opt = ' %s /D Z3GITHASH=%s' % (extra_opt, GIT_HASH)
|
||||||
if STATIC_BIN:
|
if STATIC_BIN:
|
||||||
|
@ -2385,7 +2391,7 @@ def mk_config():
|
||||||
print('OCaml Native: %s' % OCAMLOPT)
|
print('OCaml Native: %s' % OCAMLOPT)
|
||||||
print('OCaml Library: %s' % OCAML_LIB)
|
print('OCaml Library: %s' % OCAML_LIB)
|
||||||
else:
|
else:
|
||||||
global CXX, CC, GMP, FOCI2, CPPFLAGS, CXXFLAGS, LDFLAGS, EXAMP_DEBUG_FLAG, FPMATH_FLAGS
|
global CXX, CC, GMP, FOCI2, CPPFLAGS, CXXFLAGS, LDFLAGS, EXAMP_DEBUG_FLAG, FPMATH_FLAGS, HAS_OMP, LOG_SYNC
|
||||||
OS_DEFINES = ""
|
OS_DEFINES = ""
|
||||||
ARITH = "internal"
|
ARITH = "internal"
|
||||||
check_ar()
|
check_ar()
|
||||||
|
@ -2423,6 +2429,8 @@ def mk_config():
|
||||||
SLIBEXTRAFLAGS = '%s -fopenmp' % SLIBEXTRAFLAGS
|
SLIBEXTRAFLAGS = '%s -fopenmp' % SLIBEXTRAFLAGS
|
||||||
else:
|
else:
|
||||||
CXXFLAGS = '%s -D_NO_OMP_' % CXXFLAGS
|
CXXFLAGS = '%s -D_NO_OMP_' % CXXFLAGS
|
||||||
|
if HAS_OMP and LOG_SYNC:
|
||||||
|
CXXFLAGS = '%s -DZ3_LOG_SYNC' % CXXFLAGS
|
||||||
if DEBUG_MODE:
|
if DEBUG_MODE:
|
||||||
CXXFLAGS = '%s -g -Wall' % CXXFLAGS
|
CXXFLAGS = '%s -g -Wall' % CXXFLAGS
|
||||||
EXAMP_DEBUG_FLAG = '-g'
|
EXAMP_DEBUG_FLAG = '-g'
|
||||||
|
|
|
@ -26,32 +26,61 @@ std::ostream * g_z3_log = 0;
|
||||||
bool g_z3_log_enabled = false;
|
bool g_z3_log_enabled = false;
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
Z3_bool Z3_API Z3_open_log(Z3_string filename) {
|
void Z3_close_log_unsafe(void) {
|
||||||
if (g_z3_log != 0)
|
|
||||||
Z3_close_log();
|
|
||||||
g_z3_log = alloc(std::ofstream, filename);
|
|
||||||
g_z3_log_enabled = true;
|
|
||||||
if (g_z3_log->bad() || g_z3_log->fail()) {
|
|
||||||
dealloc(g_z3_log);
|
|
||||||
g_z3_log = 0;
|
|
||||||
return Z3_FALSE;
|
|
||||||
}
|
|
||||||
*g_z3_log << "V \"" << Z3_MAJOR_VERSION << "." << Z3_MINOR_VERSION << "." << Z3_BUILD_NUMBER << "." << Z3_REVISION_NUMBER << " " << __DATE__ << "\"\n";
|
|
||||||
g_z3_log->flush();
|
|
||||||
return Z3_TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Z3_API Z3_append_log(Z3_string str) {
|
|
||||||
if (g_z3_log == 0)
|
|
||||||
return;
|
|
||||||
_Z3_append_log(static_cast<char const *>(str));
|
|
||||||
}
|
|
||||||
|
|
||||||
void Z3_API Z3_close_log(void) {
|
|
||||||
if (g_z3_log != 0) {
|
if (g_z3_log != 0) {
|
||||||
dealloc(g_z3_log);
|
dealloc(g_z3_log);
|
||||||
g_z3_log_enabled = false;
|
g_z3_log_enabled = false;
|
||||||
g_z3_log = 0;
|
g_z3_log = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Z3_bool Z3_API Z3_open_log(Z3_string filename) {
|
||||||
|
#ifdef Z3_LOG_SYNC
|
||||||
|
#pragma omp critical (z3_log)
|
||||||
|
{
|
||||||
|
#endif
|
||||||
|
if (g_z3_log != 0)
|
||||||
|
Z3_close_log_unsafe();
|
||||||
|
g_z3_log = alloc(std::ofstream, filename);
|
||||||
|
if (g_z3_log->bad() || g_z3_log->fail()) {
|
||||||
|
dealloc(g_z3_log);
|
||||||
|
g_z3_log = 0;
|
||||||
|
return Z3_FALSE;
|
||||||
|
}
|
||||||
|
*g_z3_log << "V \"" << Z3_MAJOR_VERSION << "." << Z3_MINOR_VERSION << "." << Z3_BUILD_NUMBER << "." << Z3_REVISION_NUMBER << " " << __DATE__ << "\"\n";
|
||||||
|
g_z3_log->flush();
|
||||||
|
g_z3_log_enabled = true;
|
||||||
|
#ifdef Z3_LOG_SYNC
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return Z3_TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Z3_API Z3_append_log(Z3_string str) {
|
||||||
|
if (g_z3_log == 0)
|
||||||
|
return;
|
||||||
|
#ifdef Z3_LOG_SYNC
|
||||||
|
#pragma omp critical (z3_log)
|
||||||
|
{
|
||||||
|
#endif
|
||||||
|
if (g_z3_log == 0)
|
||||||
|
return;
|
||||||
|
_Z3_append_log(static_cast<char const *>(str));
|
||||||
|
#ifdef Z3_LOG_SYNC
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void Z3_API Z3_close_log(void) {
|
||||||
|
if (g_z3_log != 0) {
|
||||||
|
#ifdef Z3_LOG_SYNC
|
||||||
|
#pragma omp critical (z3_log)
|
||||||
|
{
|
||||||
|
#endif
|
||||||
|
Z3_close_log_unsafe();
|
||||||
|
#ifdef Z3_LOG_SYNC
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue