From d008a45f3c33ff777ca27d43c997eece79088084 Mon Sep 17 00:00:00 2001 From: jsteube Date: Sun, 3 Jan 2016 00:40:31 +0100 Subject: [PATCH] Activate reordering or files to help integration into linux distributions Details can be found here: https://github.com/hashcat/oclHashcat/issues/20 --- extra/rules_optimize/.lock | 0 include/common.h | 3 + include/shared.h | 3 +- include/types.h | 1 + src/Makefile | 35 +++---- src/oclHashcat.c | 209 +++++++++++++++++++++---------------- src/shared.c | 31 +++++- 7 files changed, 170 insertions(+), 112 deletions(-) delete mode 100644 extra/rules_optimize/.lock diff --git a/extra/rules_optimize/.lock b/extra/rules_optimize/.lock deleted file mode 100644 index e69de29bb..000000000 diff --git a/include/common.h b/include/common.h index d62fadf4e..40c5d498f 100644 --- a/include/common.h +++ b/include/common.h @@ -70,6 +70,9 @@ typedef UINT32 uint; typedef UINT64 uint64_t; typedef HINSTANCE HM_LIB; + +#define mkdir(name,mode) mkdir (name) + #endif #define SPEED_CACHE 128 diff --git a/include/shared.h b/include/shared.h index d711d064a..9cd39e225 100644 --- a/include/shared.h +++ b/include/shared.h @@ -108,7 +108,7 @@ #define INDUCT_DIR "induct" #define OUTFILES_DIR "outfiles" -#define LOOPBACK_FILE "loopback" +#define LOOPBACK_FILE "hashcat.loopback" /** * types @@ -1922,6 +1922,7 @@ void dump_hex (const char *s, size_t size); void truecrypt_crc32 (char *file, unsigned char keytab[64]); +char *get_exec_path (); char *get_install_dir (const char *progname); char *get_profile_dir (const char *homedir); char *get_session_dir (const char *profile_dir, const char *session); diff --git a/include/types.h b/include/types.h index 55873ebdf..47875436f 100644 --- a/include/types.h +++ b/include/types.h @@ -1081,6 +1081,7 @@ typedef struct char *install_dir; char *profile_dir; char *session_dir; + char *shared_dir; char *outfile; uint outfile_format; uint outfile_autohex; diff --git a/src/Makefile b/src/Makefile index 7a76c9342..47d7f6d04 100644 --- a/src/Makefile +++ b/src/Makefile @@ -3,18 +3,11 @@ ## License.....: MIT ## -## -## Detect number of processors -## - -NPROCS := $(shell grep -c ^processor /proc/cpuinfo) -OS := $(shell uname) - ## ## Makefile flags ## -MAKEFLAGS += -l -j $(NPROCS) -rR --no-print-directory +MAKEFLAGS += -l -j -rR --no-print-directory ifneq ($(findstring clean,$(MAKECMDGOALS)),) MAKEFLAGS += -j 1 @@ -24,13 +17,11 @@ endif ## Installation paths (Linux only) ## -INSTALL_FOLDER ?= /opt/test/usr/bin -SHARED_FOLDER ?= /opt/test/usr/share/oclHashcat -DOCUMENT_FOLDER ?= /opt/test/usr/share/doc/oclHashcat +PREFIX ?= /usr/local -#INSTALL_FOLDER ?= /usr/bin -#SHARED_FOLDER ?= /usr/share/oclHashcat -#DOCUMENT_FOLDER ?= /usr/share/doc/oclHashcat +INSTALL_FOLDER ?= $(PREFIX)/bin +SHARED_FOLDER ?= $(PREFIX)/share/oclHashcat +DOCUMENT_FOLDER ?= $(PREFIX)/share/doc/oclHashcat ## ## Main SDK @@ -58,8 +49,10 @@ NVML := $(GDK)/usr/include/nvidia/gdk ## Native compiler paths ## -INSTALL := install CP := cp +RM := rm +INSTALL := install + CC_NATIVE := gcc ## @@ -112,9 +105,9 @@ native: oclHashcat binaries: linux32 linux64 win32 win64 clean: - rm -f obj/*.o lib/*.a ./*.bin ./*.exe ./*.app *.restore *.out *.pot *.dictstat *.log oclHashcat - rm -rf *.induct - rm -rf *.outfiles + $(RM) -f obj/*.o lib/*.a ./*.bin ./*.exe ./*.app *.restore *.out *.pot *.dictstat *.log oclHashcat core + $(RM) -rf *.induct + $(RM) -rf *.outfiles linux32: oclHashcat32.bin linux64: oclHashcat64.bin @@ -137,10 +130,12 @@ install: native $(CP) -a charsets/* $(SHARED_FOLDER)/charsets/ $(INSTALL) -m 755 -d $(SHARED_FOLDER)/masks $(CP) -a masks/* $(SHARED_FOLDER)/masks/ + $(INSTALL) -m 755 -d $(SHARED_FOLDER)/OpenCL + $(CP) -a OpenCL/* $(SHARED_FOLDER)/OpenCL/ $(INSTALL) -m 755 -d $(SHARED_FOLDER)/rules $(CP) -a rules/* $(SHARED_FOLDER)/rules/ - $(INSTALL) -m 755 -T hashcat.hcstat $(SHARED_FOLDER)/hashcat.hcstat - $(INSTALL) -m 755 -s -T oclHashcat64.bin $(INSTALL_FOLDER)/oclHashcat + $(INSTALL) -m 755 -T hashcat.hcstat $(SHARED_FOLDER)/hashcat.hcstat + $(INSTALL) -m 755 -T oclHashcat $(INSTALL_FOLDER)/oclHashcat uninstall: $(RM) -f $(INSTALL_FOLDER)/oclHashcat diff --git a/src/oclHashcat.c b/src/oclHashcat.c index e7747c4a7..ec1dd2df1 100644 --- a/src/oclHashcat.c +++ b/src/oclHashcat.c @@ -345,7 +345,7 @@ const char *USAGE_BIG[] = "", "* Markov:", "", - " --markov-hcstat=FILE Specify hcstat file to use, default is hashcat.hcstat", + " --markov-hcstat=FILE Specify hcstat file to use, default is hcstat", " --markov-disable Disables markov-chains, emulates classic brute-force", " --markov-classic Enables classic markov-chains, no per-position enhancement", " -t, --markov-threshold=NUM Threshold when to stop accepting new markov-chains", @@ -1594,70 +1594,70 @@ static void status_benchmark () * oclHashcat -only- functions */ -static void generate_source_kernel_filename (const uint attack_exec, const uint attack_kern, const uint kern_type, char *install_dir, char *source_file) +static void generate_source_kernel_filename (const uint attack_exec, const uint attack_kern, const uint kern_type, char *shared_dir, char *source_file) { if (attack_exec == ATTACK_EXEC_ON_GPU) { if (attack_kern == ATTACK_KERN_STRAIGHT) - snprintf (source_file, 255, "%s/OpenCL/m%05d_a0.cl", install_dir, (int) kern_type); + snprintf (source_file, 255, "%s/OpenCL/m%05d_a0.cl", shared_dir, (int) kern_type); else if (attack_kern == ATTACK_KERN_COMBI) - snprintf (source_file, 255, "%s/OpenCL/m%05d_a1.cl", install_dir, (int) kern_type); + snprintf (source_file, 255, "%s/OpenCL/m%05d_a1.cl", shared_dir, (int) kern_type); else if (attack_kern == ATTACK_KERN_BF) - snprintf (source_file, 255, "%s/OpenCL/m%05d_a3.cl", install_dir, (int) kern_type); + snprintf (source_file, 255, "%s/OpenCL/m%05d_a3.cl", shared_dir, (int) kern_type); } else - snprintf (source_file, 255, "%s/OpenCL/m%05d.cl", install_dir, (int) kern_type); + snprintf (source_file, 255, "%s/OpenCL/m%05d.cl", shared_dir, (int) kern_type); } -static void generate_cached_kernel_filename (const uint attack_exec, const uint attack_kern, const uint kern_type, char *install_dir, char *device_name, char *device_version, char *driver_version, int vendor_id, char *cached_file) +static void generate_cached_kernel_filename (const uint attack_exec, const uint attack_kern, const uint kern_type, char *profile_dir, char *device_name, char *device_version, char *driver_version, int vendor_id, char *cached_file) { if (attack_exec == ATTACK_EXEC_ON_GPU) { if (attack_kern == ATTACK_KERN_STRAIGHT) - snprintf (cached_file, 255, "%s/kernels/%d/m%05d_a0.%s_%s_%s_%d.kernel", install_dir, vendor_id, (int) kern_type, device_name, device_version, driver_version, COMPTIME); + snprintf (cached_file, 255, "%s/kernels/%d/m%05d_a0.%s_%s_%s_%d.kernel", profile_dir, vendor_id, (int) kern_type, device_name, device_version, driver_version, COMPTIME); else if (attack_kern == ATTACK_KERN_COMBI) - snprintf (cached_file, 255, "%s/kernels/%d/m%05d_a1.%s_%s_%s_%d.kernel", install_dir, vendor_id, (int) kern_type, device_name, device_version, driver_version, COMPTIME); + snprintf (cached_file, 255, "%s/kernels/%d/m%05d_a1.%s_%s_%s_%d.kernel", profile_dir, vendor_id, (int) kern_type, device_name, device_version, driver_version, COMPTIME); else if (attack_kern == ATTACK_KERN_BF) - snprintf (cached_file, 255, "%s/kernels/%d/m%05d_a3.%s_%s_%s_%d.kernel", install_dir, vendor_id, (int) kern_type, device_name, device_version, driver_version, COMPTIME); + snprintf (cached_file, 255, "%s/kernels/%d/m%05d_a3.%s_%s_%s_%d.kernel", profile_dir, vendor_id, (int) kern_type, device_name, device_version, driver_version, COMPTIME); } else { - snprintf (cached_file, 255, "%s/kernels/%d/m%05d.%s_%s_%s_%d.kernel", install_dir, vendor_id, (int) kern_type, device_name, device_version, driver_version, COMPTIME); + snprintf (cached_file, 255, "%s/kernels/%d/m%05d.%s_%s_%s_%d.kernel", profile_dir, vendor_id, (int) kern_type, device_name, device_version, driver_version, COMPTIME); } } -static void generate_source_kernel_mp_filename (const uint opti_type, const uint opts_type, char *install_dir, char *source_file) +static void generate_source_kernel_mp_filename (const uint opti_type, const uint opts_type, char *shared_dir, char *source_file) { if ((opti_type & OPTI_TYPE_BRUTE_FORCE) && (opts_type & OPTS_TYPE_PT_GENERATE_BE)) { - snprintf (source_file, 255, "%s/OpenCL/markov_be.cl", install_dir); + snprintf (source_file, 255, "%s/OpenCL/markov_be.cl", shared_dir); } else { - snprintf (source_file, 255, "%s/OpenCL/markov_le.cl", install_dir); + snprintf (source_file, 255, "%s/OpenCL/markov_le.cl", shared_dir); } } -static void generate_cached_kernel_mp_filename (const uint opti_type, const uint opts_type, char *install_dir, char *device_name, char *device_version, char *driver_version, int vendor_id, char *cached_file) +static void generate_cached_kernel_mp_filename (const uint opti_type, const uint opts_type, char *profile_dir, char *device_name, char *device_version, char *driver_version, int vendor_id, char *cached_file) { if ((opti_type & OPTI_TYPE_BRUTE_FORCE) && (opts_type & OPTS_TYPE_PT_GENERATE_BE)) { - snprintf (cached_file, 255, "%s/kernels/%d/markov_be.%s_%s_%s_%d.kernel", install_dir, vendor_id, device_name, device_version, driver_version, COMPTIME); + snprintf (cached_file, 255, "%s/kernels/%d/markov_be.%s_%s_%s_%d.kernel", profile_dir, vendor_id, device_name, device_version, driver_version, COMPTIME); } else { - snprintf (cached_file, 255, "%s/kernels/%d/markov_le.%s_%s_%s_%d.kernel", install_dir, vendor_id, device_name, device_version, driver_version, COMPTIME); + snprintf (cached_file, 255, "%s/kernels/%d/markov_le.%s_%s_%s_%d.kernel", profile_dir, vendor_id, device_name, device_version, driver_version, COMPTIME); } } -static void generate_source_kernel_amp_filename (const uint attack_kern, char *install_dir, char *source_file) +static void generate_source_kernel_amp_filename (const uint attack_kern, char *shared_dir, char *source_file) { - snprintf (source_file, 255, "%s/OpenCL/amp_a%d.cl", install_dir, attack_kern); + snprintf (source_file, 255, "%s/OpenCL/amp_a%d.cl", shared_dir, attack_kern); } -static void generate_cached_kernel_amp_filename (const uint attack_kern, char *install_dir, char *device_name, char *device_version, char *driver_version, int vendor_id, char *cached_file) +static void generate_cached_kernel_amp_filename (const uint attack_kern, char *profile_dir, char *device_name, char *device_version, char *driver_version, int vendor_id, char *cached_file) { - snprintf (cached_file, 255, "%s/kernels/%d/amp_a%d.%s_%s_%s_%d.kernel", install_dir, vendor_id, attack_kern, device_name, device_version, driver_version, COMPTIME); + snprintf (cached_file, 255, "%s/kernels/%d/amp_a%d.%s_%s_%s_%d.kernel", profile_dir, vendor_id, attack_kern, device_name, device_version, driver_version, COMPTIME); } static uint convert_from_hex (char *line_buf, const uint line_len) @@ -5305,20 +5305,79 @@ int main (int argc, char **argv) } /** - * session + * session needs to be set, always! */ if (session == NULL) session = (char *) PROGNAME; - size_t session_size = strlen (session) + 32; + /** + * folders, as discussed on https://github.com/hashcat/oclHashcat/issues/20 + */ + + char *exec_path = get_exec_path (); + + #ifdef LINUX + + char *resolved_install_folder = realpath (INSTALL_FOLDER, NULL); + char *resolved_exec_path = realpath (exec_path, NULL); + + char *install_dir = get_install_dir (resolved_exec_path); + char *profile_dir = NULL; + char *session_dir = NULL; + char *shared_dir = NULL; + + if (strcmp (install_dir, resolved_install_folder) == 0) + { + struct passwd *pw = getpwuid (getuid ()); + + const char *homedir = pw->pw_dir; + + profile_dir = get_profile_dir (homedir); + session_dir = get_session_dir (profile_dir, session); + shared_dir = strdup (SHARED_FOLDER); + + mkdir (profile_dir, 0700); + mkdir (session_dir, 0700); + } + else + { + profile_dir = install_dir; + session_dir = install_dir; + shared_dir = install_dir; + } + + myfree (resolved_install_folder); + myfree (resolved_exec_path); + + #else + + char *install_dir = get_install_dir (exec_path); + char *profile_dir = install_dir; + char *session_dir = install_dir; + char *shared_dir = shared_dir; + + #endif + + data.install_dir = install_dir; + data.profile_dir = profile_dir; + data.session_dir = session_dir; + data.shared_dir = shared_dir; + + myfree (exec_path); + + /** + * session + */ + + size_t session_size = strlen (session_dir) + 1 + strlen (session) + 32; data.session = session; char *eff_restore_file = (char *) mymalloc (session_size); char *new_restore_file = (char *) mymalloc (session_size); - snprintf (eff_restore_file, session_size - 1, "%s.restore", session); - snprintf (new_restore_file, session_size - 1, "%s.restore.new", session); + snprintf (eff_restore_file, session_size - 1, "%s/%s.restore", data.session_dir, session); + snprintf (new_restore_file, session_size - 1, "%s/%s.restore.new", data.session_dir, session); data.eff_restore_file = eff_restore_file; data.new_restore_file = new_restore_file; @@ -5999,7 +6058,7 @@ int main (int argc, char **argv) { induction_directory = (char *) mymalloc (session_size); - snprintf (induction_directory, session_size - 1, "%s.%s", session, INDUCT_DIR); + snprintf (induction_directory, session_size - 1, "%s/%s.%s", session_dir, session, INDUCT_DIR); // create induction folder if it does not already exist @@ -6015,7 +6074,7 @@ int main (int argc, char **argv) { char *induction_directory_mv = (char *) mymalloc (session_size); - snprintf (induction_directory_mv, session_size - 1, "%s.induct.%d", session, (int) proc_start); + snprintf (induction_directory_mv, session_size - 1, "%s/%s.induct.%d", session_dir, session, (int) proc_start); if (rename (induction_directory, induction_directory_mv) != 0) { @@ -6032,10 +6091,6 @@ int main (int argc, char **argv) } } - #ifdef _WIN - #define mkdir(name,mode) mkdir (name) - #endif - if (mkdir (induction_directory, 0700) == -1) { log_error ("ERROR: %s: %s", induction_directory, strerror (errno)); @@ -6056,7 +6111,7 @@ int main (int argc, char **argv) * loopback */ - size_t loopback_size = session_size + strlen (LOOPBACK_FILE) + 12; + size_t loopback_size = strlen (session_dir) + 1 + session_size + strlen (LOOPBACK_FILE) + 12; char *loopback_file = (char *) mymalloc (loopback_size); @@ -6070,7 +6125,7 @@ int main (int argc, char **argv) { outfile_check_directory = (char *) mymalloc (session_size); - snprintf (outfile_check_directory, session_size - 1, "%s.%s", session, OUTFILES_DIR); + snprintf (outfile_check_directory, session_size - 1, "%s/%s.%s", session_dir, session, OUTFILES_DIR); } else { @@ -6096,10 +6151,6 @@ int main (int argc, char **argv) } else if (outfile_check_dir == NULL) { - #ifdef _WIN - #define mkdir(name,mode) mkdir (name) - #endif - if (mkdir (outfile_check_directory, 0700) == -1) { log_error ("ERROR: %s: %s", outfile_check_directory, strerror (errno)); @@ -6170,47 +6221,6 @@ int main (int argc, char **argv) data.truecrypt_keyfiles = truecrypt_keyfiles; data.scrypt_tmto = scrypt_tmto; - /** - * folders, as discussed on https://github.com/hashcat/oclHashcat/issues/20 - */ - - #ifdef LINUX - - char *resolved_path = realpath (myargv[0], NULL); - - char *install_dir = get_install_dir (resolved_path); - char *profile_dir = NULL; - char *session_dir = NULL; - - if (strcmp (install_dir, INSTALL_FOLDER) == 0) - { - struct passwd *pw = getpwuid (getuid ()); - - const char *homedir = pw->pw_dir; - - profile_dir = get_profile_dir (homedir); - session_dir = get_session_dir (profile_dir, session); - } - else - { - profile_dir = install_dir; - session_dir = install_dir; - } - - myfree (resolved_path); - - #else - - char *install_dir = get_install_dir (myargv[0]); - char *profile_dir = install_dir; - char *session_dir = install_dir; - - #endif - - data.install_dir = install_dir; - data.profile_dir = profile_dir; - data.session_dir = session_dir; - /** * cpu affinity */ @@ -6239,7 +6249,7 @@ int main (int argc, char **argv) char *logfile = (char *) mymalloc (logfile_size); - snprintf (logfile, logfile_size - 1, "%s.log", session); + snprintf (logfile, logfile_size - 1, "%s/%s.log", session_dir, session); data.logfile = logfile; @@ -9903,7 +9913,7 @@ int main (int argc, char **argv) { memset (dictstat, 0, sizeof (dictstat)); - snprintf (dictstat, sizeof (dictstat) - 1, "%s/%s.dictstat", install_dir, PROGNAME); + snprintf (dictstat, sizeof (dictstat) - 1, "%s/hashcat.dictstat", profile_dir); dictstat_fp = fopen (dictstat, "rb"); @@ -9961,7 +9971,7 @@ int main (int argc, char **argv) memset (potfile, 0, sizeof (potfile)); - snprintf (potfile, sizeof (potfile) - 1, "%s.pot", session); + snprintf (potfile, sizeof (potfile) - 1, "%s/%s.pot", session_dir, session); data.pot_fp = NULL; @@ -12338,6 +12348,27 @@ int main (int argc, char **argv) data.vendor_id = vendor_id; + /** + * cached kernel path depends on vendor_id which we don't know, so create it here + */ + + if (profile_dir != install_dir) // not a bug + { + int vendor_id_folder_size = strlen (profile_dir) + 1 + 7 + 1 + 10 + 1; + + char *vendor_id_folder = (char *) mymalloc (vendor_id_folder_size); + + snprintf (vendor_id_folder, vendor_id_folder_size - 1, "%s/kernels", profile_dir); + + mkdir (vendor_id_folder, 0700); + + snprintf (vendor_id_folder, vendor_id_folder_size - 1, "%s/kernels/%d", profile_dir, vendor_id); + + mkdir (vendor_id_folder, 0700); + + myfree (vendor_id_folder); + } + /** * devices */ @@ -13117,7 +13148,7 @@ int main (int argc, char **argv) memset (source_file, 0, sizeof (source_file)); - generate_source_kernel_filename (attack_exec, attack_kern, kern_type, install_dir, source_file); + generate_source_kernel_filename (attack_exec, attack_kern, kern_type, shared_dir, source_file); struct stat sst; @@ -13136,7 +13167,7 @@ int main (int argc, char **argv) memset (cached_file, 0, sizeof (cached_file)); - generate_cached_kernel_filename (attack_exec, attack_kern, kern_type, install_dir, device_name, device_version, driver_version, vendor_id, cached_file); + generate_cached_kernel_filename (attack_exec, attack_kern, kern_type, profile_dir, device_name, device_version, driver_version, vendor_id, cached_file); int cached = 1; @@ -13248,7 +13279,7 @@ int main (int argc, char **argv) memset (source_file, 0, sizeof (source_file)); - generate_source_kernel_mp_filename (opti_type, opts_type, install_dir, source_file); + generate_source_kernel_mp_filename (opti_type, opts_type, shared_dir, source_file); struct stat sst; @@ -13267,7 +13298,7 @@ int main (int argc, char **argv) memset (cached_file, 0, sizeof (cached_file)); - generate_cached_kernel_mp_filename (opti_type, opts_type, install_dir, device_name, device_version, driver_version, vendor_id, cached_file); + generate_cached_kernel_mp_filename (opti_type, opts_type, profile_dir, device_name, device_version, driver_version, vendor_id, cached_file); int cached = 1; @@ -13361,7 +13392,7 @@ int main (int argc, char **argv) memset (source_file, 0, sizeof (source_file)); - generate_source_kernel_amp_filename (attack_kern, install_dir, source_file); + generate_source_kernel_amp_filename (attack_kern, shared_dir, source_file); struct stat sst; @@ -13380,7 +13411,7 @@ int main (int argc, char **argv) memset (cached_file, 0, sizeof (cached_file)); - generate_cached_kernel_amp_filename (attack_kern, install_dir, device_name, device_version, driver_version, vendor_id, cached_file); + generate_cached_kernel_amp_filename (attack_kern, profile_dir, device_name, device_version, driver_version, vendor_id, cached_file); int cached = 1; @@ -15076,7 +15107,7 @@ int main (int argc, char **argv) if (root_table_buf == NULL) root_table_buf = (hcstat_table_t *) mycalloc (SP_ROOT_CNT, sizeof (hcstat_table_t)); if (markov_table_buf == NULL) markov_table_buf = (hcstat_table_t *) mycalloc (SP_MARKOV_CNT, sizeof (hcstat_table_t)); - sp_setup_tbl (install_dir, markov_hcstat, markov_disable, markov_classic, root_table_buf, markov_table_buf); + sp_setup_tbl (shared_dir, markov_hcstat, markov_disable, markov_classic, root_table_buf, markov_table_buf); markov_threshold = (markov_threshold != 0) ? markov_threshold : CHARSIZ; @@ -15522,7 +15553,7 @@ int main (int argc, char **argv) if (root_table_buf == NULL) root_table_buf = (hcstat_table_t *) mycalloc (SP_ROOT_CNT, sizeof (hcstat_table_t)); if (markov_table_buf == NULL) markov_table_buf = (hcstat_table_t *) mycalloc (SP_MARKOV_CNT, sizeof (hcstat_table_t)); - sp_setup_tbl (install_dir, markov_hcstat, markov_disable, markov_classic, root_table_buf, markov_table_buf); + sp_setup_tbl (shared_dir, markov_hcstat, markov_disable, markov_classic, root_table_buf, markov_table_buf); markov_threshold = (markov_threshold != 0) ? markov_threshold : CHARSIZ; diff --git a/src/shared.c b/src/shared.c index 265357abd..108031c64 100644 --- a/src/shared.c +++ b/src/shared.c @@ -3730,7 +3730,7 @@ int sp_comp_val (const void *p1, const void *p2) return b2->val - b1->val; } -void sp_setup_tbl (const char *install_dir, char *hcstat, uint disable, uint classic, hcstat_table_t *root_table_buf, hcstat_table_t *markov_table_buf) +void sp_setup_tbl (const char *shared_dir, char *hcstat, uint disable, uint classic, hcstat_table_t *root_table_buf, hcstat_table_t *markov_table_buf) { uint i; uint j; @@ -3779,7 +3779,7 @@ void sp_setup_tbl (const char *install_dir, char *hcstat, uint disable, uint cla memset (hcstat_tmp, 0, sizeof (hcstat_tmp)); - snprintf (hcstat_tmp, sizeof (hcstat_tmp) - 1, "%s/%s", install_dir, SP_HCSTAT); + snprintf (hcstat_tmp, sizeof (hcstat_tmp) - 1, "%s/%s", shared_dir, SP_HCSTAT); hcstat = hcstat_tmp; } @@ -4072,6 +4072,33 @@ void usage_big_print (const char *progname) for (uint i = 0; USAGE_BIG[i] != NULL; i++) log_info (USAGE_BIG[i], progname); } +char *get_exec_path () +{ + int exec_path_len = 1024; + + char *exec_path = (char *) mymalloc (exec_path_len); + + #ifdef LINUX + + char tmp[32]; + + sprintf (tmp, "/proc/%d/exe", getpid ()); + + const int len = readlink (tmp, exec_path, exec_path_len - 1); + + #endif + + #ifdef WIN + + const int len = GetModuleFileName (NULL, exec_path, exec_path_len - 1); + + #endif + + exec_path[len] = 0; + + return exec_path; +} + char *get_install_dir (const char *progname) { char *install_dir = mystrdup (progname);