/builders/mesa-gl-amd-sh-0/builder-target.sh (06ee004aa2e2ada0282666c89fff6f68eab15970) (3870 bytes) (mode 100644) (type blob)
src_name=mesa
git_commit=a3782a612f1a4aaf8d16bed2113c6c798afd3011
git_url0=git://anongit.freedesktop.org/mesa/$pkg_name
pkg_dir=$pkgs_dir_root/$pkg_name
src_dir=$src_dir_root/$src_name
rm -Rf $pkg_dir
mkdir -p $pkgs_dir_root
cp -r $src_dir $pkg_dir
cd $pkg_dir
git checkout --force $git_commit
git reset --hard
# Fix language support since we don't have msgfmt (gettext thingy)
sed -i -e '/^POS=/ c POS=' ./src/util/xmlpool/Makefile.am
# fix bashisms
cp $nyan_root/builders/$pkg_name/configure.ac.bashism0.patch ./
cp $nyan_root/builders/$pkg_name/configure.ac.bashism1.patch ./
patch -Np0 -i configure.ac.bashism0.patch
patch -Np0 -i configure.ac.bashism1.patch
export NOCONFIGURE=1
./autogen.sh
unset NOCONFIGURE
build_dir=$builds_dir_root/$pkg_name-$target_gnu_triple
rm -Rf $build_dir
mkdir -p $build_dir
cd $build_dir
export "PKG_CONFIG_LIBDIR=\
$target_sysroot/nyan/libXau/0/lib/pkgconfig:\
$target_sysroot/nyan/libpthread-stubs/0/lib/pkgconfig:\
$target_sysroot/nyan/libxcb/0/lib/pkgconfig:\
$target_sysroot/nyan/libX11/0/lib/pkgconfig:\
$target_sysroot/nyan/libXfixes/0/lib/pkgconfig:\
$target_sysroot/nyan/libXdamage/0/lib/pkgconfig:\
$target_sysroot/nyan/libXxf86vm/0/lib/pkgconfig:\
$target_sysroot/nyan/libXext/0/lib/pkgconfig:\
$target_sysroot/nyan/libxshmfence/0/lib/pkgconfig:\
$target_sysroot/nyan/drm/0/lib/pkgconfig:\
$target_sysroot/nyan/xorgproto/0/share/pkgconfig:\
$target_sysroot/nyan/zlib/0/lib/pkgconfig:\
$target_sysroot/nyan/expat/0/lib/pkgconfig:\
$target_sysroot/nyan/libelf/0/lib/pkgconfig"
export PKG_CONFIG_SYSROOT_DIR=$target_sysroot
OLD_PATH=$PATH
export PATH=$cross_toolchain_dir_root/bin:$PATH
# WARNING: need to hide the cross-toolchain shared libstdc++ to work around the libtool bug while compiling dri modules
# it's even worse if you would have kept .la files
libstdcxx_so_path=$(find $cross_toolchain_dir_root -name 'libstdc++.so')
if test "x$libstdcxx_so_path" != 'x'; then
mv $libstdcxx_so_path $libstdcxx_so_path.HIDDEN
fi
# WARNING: llvm-config is _ours_ and hardcoded for mesa build
# missing a libxshmfence somewhere
export "CPPFLAGS=$(pkg-config --cflags-only-I xshmfence)"
# at link time, the only way to tell gnu ld where to look for shared lib dependencies is to pass the -rpath-link option
export "CC=$target_gnu_triple-gcc -B$target_sysroot/nyan/glibc/current/lib -L$target_sysroot/nyan/glibc/current/lib -Wl,-rpath-link,$target_sysroot/nyan/glibc/current/lib -static-libgcc"
export 'CFLAGS=-O2 -pipe -fPIC'
export "CXX=$target_gnu_triple-g++ -B$target_sysroot/nyan/glibc/current/lib -L$target_sysroot/nyan/glibc/current/lib -Wl,-rpath-link,$target_sysroot/nyan/glibc/current/lib -static-libgcc -static-libstdc++"
export "CXXFLAGS=-O2 -pipe -fPIC"
export PYTHON2=$sdk_python2_path/bin/python2
export LLVM_CONFIG_TARGET_SYSROOT=$target_sysroot
$pkg_dir/configure \
--build=$build_gnu_triple \
--host=$target_gnu_triple \
--prefix=/nyan/mesa/0 \
--enable-texture-float \
--enable-dri3 \
--disable-xvmc \
--with-gallium-drivers=radeonsi \
--with-vulkan-drivers=radeon \
--with-dri-drivers=radeon \
--enable-llvm \
--disable-llvm-shared-libs \
--with-llvm-prefix=$target_sysroot/nyan/llvm/0
unset LLVM_CONFIG_TARGET_SYSROOT
unset PYTHON2
unset CXXFLAGS
unset CXX
unset CFLAGS
unset CC
unset CPPFLAGS
# parallel builds break code generation
make
make install DESTDIR=$target_sysroot
# WARNING: restore the shared libstdc++
if test "x$libstdcxx_so_path.HIDDEN" != 'x.HIDDEN'; then
mv $libstdcxx_so_path.HIDDEN $libstdcxx_so_path
fi
# cleanup and tidying
find $target_sysroot/nyan/$src_name/0 -type f -name '*.la' | xargs rm -f
find $target_sysroot/nyan/$src_name/0 -type f | while read f; do if file $f | egrep 'ELF.+(shared|executable)' >/dev/null; then $target_gnu_triple-strip -s $f; fi; done
rm -Rf $build_dir $pkg_dir
export PATH=$OLD_PATH
Mode |
Type |
Size |
Ref |
File |
100644 |
blob |
5 |
8eba6c8dd4dcaf6166bd22285ed34625f38a84ff |
.gitignore |
100755 |
blob |
2487 |
533016d4902080b22ae5dc5352802ebdd0d78b16 |
01-x86_64-nyan-linux-gnu.sh |
100755 |
blob |
4254 |
31fdc18cc3e6c6cfd8444fa404f7e82f849bad56 |
02-nyan-cross-core.sh |
100755 |
blob |
3549 |
7f1362bad6786a6818ce7a7d613d0dc11f611fb9 |
03-nyan-cross-x11.sh |
100755 |
blob |
12534 |
f9036d33f9f159ea2421ce1a1ebf7067f0f695c1 |
04-bootstrap-conf.sh |
100755 |
blob |
671 |
5f6bc5de83a883da3a7f0d4a37e1d0ef51c08561 |
10-sdk-conf.sh |
100755 |
blob |
2201 |
83fa9bf5bddbecb88db53779e324b9f270b1080e |
11-sdk.sh |
100755 |
blob |
2826 |
090b622caebd38755ef1e57a9cf0f4f673b22a8e |
12-desktop.sh |
100755 |
blob |
129 |
08460f0dece90701f01cbf7d710609ecbb3d56e0 |
13-beyond.sh |
100644 |
blob |
1075 |
1b5314b511d4c6dc7eb4db36a21dd47ba5a00a9d |
INSTALL |
100644 |
blob |
30 |
c9b735fa1332286f4b3f5f81fa10527fd7506b6e |
LICENSE |
100644 |
blob |
1973 |
6aa180fc473777d9ca6b155cbf9b973065cdd77a |
README |
040000 |
tree |
- |
a0e0b5892f7f1553c5372222f0b6bb2ab34795a3 |
builders |
100644 |
blob |
2986 |
43344438bb4d817ff81f1890de1097f627c6d6c4 |
conf.sh |
040000 |
tree |
- |
317962325b26fefabb04d8e26db40eae9e5b8d62 |
files |
100755 |
blob |
351 |
6af534903b47d67a8dcb71653e7a0e1c1a4dfda4 |
pkg-build |
100755 |
blob |
289 |
7f5fbdbb712f274d04a036b9c486cbc9cf581be6 |
pkg-build-target |
100644 |
blob |
915 |
a7f21134dbc05d0e8227eaee366856b8171832a4 |
sdk.sh |
100755 |
blob |
5001 |
ef66a8b35dbba08f4397c2163cf2e7559207783a |
x86.sh |
Hints:
Before first commit, do not forget to setup your git environment:
git config --global user.name "your_name_here"
git config --global user.email "your@email_here"
Clone this repository using HTTP(S):
git clone https://rocketgit.com/user/sylware/nyanlinux
Clone this repository using ssh (do not forget to upload a key first):
git clone ssh://rocketgit@ssh.rocketgit.com/user/sylware/nyanlinux
Clone this repository using git:
git clone git://git.rocketgit.com/user/sylware/nyanlinux
You are allowed to anonymously push to this repository.
This means that your pushed commits will automatically be transformed into a
merge request:
... clone the repository ...
... make some changes and some commits ...
git push origin main