SHA256
1
0
forked from pool/pocl

Accepting request 433980 from home:pluskalm:branches:science

- Use cmake macros
- Use ninja to speedup building

OBS-URL: https://build.opensuse.org/request/show/433980
OBS-URL: https://build.opensuse.org/package/show/science/pocl?expand=0&rev=12
This commit is contained in:
Martin Hauke 2016-10-09 18:20:32 +00:00 committed by Git OBS Bridge
parent 89c9b90d01
commit f667c3481a
3 changed files with 35 additions and 28 deletions

View File

@ -1,8 +1,8 @@
diff --git a/cmake/bitcode_rules.cmake b/cmake/bitcode_rules.cmake Index: cmake/bitcode_rules.cmake
index dd6853b..708ba24 100644 ===================================================================
--- a/cmake/bitcode_rules.cmake --- cmake/bitcode_rules.cmake.orig
+++ b/cmake/bitcode_rules.cmake +++ cmake/bitcode_rules.cmake
@@ -62,7 +62,7 @@ function(compile_cc_to_bc FILENAME SUBDIR BC_FILE_LIST) @@ -62,7 +62,7 @@ function(compile_cc_to_bc FILENAME SUBDI
DEPENDS "${FULL_F_PATH}" DEPENDS "${FULL_F_PATH}"
${KERNEL_DEPEND_HEADERS} ${KERNEL_DEPEND_HEADERS}
COMMAND "${CLANGXX}" ${CLANG_FLAGS} ${KERNEL_CLANGXX_FLAGS} COMMAND "${CLANGXX}" ${CLANG_FLAGS} ${KERNEL_CLANGXX_FLAGS}
@ -11,11 +11,11 @@ index dd6853b..708ba24 100644
COMMENT "Building C++ to LLVM bitcode ${BC_FILE}" COMMENT "Building C++ to LLVM bitcode ${BC_FILE}"
VERBATIM) VERBATIM)
endfunction() endfunction()
diff --git a/lib/kernel/rules.mk b/lib/kernel/rules.mk Index: lib/kernel/rules.mk
index 27bc9d4..aa9912c 100644 ===================================================================
--- a/lib/kernel/rules.mk --- lib/kernel/rules.mk.orig
+++ b/lib/kernel/rules.mk +++ lib/kernel/rules.mk
@@ -74,7 +74,7 @@ _kernel.h.pch: @top_builddir@/include/${TARGET_DIR}/types.h @top_srcdir@/include @@ -74,7 +74,7 @@ _kernel.h.pch: @top_builddir@/include/${
@CLANG@ ${CLANG_FLAGS} ${CLFLAGS} ${DEVICE_CL_FLAGS} -D__CBUILD__ -c -o $@ -include ${abs_top_srcdir}/include/_kernel_c.h $< @CLANG@ ${CLANG_FLAGS} ${CLFLAGS} ${DEVICE_CL_FLAGS} -D__CBUILD__ -c -o $@ -include ${abs_top_srcdir}/include/_kernel_c.h $<
%.cc.bc: %.cc ${LKERNEL_HDRS_EXTRA} %.cc.bc: %.cc ${LKERNEL_HDRS_EXTRA}
mkdir -p ${dir $@} mkdir -p ${dir $@}

View File

@ -1,3 +1,9 @@
-------------------------------------------------------------------
Sun Oct 9 09:17:33 UTC 2016 - mpluskal@suse.com
- Use cmake macros
- Use ninja to speedup building
------------------------------------------------------------------- -------------------------------------------------------------------
Mon Jul 4 15:04:04 UTC 2016 - mardnh@gmx.de Mon Jul 4 15:04:04 UTC 2016 - mardnh@gmx.de

View File

@ -18,11 +18,11 @@
Name: pocl Name: pocl
Version: 0.13
Release: 0
Summary: Portable Computing Language - an OpenCL implementation Summary: Portable Computing Language - an OpenCL implementation
License: MIT License: MIT
Group: Productivity/Other Group: Productivity/Other
Version: 0.13
Release: 0
# The whole code is under MIT # The whole code is under MIT
# except include/utlist.h which is under BSD (and unbundled) and # except include/utlist.h which is under BSD (and unbundled) and
# except lib/kernel/vecmath which is under GPLv3+ or LGPLv3+ (and unbundled in future) # except lib/kernel/vecmath which is under GPLv3+ or LGPLv3+ (and unbundled in future)
@ -30,11 +30,6 @@ Url: http://portablecl.org/
Source0: http://portablecl.org/downloads/%{name}-%{version}.tar.gz Source0: http://portablecl.org/downloads/%{name}-%{version}.tar.gz
Source99: pocl-rpmlintrc Source99: pocl-rpmlintrc
Patch0: 0001-Fixes-357-broken-build-with-GCC-6.1.patch Patch0: 0001-Fixes-357-broken-build-with-GCC-6.1.patch
BuildRoot: %{_tmppath}/%{name}-%{version}-build
# Only armv7l is supported
# PPC support is currently broken, due to path problems
# s390(x) and aarch64 also not supported, so use ExclusiveArch
ExclusiveArch: %{ix86} x86_64 armv7l armv7hl
BuildRequires: boost-devel BuildRequires: boost-devel
BuildRequires: cmake >= 2.8.12 BuildRequires: cmake >= 2.8.12
BuildRequires: libtool BuildRequires: libtool
@ -44,15 +39,21 @@ BuildRequires: llvm-clang > 3.5
BuildRequires: llvm-clang-devel > 3.5 BuildRequires: llvm-clang-devel > 3.5
BuildRequires: llvm-devel > 3.5 BuildRequires: llvm-devel > 3.5
BuildRequires: ncurses-devel BuildRequires: ncurses-devel
BuildRequires: ninja
BuildRequires: opencl-headers BuildRequires: opencl-headers
BuildRequires: pkgconfig BuildRequires: pkgconfig
BuildRequires: uthash-devel BuildRequires: uthash-devel
BuildRequires: pkgconfig(OpenCL) BuildRequires: pkgconfig(OpenCL)
BuildRequires: pkgconfig(glew)
BuildRequires: pkgconfig(hwloc) BuildRequires: pkgconfig(hwloc)
#BuildRequires: vecmath-devel
Requires: libstdc++-devel Requires: libstdc++-devel
Requires: llvm-clang > 3.5 Requires: llvm-clang > 3.5
Requires: uthash Requires: uthash
BuildRoot: %{_tmppath}/%{name}-%{version}-build
# Only armv7l is supported
# PPC support is currently broken, due to path problems
# s390(x) and aarch64 also not supported, so use ExclusiveArch
ExclusiveArch: %{ix86} x86_64 armv7l armv7hl
%description %description
Portable Computing Language (pocl) aims to become a MIT-licensed open source Portable Computing Language (pocl) aims to become a MIT-licensed open source
@ -71,10 +72,9 @@ multicore, multithread ...
Additional purpose of the project is to serve as a research platform for Additional purpose of the project is to serve as a research platform for
issues in parallel programming on heterogeneous platforms. issues in parallel programming on heterogeneous platforms.
%package devel %package devel
Summary: Portable Computing Language - development files Summary: Portable Computing Language - development files
Group: Development/Languages/Other Group: Development/Languages/Other
Requires: %{name}%{?_isa} = %{version}-%{release} Requires: %{name}%{?_isa} = %{version}-%{release}
Requires: opencl-headers Requires: opencl-headers
@ -85,20 +85,20 @@ and devices, both for homogeneous CPU and heterogenous GPUs/accelerators.
This Subpackage provides the development files needed for pocl. This Subpackage provides the development files needed for pocl.
%prep %prep
%setup -q %setup -q
%patch0 -p1 %patch0
%build %build
mkdir build %define __builder ninja
cd build %cmake ..\
cmake ..\
-DCMAKE_INSTALL_PREFIX=%{_prefix} \
-DCMAKE_C_COMPILER=clang \ -DCMAKE_C_COMPILER=clang \
-DCMAKE_CXX_COMPILER=clang++ \ -DCMAKE_CXX_COMPILER=clang++ \
-DWITH_LLVM_CONFIG=/usr/bin/llvm-config -DCMAKE_EXE_LINKER_FLAGS="-Wl,--as-needed -Wl,-z,now" \
make %{?_smp_mflags} -DCMAKE_MODULE_LINKER_FLAGS="-Wl,--as-needed -Wl,-z,now" \
-DCMAKE_SHARED_LINKER_FLAGS="-Wl,--as-needed -Wl,-z,now" \
-DWITH_LLVM_CONFIG=%{_bindir}/llvm-config
%make_jobs
# docs # docs
#cd doc/sphinx #cd doc/sphinx
@ -109,6 +109,7 @@ make %{?_smp_mflags}
# FIXME - should be handled upstream # FIXME - should be handled upstream
chmod 755 %{buildroot}/%{_bindir}/pocl-standalone chmod 755 %{buildroot}/%{_bindir}/pocl-standalone
mv %{buildroot}%{_prefix}%{_libdir} %{buildroot}%{_libdir}
# Unbundle vecmath # Unbundle vecmath
#rm -vf %{buildroot}/%{_libdir}/pocl/vecmath/ #rm -vf %{buildroot}/%{_libdir}/pocl/vecmath/