163 lines
6.2 KiB
Ruby
163 lines
6.2 KiB
Ruby
class Tbb < Formula
|
|
desc "Rich and complete approach to parallelism in C++"
|
|
homepage "https://github.com/oneapi-src/oneTBB"
|
|
url "https://github.com/oneapi-src/oneTBB/archive/refs/tags/v2021.8.0.tar.gz"
|
|
sha256 "eee380323bb7ce864355ed9431f85c43955faaae9e9bce35c62b372d7ffd9f8b"
|
|
license "Apache-2.0"
|
|
|
|
bottle do
|
|
rebuild 1
|
|
sha256 cellar: :any, arm64_ventura: "46d04d29f58feb35f4fbb7e19ce0c7fab03c105cc6197348dd42db7a385eb23f"
|
|
sha256 cellar: :any, arm64_monterey: "45ee51718a1fdf082e0c1139b63cbb28e5e7e1c6cdad827f4e5fb3b75dd1e926"
|
|
sha256 cellar: :any, arm64_big_sur: "8d20e75d3d0e7c520864f8781a0cdd3c343be0d78e40f0346e8fcb56008fc844"
|
|
sha256 cellar: :any, ventura: "9faab40fd71f8a4697e0bd3f07b17e3059ae451ef0d068a0b55e7e468d1e57f5"
|
|
sha256 cellar: :any, monterey: "854240810a892a3e690e5c75a7160d7c924ccd4853ecdb94586f9ace22f3b2b2"
|
|
sha256 cellar: :any, big_sur: "5bfb895a4fe45dc2a142288c2ae849f5b01f71fbb18d5e6ef40014bb76f80ea0"
|
|
sha256 cellar: :any_skip_relocation, x86_64_linux: "9f41e9031bc50ebbab21271523fac58c9b72e7ed8fa45ee4a910b255a1e12d99"
|
|
end
|
|
|
|
depends_on "cmake" => :build
|
|
depends_on "python@3.11" => [:build, :test]
|
|
depends_on "swig" => :build
|
|
|
|
on_linux do
|
|
depends_on "pkg-config" => :build
|
|
depends_on "hwloc"
|
|
end
|
|
|
|
# Fix installation of Python components
|
|
# See https://github.com/oneapi-src/oneTBB/issues/343
|
|
patch :DATA
|
|
|
|
# Fix thread creation under heavy load.
|
|
# https://github.com/oneapi-src/oneTBB/pull/824
|
|
# Needed for mold: https://github.com/rui314/mold/releases/tag/v1.4.0
|
|
patch do
|
|
url "https://github.com/oneapi-src/oneTBB/commit/f12c93efd04991bc982a27e2fa6142538c33ca82.patch?full_index=1"
|
|
sha256 "637a65cca11c81fa696112aca714879a2202a20e426eff2be8d2318e344ae15c"
|
|
end
|
|
|
|
def install
|
|
# Prevent `setup.py` from installing tbb4py directly into HOMEBREW_PREFIX.
|
|
# We need this due to our `python@3.11` patch.
|
|
python = Formula["python@3.11"].opt_bin/"python3.11"
|
|
site_packages = Language::Python.site_packages(python)
|
|
inreplace "python/CMakeLists.txt", "@@SITE_PACKAGES@@", site_packages
|
|
|
|
tbb_site_packages = prefix/site_packages/"tbb"
|
|
ENV.append "LDFLAGS", "-Wl,-rpath,#{rpath},-rpath,#{rpath(source: tbb_site_packages)}"
|
|
|
|
args = %w[
|
|
-DTBB_TEST=OFF
|
|
-DTBB4PY_BUILD=ON
|
|
]
|
|
|
|
system "cmake", "-S", ".", "-B", "build/shared",
|
|
"-DBUILD_SHARED_LIBS=ON",
|
|
"-DCMAKE_INSTALL_RPATH=#{rpath}",
|
|
*args, *std_cmake_args
|
|
system "cmake", "--build", "build/shared"
|
|
system "cmake", "--install", "build/shared"
|
|
|
|
system "cmake", "-S", ".", "-B", "build/static",
|
|
"-DBUILD_SHARED_LIBS=OFF",
|
|
*args, *std_cmake_args
|
|
system "cmake", "--build", "build/static"
|
|
lib.install buildpath.glob("build/static/*/libtbb*.a")
|
|
|
|
cd "python" do
|
|
ENV.append_path "CMAKE_PREFIX_PATH", prefix.to_s
|
|
ENV["TBBROOT"] = prefix
|
|
|
|
system python, *Language::Python.setup_install_args(prefix, python)
|
|
end
|
|
|
|
return unless OS.linux?
|
|
|
|
inreplace_files = prefix.glob("rml/CMakeFiles/irml.dir/{flags.make,build.make,link.txt}")
|
|
inreplace inreplace_files, Superenv.shims_path/ENV.cxx, ENV.cxx
|
|
end
|
|
|
|
test do
|
|
# The glob that installs these might fail,
|
|
# so let's check their existence.
|
|
assert_path_exists lib/"libtbb.a"
|
|
assert_path_exists lib/"libtbbmalloc.a"
|
|
|
|
# on macOS core types are not distinguished, because libhwloc does not support it for now
|
|
# see https://github.com/oneapi-src/oneTBB/blob/690aaf497a78a75ff72cddb084579427ab0a8ffc/CMakeLists.txt#L226-L228
|
|
(testpath/"cores-types.cpp").write <<~EOS
|
|
#include <cstdlib>
|
|
#include <tbb/task_arena.h>
|
|
|
|
int main() {
|
|
const auto numa_nodes = tbb::info::numa_nodes();
|
|
const auto size = numa_nodes.size();
|
|
const auto type = numa_nodes.front();
|
|
#ifdef __APPLE__
|
|
return size == 1 && type == tbb::task_arena::automatic ? EXIT_SUCCESS : EXIT_FAILURE;
|
|
#else
|
|
return size != 1 || type != tbb::task_arena::automatic ? EXIT_SUCCESS : EXIT_FAILURE;
|
|
#endif
|
|
}
|
|
EOS
|
|
|
|
system ENV.cxx, "cores-types.cpp", "--std=c++14", "-DTBB_PREVIEW_TASK_ARENA_CONSTRAINTS_EXTENSION=1",
|
|
"-L#{lib}", "-ltbb", "-o", "core-types"
|
|
system "./core-types"
|
|
|
|
(testpath/"sum1-100.cpp").write <<~EOS
|
|
#include <iostream>
|
|
#include <tbb/blocked_range.h>
|
|
#include <tbb/parallel_reduce.h>
|
|
|
|
int main()
|
|
{
|
|
auto total = tbb::parallel_reduce(
|
|
tbb::blocked_range<int>(0, 100),
|
|
0.0,
|
|
[&](tbb::blocked_range<int> r, int running_total)
|
|
{
|
|
for (int i=r.begin(); i < r.end(); ++i) {
|
|
running_total += i + 1;
|
|
}
|
|
|
|
return running_total;
|
|
}, std::plus<int>()
|
|
);
|
|
|
|
std::cout << total << std::endl;
|
|
return 0;
|
|
}
|
|
EOS
|
|
|
|
system ENV.cxx, "sum1-100.cpp", "--std=c++14", "-L#{lib}", "-ltbb", "-o", "sum1-100"
|
|
assert_equal "5050", shell_output("./sum1-100").chomp
|
|
|
|
system Formula["python@3.11"].opt_bin/"python3.11", "-c", "import tbb"
|
|
end
|
|
end
|
|
|
|
__END__
|
|
diff --git a/python/CMakeLists.txt b/python/CMakeLists.txt
|
|
index 1d2b05f..81ba8de 100644
|
|
--- a/python/CMakeLists.txt
|
|
+++ b/python/CMakeLists.txt
|
|
@@ -40,7 +40,7 @@ add_custom_target(
|
|
${PYTHON_EXECUTABLE} ${PYTHON_BUILD_WORK_DIR}/setup.py
|
|
build -b${PYTHON_BUILD_WORK_DIR}
|
|
build_ext ${TBB4PY_INCLUDE_STRING} -L$<TARGET_FILE_DIR:TBB::tbb>
|
|
- install --prefix ${PYTHON_BUILD_WORK_DIR}/build -f
|
|
+ install --prefix ${PYTHON_BUILD_WORK_DIR}/build --install-lib ${PYTHON_BUILD_WORK_DIR}/build/@@SITE_PACKAGES@@ -f
|
|
COMMENT "Build and install to work directory the oneTBB Python module"
|
|
)
|
|
|
|
@@ -49,7 +49,7 @@ add_test(NAME python_test
|
|
-DPYTHON_MODULE_BUILD_PATH=${PYTHON_BUILD_WORK_DIR}/build
|
|
-P ${PROJECT_SOURCE_DIR}/cmake/python/test_launcher.cmake)
|
|
|
|
-install(DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/${PYTHON_BUILD_WORK_DIR}/build/
|
|
+install(DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/${PYTHON_BUILD_WORK_DIR}/
|
|
DESTINATION .
|
|
COMPONENT tbb4py)
|