Skip to content

Commit

Permalink
Ubuntu20.04 と Ubuntu22.04 のビルドに clang-15 を使うように修正
Browse files Browse the repository at this point in the history
- Ubuntu20.04 は llvm.sh でインストールする
- Ubuntu22.04 は apt でインストールする
  • Loading branch information
torikizi committed Nov 11, 2023
1 parent f6a72ea commit 8150979
Show file tree
Hide file tree
Showing 3 changed files with 168 additions and 166 deletions.
16 changes: 6 additions & 10 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -151,8 +151,8 @@ elseif(MOMO_PACKAGE_NAME STREQUAL "ubuntu-20.04_x86_64")
set(WEBRTC_LIBRARY_DIR /root/webrtc/lib)

# /root/llvm/clang にあるコンパイラは使わず、apt でインストールした clang-10 を利用する
set(CMAKE_C_COMPILER clang-10)
set(CMAKE_CXX_COMPILER clang++-10)
set(CMAKE_C_COMPILER clang-15)
set(CMAKE_CXX_COMPILER clang++-15)

set(USE_LIBCXX ON)
set(LIBCXX_INCLUDE_DIR /root/llvm/libcxx/include)
Expand Down Expand Up @@ -196,9 +196,9 @@ elseif(MOMO_PACKAGE_NAME STREQUAL "ubuntu-22.04_x86_64")
set(WEBRTC_INCLUDE_DIR /root/webrtc/include)
set(WEBRTC_LIBRARY_DIR /root/webrtc/lib)

# /root/llvm/clang にあるコンパイラは使わず、apt でインストールした clang-12 を利用する
set(CMAKE_C_COMPILER clang-12)
set(CMAKE_CXX_COMPILER clang++-12)
# /root/llvm/clang にあるコンパイラは使わず、apt でインストールした clang-15 を利用する
set(CMAKE_C_COMPILER clang-15)
set(CMAKE_CXX_COMPILER clang++-15)

