mirror of
https://github.com/hashcat/hashcat.git
synced 2025-01-16 02:31:02 +00:00
commit
72abe90e10
@ -52,6 +52,11 @@
|
|||||||
#include <mach/mach.h>
|
#include <mach/mach.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef __FreeBSD__
|
||||||
|
#include <termios.h>
|
||||||
|
#include <sys/ioctl.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
typedef void *OCL_LIB;
|
typedef void *OCL_LIB;
|
||||||
|
|
||||||
#ifdef HAVE_HWMON
|
#ifdef HAVE_HWMON
|
||||||
|
@ -27,6 +27,10 @@
|
|||||||
// #include <CL/cl_ext.h> // used for CL_DEVICE_TOPOLOGY_AMD but broken for dual GPU
|
// #include <CL/cl_ext.h> // used for CL_DEVICE_TOPOLOGY_AMD but broken for dual GPU
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef __FreeBSD__
|
||||||
|
#include <CL/cl.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <shared.h>
|
#include <shared.h>
|
||||||
|
|
||||||
typedef cl_mem (CL_API_CALL *OCL_CLCREATEBUFFER) (cl_context, cl_mem_flags, size_t, void *, cl_int *);
|
typedef cl_mem (CL_API_CALL *OCL_CLCREATEBUFFER) (cl_context, cl_mem_flags, size_t, void *, cl_int *);
|
||||||
|
13
src/Makefile
13
src/Makefile
@ -17,7 +17,7 @@ UNAME := $(shell uname -s)
|
|||||||
# we need to strip the windows version number to be able to build hashcat on cygwin hosts
|
# we need to strip the windows version number to be able to build hashcat on cygwin hosts
|
||||||
UNAME := $(patsubst CYGWIN_NT-%,CYGWIN_NT-,$(UNAME))
|
UNAME := $(patsubst CYGWIN_NT-%,CYGWIN_NT-,$(UNAME))
|
||||||
|
|
||||||
ifeq (,$(filter $(UNAME),Linux Darwin CYGWIN_NT-))
|
ifeq (,$(filter $(UNAME),Linux Darwin CYGWIN_NT- FreeBSD))
|
||||||
$(error "! Your Operating System ($(UNAME)) is not supported by $(PROG_NAME) Makefile")
|
$(error "! Your Operating System ($(UNAME)) is not supported by $(PROG_NAME) Makefile")
|
||||||
endif
|
endif
|
||||||
|
|
||||||
@ -66,6 +66,10 @@ SED := sed
|
|||||||
ifeq ($(UNAME),Darwin)
|
ifeq ($(UNAME),Darwin)
|
||||||
SED := gsed
|
SED := gsed
|
||||||
endif
|
endif
|
||||||
|
ifeq ($(UNAME),FreeBSD)
|
||||||
|
CC := cc
|
||||||
|
SED := gsed
|
||||||
|
endif
|
||||||
|
|
||||||
##
|
##
|
||||||
## Cross compiler paths
|
## Cross compiler paths
|
||||||
@ -126,6 +130,13 @@ CFLAGS_NATIVE += -DHAVE_HWMON
|
|||||||
LFLAGS_NATIVE += $(LDFLAGS)
|
LFLAGS_NATIVE += $(LDFLAGS)
|
||||||
endif # linux
|
endif # linux
|
||||||
|
|
||||||
|
ifeq ($(UNAME),FreeBSD)
|
||||||
|
CFLAGS_NATIVE := -D_POSIX
|
||||||
|
CFLAGS_NATIVE += $(CFLAGS)
|
||||||
|
LFLAGS_NATIVE := -lpthread
|
||||||
|
LFLAGS_NATIVE += $(LDFLAGS)
|
||||||
|
endif # freebsd
|
||||||
|
|
||||||
##
|
##
|
||||||
## Cross compilation target
|
## Cross compilation target
|
||||||
##
|
##
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
* License.....: MIT
|
* License.....: MIT
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef DARWIN
|
#if defined(DARWIN) || defined(__FreeBSD__)
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -6171,7 +6171,8 @@ int main (int argc, char **argv)
|
|||||||
|
|
||||||
char *exec_path = get_exec_path ();
|
char *exec_path = get_exec_path ();
|
||||||
|
|
||||||
#if defined(LINUX) || defined(__APPLE__)
|
|
||||||
|
#if defined(LINUX) || defined(__APPLE__) || defined(__FreeBSD__)
|
||||||
|
|
||||||
char *resolved_install_folder = realpath (INSTALL_FOLDER, NULL);
|
char *resolved_install_folder = realpath (INSTALL_FOLDER, NULL);
|
||||||
char *resolved_exec_path = realpath (exec_path, NULL);
|
char *resolved_exec_path = realpath (exec_path, NULL);
|
||||||
|
30
src/shared.c
30
src/shared.c
@ -10,6 +10,11 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef __FreeBSD__
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <pthread_np.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <shared.h>
|
#include <shared.h>
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
|
|
||||||
@ -2382,7 +2387,7 @@ int tty_fix()
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef DARWIN
|
#if defined(DARWIN) || defined(__FreeBSD__)
|
||||||
static struct termios savemodes;
|
static struct termios savemodes;
|
||||||
static int havemodes = 0;
|
static int havemodes = 0;
|
||||||
|
|
||||||
@ -4371,6 +4376,23 @@ char *get_exec_path ()
|
|||||||
|
|
||||||
const int len = strlen (exec_path);
|
const int len = strlen (exec_path);
|
||||||
|
|
||||||
|
#elif __FreeBSD__
|
||||||
|
|
||||||
|
#include <sys/sysctl.h>
|
||||||
|
|
||||||
|
int mib[4];
|
||||||
|
mib[0] = CTL_KERN;
|
||||||
|
mib[1] = KERN_PROC;
|
||||||
|
mib[2] = KERN_PROC_PATHNAME;
|
||||||
|
mib[3] = -1;
|
||||||
|
|
||||||
|
char tmp[32] = { 0 };
|
||||||
|
|
||||||
|
size_t size = exec_path_len;
|
||||||
|
sysctl(mib, 4, exec_path, &size, NULL, 0);
|
||||||
|
|
||||||
|
const int len = readlink (tmp, exec_path, exec_path_len - 1);
|
||||||
|
|
||||||
#else
|
#else
|
||||||
#error Your Operating System is not supported or detected
|
#error Your Operating System is not supported or detected
|
||||||
#endif
|
#endif
|
||||||
@ -4523,6 +4545,9 @@ void set_cpu_affinity (char *cpu_affinity)
|
|||||||
{
|
{
|
||||||
#ifdef _WIN
|
#ifdef _WIN
|
||||||
DWORD_PTR aff_mask = 0;
|
DWORD_PTR aff_mask = 0;
|
||||||
|
#elif __FreeBSD__
|
||||||
|
cpuset_t cpuset;
|
||||||
|
CPU_ZERO (&cpuset);
|
||||||
#elif _POSIX
|
#elif _POSIX
|
||||||
cpu_set_t cpuset;
|
cpu_set_t cpuset;
|
||||||
CPU_ZERO (&cpuset);
|
CPU_ZERO (&cpuset);
|
||||||
@ -4570,6 +4595,9 @@ void set_cpu_affinity (char *cpu_affinity)
|
|||||||
#ifdef _WIN
|
#ifdef _WIN
|
||||||
SetProcessAffinityMask (GetCurrentProcess (), aff_mask);
|
SetProcessAffinityMask (GetCurrentProcess (), aff_mask);
|
||||||
SetThreadAffinityMask (GetCurrentThread (), aff_mask);
|
SetThreadAffinityMask (GetCurrentThread (), aff_mask);
|
||||||
|
#elif __FreeBSD__
|
||||||
|
pthread_t thread = pthread_self ();
|
||||||
|
pthread_setaffinity_np (thread, sizeof (cpuset_t), &cpuset);
|
||||||
#elif _POSIX
|
#elif _POSIX
|
||||||
pthread_t thread = pthread_self ();
|
pthread_t thread = pthread_self ();
|
||||||
pthread_setaffinity_np (thread, sizeof (cpu_set_t), &cpuset);
|
pthread_setaffinity_np (thread, sizeof (cpu_set_t), &cpuset);
|
||||||
|
Loading…
Reference in New Issue
Block a user