llvm-project/llvm/unittests/Support/ProgramStackTest.cpp
David Spickett f7fdc8d0cf [llvm][Support] Disable runOnNewStack test when threading is disabled
On our buildbot https://lab.llvm.org/buildbot/#/builders/122/builds/1478,
one of the new tests added by https://github.com/llvm/llvm-project/pull/136046
failed.

This is because on non-Apple Silicon platforms, the implementation
is to start a new thread, but when threading is disabled this is the
same as calling a function normally.
2025-05-02 09:52:47 +00:00

41 lines
1.4 KiB
C++

//===- unittest/Support/ProgramStackTest.cpp ------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#include "llvm/Support/ProgramStack.h"
#include "llvm/Support/Process.h"
#include "gtest/gtest.h"
using namespace llvm;
// One way of running on a new stack is to start a new thread. When threading
// is disabled a "new thread" is implemented as simply calling the function.
#if LLVM_ENABLE_THREADS
static uintptr_t func(int &A) {
A = 7;
return getStackPointer();
}
static void func2(int &A) {
A = 5;
}
TEST(ProgramStackTest, runOnNewStack) {
int A = 0;
uintptr_t Stack = runOnNewStack(0, function_ref<uintptr_t(int &)>(func), A);
EXPECT_EQ(A, 7);
intptr_t StackDiff = (intptr_t)llvm::getStackPointer() - (intptr_t)Stack;
size_t StackDistance = (size_t)std::abs(StackDiff);
// Page size is used as it's large enough to guarantee were not on the same
// stack but not too large to cause spurious failures.
EXPECT_GT(StackDistance, llvm::sys::Process::getPageSizeEstimate());
runOnNewStack(0, function_ref<void(int &)>(func2), A);
EXPECT_EQ(A, 5);
}
#endif /*if LLVM_ENABLE_THREADS */