set(USE_LIBCXX ON)
set(LIBCXX_INCLUDE_DIR /root/llvm/libcxx/include)
Expand Down Expand Up @@ -316,11 +316,7 @@ target_sources(momo

target_include_directories(momo PRIVATE src)

if (WIN32)
set_target_properties(momo PROPERTIES CXX_STANDARD 20 C_STANDARD 99)
else()
set_target_properties(momo PROPERTIES CXX_STANDARD 17 C_STANDARD 99)
endif()
set_target_properties(momo PROPERTIES CXX_STANDARD 20 C_STANDARD 99)

target_link_libraries(momo
PRIVATE
Expand Down
162 changes: 84 additions & 78 deletions build/ubuntu-20.04_x86_64/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -39,29 +39,29 @@ RUN \
&& cd /root/boost-source/source \
&& echo 'using clang : : /root/llvm/clang/bin/clang++ : ;' > project-config.jam \
&& ./b2 \
cxxstd=17 \
cxxflags=' \
-D_LIBCPP_ABI_NAMESPACE=Cr \
-D_LIBCPP_ABI_VERSION=2 \
-D_LIBCPP_DISABLE_AVAILABILITY \
-nostdinc++ \
-isystem/root/llvm/libcxx/include \
' \
linkflags=' \
' \
toolset=clang \
visibility=global \
target-os=linux \
address-model=64 \
link=static \
variant=release \
install \
-d+0 \
-j`nproc` \
--ignore-site-config \
--prefix=/root/boost \
--with-filesystem \
--with-json
cxxstd=17 \
cxxflags=' \
-D_LIBCPP_ABI_NAMESPACE=Cr \
-D_LIBCPP_ABI_VERSION=2 \
-D_LIBCPP_DISABLE_AVAILABILITY \
-nostdinc++ \
-isystem/root/llvm/libcxx/include \
' \
linkflags=' \
' \
toolset=clang \
visibility=global \
target-os=linux \
address-model=64 \
link=static \
variant=release \
install \
-d+0 \
-j`nproc` \
--ignore-site-config \
--prefix=/root/boost \
--with-filesystem \
--with-json

# CLI11 の取得

Expand All @@ -85,45 +85,45 @@ RUN \
&& mkdir -p /root/sdl2-source/build \
&& cd /root/sdl2-source/build \
&& cmake ../source \
-DCMAKE_BUILD_TYPE=Release \
-DCMAKE_INSTALL_PREFIX=/root/SDL2 \
-DCMAKE_C_COMPILER=/root/llvm/clang/bin/clang \
-DCMAKE_CXX_COMPILER=/root/llvm/clang/bin/clang++ \
-DBUILD_SHARED_LIBS=OFF \
-DSDL_ATOMIC=OFF \
-DSDL_AUDIO=OFF \
-DSDL_VIDEO=ON \
-DSDL_RENDER=ON \
-DSDL_EVENTS=ON \
-DSDL_JOYSTICK=ON \
-DSDL_HAPTIC=ON \
-DSDL_POWER=ON \
-DSDL_THREADS=ON \
-DSDL_TIMERS=OFF \
-DSDL_FILE=OFF \
-DSDL_LOADSO=ON \
-DSDL_CPUINFO=OFF \
-DSDL_FILESYSTEM=OFF \
-DSDL_DLOPEN=ON \
-DSDL_SENSOR=ON \
-DVIDEO_OPENGL=ON \
-DVIDEO_OPENGLES=ON \
-DVIDEO_RPI=OFF \
-DVIDEO_WAYLAND=OFF \
-DVIDEO_X11=ON \
-DX11_SHARED=OFF \
-DVIDEO_X11_XCURSOR=OFF \
-DVIDEO_X11_XINERAMA=OFF \
-DVIDEO_X11_XINPUT=OFF \
-DVIDEO_X11_XRANDR=OFF \
-DVIDEO_X11_XSCRNSAVER=OFF \
-DVIDEO_X11_XSHAPE=OFF \
-DVIDEO_X11_XVM=OFF \
-DVIDEO_VULKAN=OFF \
-DVIDEO_VIVANTE=OFF \
-DVIDEO_COCOA=OFF \
-DVIDEO_METAL=OFF \
-DVIDEO_KMSDRM=OFF \
-DCMAKE_BUILD_TYPE=Release \
-DCMAKE_INSTALL_PREFIX=/root/SDL2 \
-DCMAKE_C_COMPILER=/root/llvm/clang/bin/clang \
-DCMAKE_CXX_COMPILER=/root/llvm/clang/bin/clang++ \
-DBUILD_SHARED_LIBS=OFF \
-DSDL_ATOMIC=OFF \
-DSDL_AUDIO=OFF \
-DSDL_VIDEO=ON \
-DSDL_RENDER=ON \
-DSDL_EVENTS=ON \
-DSDL_JOYSTICK=ON \
-DSDL_HAPTIC=ON \
-DSDL_POWER=ON \
-DSDL_THREADS=ON \
-DSDL_TIMERS=OFF \
-DSDL_FILE=OFF \
-DSDL_LOADSO=ON \
-DSDL_CPUINFO=OFF \
-DSDL_FILESYSTEM=OFF \
-DSDL_DLOPEN=ON \
-DSDL_SENSOR=ON \
-DVIDEO_OPENGL=ON \
-DVIDEO_OPENGLES=ON \
-DVIDEO_RPI=OFF \
-DVIDEO_WAYLAND=OFF \
-DVIDEO_X11=ON \
-DX11_SHARED=OFF \
-DVIDEO_X11_XCURSOR=OFF \
-DVIDEO_X11_XINERAMA=OFF \
-DVIDEO_X11_XINPUT=OFF \
-DVIDEO_X11_XRANDR=OFF \
-DVIDEO_X11_XSCRNSAVER=OFF \
-DVIDEO_X11_XSHAPE=OFF \
-DVIDEO_X11_XVM=OFF \
-DVIDEO_VULKAN=OFF \
-DVIDEO_VIVANTE=OFF \
-DVIDEO_COCOA=OFF \
-DVIDEO_METAL=OFF \
-DVIDEO_KMSDRM=OFF \
&& make -j`nproc` \
&& make install

Expand All @@ -137,7 +137,13 @@ RUN set -ex \
&& apt-key adv --fetch-keys https://developer.download.nvidia.com/compute/cuda/repos/ubuntu2004/x86_64/3bf863cc.pub \
&& add-apt-repository "deb http://developer.download.nvidia.com/compute/cuda/repos/ubuntu2004/x86_64/ /" \
&& apt-get update \
&& DEBIAN_FRONTEND=noninteractive apt-get -y install cuda=$CUDA_VERSION clang-10
&& DEBIAN_FRONTEND=noninteractive apt-get -y install cuda=$CUDA_VERSION

# llvm.sh で Clang 15 のインストール
RUN set -ex \
&& wget https://apt.llvm.org/llvm.sh \
&& chmod a+x llvm.sh \
&& ./llvm.sh 15

# libva
ARG LIBVA_VERSION
Expand All @@ -146,13 +152,13 @@ RUN set -ex \
&& mkdir -p /root/libva-build \
&& cd /root/libva-build \
&& CC=/root/llvm/clang/bin/clang \
CXX=/root/llvm/clang/bin/clang++ \
CFLAGS="-fPIC" \
/root/libva-source/autogen.sh \
--enable-static \
--disable-shared \
--with-drivers-path=/usr/lib/x86_64-linux-gnu/dri \
--prefix /root/libva \
CXX=/root/llvm/clang/bin/clang++ \
CFLAGS="-fPIC" \
/root/libva-source/autogen.sh \
--enable-static \
--disable-shared \
--with-drivers-path=/usr/lib/x86_64-linux-gnu/dri \
--prefix /root/libva \
&& make -j`nproc` \
&& make install \
&& rm -rf /root/libva-build \
Expand All @@ -167,14 +173,14 @@ RUN set -ex \
&& mkdir -p /root/msdk-build \
&& cd /root/msdk-build \
&& cmake \
-DCMAKE_INSTALL_PREFIX=/root/msdk \
-DCMAKE_BUILD_TYPE=Release \
-DCMAKE_PREFIX_PATH=/root/libva \
-DCMAKE_C_COMPILER=/root/llvm/clang/bin/clang \
-DCMAKE_CXX_COMPILER=/root/llvm/clang/bin/clang++ \
-DBUILD_SAMPLES=OFF \
-DBUILD_TUTORIALS=OFF \
/root/msdk-source \
-DCMAKE_INSTALL_PREFIX=/root/msdk \
-DCMAKE_BUILD_TYPE=Release \
-DCMAKE_PREFIX_PATH=/root/libva \
-DCMAKE_C_COMPILER=/root/llvm/clang/bin/clang \
-DCMAKE_CXX_COMPILER=/root/llvm/clang/bin/clang++ \
-DBUILD_SAMPLES=OFF \
-DBUILD_TUTORIALS=OFF \
/root/msdk-source \
&& cmake --build . -j`nproc` \
&& cmake --install . \
&& rm -rf /root/msdk-build \
Expand Down
Loading

0 comments on commit 8150979

Please sign in to comment.