Add x86 support to standalone build scripts.

This commit is contained in:
casey langen 2023-09-10 13:32:27 -07:00
parent 4f44829cda
commit a46813db3d
5 changed files with 34 additions and 10 deletions

View File

@ -5,10 +5,10 @@ By default when you build `musikcube` it's almost exclusively tied to your Linux
It turns out that building a single C++ app once that works across many Linux distributions and versions can be very challenging, especially when there are external dependencies involved. The difficulties have been documented and discussed countless times and include, but are not limited to:
1. Incompatible `GLIBC`/`GLIBCXX` versions
3. Incompatible versions of required dependencies
4. Incompatible locations of required dependencies (e.g. `/lib` vs `/usr/lib` vs `/usr/local/lib`)
5. Incompatible filenames for required depdencies (eg `libfoo.so.3` vs `libfoo.so`)
6. General unavailability of required dependencies (i.e. "dependency `foo` doesn't exist in `Ubuntu`'s `apt`")
2. Incompatible versions of required dependencies
3. Incompatible locations of required dependencies (e.g. `/lib` vs `/usr/lib` vs `/usr/local/lib`)
4. Incompatible filenames for required depdencies (eg `libfoo.so.3` vs `libfoo.so`)
5. General unavailability of required dependencies (i.e. "dependency `foo` doesn't exist in `Ubuntu`'s `apt`")
In an ideal world we wouldn't have to worry about these problems, and `musikcube` would be available via all major Linux distribution package management systems. In practice, however, it's not. It can take tremendous time and effort to get packages accepted upstream by maintainers. For example, see the [DebianMentorsFaq](https://wiki.debian.org/DebianMentorsFaq).
@ -31,13 +31,15 @@ It's probably easiest to just install a `docker` image and use that, but an inst
## Install dependencies
### From `apt-get`:
- `sudo apt update`
- `sudo apt dist-upgrade`
- `sudo apt install build-essential g++ gcc git libasound2-dev libev-dev libncurses-dev libopus-dev libopus-dev libopus0 libpulse-dev libsndio-dev libssl-dev libsystemd-dev libvorbis-dev libvorbis-dev libvorbis0a libvorbisenc2 portaudio19-dev rpm wget zlib1g-dev`
- `sudo apt install build-essential g++ gcc git libasound2-dev libev-dev libncurses-dev libopus-dev libopus-dev libopus0 libpulse-dev libsndio-dev libssl-dev libsystemd-dev libvorbis-dev libvorbis-dev libvorbis0a libvorbisenc2 portaudio19-dev rpm wget zlib1g-dev libdbus-1-dev libudev-dev libglib2.0-dev patchelf libstdc++6-i386-cross`
### Compile from source:
Install the following from source, as the distro-provided packages are too old:
- `cmake` v3.27.4+
- `pipewire` v0.3.x (optional -- only if you want to use `pipewire`)
@ -66,4 +68,4 @@ Now that we have all required dependencies available it's time to compile the ap
- `x.y.z` is the version of `musikcube` we'd like to appear in the filename. You can use anything you want, e.g. `0.0.0`
- The build process will automatically discover and use the `/build/vendor-${arch}` directory created in the previous step.
After the script has completed you should have a set of "relocatable" binaries in `/build/musikcube/dist/x.y.z/` that will work on most Linux distributions released in 2018 or later.
After the script has completed you should have a set of "relocatable" binaries in `/build/musikcube/dist/x.y.z/` that will work on most Linux distributions released in 2018 or later.

View File

@ -34,6 +34,10 @@ if [[ $CROSSCOMPILE == rpi-* ]]; then
FRIENDLY_ARCH_NAME="armv6"
fi
STRIP="/build/x-tools/${XTOOLS_NAME}/${XTOOLS_NAME}/bin/strip"
elif [[ $CROSSCOMPILE == "x86" ]]; then
VENDOR=${CROSSCOMPILE}
FRIENDLY_ARCH_NAME="x86"
DEB_ARCH="x86"
elif [[ $FRIENDLY_ARCH_NAME == "x86_64" ]]; then
DEB_ARCH="amd64"
fi
@ -112,7 +116,7 @@ cp bin/themes/*.json $OUTDIR/themes
cp -rfp bin/share/terminfo/* $OUTDIR/share/terminfo/
if [[ $CROSSCOMPILE == rpi-* ]]; then
printf "\n\n\n ***** CROSSCOMPILE DETECTED, **NOT** SCANNING DEPENDENCIES! *****\n\n\n"
printf "\n\n\n ***** RPI CROSSCOMPILE DETECTED, **NOT** SCANNING DEPENDENCIES! *****\n\n\n"
sleep 1
else
printf "\n\n\n ***** SCANNING DEPENDENCIES *****\n\n\n"

View File

@ -108,6 +108,23 @@ function configure_crosscompile_if_necessary() {
GENERIC_CONFIGURE_FLAGS="--build=x86_64-pc-linux-gnu --host=${XTOOLS_TOOLCHAIN_NAME} --with-sysroot=${XTOOLS_SYSROOT}"
FFMPEG_CONFIGURE_FLAGS="--arch=${ARCH} --target-os=linux --enable-cross-compile --sysroot=${XTOOLS_SYSROOT} --cross-prefix=${XTOOLS_TOOLCHAIN_NAME}-"
fi
if [[ $CROSSCOMPILE == "x86" ]]; then
OPENSSL_TYPE="linux-x86"
CFLAGS="$CFLAGS -I/usr/include/i386-linux-gnu/"
CXXFLAGS="$CXXFLAGS -I/usr/include/i386-linux-gnu/"
# X86_LOCAL_SYSROOT="${BUILD_ROOT}/x86-sysroot"
# X86_GLOBAL_SYSROOT="/usr/i686-linux-gnu/"
# OPENSSL_TYPE="linux-x86"
# VENDOR_PKG_CONFIG_PATH="${LIBDIR}/pkgconfig/"
# SYSROOT_PKG_CONFIG_PATH="${X86_LOCAL_SYSROOT}/usr/lib/i386-linux-gnu/pkgconfig"
# CFLAGS="$CFLAGS -m32 -I${X86_GLOBAL_SYSROOT}/include/ --sysroot=${X86_LOCAL_SYSROOT}"
# CXXFLAGS="$CXXFLAGS -m32 -I${X86_GLOBAL_SYSROOT}/include/ --sysroot=${X86_LOCAL_SYSROOT}"
# LDFLAGS="$LDFLAGS -m32 -L${X86_GLOBAL_SYSROOT}/lib/ --sysroot=${X86_LOCAL_SYSROOT}"
# GENERIC_CONFIGURE_FLAGS="--build=x86_64-pc-linux-gnu --host=x86"
# export PKG_CONFIG_PATH="${VENDOR_PKG_CONFIG_PATH}:${SYSROOT_PKG_CONFIG_PATH}"
fi
}
function print_build_configuration() {

View File

@ -10,14 +10,13 @@ during app build-time. */
const { promisify } = require('util');
const exec = promisify(require('child_process').exec);
const fs = require('fs');
const rm = promisify(fs.rm);
const unlink = promisify(fs.unlink);
const symlink = promisify(fs.symlink);
const mac = process.platform === 'darwin';
if (!mac) {
console.log(`\n\n no need to relink libraries on '${process.platform}\n\n`);
console.log(`\n\n no need to relink libraries on '${process.platform}'\n\n`);
process.exit(0);
}
@ -111,7 +110,7 @@ const rebuildSymlinks = async () => {
const [src, dst] = symlinks[i];
console.log('removing symlink:', `${path}/${dst}`);
try {
await rm(`${path}/${dst}`);
await exec(`rm ${path}/${dst}`);
} catch (e) {}
try {
await unlink(`${path}/${dst}`);

View File

@ -56,6 +56,8 @@ elif [[ "$PLATFORM" == 'Linux' ]]; then
fi
SYSTEM_ROOT="/build/x-tools/${XTOOLS_ARCH}/${XTOOLS_ARCH}/sysroot"
SYSTEM_TYPE="arm-linux-gnueabihf"
elif [[ $CROSSCOMPILE == "x86" ]]; then
SYSTEM_TYPE="i386-linux-gnu"
fi
cp $SYSTEM_ROOT/lib/$SYSTEM_TYPE/libncursesw.so.6 ./bin/lib