Added ifdefs for DragonflyBSD

Possible fix for #3179
This commit is contained in:
SChernykh 2022-12-16 15:26:37 +01:00
parent 25decd1b7f
commit a02afe6d4f
4 changed files with 10 additions and 10 deletions

View file

@ -27,7 +27,7 @@
#if __ARM_FEATURE_CRYPTO && !defined(__APPLE__) #if __ARM_FEATURE_CRYPTO && !defined(__APPLE__)
# include <sys/auxv.h> # include <sys/auxv.h>
# ifndef __FreeBSD__ # if !defined(__FreeBSD__) && !defined(__DragonFly__)
# include <asm/hwcap.h> # include <asm/hwcap.h>
# else # else
# include <stdint.h> # include <stdint.h>
@ -71,7 +71,7 @@ xmrig::BasicCpuInfo::BasicCpuInfo() :
# if __ARM_FEATURE_CRYPTO # if __ARM_FEATURE_CRYPTO
# if defined(__APPLE__) # if defined(__APPLE__)
m_flags.set(FLAG_AES, true); m_flags.set(FLAG_AES, true);
# elif defined(__FreeBSD__) # elif defined(__FreeBSD__) || defined(__DragonFly__)
uint64_t isar0 = READ_SPECIALREG(id_aa64isar0_el1); uint64_t isar0 = READ_SPECIALREG(id_aa64isar0_el1);
m_flags.set(FLAG_AES, ID_AA64ISAR0_AES_VAL(isar0) >= ID_AA64ISAR0_AES_BASE); m_flags.set(FLAG_AES, ID_AA64ISAR0_AES_VAL(isar0) >= ID_AA64ISAR0_AES_BASE);
# else # else

View file

@ -16,7 +16,7 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>. * along with this program. If not, see <http://www.gnu.org/licenses/>.
*/ */
#ifdef __FreeBSD__ #if defined(__FreeBSD__) || defined(__DragonFly__)
# include <sys/types.h> # include <sys/types.h>
# include <sys/param.h> # include <sys/param.h>
# include <sys/cpuset.h> # include <sys/cpuset.h>
@ -41,7 +41,7 @@
#include "version.h" #include "version.h"
#ifdef __FreeBSD__ #if defined(__FreeBSD__) || defined(__DragonFly__)
typedef cpuset_t cpu_set_t; typedef cpuset_t cpu_set_t;
#endif #endif

View file

@ -65,7 +65,7 @@
#endif #endif
#if defined(XMRIG_OS_LINUX) || (!defined(XMRIG_OS_APPLE) && !defined(__FreeBSD__)) #if defined(XMRIG_OS_LINUX) || (!defined(XMRIG_OS_APPLE) && !defined(__FreeBSD__) && !defined(__DragonFly__))
static inline int hugePagesFlag(size_t size) static inline int hugePagesFlag(size_t size)
{ {
return (static_cast<int>(log2(size)) & MAP_HUGE_MASK) << MAP_HUGE_SHIFT; return (static_cast<int>(log2(size)) & MAP_HUGE_MASK) << MAP_HUGE_SHIFT;
@ -135,7 +135,7 @@ void *xmrig::VirtualMemory::allocateExecutableMemory(size_t size, bool hugePages
# ifdef XMRIG_ARM # ifdef XMRIG_ARM
pthread_jit_write_protect_np(false); pthread_jit_write_protect_np(false);
# endif # endif
# elif defined(__FreeBSD__) # elif defined(__FreeBSD__) || defined(__DragonFly__)
void *mem = nullptr; void *mem = nullptr;
if (hugePages) { if (hugePages) {
@ -168,7 +168,7 @@ void *xmrig::VirtualMemory::allocateLargePagesMemory(size_t size)
{ {
# if defined(XMRIG_OS_APPLE) # if defined(XMRIG_OS_APPLE)
void *mem = mmap(0, size, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANON, VM_FLAGS_SUPERPAGE_SIZE_2MB, 0); void *mem = mmap(0, size, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANON, VM_FLAGS_SUPERPAGE_SIZE_2MB, 0);
# elif defined(__FreeBSD__) # elif defined(__FreeBSD__) || defined(__DragonFly__)
void *mem = mmap(0, size, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS | MAP_ALIGNED_SUPER | MAP_PREFAULT_READ, -1, 0); void *mem = mmap(0, size, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS | MAP_ALIGNED_SUPER | MAP_PREFAULT_READ, -1, 0);
# else # else
void *mem = mmap(0, size, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS | MAP_HUGETLB | MAP_POPULATE | hugePagesFlag(hugePageSize()), 0, 0); void *mem = mmap(0, size, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS | MAP_HUGETLB | MAP_POPULATE | hugePagesFlag(hugePageSize()), 0, 0);

View file

@ -31,7 +31,7 @@
#include <unistd.h> #include <unistd.h>
#include <cstdio> #include <cstdio>
#ifdef __FreeBSD__ #if defined(__FreeBSD__) || defined(__DragonFly__)
# include <kenv.h> # include <kenv.h>
#endif #endif
@ -288,7 +288,7 @@ static off_t address_from_efi()
const char *filename; const char *filename;
char linebuf[64]; char linebuf[64];
off_t address = 0; off_t address = 0;
# elif defined(__FreeBSD__) # elif defined(__FreeBSD__) || defined(__DragonFly__)
char addrstr[KENV_MVALLEN + 1]; char addrstr[KENV_MVALLEN + 1];
# endif # endif
@ -310,7 +310,7 @@ static off_t address_from_efi()
fclose(efi_systab); fclose(efi_systab);
return address; return address;
# elif defined(__FreeBSD__) # elif defined(__FreeBSD__) || defined(__DragonFly__)
if (kenv(KENV_GET, "hint.smbios.0.mem", addrstr, sizeof(addrstr)) == -1) { if (kenv(KENV_GET, "hint.smbios.0.mem", addrstr, sizeof(addrstr)) == -1) {
return EFI_NOT_FOUND; return EFI_NOT_FOUND;
} }