Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 9 additions & 3 deletions eng/common/cross/toolchain.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -225,13 +225,19 @@ elseif(ILLUMOS)
locate_toolchain_exec(g++ CMAKE_CXX_COMPILER)
elseif(HAIKU)
set(CMAKE_SYSROOT "${CROSS_ROOTFS}")
set(CMAKE_PROGRAM_PATH "${CMAKE_PROGRAM_PATH};${CROSS_ROOTFS}/cross-tools-x86_64/bin")
set(CMAKE_SYSTEM_PREFIX_PATH "${CROSS_ROOTFS}")
set(CMAKE_C_STANDARD_LIBRARIES "${CMAKE_C_STANDARD_LIBRARIES} -lssp")
set(CMAKE_CXX_STANDARD_LIBRARIES "${CMAKE_CXX_STANDARD_LIBRARIES} -lssp")

locate_toolchain_exec(gcc CMAKE_C_COMPILER)
locate_toolchain_exec(g++ CMAKE_CXX_COMPILER)
if ($ENV{CCC_CC} MATCHES ".*gcc.*")
set(CMAKE_PROGRAM_PATH "${CMAKE_PROGRAM_PATH};${CROSS_ROOTFS}/cross-tools-x86_64/bin")
locate_toolchain_exec(gcc CMAKE_C_COMPILER)
locate_toolchain_exec(g++ CMAKE_CXX_COMPILER)
else()
set(CMAKE_C_COMPILER_EXTERNAL_TOOLCHAIN "${CROSS_ROOTFS}/cross-tools-x86_64")
set(CMAKE_CXX_COMPILER_EXTERNAL_TOOLCHAIN "${CROSS_ROOTFS}/cross-tools-x86_64")
set(CMAKE_ASM_COMPILER_EXTERNAL_TOOLCHAIN "${CROSS_ROOTFS}/cross-tools-x86_64")
endif()

# let CMake set up the correct search paths
include(Platform/Haiku)
Expand Down
6 changes: 5 additions & 1 deletion eng/native/configureplatform.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -494,7 +494,11 @@ if(NOT CLR_CMAKE_TARGET_BROWSER AND NOT CLR_CMAKE_TARGET_WASI)
# The default linker on Solaris also does not support PIE.
if(NOT CLR_CMAKE_TARGET_ANDROID AND NOT CLR_CMAKE_TARGET_SUNOS AND NOT CLR_CMAKE_TARGET_APPLE AND NOT MSVC)
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -pie")
add_compile_options($<$<STREQUAL:$<TARGET_PROPERTY:TYPE>,EXECUTABLE>:-fPIE>)
if(CLR_CMAKE_TARGET_HAIKU)
add_compile_options($<$<STREQUAL:$<TARGET_PROPERTY:TYPE>,EXECUTABLE>:-fPIC>)
else()
add_compile_options($<$<STREQUAL:$<TARGET_PROPERTY:TYPE>,EXECUTABLE>:-fPIE>)
endif()
add_compile_options($<$<STREQUAL:$<TARGET_PROPERTY:TYPE>,SHARED_LIBRARY>:-fPIC>)
endif()

Expand Down
2 changes: 1 addition & 1 deletion src/coreclr/gc/unix/gcenv.unix.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -208,7 +208,7 @@ bool GCToOSInterface::Initialize()

#else // HAVE_SCHED_GETAFFINITY

for (size_t i = 0; i < configuredCpuCount; i++)
for (int i = 0; i < configuredCpuCount; i++)
{
g_processAffinitySet.Add(i);
}
Expand Down
4 changes: 2 additions & 2 deletions src/native/libs/System.Native/pal_environment.c
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,8 @@ char** SystemNative_GetEnviron(void)
#endif
}

void SystemNative_FreeEnviron(char** environ)
void SystemNative_FreeEnviron(char** environment)
{
// no op
(void)environ;
(void)environment;
}
2 changes: 1 addition & 1 deletion src/native/libs/System.Native/pal_mount.c
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@
#endif // __HAIKU__

// Android does not define MNTOPT_RO
#ifndef MNTOPT_RO
#if !defined(MNTOPT_RO) && (HAVE_SYS_MNTENT_H || HAVE_MNTENT_H)
#define MNTOPT_RO "r"
#endif
#endif
Expand Down
2 changes: 1 addition & 1 deletion src/native/libs/System.Native/pal_networking.c
Original file line number Diff line number Diff line change
Expand Up @@ -3681,6 +3681,7 @@ int32_t SystemNative_SendFile(intptr_t out_fd, intptr_t in_fd, int64_t offset, i
// Emulate sendfile using a simple read/send loop.
*sent = 0;
char* buffer = NULL;
size_t bufferLength = Min((size_t)count, 80 * 1024 * sizeof(char));

// Save the original input file position and seek to the offset position
off_t inputFileOrigOffset = lseek(infd, 0, SEEK_CUR);
Expand All @@ -3690,7 +3691,6 @@ int32_t SystemNative_SendFile(intptr_t out_fd, intptr_t in_fd, int64_t offset, i
}

// Allocate a buffer
size_t bufferLength = Min((size_t)count, 80 * 1024 * sizeof(char));
buffer = (char*)malloc(bufferLength);
if (buffer == NULL)
{
Expand Down
13 changes: 9 additions & 4 deletions src/native/libs/System.Native/pal_process.c
Original file line number Diff line number Diff line change
Expand Up @@ -784,24 +784,29 @@ static int32_t ConvertRLimitResourcesPalToPlatform(RLimitResources value)
#elif defined(RLIMIT_VMEM)
case PAL_RLIMIT_RSS:
return RLIMIT_VMEM;
#else
case PAL_RLIMIT_RSS:
break;
#endif
#ifdef RLIMIT_MEMLOCK
case PAL_RLIMIT_MEMLOCK:
return RLIMIT_MEMLOCK;
#elif defined(RLIMIT_VMEM)
case PAL_RLIMIT_MEMLOCK:
return RLIMIT_VMEM;
#else
case PAL_RLIMIT_MEMLOCK:
break;
#endif
#ifdef RLIMIT_NPROC
case PAL_RLIMIT_NPROC:
return RLIMIT_NPROC;
#else
case PAL_RLIMIT_NPROC:
break;
#endif
case PAL_RLIMIT_NOFILE:
return RLIMIT_NOFILE;
#if !defined(RLIMIT_RSS) || !(defined(RLIMIT_MEMLOCK) || defined(RLIMIT_VMEM)) || !defined(RLIMIT_NPROC)
default:
break;
#endif
}

assert_msg(false, "Unknown RLIMIT value", (int)value);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1005,7 +1005,11 @@ EVP_PKEY* CryptoNative_LoadKeyFromProvider(const char* providerName, const char*
EvpPKeyExtraHandle* extra = (EvpPKeyExtraHandle*)malloc(sizeof(EvpPKeyExtraHandle));
extra->prov = prov;
extra->libCtx = libCtx;
#if defined(TARGET_HAIKU) && defined(__clang__)
__c11_atomic_init(&extra->refCount, 1);
#else
atomic_init(&extra->refCount, 1);
#endif
*extraHandle = extra;
}

Expand Down
Loading