mirror of
https://github.com/libretro/Lakka-LibreELEC.git
synced 2025-04-04 06:55:21 +00:00
Fix Switch build in new tree (#1687)
This commit is contained in:
distributions/Lakka
packages
projects/L4T/packages
alsa-lib
alsa-topology-conf
alsa-ucm-conf
alsa-utils
glibc/patches
openssl
pulseaudio
config
package.mkpatches
L4T
pulseaudio-0900.03-eliminates-lags-after-bluetooth-packet-loss.patchpulseaudio-100.01-never-append-dirty-to-server-module-version.patchpulseaudio-100.02-check_uid.patchpulseaudio-100.03-fix-disable-doxygen.patchprofile.d
system.d
systemd
config
hosts.conf
hwdb.d
logind.conf.d
modules-load.d
sleep.conf.d
sysctl.d
system.d
timesyncd.conf.d
tmpfiles.d
udev.rules.d
hwdb.d
package.mkpatches
systemd-0001-move-etc-systemd-system-to-storage-.config-system.d.patchsystemd-0002-move-hwdb.bin-to-run.patchsystemd-0003-remove-nonexistant-dependency.patchsystemd-0200-persist-persistent-timer-stamps.patchsystemd-0300-config-env-unhide-cursor.patch
profile.d
scripts
cpufreqenvironment-setupnetwork-base-setupsystemd-machine-id-setupsystemd-timesyncd-setupusercache-setupuserconfig-setup
system.d
cpufreq.servicedebugconfig.serviceenvconfig.service
flash.mount.d
hwdb.servicemachine-id.servicenetwork-base.servicestorage.mount.d
systemd-timesyncd-setup.servicesystemd-timesyncd.service.d
usercache.serviceuserconfig.servicetmpfiles.d
udev.d
util-linux
config
package.mkpatches
util-linux-01-fix-pkgconf.patchutil-linux-0100-enable-lscpu.patchutil-linux-blkid_swapon_mkfs_uuidgen.patch
scripts
sysctl.d
system.d
xorg-server
debug.d
package.mkpatches
xorg-server-0001-sdksyms.sh-Make-sdksyms.sh-work-with-gcc5.patchxorg-server-1.12.4-05_pkg_config.patchxorg-server-1.12.4-14-detect_radeon.patchxorg-server-1.12.4-20_extra_modelines_fromxorg.patchxorg-server-1.18.0-add_prime_support-1.patch
profile.d
scripts
system.d
tmpfiles.d
udev.d
@ -374,6 +374,7 @@
|
||||
elif [ "${PROJECT}" = "Generic" -a "${ARCH}" = "i386" ]; then
|
||||
EXCLUDE_LIBRETRO_CORES+=" openlara"
|
||||
elif [ "${PROJECT}" = "L4T" -a "${DEVICE}" = "Switch" ]; then
|
||||
#EXCLUDE_LIBRETRO_CORES+=" lr_moonlight"
|
||||
#Remove xpadneo from L4T builds
|
||||
ADDITIONAL_PACKAGES=${ADDITIONAL_PACKAGES/xpadneo/}
|
||||
elif [ "${OPENGLES_SUPPORT}" = "yes" ]; then
|
||||
|
@ -10,6 +10,9 @@ PKG_SITE="https://github.com/KhronosGroup/Vulkan-Loader"
|
||||
PKG_URL="https://github.com/KhronosGroup/Vulkan-Loader/archive/v${PKG_VERSION}.tar.gz"
|
||||
PKG_DEPENDS_HOST="toolchain:host vulkan-headers:host"
|
||||
PKG_DEPENDS_TARGET="toolchain vulkan-headers"
|
||||
if [ ${DISPLAYSERVER} = "x11" ]; then
|
||||
PKG_DEPENDS_TARGET+=" xrandr"
|
||||
fi
|
||||
PKG_LONGDESC="Vulkan Installable Client Driver (ICD) Loader."
|
||||
|
||||
configure_package() {
|
||||
|
@ -137,6 +137,8 @@ makeinstall_host() {
|
||||
|
||||
mkdir -p ${SYSROOT_PREFIX}/usr/include
|
||||
cp -R dest/include/* ${SYSROOT_PREFIX}/usr/include
|
||||
|
||||
echo ${SYSROOT_PREFIX}
|
||||
}
|
||||
|
||||
pre_make_target() {
|
||||
@ -374,7 +376,7 @@ make_target() {
|
||||
fi
|
||||
|
||||
if [ "${LINUX}" = "L4T" ]; then
|
||||
export KCFLAGS+="-Wno-error=sizeof-pointer-memaccess -Wno-error=missing-attributes -Wno-error=stringop-truncation -Wno-error=stringop-overflow= -Wno-error=address-of-packed-member -Wno-error=tautological-compare -Wno-error=packed-not-aligned -Wno-error=implicit-function-declaration"
|
||||
export KCFLAGS+="-Wno-error=sizeof-pointer-memaccess -Wno-error=missing-attributes -Wno-error=stringop-truncation -Wno-error=stringop-overflow= -Wno-error=address-of-packed-member -Wno-error=tautological-compare -Wno-error=packed-not-aligned -Wno-error=implicit-function-declaration -Wno-error=misleading-indentation"
|
||||
fi
|
||||
|
||||
DTC_FLAGS=-@ kernel_make TOOLCHAIN="${TOOLCHAIN}" ${KERNEL_TARGET} ${KERNEL_MAKE_EXTRACMD} modules
|
||||
|
@ -266,7 +266,7 @@ configure_target() {
|
||||
--host-cc="${HOST_CC}" \
|
||||
--host-cflags="${HOST_CFLAGS}" \
|
||||
--host-ldflags="${HOST_LDFLAGS}" \
|
||||
--extra-cflags="${CFLAGS}" \
|
||||
--extra-cflags="${CFLAGS} ${EXTRA_CFLAGS}" \
|
||||
--extra-ldflags="${LDFLAGS}" \
|
||||
--extra-libs="${PKG_FFMPEG_LIBS}" \
|
||||
--pkg-config="${TOOLCHAIN}/bin/pkg-config" \
|
||||
|
File diff suppressed because it is too large
Load Diff
11415
packages/multimedia/ffmpeg/patches/L4T/ffmpeg-4.4-N-add-nvv4l-encoder-decoder.patch
Normal file
11415
packages/multimedia/ffmpeg/patches/L4T/ffmpeg-4.4-N-add-nvv4l-encoder-decoder.patch
Normal file
File diff suppressed because it is too large
Load Diff
@ -12,7 +12,7 @@ PKG_DEPENDS_TARGET="toolchain xkeyboard-config libxml2"
|
||||
PKG_LONGDESC="xkbcommon is a library to handle keyboard descriptions."
|
||||
|
||||
PKG_MESON_OPTS_TARGET="-Denable-docs=false"
|
||||
if ! [ "${PROJECT}" = "L4T" ]; then
|
||||
#if ! [ "${PROJECT}" = "L4T" ]; then
|
||||
if [ "${DISPLAYSERVER}" = "x11" ]; then
|
||||
PKG_MESON_OPTS_TARGET+=" -Denable-x11=true \
|
||||
-Denable-wayland=false"
|
||||
@ -23,12 +23,12 @@ if ! [ "${PROJECT}" = "L4T" ]; then
|
||||
PKG_MESON_OPTS_TARGET+=" -Denable-x11=false \
|
||||
-Denable-wayland=false"
|
||||
fi
|
||||
fi
|
||||
#fi
|
||||
|
||||
pre_configure_target() {
|
||||
if ! [ "${PROJECT}" = "L4T" ]; then
|
||||
# if ! [ "${PROJECT}" = "L4T" ]; then
|
||||
if [ "${DISPLAYSERVER}" = "x11" ]; then
|
||||
TARGET_LDFLAGS="${LDFLAGS} -lXau -lxcb"
|
||||
fi
|
||||
fi
|
||||
# fi
|
||||
}
|
||||
|
@ -0,0 +1,16 @@
|
||||
# INTEL HBR WORKAROUND FOR DTS-MA & Dolby TrueHD PLAYBACK
|
||||
|
||||
# Uncomment the following lines to disable any S/PDIF out to deliver
|
||||
# bitstreamed audio on Intel builds. This is a rough workaround for
|
||||
# users that have both S/PDIF and HDMI audio outputs on their motherboard
|
||||
# or motherboard+discrete graphics combo.
|
||||
|
||||
# EVEN IF YOU ARE NOT USING THE S/PDIF OUTPUT
|
||||
# but still have one, you will need to uncomment the lines below !
|
||||
|
||||
# after uncommenting these lines, you must reboot for these settings to take effect
|
||||
|
||||
# blacklist snd_hda_codec_realtek
|
||||
# blacklist snd_hda_codec_sigmatel
|
||||
# blacklist snd_hda_codec_cirrus
|
||||
|
23
projects/L4T/packages/alsa-lib/modprobe.d/alsa-base.conf
Normal file
23
projects/L4T/packages/alsa-lib/modprobe.d/alsa-base.conf
Normal file
@ -0,0 +1,23 @@
|
||||
#############################
|
||||
# ALSA drivers load options #
|
||||
#############################
|
||||
|
||||
# Prevent abnormal drivers from grabbing index 0
|
||||
options snd-bt87x index=-2
|
||||
options cx88-alsa index=-2
|
||||
options saa7134-alsa index=-2
|
||||
options snd-atiixp-modem index=-2
|
||||
options snd-intel8x0m index=-2
|
||||
options snd-via82xx-modem index=-2
|
||||
options snd-usb-audio index=-2
|
||||
options snd-usb-usx2y index=-2
|
||||
options snd-usb-caiaq index=-2
|
||||
options snd-cmipci mpu_port=0x330 fm_port=0x388
|
||||
|
||||
# Some Toshiba laptops might require this
|
||||
# options snd-hda-intel model=toshiba
|
||||
options snd-hda-intel model=auto
|
||||
|
||||
# fix some Audio Problems with HDMI on ION based Hardware
|
||||
# see: http://xbmc.org/forum/showthread.php?t=69479
|
||||
alias snd-card-0 snd-hda-codec-nvhdmi
|
@ -0,0 +1,2 @@
|
||||
# use legacy hda-intel driver even if a DSP is present
|
||||
options snd_intel_dspcfg dsp_driver=1
|
43
projects/L4T/packages/alsa-lib/package.mk
Normal file
43
projects/L4T/packages/alsa-lib/package.mk
Normal file
@ -0,0 +1,43 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2016 Stephan Raue (stephan@openelec.tv)
|
||||
# Copyright (C) 2016-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
PKG_NAME="alsa-lib"
|
||||
PKG_VERSION="1.2.4"
|
||||
PKG_SHA256="f7554be1a56cdff468b58fc1c29b95b64864c590038dd309c7a978c7116908f7"
|
||||
PKG_LICENSE="GPL"
|
||||
PKG_SITE="http://www.alsa-project.org/"
|
||||
PKG_URL="ftp://ftp.alsa-project.org/pub/lib/alsa-lib-${PKG_VERSION}.tar.bz2"
|
||||
PKG_DEPENDS_TARGET="toolchain"
|
||||
PKG_LONGDESC="ALSA (Advanced Linux Sound Architecture) is the next generation Linux Sound API."
|
||||
PKG_TOOLCHAIN="autotools"
|
||||
PKG_BUILD_FLAGS="+pic"
|
||||
|
||||
if build_with_debug; then
|
||||
PKG_ALSA_DEBUG=--with-debug
|
||||
else
|
||||
PKG_ALSA_DEBUG=--without-debug
|
||||
fi
|
||||
|
||||
PKG_CONFIGURE_OPTS_TARGET="${PKG_ALSA_DEBUG} \
|
||||
--disable-dependency-tracking \
|
||||
--with-plugindir=/usr/lib/alsa \
|
||||
--disable-python"
|
||||
|
||||
post_configure_target() {
|
||||
sed -i 's/.*PKGLIBDIR.*/#define PKGLIBDIR ""/' include/config.h
|
||||
}
|
||||
|
||||
post_makeinstall_target() {
|
||||
rm -rf ${INSTALL}/usr/bin
|
||||
|
||||
mkdir -p ${INSTALL}/usr/config
|
||||
cp -PR ${PKG_DIR}/config/modprobe.d ${INSTALL}/usr/config
|
||||
}
|
||||
|
||||
post_install() {
|
||||
if [ "${DISTRO}" = "Lakka" ] && [ "${DEVICE}" = "RPi4-RetroDreamer" ]; then
|
||||
sed -e "s|^options snd-usb-audio index=.*$|options snd-usb-audio index=0|g" \
|
||||
-i ${INSTALL}/usr/lib/modprobe.d/alsa-base.conf
|
||||
fi
|
||||
}
|
@ -0,0 +1,14 @@
|
||||
diff --git a/src/conf/alsa.conf b/src/conf/alsa.conf
|
||||
index a04173a0..1f13fd84 100644
|
||||
--- a/src/conf/alsa.conf
|
||||
+++ b/src/conf/alsa.conf
|
||||
@@ -11,7 +11,8 @@
|
||||
"/usr/etc/alsa/conf.d"
|
||||
"/etc/alsa/conf.d"
|
||||
"/etc/asound.conf|||/usr/etc/asound.conf"
|
||||
- "~/.asoundrc"
|
||||
+ "/run/asound.conf"
|
||||
+ "/storage/.config/asound.conf"
|
||||
{
|
||||
@func concat
|
||||
strings [
|
16
projects/L4T/packages/alsa-topology-conf/package.mk
Normal file
16
projects/L4T/packages/alsa-topology-conf/package.mk
Normal file
@ -0,0 +1,16 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2020-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
PKG_NAME="alsa-topology-conf"
|
||||
PKG_VERSION="1.2.4"
|
||||
PKG_SHA256="55e0e6e42eca4cc7656c257af2440cdc65b83689dca49fc60ca0194db079ed07"
|
||||
PKG_LICENSE="BSD-3c"
|
||||
PKG_SITE="http://www.alsa-project.org/"
|
||||
PKG_URL="ftp://ftp.alsa-project.org/pub/lib/alsa-topology-conf-${PKG_VERSION}.tar.bz2"
|
||||
PKG_LONGDESC="ALSA topology configuration files"
|
||||
PKG_TOOLCHAIN="manual"
|
||||
|
||||
makeinstall_target() {
|
||||
mkdir -p ${INSTALL}/usr/share/alsa/
|
||||
cp -PR ${PKG_BUILD}/topology ${INSTALL}/usr/share/alsa/
|
||||
}
|
17
projects/L4T/packages/alsa-ucm-conf/package.mk
Normal file
17
projects/L4T/packages/alsa-ucm-conf/package.mk
Normal file
@ -0,0 +1,17 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2020-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
PKG_NAME="alsa-ucm-conf"
|
||||
PKG_VERSION="1.2.4"
|
||||
PKG_SHA256="2c3b535c77dcb9aaf62a61f4f8324f1ab184162f105f7ec9ed1e37c742fcd340"
|
||||
PKG_LICENSE="BSD-3c"
|
||||
PKG_SITE="http://www.alsa-project.org/"
|
||||
PKG_URL="ftp://ftp.alsa-project.org/pub/lib/alsa-ucm-conf-${PKG_VERSION}.tar.bz2"
|
||||
PKG_LONGDESC="ALSA Use Case Manager configuration (and topologies)"
|
||||
PKG_TOOLCHAIN="manual"
|
||||
|
||||
makeinstall_target() {
|
||||
mkdir -p ${INSTALL}/usr/share/alsa/
|
||||
cp -PR ${PKG_BUILD}/ucm2 ${INSTALL}/usr/share/alsa/
|
||||
safe_remove ${INSTALL}/usr/share/alsa/ucm2/README.md
|
||||
}
|
42
projects/L4T/packages/alsa-utils/package.mk
Normal file
42
projects/L4T/packages/alsa-utils/package.mk
Normal file
@ -0,0 +1,42 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2016 Stephan Raue (stephan@openelec.tv)
|
||||
# Copyright (C) 2016-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
PKG_NAME="alsa-utils"
|
||||
PKG_VERSION="1.2.4"
|
||||
PKG_SHA256="98ffc2d599de0577d423a48fa5f20a992ca0b82d812ed1f2e58ade49ac6da426"
|
||||
PKG_LICENSE="GPL"
|
||||
PKG_SITE="http://www.alsa-project.org/"
|
||||
PKG_URL="ftp://ftp.alsa-project.org/pub/utils/alsa-utils-${PKG_VERSION}.tar.bz2"
|
||||
PKG_DEPENDS_TARGET="toolchain alsa-lib ncurses systemd"
|
||||
PKG_LONGDESC="This package includes the utilities for ALSA, like alsamixer, aplay, arecord, alsactl, iecset and speaker-test."
|
||||
|
||||
PKG_CONFIGURE_OPTS_TARGET="--disable-alsaconf \
|
||||
--disable-alsaloop \
|
||||
--enable-alsatest \
|
||||
--disable-bat \
|
||||
--disable-dependency-tracking \
|
||||
--disable-nls \
|
||||
--disable-rst2man \
|
||||
--disable-xmlto"
|
||||
|
||||
post_makeinstall_target() {
|
||||
rm -rf ${INSTALL}/lib ${INSTALL}/var
|
||||
rm -rf ${INSTALL}/usr/share/alsa/speaker-test
|
||||
rm -rf ${INSTALL}/usr/share/sounds
|
||||
rm -rf ${INSTALL}/usr/lib/systemd/system
|
||||
|
||||
# remove default udev rule to restore mixer configs, we install our own.
|
||||
# so we avoid resetting our soundconfig
|
||||
rm -rf ${INSTALL}/usr/lib/udev/rules.d/90-alsa-restore.rules
|
||||
|
||||
if [ "${DISTRO}" != "Lakka" ]; then # keep the utils for Lakka
|
||||
mkdir -p ${INSTALL}/.noinstall
|
||||
for i in aconnect alsamixer amidi aplaymidi arecord arecordmidi aseqdump aseqnet iecset; do
|
||||
mv ${INSTALL}/usr/bin/${i} ${INSTALL}/.noinstall
|
||||
done
|
||||
fi
|
||||
|
||||
mkdir -p ${INSTALL}/usr/lib/udev
|
||||
cp ${PKG_DIR}/scripts/soundconfig ${INSTALL}/usr/lib/udev
|
||||
}
|
165
projects/L4T/packages/alsa-utils/scripts/soundconfig
Executable file
165
projects/L4T/packages/alsa-utils/scripts/soundconfig
Executable file
@ -0,0 +1,165 @@
|
||||
#!/bin/sh
|
||||
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2014 Stephan Raue (stephan@openelec.tv)
|
||||
# Copyright (C) 2018-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
# setup alsa (especially the mixer config)
|
||||
|
||||
mixer() {
|
||||
parm=${4:-on}
|
||||
amixer -c "$1" sset "$2" "$3" $parm >/dev/null 2>&1
|
||||
amixer -c "$1" sset "$2" $parm >/dev/null 2>&1
|
||||
}
|
||||
|
||||
(
|
||||
. /etc/profile
|
||||
|
||||
progress "Setting up sound card"
|
||||
|
||||
if [ -f $HOME/.config/sound.conf ]; then
|
||||
|
||||
alsactl restore -f $HOME/.config/sound.conf
|
||||
|
||||
else
|
||||
|
||||
# get card num
|
||||
card=`echo $1 | sed 's/[^0-9]*//g'`
|
||||
|
||||
# set common mixer params
|
||||
mixer $card Master 0db
|
||||
mixer $card Front 100%
|
||||
mixer $card PCM 0db
|
||||
mixer $card Synth 100%
|
||||
|
||||
# mute CD, since using digital audio instead
|
||||
mixer $card CD 0% mute
|
||||
|
||||
# Only unmute Line and Aux if they are possibly used.
|
||||
# mixer $card Line 100%
|
||||
# mixer $card Aux 100%
|
||||
|
||||
# mute mic
|
||||
mixer $card Mic 0% mute
|
||||
|
||||
# ESS 1969 chipset has 2 PCM channels
|
||||
mixer $card PCM,1 100%
|
||||
|
||||
# Trident/YMFPCI/emu10k1
|
||||
mixer $card Wave 100%
|
||||
mixer $card Music 100%
|
||||
mixer $card AC97 100%
|
||||
mixer $card Surround 90%
|
||||
mixer $card 'Surround Digital' 90%
|
||||
mixer $card 'Wave Surround' 90%
|
||||
mixer $card 'Duplicate Front' 90%
|
||||
mixer $card 'Sigmatel 4-Speaker Stereo' 90%
|
||||
|
||||
# CS4237B chipset:
|
||||
mixer $card 'Master Digital' 100%
|
||||
|
||||
# DRC
|
||||
mixer $card 'Dynamic Range Compression' 90%
|
||||
|
||||
# Envy24 chips with analog outs
|
||||
mixer $card DAC 100%
|
||||
mixer $card DAC,0 100%
|
||||
mixer $card DAC,1 100%
|
||||
|
||||
# some notebooks use headphone instead of master
|
||||
mixer $card Headphone 100%
|
||||
mixer $card Speaker 100%
|
||||
mixer $card 'Internal Speaker' 0% mute
|
||||
mixer $card Playback 100%
|
||||
mixer $card Headphone 100%
|
||||
mixer $card Speaker 100%
|
||||
mixer $card Center 100%
|
||||
mixer $card LFE 100%
|
||||
mixer $card Center/LFE 100%
|
||||
|
||||
# Intel P4P800-MX (Ubuntu bug #5813)
|
||||
mixer $card 'Master Playback Switch' on
|
||||
|
||||
# set digital output mixer params
|
||||
mixer $card 'IEC958' 100% on
|
||||
mixer $card 'IEC958 Output' 100%
|
||||
mixer $card 'IEC958 Coaxial' 100%
|
||||
mixer $card 'IEC958 LiveDrive' 100%
|
||||
mixer $card 'IEC958 Optical Raw' 100%
|
||||
mixer $card 'SPDIF Out' 100%
|
||||
mixer $card 'SPDIF Front' 100%
|
||||
mixer $card 'SPDIF Rear' 100%
|
||||
mixer $card 'SPDIF Center/LFE' 100%
|
||||
mixer $card 'Master Digital' 100%
|
||||
|
||||
mixer $card 'Analog Front' 100%
|
||||
mixer $card 'Analog Rear' 100%
|
||||
mixer $card 'Analog Center/LFE' 100%
|
||||
|
||||
# ASRock ION 330 (and perhaps others) has 2 IEC958 channels
|
||||
mixer $card IEC958,0 on
|
||||
mixer $card IEC958,1 on
|
||||
|
||||
# some ION2 has much more IEC958 channels ...
|
||||
mixer $card IEC958,2 on
|
||||
mixer $card IEC958,3 on
|
||||
|
||||
# ASRock ION 330 has Master Front set to 0
|
||||
mixer $card 'Master Front' 100%
|
||||
|
||||
# Shuttle XS35GT needs this too
|
||||
mixer $card 'Master',0 100% on
|
||||
|
||||
# and this for various Fusion devices like Zotac ZBOX
|
||||
mixer $card 'Front',0 100% on
|
||||
|
||||
# NVidia CK804 sound devices
|
||||
mixer $card 'IEC958 Playback AC97-SPSA' 100%
|
||||
|
||||
# Allwinner H3 Analog
|
||||
mixer $card 'Line Out' 0db on
|
||||
|
||||
# Allwinner A20 Analog
|
||||
mixer $card 'Power Amplifier' 0db
|
||||
mixer $card 'Power Amplifier DAC' on
|
||||
mixer $card 'Power Amplifier Mute' on
|
||||
|
||||
# Allwinner A64 Analog
|
||||
mixer $card Headphone 0db on
|
||||
mixer $card 'AIF1 Slot 0 Digital DAC' on
|
||||
|
||||
# Amlogic G12A/G12B/SM1 HDMI
|
||||
case $(dtname) in
|
||||
azw,gsking-x|khadas,vim3*) #TDM_A
|
||||
mixer $card 'FRDDR_A SINK 1 SEL' 'OUT 0'
|
||||
mixer $card 'FRDDR_A SRC 1 EN' on
|
||||
mixer $card 'TDMOUT_A SRC SEL' 'IN 0'
|
||||
mixer $card 'TOHDMITX' on
|
||||
mixer $card 'TOHDMITX I2S SRC' 'I2S A'
|
||||
;;
|
||||
*) #TDM_B
|
||||
mixer $card 'FRDDR_A SINK 1 SEL' 'OUT 1'
|
||||
mixer $card 'FRDDR_A SRC 1 EN' on
|
||||
mixer $card 'TDMOUT_B SRC SEL' 'IN 0'
|
||||
mixer $card 'TOHDMITX' on
|
||||
mixer $card 'TOHDMITX I2S SRC' 'I2S B'
|
||||
;;
|
||||
esac
|
||||
|
||||
# Amlogic G12A/G12B/SM1 S/PDIF
|
||||
mixer $card 'FRDDR_B SINK 1 SEL' 'OUT 3'
|
||||
mixer $card 'FRDDR_B SRC 1 EN' on
|
||||
mixer $card 'SPDIFOUT SRC SEL' 'IN 1'
|
||||
mixer $card 'SPDIFOUT Playback' on
|
||||
|
||||
# Amlogic GX HDMI and S/PDIF
|
||||
mixer $card 'AIU HDMI CTRL SRC' 'I2S'
|
||||
mixer $card 'AIU SPDIF SRC SEL' 'SPDIF'
|
||||
|
||||
# ES8316 headphone jack
|
||||
mixer $card 'Right Headphone Mixer Right DAC' on
|
||||
mixer $card 'Left Headphone Mixer Left DAC' on
|
||||
fi
|
||||
|
||||
exit 0
|
||||
)&
|
@ -0,0 +1,5 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2014 Stephan Raue (stephan@openelec.tv)
|
||||
|
||||
# When a sound device is detected, restore the volume settings
|
||||
KERNEL=="controlC[0-9]*", NAME="snd/%k", ACTION=="add", RUN+="soundconfig %k"
|
12
projects/L4T/packages/glibc/patches/fix_autoconf.patch
Normal file
12
projects/L4T/packages/glibc/patches/fix_autoconf.patch
Normal file
@ -0,0 +1,12 @@
|
||||
diff -Naur glibc-2.27/aclocal.m4 glibc-2.27-2/aclocal.m4
|
||||
--- glibc-2.27/aclocal.m4 2022-04-20 02:23:50.549365949 +0200
|
||||
+++ glibc-2.27-2/aclocal.m4 2022-04-20 02:26:23.179843270 +0200
|
||||
@@ -2,7 +2,7 @@
|
||||
dnl the internal functions defined and used by the main configure script
|
||||
dnl match those expected by the fragments. When changing this version,
|
||||
dnl install.texi also needs to be updated.
|
||||
-m4_define([GLIBC_AUTOCONF_VERSION], [2.69])
|
||||
+m4_define([GLIBC_AUTOCONF_VERSION], [2.71])
|
||||
m4_if(m4_defn([AC_AUTOCONF_VERSION]), GLIBC_AUTOCONF_VERSION, [],
|
||||
[m4_fatal(m4_flatten(
|
||||
Exactly version GLIBC_AUTOCONF_VERSION of Autoconf is required but you have
|
@ -0,0 +1,18 @@
|
||||
2010-02-27 Aurelien Jarno <aurelien@aurel32.net>
|
||||
|
||||
* pthreadP.h(INVALID_TD_P, INVALID_NOT_TERMINATED_TD_P): detect
|
||||
NULL pointers.
|
||||
|
||||
--- a/nptl/pthreadP.h
|
||||
+++ b/nptl/pthreadP.h
|
||||
@@ -207,8 +207,8 @@ extern int __pthread_debug attribute_hidden;
|
||||
/* Simplified test. This will not catch all invalid descriptors but
|
||||
is better than nothing. And if the test triggers the thread
|
||||
descriptor is guaranteed to be invalid. */
|
||||
-# define INVALID_TD_P(pd) __builtin_expect ((pd)->tid <= 0, 0)
|
||||
-# define INVALID_NOT_TERMINATED_TD_P(pd) __builtin_expect ((pd)->tid < 0, 0)
|
||||
+# define INVALID_TD_P(pd) __builtin_expect (!pd || ((pd)->tid <= 0), 0)
|
||||
+# define INVALID_NOT_TERMINATED_TD_P(pd) __builtin_expect (!pd || ((pd)->tid < 0), 0)
|
||||
#endif
|
||||
|
||||
|
3154
projects/L4T/packages/openssl/cert/cacert.pem
Normal file
3154
projects/L4T/packages/openssl/cert/cacert.pem
Normal file
File diff suppressed because it is too large
Load Diff
114
projects/L4T/packages/openssl/package.mk
Normal file
114
projects/L4T/packages/openssl/package.mk
Normal file
@ -0,0 +1,114 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2014 Stephan Raue (stephan@openelec.tv)
|
||||
# Copyright (C) 2016-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
PKG_NAME="openssl"
|
||||
PKG_VERSION="1.1.1k"
|
||||
PKG_SHA256="892a0875b9872acd04a9fde79b1f943075d5ea162415de3047c327df33fbaee5"
|
||||
PKG_LICENSE="BSD"
|
||||
PKG_SITE="https://www.openssl.org"
|
||||
PKG_URL="https://www.openssl.org/source/${PKG_NAME}-${PKG_VERSION}.tar.gz"
|
||||
PKG_DEPENDS_HOST="ccache:host"
|
||||
PKG_DEPENDS_TARGET="toolchain"
|
||||
PKG_LONGDESC="The Open Source toolkit for Secure Sockets Layer and Transport Layer Security"
|
||||
PKG_TOOLCHAIN="configure"
|
||||
PKG_BUILD_FLAGS="-parallel"
|
||||
|
||||
PKG_CONFIGURE_OPTS_SHARED="--libdir=lib \
|
||||
shared \
|
||||
threads \
|
||||
no-ec2m \
|
||||
no-md2 \
|
||||
no-rc5 \
|
||||
no-rfc3779 \
|
||||
no-sctp \
|
||||
no-ssl-trace \
|
||||
no-ssl3 \
|
||||
no-unit-test \
|
||||
no-weak-ssl-ciphers \
|
||||
no-zlib \
|
||||
no-zlib-dynamic \
|
||||
no-static-engine"
|
||||
|
||||
PKG_CONFIGURE_OPTS_HOST="--prefix=${TOOLCHAIN} \
|
||||
--openssldir=${TOOLCHAIN}/etc/ssl"
|
||||
PKG_CONFIGURE_OPTS_TARGET="--prefix=/usr \
|
||||
--openssldir=/etc/ssl"
|
||||
|
||||
post_unpack() {
|
||||
find ${PKG_BUILD}/apps -type f | xargs -n 1 -t sed 's|./demoCA|/etc/ssl|' -i
|
||||
}
|
||||
|
||||
pre_configure_host() {
|
||||
mkdir -p ${PKG_BUILD}/.${HOST_NAME}
|
||||
cp -a ${PKG_BUILD}/* ${PKG_BUILD}/.${HOST_NAME}/
|
||||
}
|
||||
|
||||
configure_host() {
|
||||
cd ${PKG_BUILD}/.${HOST_NAME}
|
||||
./Configure ${PKG_CONFIGURE_OPTS_HOST} ${PKG_CONFIGURE_OPTS_SHARED} linux-${MACHINE_HARDWARE_NAME} ${CFLAGS} ${LDFLAGS}
|
||||
}
|
||||
|
||||
makeinstall_host() {
|
||||
make install_sw
|
||||
}
|
||||
|
||||
pre_configure_target() {
|
||||
mkdir -p ${PKG_BUILD}/.${TARGET_NAME}
|
||||
cp -a ${PKG_BUILD}/* ${PKG_BUILD}/.${TARGET_NAME}/
|
||||
|
||||
case ${TARGET_ARCH} in
|
||||
x86_64)
|
||||
OPENSSL_TARGET=linux-x86_64
|
||||
PLATFORM_FLAGS=enable-ec_nistp_64_gcc_128
|
||||
;;
|
||||
arm)
|
||||
OPENSSL_TARGET=linux-armv4
|
||||
;;
|
||||
aarch64)
|
||||
OPENSSL_TARGET=linux-aarch64
|
||||
;;
|
||||
i386)
|
||||
OPENSSL_TARGET=linux-generic32
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
configure_target() {
|
||||
cd ${PKG_BUILD}/.${TARGET_NAME}
|
||||
./Configure ${PKG_CONFIGURE_OPTS_TARGET} ${PKG_CONFIGURE_OPTS_SHARED} ${PLATFORM_FLAGS} ${OPENSSL_TARGET} ${CFLAGS} ${LDFLAGS}
|
||||
}
|
||||
|
||||
makeinstall_target() {
|
||||
make DESTDIR=${INSTALL} install_sw
|
||||
make DESTDIR=${SYSROOT_PREFIX} install_sw
|
||||
}
|
||||
|
||||
post_makeinstall_target() {
|
||||
rm -rf ${INSTALL}/etc/ssl/misc
|
||||
rm -rf ${INSTALL}/usr/bin/c_rehash
|
||||
|
||||
debug_strip ${INSTALL}/usr/bin/openssl
|
||||
|
||||
# cert from https://curl.haxx.se/docs/caextract.html
|
||||
mkdir -p ${INSTALL}/etc/ssl
|
||||
cp ${PKG_DIR}/cert/cacert.pem ${INSTALL}/etc/ssl/cacert.pem.system
|
||||
|
||||
# give user the chance to include their own CA
|
||||
mkdir -p ${INSTALL}/usr/bin
|
||||
cp ${PKG_DIR}/scripts/openssl-config ${INSTALL}/usr/bin
|
||||
ln -sf /run/libreelec/cacert.pem ${INSTALL}/etc/ssl/cacert.pem
|
||||
ln -sf /run/libreelec/cacert.pem ${INSTALL}/etc/ssl/cert.pem
|
||||
|
||||
# backwards comatibility
|
||||
mkdir -p ${INSTALL}/etc/pki/tls
|
||||
ln -sf /run/libreelec/cacert.pem ${INSTALL}/etc/pki/tls/cacert.pem
|
||||
mkdir -p ${INSTALL}/etc/pki/tls/certs
|
||||
ln -sf /run/libreelec/cacert.pem ${INSTALL}/etc/pki/tls/certs/ca-bundle.crt
|
||||
mkdir -p ${INSTALL}/usr/lib/ssl
|
||||
ln -sf /run/libreelec/cacert.pem ${INSTALL}/usr/lib/ssl/cert.pem
|
||||
}
|
||||
|
||||
post_install() {
|
||||
enable_service openssl-config.service
|
||||
}
|
10
projects/L4T/packages/openssl/scripts/openssl-config
Executable file
10
projects/L4T/packages/openssl/scripts/openssl-config
Executable file
@ -0,0 +1,10 @@
|
||||
#!/bin/bash
|
||||
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
# Copyright (C) 2018-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
cp /etc/ssl/cacert.pem.system /run/libreelec/cacert.pem
|
||||
|
||||
[ -f /storage/.config/cacert.pem ] && cat /storage/.config/cacert.pem >>/run/libreelec/cacert.pem
|
||||
|
||||
exit 0
|
@ -0,0 +1,12 @@
|
||||
[Unit]
|
||||
Description=OpenSSL configuration service
|
||||
DefaultDependencies=no
|
||||
After=systemd-tmpfiles-setup.service
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
RemainAfterExit=yes
|
||||
ExecStart=/usr/bin/openssl-config
|
||||
|
||||
[Install]
|
||||
WantedBy=sysinit.target
|
@ -0,0 +1,5 @@
|
||||
Files have to have the .conf file name extension, but otherwise the file names can be
|
||||
chosen freely. The files under pulse-daemon.conf.d are processed in alphabetical order.
|
||||
In case the same option is set in multiple files, the last file to set an option
|
||||
overrides earlier files. The main daemon.conf file is processed first, so
|
||||
options set in files under pulse-daemon.conf.d override the main file.
|
59
projects/L4T/packages/pulseaudio/config/system.pa
Normal file
59
projects/L4T/packages/pulseaudio/config/system.pa
Normal file
@ -0,0 +1,59 @@
|
||||
#!/usr/bin/pulseaudio -nF
|
||||
#
|
||||
# This file is part of PulseAudio.
|
||||
#
|
||||
# PulseAudio is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Lesser General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# PulseAudio is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
# General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Lesser General Public License
|
||||
# along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
# This startup script is used only if PulseAudio is started in system
|
||||
# mode.
|
||||
|
||||
### Load several protocols
|
||||
load-module module-native-protocol-unix
|
||||
|
||||
### Automatically restore the volume of streams and devices
|
||||
load-module module-stream-restore
|
||||
load-module module-device-restore
|
||||
load-module module-card-restore
|
||||
|
||||
### Automatically restore the default sink/source when changed by the user
|
||||
### during runtime
|
||||
### NOTE: This should be loaded as early as possible so that subsequent modules
|
||||
### that look up the default sink/source get the right value
|
||||
load-module module-default-device-restore
|
||||
|
||||
### Make sure we always have a sink around, even if it is a null sink.
|
||||
load-module module-always-sink
|
||||
|
||||
### Automatically suspend sinks/sources that become idle for too long
|
||||
load-module module-suspend-on-idle
|
||||
|
||||
### Automatically load modules for dbus
|
||||
.ifexists module-dbus-protocol.so
|
||||
load-module module-dbus-protocol
|
||||
.endif
|
||||
|
||||
### Automatically load modules for bluetooth
|
||||
.ifexists module-bluetooth-policy.so
|
||||
load-module module-bluetooth-policy
|
||||
.endif
|
||||
|
||||
.ifexists module-bluetooth-discover.so
|
||||
load-module module-bluetooth-discover
|
||||
.endif
|
||||
|
||||
.ifexists module-zeroconf-publish.so
|
||||
load-module module-zeroconf-publish
|
||||
.endif
|
||||
|
||||
load-module module-switch-on-connect
|
103
projects/L4T/packages/pulseaudio/package.mk
Normal file
103
projects/L4T/packages/pulseaudio/package.mk
Normal file
@ -0,0 +1,103 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2016 Stephan Raue (stephan@openelec.tv)
|
||||
# Copyright (C) 2016-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
PKG_NAME="pulseaudio"
|
||||
PKG_VERSION="14.2"
|
||||
PKG_SHA256="75d3f7742c1ae449049a4c88900e454b8b350ecaa8c544f3488a2562a9ff66f1"
|
||||
PKG_LICENSE="GPL"
|
||||
PKG_SITE="http://pulseaudio.org/"
|
||||
PKG_URL="http://www.freedesktop.org/software/pulseaudio/releases/${PKG_NAME}-${PKG_VERSION}.tar.xz"
|
||||
PKG_DEPENDS_TARGET="toolchain alsa-lib dbus libcap libsndfile libtool openssl soxr speexdsp systemd glib:host glib"
|
||||
PKG_LONGDESC="PulseAudio is a sound system for POSIX OSes, meaning that it is a proxy for your sound applications."
|
||||
PKG_TOOLCHAIN="meson"
|
||||
|
||||
if [ "${PROJECT}" = "L4T" ]; then
|
||||
PKG_PATCH_DIRS="${PROJECT}"
|
||||
fi
|
||||
|
||||
if [ "${BLUETOOTH_SUPPORT}" = "yes" ]; then
|
||||
PKG_DEPENDS_TARGET+=" sbc"
|
||||
PKG_PULSEAUDIO_BLUETOOTH="-Dbluez5=true"
|
||||
else
|
||||
PKG_PULSEAUDIO_BLUETOOTH="-Dbluez5=false"
|
||||
fi
|
||||
|
||||
if [ "${AVAHI_DAEMON}" = "yes" ]; then
|
||||
PKG_DEPENDS_TARGET+=" avahi"
|
||||
PKG_PULSEAUDIO_AVAHI="-Davahi=enabled"
|
||||
else
|
||||
PKG_PULSEAUDIO_AVAHI="-Davahi=disabled"
|
||||
fi
|
||||
|
||||
PKG_MESON_OPTS_TARGET="-Dgcov=false \
|
||||
-Dman=false \
|
||||
-Dtests=false \
|
||||
-Dsystem_user=root \
|
||||
-Dsystem_group=root \
|
||||
-Daccess_group=root \
|
||||
-Ddatabase=simple \
|
||||
-Dlegacy-database-entry-format=false \
|
||||
-Drunning-from-build-tree=false \
|
||||
-Datomic-arm-linux-helpers=true \
|
||||
-Datomic-arm-memory-barrier=false \
|
||||
-Dmodlibexecdir=/usr/lib/pulse \
|
||||
-Dudevrulesdir=/usr/lib/udev/rules.d \
|
||||
-Dalsa=enabled \
|
||||
-Dasyncns=disabled \
|
||||
${PKG_PULSEAUDIO_AVAHI} \
|
||||
${PKG_PULSEAUDIO_BLUETOOTH} \
|
||||
-Dbluez5-native-headset=false \
|
||||
-Dbluez5-ofono-headset=false \
|
||||
-Ddbus=enabled \
|
||||
-Dfftw=disabled \
|
||||
-Dglib=enabled \
|
||||
-Dgsettings=disabled \
|
||||
-Dgtk=disabled \
|
||||
-Dhal-compat=false \
|
||||
-Dipv6=true \
|
||||
-Djack=disabled \
|
||||
-Dlirc=disabled \
|
||||
-Dopenssl=enabled \
|
||||
-Dorc=disabled \
|
||||
-Dsamplerate=disabled \
|
||||
-Dsoxr=enabled \
|
||||
-Dspeex=enabled \
|
||||
-Dsystemd=enabled \
|
||||
-Dudev=enabled \
|
||||
-Dx11=disabled \
|
||||
-Dadrian-aec=true \
|
||||
-Dwebrtc-aec=disabled \
|
||||
-Ddoxygen=false"
|
||||
|
||||
pre_configure_target() {
|
||||
sed -e 's|; remixing-use-all-sink-channels = yes|; remixing-use-all-sink-channels = no|' \
|
||||
-i ${PKG_BUILD}/src/daemon/daemon.conf.in
|
||||
}
|
||||
|
||||
post_makeinstall_target() {
|
||||
safe_remove ${INSTALL}/usr/include
|
||||
safe_remove ${INSTALL}/usr/lib/cmake
|
||||
safe_remove ${INSTALL}/usr/lib/pkgconfig
|
||||
safe_remove ${INSTALL}/usr/lib/systemd
|
||||
safe_remove ${INSTALL}/usr/share/vala
|
||||
safe_remove ${INSTALL}/usr/share/zsh
|
||||
safe_remove ${INSTALL}/usr/share/bash-completion
|
||||
|
||||
cp ${PKG_DIR}/config/system.pa ${INSTALL}/etc/pulse/
|
||||
|
||||
if [ "${PROJECT}" = "L4T" ]; then
|
||||
echo load-module module-switch-on-port-available >> ${INSTALL}/etc/pulse/system.pa
|
||||
fi
|
||||
|
||||
sed 's/user="pulse"/user="root"/' -i ${INSTALL}/etc/dbus-1/system.d/pulseaudio-system.conf
|
||||
|
||||
mkdir -p ${INSTALL}/usr/config
|
||||
cp -PR ${PKG_DIR}/config/pulse-daemon.conf.d ${INSTALL}/usr/config
|
||||
|
||||
ln -sf /storage/.config/pulse-daemon.conf.d ${INSTALL}/etc/pulse/daemon.conf.d
|
||||
}
|
||||
|
||||
post_install() {
|
||||
enable_service pulseaudio.service
|
||||
}
|
204
projects/L4T/packages/pulseaudio/patches/pulseaudio-0900.03-eliminates-lags-after-bluetooth-packet-loss.patch
Normal file
204
projects/L4T/packages/pulseaudio/patches/pulseaudio-0900.03-eliminates-lags-after-bluetooth-packet-loss.patch
Normal file
@ -0,0 +1,204 @@
|
||||
diff --git a/packages/audio/pulseaudio/patches/pulseaudio-0900.03-eliminates-lags-after-bluetooth-packet-loss.patch b/packages/audio/pulseaudio/patches/pulseaudio-0900.03-eliminates-lags-after-bluetooth-packet-loss.patch
|
||||
new file mode 100644
|
||||
index 0000000..6a7aeab
|
||||
--- /dev/null
|
||||
+++ b/packages/audio/pulseaudio/patches/pulseaudio-0900.03-eliminates-lags-after-bluetooth-packet-loss.patch
|
||||
@@ -0,0 +1,198 @@
|
||||
+diff --git a/src/modules/bluetooth/module-bluez5-device.c b/src/modules/bluetooth/module-bluez5-device.c
|
||||
+index 84e6d55..b96a80d 100644
|
||||
+--- a/src/modules/bluetooth/module-bluez5-device.c
|
||||
++++ b/src/modules/bluetooth/module-bluez5-device.c
|
||||
+@@ -649,6 +649,29 @@ static int a2dp_process_push(struct userdata *u) {
|
||||
+ return ret;
|
||||
+ }
|
||||
+
|
||||
++static void update_buffer_size(struct userdata *u) {
|
||||
++ int old_bufsize, new_bufsize;
|
||||
++ socklen_t len = sizeof(int);
|
||||
++ int rc;
|
||||
++
|
||||
++ rc = getsockopt(u->stream_fd, SOL_SOCKET, SO_SNDBUF, &old_bufsize, &len);
|
||||
++ if (rc == -1) {
|
||||
++ pa_log_warn("Changing bluetooth buffer size: Failed to getsockopt(SO_SNDBUF): %s", pa_cstrerror(errno));
|
||||
++ } else {
|
||||
++ bool ok = false;
|
||||
++ for (int n = 2; !ok && n < 16; ++n) {
|
||||
++ new_bufsize = n * u->write_link_mtu;
|
||||
++ rc = setsockopt(u->stream_fd, SOL_SOCKET, SO_SNDBUF, &new_bufsize, len);
|
||||
++ if (rc == -1) {
|
||||
++ pa_log_warn("Changing bluetooth buffer size: Failed to change from %d to %d: %s", old_bufsize, new_bufsize, pa_cstrerror(errno));
|
||||
++ } else {
|
||||
++ ok = true;
|
||||
++ pa_log_info("Changing bluetooth buffer size: Changed from %d to %d", old_bufsize, new_bufsize);
|
||||
++ }
|
||||
++ }
|
||||
++ }
|
||||
++}
|
||||
++
|
||||
+ /* Run from I/O thread */
|
||||
+ static void a2dp_set_bitpool(struct userdata *u, uint8_t bitpool) {
|
||||
+ struct sbc_info *sbc_info;
|
||||
+@@ -683,6 +706,8 @@ static void a2dp_set_bitpool(struct userdata *u, uint8_t bitpool) {
|
||||
+ pa_sink_set_max_request_within_thread(u->sink, u->write_block_size);
|
||||
+ pa_sink_set_fixed_latency_within_thread(u->sink,
|
||||
+ FIXED_LATENCY_PLAYBACK_A2DP + pa_bytes_to_usec(u->write_block_size, &u->sample_spec));
|
||||
++
|
||||
++ update_buffer_size(u);
|
||||
+ }
|
||||
+
|
||||
+ /* Run from I/O thread */
|
||||
+@@ -814,6 +839,8 @@ static void setup_stream(struct userdata *u) {
|
||||
+
|
||||
+ if (u->profile == PA_BLUETOOTH_PROFILE_A2DP_SINK)
|
||||
+ a2dp_set_bitpool(u, u->sbc_info.max_bitpool);
|
||||
++
|
||||
++ update_buffer_size(u);
|
||||
+
|
||||
+ u->rtpoll_item = pa_rtpoll_item_new(u->rtpoll, PA_RTPOLL_NEVER, 1);
|
||||
+ pollfd = pa_rtpoll_item_get_pollfd(u->rtpoll_item, NULL);
|
||||
+@@ -1327,6 +1354,7 @@ static void thread_func(void *userdata) {
|
||||
+ unsigned do_write = 0;
|
||||
+ unsigned pending_read_bytes = 0;
|
||||
+ bool writable = false;
|
||||
++ pa_usec_t ts_last_frame;
|
||||
+
|
||||
+ pa_assert(u);
|
||||
+ pa_assert(u->transport);
|
||||
+@@ -1341,11 +1369,16 @@ static void thread_func(void *userdata) {
|
||||
+ /* Setup the stream only if the transport was already acquired */
|
||||
+ if (u->transport_acquired)
|
||||
+ setup_stream(u);
|
||||
++ u->started_at = pa_rtclock_now();
|
||||
+
|
||||
++ ts_last_frame = u->started_at;
|
||||
++
|
||||
+ for (;;) {
|
||||
+ struct pollfd *pollfd;
|
||||
+ int ret;
|
||||
+ bool disable_timer = true;
|
||||
++ pa_usec_t ts_now = pa_rtclock_now();
|
||||
++ pa_usec_t ts_next_frame = ts_last_frame + pa_bytes_to_usec(u->write_block_size, &u->sample_spec);
|
||||
+
|
||||
+ pollfd = u->rtpoll_item ? pa_rtpoll_item_get_pollfd(u->rtpoll_item, NULL) : NULL;
|
||||
+
|
||||
+@@ -1404,86 +1437,57 @@ static void thread_func(void *userdata) {
|
||||
+ if (pollfd->revents & POLLOUT)
|
||||
+ writable = true;
|
||||
+
|
||||
+- if ((!u->source || !PA_SOURCE_IS_LINKED(u->source->thread_info.state)) && do_write <= 0 && writable) {
|
||||
+- pa_usec_t time_passed;
|
||||
+- pa_usec_t audio_sent;
|
||||
++ if ((!u->source || !PA_SOURCE_IS_LINKED(u->source->thread_info.state))) {
|
||||
+
|
||||
+- /* Hmm, there is no input stream we could synchronize
|
||||
+- * to. So let's do things by time */
|
||||
++ if (ts_now >= ts_next_frame) {
|
||||
+
|
||||
+- time_passed = pa_rtclock_now() - u->started_at;
|
||||
+- audio_sent = pa_bytes_to_usec(u->write_index, &u->sample_spec);
|
||||
++ if (writable) {
|
||||
++ int n_written;
|
||||
++
|
||||
++ if (u->profile == PA_BLUETOOTH_PROFILE_A2DP_SINK) {
|
||||
++ if ((n_written = a2dp_process_render(u)) < 0)
|
||||
++ goto fail;
|
||||
++ } else {
|
||||
++ if ((n_written = sco_process_render(u)) < 0)
|
||||
++ goto fail;
|
||||
++ }
|
||||
+
|
||||
+- if (audio_sent <= time_passed) {
|
||||
+- pa_usec_t audio_to_send = time_passed - audio_sent;
|
||||
++ if (n_written == 0)
|
||||
++ pa_log("Broken kernel: we got EAGAIN on write() after POLLOUT!");
|
||||
+
|
||||
+- /* Never try to catch up for more than 100ms */
|
||||
+- if (u->write_index > 0 && audio_to_send > MAX_PLAYBACK_CATCH_UP_USEC) {
|
||||
++ do_write -= n_written;
|
||||
++ writable = false;
|
||||
++ } else {
|
||||
+ pa_usec_t skip_usec;
|
||||
+ uint64_t skip_bytes;
|
||||
++ pa_memchunk tmp;
|
||||
+
|
||||
+- skip_usec = audio_to_send - MAX_PLAYBACK_CATCH_UP_USEC;
|
||||
++ skip_usec = ts_now - ts_last_frame;
|
||||
+ skip_bytes = pa_usec_to_bytes(skip_usec, &u->sample_spec);
|
||||
+
|
||||
+- if (skip_bytes > 0) {
|
||||
+- pa_memchunk tmp;
|
||||
++ pa_log_warn("Skipping %llu us (= %llu bytes) in audio stream",
|
||||
++ (unsigned long long) skip_usec,
|
||||
++ (unsigned long long) skip_bytes);
|
||||
+
|
||||
+- pa_log_warn("Skipping %llu us (= %llu bytes) in audio stream",
|
||||
+- (unsigned long long) skip_usec,
|
||||
+- (unsigned long long) skip_bytes);
|
||||
++ pa_sink_render_full(u->sink, skip_bytes, &tmp);
|
||||
++ pa_memblock_unref(tmp.memblock);
|
||||
++ u->write_index += skip_bytes;
|
||||
+
|
||||
+- pa_sink_render_full(u->sink, skip_bytes, &tmp);
|
||||
+- pa_memblock_unref(tmp.memblock);
|
||||
+- u->write_index += skip_bytes;
|
||||
+-
|
||||
+- if (u->profile == PA_BLUETOOTH_PROFILE_A2DP_SINK)
|
||||
+- a2dp_reduce_bitpool(u);
|
||||
+- }
|
||||
++ if (u->profile == PA_BLUETOOTH_PROFILE_A2DP_SINK)
|
||||
++ a2dp_reduce_bitpool(u);
|
||||
+ }
|
||||
+-
|
||||
+- do_write = 1;
|
||||
++ ts_last_frame = ts_now;
|
||||
++ // TODO: ts_last_frame might be slightly inaccurate; it should depend on ts_next_frame
|
||||
+ pending_read_bytes = 0;
|
||||
+ }
|
||||
+- }
|
||||
+-
|
||||
+- if (writable && do_write > 0) {
|
||||
+- int n_written;
|
||||
+
|
||||
+- if (u->write_index <= 0)
|
||||
+- u->started_at = pa_rtclock_now();
|
||||
++ {
|
||||
++ pa_usec_t ts_now2 = pa_rtclock_now();
|
||||
++ pa_usec_t sleep_for = ts_now2 > ts_next_frame ? 0 : ts_next_frame - ts_now2;
|
||||
+
|
||||
+- if (u->profile == PA_BLUETOOTH_PROFILE_A2DP_SINK) {
|
||||
+- if ((n_written = a2dp_process_render(u)) < 0)
|
||||
+- goto fail;
|
||||
+- } else {
|
||||
+- if ((n_written = sco_process_render(u)) < 0)
|
||||
+- goto fail;
|
||||
++ pa_rtpoll_set_timer_relative(u->rtpoll, sleep_for);
|
||||
++ disable_timer = false;
|
||||
+ }
|
||||
+-
|
||||
+- if (n_written == 0)
|
||||
+- pa_log("Broken kernel: we got EAGAIN on write() after POLLOUT!");
|
||||
+-
|
||||
+- do_write -= n_written;
|
||||
+- writable = false;
|
||||
+- }
|
||||
+-
|
||||
+- if ((!u->source || !PA_SOURCE_IS_LINKED(u->source->thread_info.state)) && do_write <= 0) {
|
||||
+- pa_usec_t sleep_for;
|
||||
+- pa_usec_t time_passed, next_write_at;
|
||||
+-
|
||||
+- if (writable) {
|
||||
+- /* Hmm, there is no input stream we could synchronize
|
||||
+- * to. So let's estimate when we need to wake up the latest */
|
||||
+- time_passed = pa_rtclock_now() - u->started_at;
|
||||
+- next_write_at = pa_bytes_to_usec(u->write_index, &u->sample_spec);
|
||||
+- sleep_for = time_passed < next_write_at ? next_write_at - time_passed : 0;
|
||||
+- /* pa_log("Sleeping for %lu; time passed %lu, next write at %lu", (unsigned long) sleep_for, (unsigned long) time_passed, (unsigned long)next_write_at); */
|
||||
+- } else
|
||||
+- /* drop stream every 500 ms */
|
||||
+- sleep_for = PA_USEC_PER_MSEC * 500;
|
||||
+-
|
||||
+- pa_rtpoll_set_timer_relative(u->rtpoll, sleep_for);
|
||||
+- disable_timer = false;
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
24
projects/L4T/packages/pulseaudio/patches/pulseaudio-100.01-never-append-dirty-to-server-module-version.patch
Normal file
24
projects/L4T/packages/pulseaudio/patches/pulseaudio-100.01-never-append-dirty-to-server-module-version.patch
Normal file
@ -0,0 +1,24 @@
|
||||
From c9d7dcaa87f9ada49d75483a7c604dba27a0d71a Mon Sep 17 00:00:00 2001
|
||||
From: Stefan Saraev <stefan@saraev.ca>
|
||||
Date: Tue, 7 Jan 2014 13:22:48 +0200
|
||||
Subject: [PATCH] never append -dirty to server/module version
|
||||
|
||||
---
|
||||
git-version-gen | 1 +
|
||||
1 files changed, 1 insertions(+), 0 deletions(-)
|
||||
|
||||
diff --git a/git-version-gen b/git-version-gen
|
||||
index 9d65b80..fcf11fd 100755
|
||||
--- a/git-version-gen
|
||||
+++ b/git-version-gen
|
||||
@@ -152,6 +152,7 @@ v=`echo "$v" |sed 's/^v//'`
|
||||
git status > /dev/null 2>&1
|
||||
|
||||
dirty=`sh -c 'git diff-index --name-only HEAD' 2>/dev/null` || dirty=
|
||||
+dirty=
|
||||
case "$dirty" in
|
||||
'') ;;
|
||||
*) # Append the suffix only if there isn't one already.
|
||||
--
|
||||
1.7.2.5
|
||||
|
@ -0,0 +1,13 @@
|
||||
--- pulseaudio-4.0.orig/src/pulsecore/core-util.c 2014-01-12 23:31:26.281525000 -0800
|
||||
+++ pulseaudio-4.0/src/pulsecore/core-util.c 2014-01-12 23:32:32.977118803 -0800
|
||||
@@ -1447,10 +1447,6 @@
|
||||
if (stat(p, &st) < 0)
|
||||
return -errno;
|
||||
|
||||
-#ifdef HAVE_GETUID
|
||||
- if (st.st_uid != getuid() && st.st_uid != 0)
|
||||
- return -EACCES;
|
||||
-#endif
|
||||
|
||||
return 0;
|
||||
}
|
@ -0,0 +1,24 @@
|
||||
diff -Naur pulseaudio-14.2/meson.build pulseaudio-14.2-2/meson.build
|
||||
--- pulseaudio-14.2/meson.build 2022-04-20 18:18:28.025307372 +0200
|
||||
+++ pulseaudio-14.2-2/meson.build 2022-04-20 18:19:24.426473050 +0200
|
||||
@@ -699,7 +699,9 @@
|
||||
|
||||
# Subdirs
|
||||
|
||||
-subdir('doxygen')
|
||||
+if get_option('doxygen')
|
||||
+ subdir('doxygen')
|
||||
+endif
|
||||
subdir('po')
|
||||
if get_option('man')
|
||||
subdir('man')
|
||||
diff -Naur pulseaudio-14.2/meson_options.txt pulseaudio-14.2-2/meson_options.txt
|
||||
--- pulseaudio-14.2/meson_options.txt 2022-04-20 18:18:28.021307289 +0200
|
||||
+++ pulseaudio-14.2-2/meson_options.txt 2022-04-20 18:20:56.216359698 +0200
|
||||
@@ -1,3 +1,6 @@
|
||||
+option('doxygen',
|
||||
+ type : 'boolean', value : true,
|
||||
+ description : 'Enable building and installation of documentation generated with doxygen')
|
||||
option('gcov',
|
||||
type : 'boolean', value : false,
|
||||
description : 'Enable optional gcov coverage analysis')
|
@ -0,0 +1,4 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2014 Stephan Raue (stephan@openelec.tv)
|
||||
|
||||
export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/usr/lib/pulseaudio"
|
14
projects/L4T/packages/pulseaudio/system.d/pulseaudio.service
Normal file
14
projects/L4T/packages/pulseaudio/system.d/pulseaudio.service
Normal file
@ -0,0 +1,14 @@
|
||||
[Unit]
|
||||
Description=PulseAudio Sound Service
|
||||
After=syslog.target local-fs.target
|
||||
|
||||
[Service]
|
||||
Type=dbus
|
||||
BusName=org.pulseaudio.Server
|
||||
ExecStart=/usr/bin/pulseaudio --system --disallow-exit --exit-idle-time=-1 --disable-shm --enable-memfd --realtime
|
||||
Restart=on-failure
|
||||
Environment=PULSE_STATE_PATH=/storage/.config/pulse
|
||||
Environment=PULSE_CONFIG_PATH=/storage/.config/pulse
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
10
projects/L4T/packages/systemd/config/hosts.conf
Normal file
10
projects/L4T/packages/systemd/config/hosts.conf
Normal file
@ -0,0 +1,10 @@
|
||||
# hosts.conf
|
||||
|
||||
# This configuration file allows you to manually map hostnames to
|
||||
# IP addresses
|
||||
|
||||
# Format: <ipaddress> <hostname1> <hostname2>
|
||||
# Example: 192.168.0.3 libreelec libreelec.mynetwork
|
||||
|
||||
# NOTE: do not edit /etc/hosts directly
|
||||
# edit /storage/.config/hosts.conf then reboot
|
17
projects/L4T/packages/systemd/config/hwdb.d/99-osmcrf.hwdb
Normal file
17
projects/L4T/packages/systemd/config/hwdb.d/99-osmcrf.hwdb
Normal file
@ -0,0 +1,17 @@
|
||||
evdev:input:b0003v2017p1689*
|
||||
KEYBOARD_KEY_7002e=volumeup
|
||||
KEYBOARD_KEY_7002d=volumedown
|
||||
KEYBOARD_KEY_7000c=kpleftparen
|
||||
KEYBOARD_KEY_70006=kprightparen
|
||||
|
||||
evdev:input:b0003v2017p1688*
|
||||
KEYBOARD_KEY_7004a=esc
|
||||
KEYBOARD_KEY_c0060=kpleftparen
|
||||
KEYBOARD_KEY_10084=kprightparen
|
||||
KEYBOARD_KEY_7002e=volumeup
|
||||
KEYBOARD_KEY_7002d=volumedown
|
||||
|
||||
evdev:input:b0003v2252p1037*
|
||||
KEYBOARD_KEY_7004a=esc
|
||||
KEYBOARD_KEY_c0060=kpleftparen
|
||||
KEYBOARD_KEY_10084=kprightparen
|
10
projects/L4T/packages/systemd/config/hwdb.d/README
Normal file
10
projects/L4T/packages/systemd/config/hwdb.d/README
Normal file
@ -0,0 +1,10 @@
|
||||
Hardware Database Files
|
||||
|
||||
The hwdb files are read from the files located in the system hwdb directory
|
||||
/usr/lib/udev/hwdb.d and the user runtime directory /storage/.config/hwdb.d
|
||||
All hwdb files are collectively sorted and processed in lexical order, regardless of
|
||||
the directories in which they live. However, files with identical filenames
|
||||
replace each other. /usr/lib/udev/hwdb.d/* takes precedence over /storage/.config/hwdb.d/*
|
||||
|
||||
your files must be named 99-xxxxx.hwdb
|
||||
|
233
projects/L4T/packages/systemd/config/logind.conf.d/README
Normal file
233
projects/L4T/packages/systemd/config/logind.conf.d/README
Normal file
@ -0,0 +1,233 @@
|
||||
LOGIND.CONF(5) logind.conf LOGIND.CONF(5)
|
||||
|
||||
NAME
|
||||
logind.conf, logind.conf.d - Login manager configuration files
|
||||
|
||||
SYNOPSIS
|
||||
/etc/systemd/logind.conf
|
||||
|
||||
/etc/systemd/logind.conf.d/*.conf
|
||||
|
||||
/run/systemd/logind.conf.d/*.conf
|
||||
|
||||
/usr/lib/systemd/logind.conf.d/*.conf
|
||||
|
||||
DESCRIPTION
|
||||
These files configure various parameters of the systemd login manager,
|
||||
systemd-logind.service(8).
|
||||
|
||||
CONFIGURATION DIRECTORIES AND PRECEDENCE
|
||||
The default configuration is defined during compilation, so a
|
||||
configuration file is only needed when it is necessary to deviate from
|
||||
those defaults. By default, the configuration file in /etc/systemd/
|
||||
contains commented out entries showing the defaults as a guide to the
|
||||
administrator. This file can be edited to create local overrides.
|
||||
|
||||
When packages need to customize the configuration, they can install
|
||||
configuration snippets in /usr/lib/systemd/*.conf.d/. Files in /etc/
|
||||
are reserved for the local administrator, who may use this logic to
|
||||
override the configuration files installed by vendor packages. The main
|
||||
configuration file is read before any of the configuration directories,
|
||||
and has the lowest precedence; entries in a file in any configuration
|
||||
directory override entries in the single configuration file. Files in
|
||||
the *.conf.d/ configuration subdirectories are sorted by their filename
|
||||
in lexicographic order, regardless of which of the subdirectories they
|
||||
reside in. When multiple files specify the same option, for options
|
||||
which accept just a single value, the entry in the file with the
|
||||
lexicographically latest name takes precedence. For options which
|
||||
accept a list of values, entries are collected as they occur in files
|
||||
sorted lexicographically. It is recommended to prefix all filenames in
|
||||
those subdirectories with a two-digit number and a dash, to simplify
|
||||
the ordering of the files.
|
||||
|
||||
To disable a configuration file supplied by the vendor, the recommended
|
||||
way is to place a symlink to /dev/null in the configuration directory
|
||||
in /etc/, with the same filename as the vendor configuration file.
|
||||
|
||||
OPTIONS
|
||||
All options are configured in the "[Login]" section:
|
||||
|
||||
NAutoVTs=
|
||||
Takes a positive integer. Configures how many virtual terminals
|
||||
(VTs) to allocate by default that, when switched to and are
|
||||
previously unused, "autovt" services are automatically spawned on.
|
||||
These services are instantiated from the template unit
|
||||
autovt@.service for the respective VT TTY name, for example,
|
||||
autovt@tty4.service. By default, autovt@.service is linked to
|
||||
getty@.service. In other words, login prompts are started
|
||||
dynamically as the user switches to unused virtual terminals.
|
||||
Hence, this parameter controls how many login "gettys" are
|
||||
available on the VTs. If a VT is already used by some other
|
||||
subsystem (for example, a graphical login), this kind of activation
|
||||
will not be attempted. Note that the VT configured in ReserveVT= is
|
||||
always subject to this kind of activation, even if it is not one of
|
||||
the VTs configured with the NAutoVTs= directive. Defaults to 6.
|
||||
When set to 0, automatic spawning of "autovt" services is disabled.
|
||||
|
||||
ReserveVT=
|
||||
Takes a positive integer. Identifies one virtual terminal that
|
||||
shall unconditionally be reserved for autovt@.service activation
|
||||
(see above). The VT selected with this option will be marked busy
|
||||
unconditionally, so that no other subsystem will allocate it. This
|
||||
functionality is useful to ensure that, regardless of how many VTs
|
||||
are allocated by other subsystems, one login "getty" is always
|
||||
available. Defaults to 6 (in other words, there will always be a
|
||||
"getty" available on Alt-F6.). When set to 0, VT reservation is
|
||||
disabled.
|
||||
|
||||
KillUserProcesses=
|
||||
Takes a boolean argument. Configures whether the processes of a
|
||||
user should be killed when the user logs out. If true, the scope
|
||||
unit corresponding to the session and all processes inside that
|
||||
scope will be terminated. If false, the scope is "abandoned", see
|
||||
systemd.scope(5), and processes are not killed. Defaults to "yes",
|
||||
but see the options KillOnlyUsers= and KillExcludeUsers= below.
|
||||
|
||||
In addition to session processes, user process may run under the
|
||||
user manager unit user@.service. Depending on the linger settings,
|
||||
this may allow users to run processes independent of their login
|
||||
sessions. See the description of enable-linger in loginctl(1).
|
||||
|
||||
Note that setting KillUserProcesses=yes will break tools like
|
||||
screen(1) and tmux(1), unless they are moved out of the session
|
||||
scope. See example in systemd-run(1).
|
||||
|
||||
KillOnlyUsers=, KillExcludeUsers=
|
||||
These settings take space-separated lists of usernames that
|
||||
override the KillUserProcesses= setting. A user name may be added
|
||||
to KillExcludeUsers= to exclude the processes in the session scopes
|
||||
of that user from being killed even if KillUserProcesses=yes is
|
||||
set. If KillExcludeUsers= is not set, the "root" user is excluded
|
||||
by default. KillExcludeUsers= may be set to an empty value to
|
||||
override this default. If a user is not excluded, KillOnlyUsers= is
|
||||
checked next. If this setting is specified, only the session scopes
|
||||
of those users will be killed. Otherwise, users are subject to the
|
||||
KillUserProcesses=yes setting.
|
||||
|
||||
IdleAction=
|
||||
Configures the action to take when the system is idle. Takes one of
|
||||
"ignore", "poweroff", "reboot", "halt", "kexec", "suspend",
|
||||
"hibernate", "hybrid-sleep", and "lock". Defaults to "ignore".
|
||||
|
||||
Note that this requires that user sessions correctly report the
|
||||
idle status to the system. The system will execute the action after
|
||||
all sessions report that they are idle, no idle inhibitor lock is
|
||||
active, and subsequently, the time configured with IdleActionSec=
|
||||
(see below) has expired.
|
||||
|
||||
IdleActionSec=
|
||||
Configures the delay after which the action configured in
|
||||
IdleAction= (see above) is taken after the system is idle.
|
||||
|
||||
InhibitDelayMaxSec=
|
||||
Specifies the maximum time a system shutdown or sleep request is
|
||||
delayed due to an inhibitor lock of type "delay" being active
|
||||
before the inhibitor is ignored and the operation executes anyway.
|
||||
Defaults to 5.
|
||||
|
||||
HandlePowerKey=, HandleSuspendKey=, HandleHibernateKey=,
|
||||
HandleLidSwitch=, HandleLidSwitchExternalPower=, HandleLidSwitchDocked=
|
||||
Controls how logind shall handle the system power and sleep keys
|
||||
and the lid switch to trigger actions such as system power-off or
|
||||
suspend. Can be one of "ignore", "poweroff", "reboot", "halt",
|
||||
"kexec", "suspend", "hibernate", "hybrid-sleep", and "lock". If
|
||||
"ignore", logind will never handle these keys. If "lock", all
|
||||
running sessions will be screen-locked; otherwise, the specified
|
||||
action will be taken in the respective event. Only input devices
|
||||
with the "power-switch" udev tag will be watched for key/lid switch
|
||||
events. HandlePowerKey= defaults to "poweroff". HandleSuspendKey=
|
||||
and HandleLidSwitch= default to "suspend".
|
||||
HandleLidSwitchExternalPower= is completely ignored by default (for
|
||||
backwards compatibility) — an explicit value must be set before it
|
||||
will be used to determine behaviour. HandleLidSwitchDocked=
|
||||
defaults to "ignore". HandleHibernateKey= defaults to "hibernate".
|
||||
If the system is inserted in a docking station, or if more than one
|
||||
display is connected, the action specified by
|
||||
HandleLidSwitchDocked= occurs; if the system is on external power
|
||||
the action (if any) specified by HandleLidSwitchExternalPower=
|
||||
occurs; otherwise the HandleLidSwitch= action occurs.
|
||||
|
||||
A different application may disable logind's handling of system
|
||||
power and sleep keys and the lid switch by taking a low-level
|
||||
inhibitor lock ("handle-power-key", "handle-suspend-key",
|
||||
"handle-hibernate-key", "handle-lid-switch"). This is most commonly
|
||||
used by graphical desktop environments to take over suspend and
|
||||
hibernation handling, and to use their own configuration
|
||||
mechanisms. If a low-level inhibitor lock is taken, logind will not
|
||||
take any action when that key or switch is triggered and the
|
||||
Handle*= settings are irrelevant.
|
||||
|
||||
PowerKeyIgnoreInhibited=, SuspendKeyIgnoreInhibited=,
|
||||
HibernateKeyIgnoreInhibited=, LidSwitchIgnoreInhibited=
|
||||
Controls whether actions that systemd-logind takes when the power
|
||||
and sleep keys and the lid switch are triggered are subject to
|
||||
high-level inhibitor locks ("shutdown", "sleep", "idle"). Low level
|
||||
inhibitor locks ("handle-power-key", "handle-suspend-key",
|
||||
"handle-hibernate-key", "handle-lid-switch"), are always honored,
|
||||
irrespective of this setting.
|
||||
|
||||
These settings take boolean arguments. If "no", the inhibitor locks
|
||||
taken by applications are respected. If "yes", "shutdown", "sleep",
|
||||
and "idle" inhibitor locks are ignored. PowerKeyIgnoreInhibited=,
|
||||
SuspendKeyIgnoreInhibited=, and HibernateKeyIgnoreInhibited=
|
||||
default to "no". LidSwitchIgnoreInhibited= defaults to "yes". This
|
||||
means that when systemd-logind is handling events by itself (no low
|
||||
level inhibitor locks are taken by another application), the lid
|
||||
switch does not respect suspend blockers by default, but the power
|
||||
and sleep keys do.
|
||||
|
||||
HoldoffTimeoutSec=
|
||||
Specifies the timeout after system startup or system resume in
|
||||
which systemd will hold off on reacting to lid events. This is
|
||||
required for the system to properly detect any hotplugged devices
|
||||
so systemd can ignore lid events if external monitors, or docks,
|
||||
are connected. If set to 0, systemd will always react immediately,
|
||||
possibly before the kernel fully probed all hotplugged devices.
|
||||
This is safe, as long as you do not care for systemd to account for
|
||||
devices that have been plugged or unplugged while the system was
|
||||
off. Defaults to 30s.
|
||||
|
||||
RuntimeDirectorySize=
|
||||
Sets the size limit on the $XDG_RUNTIME_DIR runtime directory for
|
||||
each user who logs in. Takes a size in bytes, optionally suffixed
|
||||
with the usual K, G, M, and T suffixes, to the base 1024 (IEC).
|
||||
Alternatively, a numerical percentage suffixed by "%" may be
|
||||
specified, which sets the size limit relative to the amount of
|
||||
physical RAM. Defaults to 10%. Note that this size is a safety
|
||||
limit only. As each runtime directory is a tmpfs file system, it
|
||||
will only consume as much memory as is needed.
|
||||
|
||||
InhibitorsMax=
|
||||
Controls the maximum number of concurrent inhibitors to permit.
|
||||
Defaults to 8192 (8K).
|
||||
|
||||
SessionsMax=
|
||||
Controls the maximum number of concurrent user sessions to manage.
|
||||
Defaults to 8192 (8K). Depending on how the pam_systemd.so module
|
||||
is included in the PAM stack configuration, further login sessions
|
||||
will either be refused, or permitted but not tracked by
|
||||
systemd-logind.
|
||||
|
||||
UserTasksMax=
|
||||
Sets the maximum number of OS tasks each user may run concurrently.
|
||||
This controls the TasksMax= setting of the per-user slice unit, see
|
||||
systemd.resource-control(5) for details. If assigned the special
|
||||
value "infinity", no tasks limit is applied. Defaults to 33%, which
|
||||
equals 10813 with the kernel's defaults on the host, but might be
|
||||
smaller in OS containers.
|
||||
|
||||
RemoveIPC=
|
||||
Controls whether System V and POSIX IPC objects belonging to the
|
||||
user shall be removed when the user fully logs out. Takes a boolean
|
||||
argument. If enabled, the user may not consume IPC resources after
|
||||
the last of the user's sessions terminated. This covers System V
|
||||
semaphores, shared memory and message queues, as well as POSIX
|
||||
shared memory and message queues. Note that IPC objects of the root
|
||||
user and other system users are excluded from the effect of this
|
||||
setting. Defaults to "yes".
|
||||
|
||||
SEE ALSO
|
||||
systemd(1), systemd-logind.service(8), loginctl(1), systemd-
|
||||
system.conf(5)
|
||||
|
||||
systemd 238 LOGIND.CONF(5)
|
33
projects/L4T/packages/systemd/config/modules-load.d/README
Normal file
33
projects/L4T/packages/systemd/config/modules-load.d/README
Normal file
@ -0,0 +1,33 @@
|
||||
Name
|
||||
|
||||
modules-load.d — Configure kernel modules to load at boot
|
||||
|
||||
Synopsis
|
||||
|
||||
/etc/modules-load.d/*.conf
|
||||
|
||||
/run/modules-load.d/*.conf
|
||||
|
||||
/usr/lib/modules-load.d/*.conf
|
||||
|
||||
Description
|
||||
|
||||
systemd-modules-load.service(8) reads files from the above directories which contain kernel modules to load during boot in a static list. Each configuration file is named in the style of /etc/modules-load.d/program.conf. Note that it is usually a better idea to rely on the automatic module loading by PCI IDs, USB IDs, DMI IDs or similar triggers encoded in the kernel modules themselves instead of static configuration like this. In fact, most modern kernel modules are prepared for automatic loading already.
|
||||
Configuration Format
|
||||
|
||||
The configuration files should simply contain a list of kernel module names to load, separated by newlines. Empty lines and lines whose first non-whitespace character is # or ; are ignored.
|
||||
|
||||
Each configuration file shall be named in the style of program.conf. Files in /etc/ override files with the same name in /usr/lib/ and /run/. Files in /run/ override files with the same name in /usr/lib/. Packages should install their configuration files in /usr/lib/, files in /etc/ are reserved for the local administrator, who may use this logic to override the configuration files installed from vendor packages.
|
||||
|
||||
If the administrator wants to disable a configuration file supplied by the vendor the recommended way is to place a symlink to /dev/null in /etc/modules-load.d/ bearing the same filename.
|
||||
Example
|
||||
|
||||
Example 1. /etc/modules-load.d/virtio-net.conf example:
|
||||
|
||||
# Load virtio-net.ko at boot
|
||||
virtio-net
|
||||
|
||||
|
||||
See Also
|
||||
|
||||
systemd(1), systemd-modules-load.service(8), systemd-delta(1), modprobe(8)
|
59
projects/L4T/packages/systemd/config/sleep.conf.d/README
Normal file
59
projects/L4T/packages/systemd/config/sleep.conf.d/README
Normal file
@ -0,0 +1,59 @@
|
||||
NAME
|
||||
systemd-sleep.conf, sleep.conf.d - Suspend and hibernation configuration file
|
||||
|
||||
SYNOPSIS
|
||||
/etc/systemd/sleep.conf
|
||||
|
||||
/etc/systemd/sleep.conf.d/*.conf
|
||||
|
||||
/run/systemd/sleep.conf.d/*.conf
|
||||
|
||||
/usr/lib/systemd/sleep.conf.d/*.conf
|
||||
|
||||
DESCRIPTION
|
||||
systemd supports three general power-saving modes:
|
||||
|
||||
suspend
|
||||
a low-power state where execution of the OS is paused, and complete power loss might result in lost data, and which is fast to enter and exit. This corresponds to suspend, standby, or freeze states as understood by the
|
||||
kernel.
|
||||
|
||||
hibernate
|
||||
a low-power state where execution of the OS is paused, and complete power loss does not result in lost data, and which might be slow to enter and exit. This corresponds to the hibernation as understood by the kernel.
|
||||
|
||||
hybrid-sleep
|
||||
a low-power state where execution of the OS is paused, which might be slow to enter, and on complete power loss does not result in lost data but might be slower to exit in that case. This mode is called suspend-to-both
|
||||
by the kernel.
|
||||
|
||||
Settings in these files determine what strings will be written to /sys/power/disk and /sys/power/state by systemd-sleep(8) when systemd(1) attempts to suspend or hibernate the machine.
|
||||
|
||||
CONFIGURATION DIRECTORIES AND PRECEDENCE
|
||||
The default configuration is defined during compilation, so a configuration file is only needed when it is necessary to deviate from those defaults. By default, the configuration file in /etc/systemd/ contains commented out
|
||||
entries showing the defaults as a guide to the administrator. This file can be edited to create local overrides.
|
||||
|
||||
When packages need to customize the configuration, they can install configuration snippets in /usr/lib/systemd/*.conf.d/. Files in /etc/ are reserved for the local administrator, who may use this logic to override the
|
||||
configuration files installed by vendor packages. The main configuration file is read before any of the configuration directories, and has the lowest precedence; entries in a file in any configuration directory override
|
||||
entries in the single configuration file. Files in the *.conf.d/ configuration subdirectories are sorted by their filename in lexicographic order, regardless of which of the subdirectories they reside in. If multiple files
|
||||
specify the same option, the entry in the file with the lexicographically latest name takes precedence. It is recommended to prefix all filenames in those subdirectories with a two-digit number and a dash, to simplify the
|
||||
ordering of the files.
|
||||
|
||||
To disable a configuration file supplied by the vendor, the recommended way is to place a symlink to /dev/null in the configuration directory in /etc/, with the same filename as the vendor configuration file.
|
||||
|
||||
OPTIONS
|
||||
The following options can be configured in the "[Sleep]" section of /etc/systemd/sleep.conf or a sleep.conf.d file:
|
||||
|
||||
SuspendMode=, HibernateMode=, HybridSleepMode=
|
||||
The string to be written to /sys/power/disk by, respectively, systemd-suspend.service(8), systemd-hibernate.service(8), or systemd-hybrid-sleep.service(8). More than one value can be specified by separating multiple
|
||||
values with whitespace. They will be tried in turn, until one is written without error. If neither succeeds, the operation will be aborted.
|
||||
|
||||
SuspendState=, HibernateState=, HybridSleepState=
|
||||
The string to be written to /sys/power/state by, respectively, systemd-suspend.service(8), systemd-hibernate.service(8), or systemd-hybrid-sleep.service(8). More than one value can be specified by separating multiple
|
||||
values with whitespace. They will be tried in turn, until one is written without error. If neither succeeds, the operation will be aborted.
|
||||
|
||||
EXAMPLE: FREEZE
|
||||
Example: to exploit the “freeze” mode added in Linux 3.9, one can use systemctl suspend with
|
||||
|
||||
[Sleep]
|
||||
SuspendState=freeze
|
||||
|
||||
SEE ALSO
|
||||
systemd-sleep(8), systemd-suspend.service(8), systemd-hibernate.service(8), systemd-hybrid-sleep.service(8), systemd(1), systemd.directives(7)
|
@ -0,0 +1,3 @@
|
||||
[Sleep]
|
||||
SuspendMode=false
|
||||
HibernateMode=false
|
35
projects/L4T/packages/systemd/config/sysctl.d/README
Normal file
35
projects/L4T/packages/systemd/config/sysctl.d/README
Normal file
@ -0,0 +1,35 @@
|
||||
Name
|
||||
|
||||
sysctl.d — Configure kernel parameters at boot
|
||||
|
||||
Synopsis
|
||||
|
||||
/etc/sysctl.d/*.conf
|
||||
|
||||
/run/sysctl.d/*.conf
|
||||
|
||||
/usr/lib/sysctl.d/*.conf
|
||||
|
||||
Description
|
||||
|
||||
At boot, systemd-sysctl.service(8) reads configuration files from the above directories to configure sysctl(8) kernel parameters.
|
||||
Configuration Format
|
||||
|
||||
The configuration files contain a list of variable assignments, separated by newlines. Empty lines and lines whose first non-whitespace character is # or ; are ignored.
|
||||
|
||||
Note that both / and . are accepted as label separators within sysctl variable names. "kernel.domainname=foo" and "kernel/domainname=foo" hence are entirely equivalent.
|
||||
|
||||
Each configuration file shall be named in the style of program.conf. Files in /etc/ override files with the same name in /usr/lib/ and /run/. Files in /run/ override files with the same name in /usr/lib/. Packages should install their configuration files in /usr/lib/. Files in /etc/ are reserved for the local administrator, who may use this logic to override the configuration files installed by vendor packages. All configuration files are sorted by their filename in alphabetical order, regardless in which of the directories they reside, to guarantee that a specific configuration file takes precedence over another file with an alphabetically later name, if both files contain the same variable setting.
|
||||
|
||||
If the administrator wants to disable a configuration file supplied by the vendor, the recommended way is to place a symlink to /dev/null in /etc/sysctl.d/ bearing the same filename.
|
||||
Example
|
||||
|
||||
Example 1. /etc/sysctl.d/domain-name.conf example:
|
||||
|
||||
# Set kernel YP domain name
|
||||
kernel.domainname=example.com
|
||||
|
||||
|
||||
See Also
|
||||
|
||||
systemd(1), systemd-sysctl.service(8), systemd-delta(1), sysctl(8), sysctl.conf(5)
|
232
projects/L4T/packages/systemd/config/system.d/README
Normal file
232
projects/L4T/packages/systemd/config/system.d/README
Normal file
@ -0,0 +1,232 @@
|
||||
Name
|
||||
|
||||
systemd.unit — Unit configuration
|
||||
|
||||
Synopsis
|
||||
|
||||
service.service, socket.socket, device.device, mount.mount, automount.automount, swap.swap, target.target, path.path, timer.timer, snapshot.snapshot, slice.slice, scope.scope
|
||||
|
||||
/etc/systemd/system/*
|
||||
/run/systemd/system/*
|
||||
/usr/lib/systemd/system/*
|
||||
...
|
||||
|
||||
|
||||
$HOME/.config/systemd/user/*
|
||||
/etc/systemd/user/*
|
||||
/run/systemd/user/*
|
||||
/usr/lib/systemd/user/*
|
||||
...
|
||||
|
||||
Description
|
||||
|
||||
A unit configuration file encodes information about a service, a socket, a device, a mount point, an automount point, a swap file or partition, a start-up target, a watched file system path, a timer controlled and supervised by systemd(1), a temporary system state snapshot, a resource management slice or a group of externally created processes. The syntax is inspired by XDG Desktop Entry Specification .desktop files, which are in turn inspired by Microsoft Windows .ini files.
|
||||
|
||||
This man page lists the common configuration options of all the unit types. These options need to be configured in the [Unit] or [Install] sections of the unit files.
|
||||
|
||||
In addition to the generic [Unit] and [Install] sections described here, each unit may have a type-specific section, e.g. [Service] for a service unit. See the respective man pages for more information: systemd.service(5), systemd.socket(5), systemd.device(5), systemd.mount(5), systemd.automount(5), systemd.swap(5), systemd.target(5), systemd.path(5), systemd.timer(5), systemd.snapshot(5). systemd.slice(5). systemd.scope(5).
|
||||
|
||||
Unit files are loaded from a set of paths determined during compilation, described in the next section.
|
||||
|
||||
Unit files may contain additional options on top of those listed here. If systemd encounters an unknown option it will write a warning log message but continue loading the unit. If an option is prefixed with X- it is ignored completely by systemd. Applications may use this to include additional information in the unit files.
|
||||
|
||||
Boolean arguments used in unit files can be written in various formats. For positive settings the strings 1, yes, true and on are equivalent. For negative settings the strings 0, no, false and off are equivalent.
|
||||
|
||||
Time span values encoded in unit files can be written in various formats. A stand-alone number specifies a time in seconds. If suffixed with a time unit, the unit is honored. A concatenation of multiple values with units is supported, in which case the values are added up. Example: "50" refers to 50 seconds; "2min 200ms" refers to 2 minutes plus 200 milliseconds, i.e. 120200ms. The following time units are understood: s, min, h, d, w, ms, us. For details see systemd.time(7).
|
||||
|
||||
Empty lines and lines starting with # or ; are ignored. This may be used for commenting. Lines ending in a backslash are concatenated with the following line while reading and the backslash is replaced by a space character. This may be used to wrap long lines.
|
||||
|
||||
Along with a unit file foo.service the directory foo.service.wants/ may exist. All unit files symlinked from such a directory are implicitly added as dependencies of type Wanted= to the unit. This is useful to hook units into the start-up of other units, without having to modify their unit files. For details about the semantics of Wanted= see below. The preferred way to create symlinks in the .wants/ directory of a unit file is with the enable command of the systemctl(1) tool which reads information from the [Install] section of unit files (see below). A similar functionality exists for Requires= type dependencies as well, the directory suffix is .requires/ in this case.
|
||||
|
||||
Along with a unit file foo.service a directory foo.service.d/ may exist. All files with the suffix ".conf" from this directory will be parsed after the file itself is parsed. This is useful to alter or add configuration settings to a unit, without having to modify their unit files. Make sure that the file that is included has the appropriate section headers before any directive.
|
||||
|
||||
If a line starts with .include followed by a filename, the specified file will be parsed at this point. Make sure that the file that is included has the appropriate section headers before any directives.
|
||||
|
||||
Note that while systemd offers a flexible dependency system between units it is recommended to use this functionality only sparingly and instead rely on techniques such as bus-based or socket-based activation which make dependencies implicit, resulting in a both simpler and more flexible system.
|
||||
|
||||
Some unit names reflect paths existing in the file system namespace. Example: a device unit dev-sda.device refers to a device with the device node /dev/sda in the file system namespace. If this applies a special way to escape the path name is used, so that the result is usable as part of a filename. Basically, given a path, "/" is replaced by "-", and all unprintable characters and the "-" are replaced by C-style "\x20" escapes. The root directory "/" is encoded as single dash, while otherwise the initial and ending "/" is removed from all paths during transformation. This escaping is reversible.
|
||||
|
||||
Optionally, units may be instantiated from a template file at runtime. This allows creation of multiple units from a single configuration file. If systemd looks for a unit configuration file it will first search for the literal unit name in the filesystem. If that yields no success and the unit name contains an "@" character, systemd will look for a unit template that shares the same name but with the instance string (i.e. the part between the "@" character and the suffix) removed. Example: if a service getty@tty3.service is requested and no file by that name is found, systemd will look for getty@.service and instantiate a service from that configuration file if it is found.
|
||||
|
||||
To refer to the instance string from within the configuration file you may use the special "%i" specifier in many of the configuration options. See below for details.
|
||||
|
||||
If a unit file is empty (i.e. has the file size 0) or is symlinked to /dev/null its configuration will not be loaded and it appears with a load state of "masked", and cannot be activated. Use this as an effective way to fully disable a unit, making it impossible to start it even manually.
|
||||
|
||||
The unit file format is covered by the Interface Stability Promise.
|
||||
Unit Load Path
|
||||
|
||||
Unit files are loaded from a set of paths determined during compilation, described in the two tables below. Unit files found in directories listed earlier override files with the same name in directories lower in the list.
|
||||
|
||||
When systemd is running in user mode (--user) and the variable $SYSTEMD_UNIT_PATH is set, this contents of this variable overrides the unit load path.
|
||||
|
||||
Table 1. Load path when running in system mode (--system).
|
||||
Path Description
|
||||
/etc/systemd/system Local configuration
|
||||
/run/systemd/systemd Runtime units
|
||||
/usr/lib/systemd/system Units of installed packages
|
||||
|
||||
Table 2. Load path when running in user mode (--user).
|
||||
Path Description
|
||||
$HOME/.config/systemd/user User configuration
|
||||
/etc/systemd/user Local configuration
|
||||
/run/systemd/user Runtime units
|
||||
/usr/lib/systemd/user Units of installed packages
|
||||
|
||||
Additional units might be loaded into systemd ("linked") from directories not on the unit load path. See the link command for systemctl(1). Also, some units are dynamically created via generators Generators.
|
||||
Options
|
||||
|
||||
Unit file may include a [Unit] section, which carries generic information about the unit that is not dependent on the type of unit:
|
||||
|
||||
Description=
|
||||
A free-form string describing the unit. This is intended for use in UIs to show descriptive information along with the unit name.
|
||||
|
||||
Documentation=
|
||||
A space-separated list of URIs referencing documentation for this unit or its configuration. Accepted are only URIs of the types "http://", "https://", "file:", "info:", "man:". For more information about the syntax of these URIs, see uri(7). The URIs should be listed in order of relevance, starting with the most relevant. It is a good idea to first reference documentation that explains what the unit's purpose is, followed by how it is configured, followed by any other related documentation. This option may be specified more than once in which case the specified list of URIs is merged. If the empty string is assigned to this option, the list is reset and all prior assignments will have no effect.
|
||||
Requires=
|
||||
|
||||
Configures requirement dependencies on other units. If this unit gets activated, the units listed here will be activated as well. If one of the other units gets deactivated or its activation fails, this unit will be deactivated. This option may be specified more than once, in which case requirement dependencies for all listed names are created. Note that requirement dependencies do not influence the order in which services are started or stopped. This has to be configured independently with the After= or Before= options. If a unit foo.service requires a unit bar.service as configured with Requires= and no ordering is configured with After= or Before=, then both units will be started simultaneously and without any delay between them if foo.service is activated. Often it is a better choice to use Wants= instead of Requires= in order to achieve a system that is more robust when dealing with failing services.
|
||||
|
||||
Note that dependencies of this type may also be configured outside of the unit configuration file by adding a symlink to a .requires/ directory accompanying the unit file. For details see above.
|
||||
|
||||
RequiresOverridable=
|
||||
Similar to Requires=. Dependencies listed in RequiresOverridable= which cannot be fulfilled or fail to start are ignored if the startup was explicitly requested by the user. If the start-up was pulled in indirectly by some dependency or automatic start-up of units that is not requested by the user this dependency must be fulfilled and otherwise the transaction fails. Hence, this option may be used to configure dependencies that are normally honored unless the user explicitly starts up the unit, in which case whether they failed or not is irrelevant.
|
||||
|
||||
Requisite=, RequisiteOverridable=
|
||||
Similar to Requires= and RequiresOverridable=, respectively. However, if a unit listed here is not started already it will not be started and the transaction fails immediately.
|
||||
|
||||
Wants=
|
||||
A weaker version of Requires=. A unit listed in this option will be started if the configuring unit is. However, if the listed unit fails to start up or cannot be added to the transaction this has no impact on the validity of the transaction as a whole. This is the recommended way to hook start-up of one unit to the start-up of another unit.
|
||||
|
||||
Note that dependencies of this type may also be configured outside of the unit configuration file by adding a symlink to a .wants/ directory accompanying the unit file. For details see above.
|
||||
|
||||
BindsTo=
|
||||
Configures requirement dependencies, very similar in style to Requires=, however in addition to this behavior it also declares that this unit is stopped when any of the units listed suddenly disappears. Units can suddenly, unexpectedly disappear if a service terminates on its own choice, a device is unplugged or a mount point unmounted without involvement of systemd.
|
||||
|
||||
PartOf=
|
||||
Configures dependencies similar to Requires=, but limited to stopping and restarting of units. When systemd stops or restarts the units listed here, the action is propagated to this unit. Note that this is a one way dependency - changes to this unit do not affect the listed units.
|
||||
|
||||
Conflicts=
|
||||
Configures negative requirement dependencies. If a unit has a Conflicts= setting on another unit, starting the former will stop the latter and vice versa. Note that this setting is independent of and orthogonal to the After= and Before= ordering dependencies.
|
||||
|
||||
If a unit A that conflicts with a unit B is scheduled to be started at the same time as B, the transaction will either fail (in case both are required part of the transaction) or be modified to be fixed (in case one or both jobs are not a required part of the transaction). In the latter case the job that is not the required will be removed, or in case both are not required the unit that conflicts will be started and the unit that is conflicted is stopped.
|
||||
|
||||
Before=, After=
|
||||
Configures ordering dependencies between units. If a unit foo.service contains a setting Before=bar.service and both units are being started, bar.service's start-up is delayed until foo.service is started up. Note that this setting is independent of and orthogonal to the requirement dependencies as configured by Requires=. It is a common pattern to include a unit name in both the After= and Requires= option in which case the unit listed will be started before the unit that is configured with these options. This option may be specified more than once, in which case ordering dependencies for all listed names are created. After= is the inverse of Before=, i.e. while After= ensures that the configured unit is started after the listed unit finished starting up, Before= ensures the opposite, i.e. that the configured unit is fully started up before the listed unit is started. Note that when two units with an ordering dependency between them are shut down, the inverse of the start-up order is applied. i.e. if a unit is configured with After= on another unit, the former is stopped before the latter if both are shut down. If one unit with an ordering dependency on another unit is shut down while the latter is started up, the shut down is ordered before the start-up regardless whether the ordering dependency is actually of type After= or Before=. If two units have no ordering dependencies between them they are shut down or started up simultaneously, and no ordering takes place.
|
||||
|
||||
OnFailure=
|
||||
Lists one or more units that are activated when this unit enters the "failed" state.
|
||||
|
||||
PropagatesReloadTo=, ReloadPropagatedFrom=
|
||||
Lists one or more units where reload requests on the unit will be propagated to/on the other unit will be propagated from. Issuing a reload request on a unit will automatically also enqueue a reload request on all units that the reload request shall be propagated to via these two settings.
|
||||
|
||||
RequiresMountsFor=
|
||||
Takes a space-separated list of absolute paths. Automatically adds dependencies of type Requires= and After= for all mount units required to access the specified path.
|
||||
|
||||
OnFailureIsolate=
|
||||
Takes a boolean argument. If true the unit listed in OnFailure= will be enqueued in isolation mode, i.e. all units that are not its dependency will be stopped. If this is set only a single unit may be listed in OnFailure=. Defaults to false.
|
||||
|
||||
IgnoreOnIsolate=
|
||||
Takes a boolean argument. If true this unit will not be stopped when isolating another unit. Defaults to false.
|
||||
|
||||
IgnoreOnSnapshot=
|
||||
Takes a boolean argument. If true this unit will not be included in snapshots. Defaults to true for device and snapshot units, false for the others.
|
||||
|
||||
StopWhenUnneeded=
|
||||
Takes a boolean argument. If true this unit will be stopped when it is no longer used. Note that in order to minimize the work to be executed, systemd will not stop units by default unless they are conflicting with other units, or the user explicitly requested their shut down. If this option is set, a unit will be automatically cleaned up if no other active unit requires it. Defaults to false.
|
||||
|
||||
RefuseManualStart=, RefuseManualStop=
|
||||
Takes a boolean argument. If true this unit can only be activated or deactivated indirectly. In this case explicit start-up or termination requested by the user is denied, however if it is started or stopped as a dependency of another unit, start-up or termination will succeed. This is mostly a safety feature to ensure that the user does not accidentally activate units that are not intended to be activated explicitly, and not accidentally deactivate units that are not intended to be deactivated. These options default to false.
|
||||
|
||||
AllowIsolate=
|
||||
Takes a boolean argument. If true this unit may be used with the systemctl isolate command. Otherwise this will be refused. It probably is a good idea to leave this disabled except for target units that shall be used similar to runlevels in SysV init systems, just as a precaution to avoid unusable system states. This option defaults to false.
|
||||
|
||||
DefaultDependencies=
|
||||
Takes a boolean argument. If true (the default), a few default dependencies will implicitly be created for the unit. The actual dependencies created depend on the unit type. For example, for service units, these dependencies ensure that the service is started only after basic system initialization is completed and is properly terminated on system shutdown. See the respective man pages for details. Generally, only services involved with early boot or late shutdown should set this option to false. It is highly recommended to leave this option enabled for the majority of common units. If set to false, this option does not disable all implicit dependencies, just non-essential ones.
|
||||
|
||||
JobTimeoutSec=
|
||||
When clients are waiting for a job of this unit to complete, time out after the specified time. If this time limit is reached the job will be cancelled, the unit however will not change state or even enter the "failed" mode. This value defaults to 0 (job timeouts disabled), except for device units. NB: this timeout is independent from any unit-specific timeout (for example, the timeout set with Timeout= in service units) as the job timeout has no effect on the unit itself, only on the job that might be pending for it. Or in other words: unit-specific timeouts are useful to abort unit state changes, and revert them. The job timeout set with this option however is useful to abort only the job waiting for the unit state to change.
|
||||
|
||||
ConditionPathExists=, ConditionPathExistsGlob=, ConditionPathIsDirectory=, ConditionPathIsSymbolicLink=, ConditionPathIsMountPoint=, ConditionPathIsReadWrite=, ConditionDirectoryNotEmpty=, ConditionFileNotEmpty=, ConditionFileIsExecutable=, ConditionKernelCommandLine=, ConditionVirtualization=, ConditionSecurity=, ConditionCapability=, ConditionHost=, ConditionACPower=, ConditionNull=
|
||||
Before starting a unit verify that the specified condition is true. If it is not true the starting of the unit will be skipped, however all ordering dependencies of it are still respected. A failing condition will not result in the unit being moved into a failure state. The condition is checked at the time the queued start job is to be executed.
|
||||
|
||||
With ConditionPathExists= a file existence condition is checked before a unit is started. If the specified absolute path name does not exist the condition will fail. If the absolute path name passed to ConditionPathExists= is prefixed with an exclamation mark ("!"), the test is negated, and the unit is only started if the path does not exist.
|
||||
|
||||
ConditionPathExistsGlob= is similar to ConditionPathExists=, but checks for the existence of at least one file or directory matching the specified globbing pattern.
|
||||
|
||||
ConditionPathIsDirectory= is similar to ConditionPathExists= but verifies whether a certain path exists and is a directory.
|
||||
|
||||
ConditionPathIsSymbolicLink= is similar to ConditionPathExists= but verifies whether a certain path exists and is a symbolic link.
|
||||
|
||||
ConditionPathIsMountPoint= is similar to ConditionPathExists= but verifies whether a certain path exists and is a mount point.
|
||||
|
||||
ConditionPathIsReadWrite= is similar to ConditionPathExists= but verifies whether the underlying file system is readable and writable (i.e. not mounted read-only).
|
||||
|
||||
ConditionDirectoryNotEmpty= is similar to ConditionPathExists= but verifies whether a certain path exists and is a non-empty directory.
|
||||
|
||||
ConditionFileNotEmpty= is similar to ConditionPathExists= but verifies whether a certain path exists and refers to a regular file with a non-zero size.
|
||||
|
||||
ConditionFileIsExecutable= is similar to ConditionPathExists= but verifies whether a certain path exists, is a regular file and marked executable.
|
||||
|
||||
Similar, ConditionKernelCommandLine= may be used to check whether a specific kernel command line option is set (or if prefixed with the exclamation mark unset). The argument must either be a single word, or an assignment (i.e. two words, separated "="). In the former case the kernel command line is searched for the word appearing as is, or as left hand side of an assignment. In the latter case the exact assignment is looked for with right and left hand side matching.
|
||||
|
||||
ConditionVirtualization= may be used to check whether the system is executed in a virtualized environment and optionally test whether it is a specific implementation. Takes either boolean value to check if being executed in any virtualized environment, or one of vm and container to test against a generic type of virtualization solution, or one of qemu, kvm, vmware, microsoft, oracle, xen, bochs, chroot, uml, openvz, lxc, lxc-libvirt, systemd-nspawn to test against a specific implementation. If multiple virtualization technologies are nested only the innermost is considered. The test may be negated by prepending an exclamation mark.
|
||||
|
||||
ConditionSecurity= may be used to check whether the given security module is enabled on the system. Currently the recognized values values are selinux, apparmor, ima and smack. The test may be negated by prepending an exclamation mark.
|
||||
|
||||
ConditionCapability= may be used to check whether the given capability exists in the capability bounding set of the service manager (i.e. this does not check whether capability is actually available in the permitted or effective sets, see capabilities(7) for details). Pass a capability name such as "CAP_MKNOD", possibly prefixed with an exclamation mark to negate the check.
|
||||
|
||||
ConditionHost= may be used to match against the hostname or machine ID of the host. This either takes a hostname string (optionally with shell style globs) which is tested against the locally set hostname as returned by gethostname(2), or a machine ID formatted as string (see machine-id(5)). The test may be negated by prepending an exclamation mark.
|
||||
|
||||
ConditionACPower= may be used to check whether the system has AC power, or is exclusively battery powered at the time of activation of the unit. This takes a boolean argument. If set to true the condition will hold only if at least one AC connector of the system is connected to a power source, or if no AC connectors are known. Conversely, if set to false the condition will hold only if there is at least one AC connector known and all AC connectors are disconnected from a power source.
|
||||
|
||||
Finally, ConditionNull= may be used to add a constant condition check value to the unit. It takes a boolean argument. If set to false the condition will always fail, otherwise succeed.
|
||||
|
||||
If multiple conditions are specified the unit will be executed if all of them apply (i.e. a logical AND is applied). Condition checks can be prefixed with a pipe symbol (|) in which case a condition becomes a triggering condition. If at least one triggering condition is defined for a unit then the unit will be executed if at least one of the triggering conditions apply and all of the non-triggering conditions. If you prefix an argument with the pipe symbol and an exclamation mark the pipe symbol must be passed first, the exclamation second. Except for ConditionPathIsSymbolicLink=, all path checks follow symlinks. If any of these options is assigned the empty string the list of conditions is reset completely, all previous condition settings (of any kind) will have no effect.
|
||||
|
||||
SourcePath=
|
||||
A path to a configuration file this unit has been generated from. This is primarily useful for implementation of generator tools that convert configuration from an external configuration file format into native unit files. Thus functionality should not be used in normal units.
|
||||
|
||||
Unit file may include a [Install] section, which carries installation information for the unit. This section is not interpreted by systemd(1) during runtime. It is used exclusively by the enable and disable commands of the systemctl(1) tool during installation of a unit:
|
||||
|
||||
Alias=
|
||||
Additional names this unit shall be installed under. The names listed here must have the same suffix (i.e. type) as the unit file name. This option may be specified more than once, in which case all listed names are used. At installation time, systemctl enable will create symlinks from these names to the unit filename.
|
||||
|
||||
WantedBy=, RequiredBy=
|
||||
A symbolic link is created in the .wants/ or .requires/ directory of the listed unit when this unit is activated by systemctl enable. This has the effect that a dependency of type Wants= or Requires= is added from the listed unit to the current unit. The primary result is that the current unit will be started when the listed unit is started. See the description of Wants= and Requires= in the [Unit] section for details.
|
||||
|
||||
WantedBy=foo.service in a service bar.service is mostly equivalent to Alias=foo.service.wants/bar.service in the same file. In case of template units, systemctl enable must be called with an instance name, and this instance will be added to the .wants/ or .requires/ list of the listed unit. E.g. WantedBy=getty.target in a service getty@.service will result in systemctl enable getty@tty2.service creating a getty.target.wants/getty@tty2.service link to getty@.service.
|
||||
|
||||
Also=
|
||||
Additional units to install/deinstall when this unit is installed/deinstalled. If the user requests installation/deinstallation of a unit with this option configured, systemctl enable and systemctl disable will automatically install/uninstall units listed in this option as well.
|
||||
|
||||
The following specifiers are interpreted in the Install section: %n, %N, %p, %i, %U, %u, %m, %H, %b, %v. For their meaning see the next section.
|
||||
Specifiers
|
||||
|
||||
Many settings resolve specifiers which may be used to write generic unit files referring to runtime or unit parameters that are replaced when the unit files are loaded. The following specifiers are understood:
|
||||
|
||||
Table 3. Specifiers available in unit files
|
||||
Specifier Meaning Details
|
||||
"%n" Full unit name
|
||||
"%N" Unescaped full unit name
|
||||
"%p" Prefix name For instantiated units this refers to the string before the @. For non-instantiated units this refers to to the name of the unit with the type suffix removed.
|
||||
"%P" Unescaped prefix name
|
||||
"%i" Instance name For instantiated units: this is the string between the "@" character and the suffix.
|
||||
"%I" Unescaped instance name
|
||||
"%f" Unescaped filename This is either the unescaped instance name (if applicable) with / prepended (if applicable), or the prefix name similarly prepended with /.
|
||||
"%c" Control group path of the unit
|
||||
"%r" Root control group path where units are placed. For system instances this usually resolves to /system, except in containers, where the path might be prefixed with the container's root control group.
|
||||
"%R" Parent directory of the control group path where units are placed. For system instances this usually resolves to /, except in containers, where this resolves to the container's root directory. This specifier is particularly useful in the ControlGroup= setting (see systemd.exec(5)).
|
||||
"%t" Runtime socket dir This is either /run (for the system manager) or "$XDG_RUNTIME_DIR" (for user managers).
|
||||
"%u" User name This is the name of the configured user of the unit, or (if none is set) the user running the systemd instance.
|
||||
"%U" User UID This is the UID of the configured user of the unit, or (if none is set) the user running the systemd instance.
|
||||
"%h" User home directory This is the home directory of the configured user of the unit, or (if none is set) the user running the systemd instance.
|
||||
"%s" User shell This is the shell of the configured user of the unit, or (if none is set) the user running the systemd instance. If the user is "root" (UID equal to 0), the shell configured in account database is ignored and /bin/sh is always used.
|
||||
"%m" Machine ID The machine ID of the running system, formatted as string. See machine-id(5) for more information.
|
||||
"%b" Boot ID The boot ID of the running system, formatted as string. See random(4) for more information.
|
||||
"%H" Host name The hostname of the running system.
|
||||
"%v" Kernel release Identical to uname -r output.
|
||||
"%%" Escaped % Single percent sign.
|
||||
|
||||
See Also
|
||||
|
||||
systemd(1), systemctl(8), systemd.special(7), systemd.service(5), systemd.socket(5), systemd.device(5), systemd.mount(5), systemd.automount(5), systemd.swap(5), systemd.target(5), systemd.path(5), systemd.timer(5), systemd.snapshot(5), systemd.scope(5), systemd.slice(5), systemd.time(7), capabilities(7), systemd.directives(7), uname(1)
|
@ -0,0 +1,50 @@
|
||||
# This is a sample service script to mount CIFS/SAMBA shares.
|
||||
# Please read carefully the comments in this file. For production usage
|
||||
# you can remove all comments (lines beginning with "#") from this file.
|
||||
|
||||
|
||||
[Unit]
|
||||
# The description should be used to explain what this servicefile is for
|
||||
Description=test cifs mount script
|
||||
|
||||
# if we do network mounts like here we *require* 'network-online.service'
|
||||
# which checks if the network is online
|
||||
Requires=network-online.service
|
||||
|
||||
# our scripts must start *after* 'network-online.service', on timeout and if
|
||||
# 'network-online.service' fails we can not mount and this scripts fails too
|
||||
After=network-online.service
|
||||
|
||||
# usually we mount networks shares because we want they avaible *before* XBMC starts.
|
||||
# so XBMC has access to this mounts from beginning. Note: this slows down the boot!
|
||||
Before=kodi.service
|
||||
|
||||
|
||||
[Mount]
|
||||
# The share we want mount
|
||||
What=//192.168.0.31/Music
|
||||
|
||||
# Where we want mount this share
|
||||
Where=/storage/music2
|
||||
|
||||
# Any options you usually use with the "-o" parameter in the mount command
|
||||
Options=username=myusername,password=mypassword
|
||||
|
||||
# filesystem type
|
||||
Type=cifs
|
||||
|
||||
|
||||
[Install]
|
||||
# The target is used by 'systemctl enable <name_of_this_file.mount>' to link
|
||||
# this service to a runlevel for starting on boot. usually 'multi-user.target'
|
||||
# is ok here.
|
||||
WantedBy=multi-user.target
|
||||
|
||||
# Important:
|
||||
# this file must be renamed to <mountpoint>.mount where <mountpoint>, is the FULL path
|
||||
# where the share will be mounted but slashes "/" MUST BE REPLACED with dashes "-" with .mount
|
||||
# as extension.
|
||||
# This means, if we want mount to "/storage/music2" (see above "Where=/storage/music2")
|
||||
# then this file must be renamed to 'storage-music2.mount' and can be enabled via ssh with the
|
||||
# command 'systemctl enable storage-music2.mount'
|
||||
|
@ -0,0 +1,50 @@
|
||||
# This is a sample service script to mount NFS shares.
|
||||
# Please read carefully the comments in this file. For production usage
|
||||
# you can remove all comments (lines beginning with "#") from this file.
|
||||
|
||||
|
||||
[Unit]
|
||||
# The description should be used to explain what this servicefile is for
|
||||
Description=test nfs mount script
|
||||
|
||||
# if we do network mounts like here we *require* 'network-online.service'
|
||||
# which checks if the network is online
|
||||
Requires=network-online.service
|
||||
|
||||
# our scripts must start *after* 'network-online.service', on timeout and if
|
||||
# 'network-online.service' fails we can not mount and this scripts fails too
|
||||
After=network-online.service
|
||||
|
||||
# usually we mount networks shares because we want they avaible *before* XBMC starts.
|
||||
# so XBMC has access to this mounts from beginning. Note: this slows down the boot!
|
||||
Before=kodi.service
|
||||
|
||||
|
||||
[Mount]
|
||||
# The share we want mount
|
||||
What=192.168.0.31:/movies
|
||||
|
||||
# Where we want mount this share
|
||||
Where=/storage/movies2
|
||||
|
||||
# Any options you usually use with the "-o" parameter in the mount command
|
||||
Options=
|
||||
|
||||
# filesystem type
|
||||
Type=nfs
|
||||
|
||||
|
||||
[Install]
|
||||
# The target is used by 'systemctl enable <name_of_this_file.mount>' to link
|
||||
# this service to a runlevel for starting on boot. usually 'multi-user.target'
|
||||
# is ok here.
|
||||
WantedBy=multi-user.target
|
||||
|
||||
# Important:
|
||||
# this file must be renamed to <mountpoint>.mount where <mountpoint>, is the FULL path
|
||||
# where the share will be mounted but slashes "/" MUST BE REPLACED with dashes "-" with .mount
|
||||
# as extension.
|
||||
# This means, if we want mount to "/storage/movies2" (see above "Where=/storage/movies2")
|
||||
# then this file must be renamed to 'storage-movies2.mount' and can be enabled via ssh with the
|
||||
# command 'systemctl enable storage-movies2.mount'
|
||||
|
@ -0,0 +1,44 @@
|
||||
[Unit]
|
||||
Description=OpenVPN Autorun Service
|
||||
|
||||
[Service]
|
||||
Type=forking
|
||||
Requires=network-online.service
|
||||
After=network-online.service
|
||||
ExecStart=/usr/sbin/openvpn --daemon --config /storage/.config/openvpn.config
|
||||
Restart=always
|
||||
RestartSec=15
|
||||
|
||||
[Install]
|
||||
WantedBy=kodi.target
|
||||
|
||||
# NOTES:
|
||||
#
|
||||
# 1) Edit /storage/.config/openvpn.config to the .config/.conf/.ovpn file
|
||||
# from your VPN service provider and test it works first by connecting at
|
||||
# the console:
|
||||
#
|
||||
# /usr/sbin/openvpn --daemon --config /storage/.config/openvpn.config
|
||||
#
|
||||
# 2) The openvpn.service file must be addeded to the active systemd config
|
||||
# before it will work. This is done by running:
|
||||
#
|
||||
# systemctl enable openvpn.service
|
||||
#
|
||||
# 3) If you suspend/resume your LibreELEC system you will need to stop and
|
||||
# restart the connection with a systemd *.power script, e.g.
|
||||
#
|
||||
# mkdir -p /storage/.config/sleep.d
|
||||
# nano /storage/.config/sleep.d/01-openvpn.power
|
||||
#
|
||||
# Copy the sample script below. Remove # marks except for #!/bin/bash
|
||||
#
|
||||
# #!/bin/sh
|
||||
# case "$1" in
|
||||
# pre)
|
||||
# systemctl stop openvpn.service
|
||||
# ;;
|
||||
# post)
|
||||
# systemctl start openvpn.service
|
||||
# ;;
|
||||
# esac
|
86
projects/L4T/packages/systemd/config/timesyncd.conf.d/README
Normal file
86
projects/L4T/packages/systemd/config/timesyncd.conf.d/README
Normal file
@ -0,0 +1,86 @@
|
||||
TIMESYNCD.CONF(5) timesyncd.conf TIMESYNCD.CONF(5)
|
||||
|
||||
NAME
|
||||
timesyncd.conf, timesyncd.conf.d - Network Time Synchronization
|
||||
configuration files
|
||||
|
||||
SYNOPSIS
|
||||
/etc/systemd/timesyncd.conf
|
||||
|
||||
/etc/systemd/timesyncd.conf.d/*.conf
|
||||
|
||||
/run/systemd/timesyncd.conf.d/*.conf
|
||||
|
||||
/usr/lib/systemd/timesyncd.conf.d/*.conf
|
||||
|
||||
DESCRIPTION
|
||||
These configuration files control NTP network time synchronization. See
|
||||
systemd.syntax(5) for a general description of the syntax.
|
||||
|
||||
CONFIGURATION DIRECTORIES AND PRECEDENCE
|
||||
The default configuration is defined during compilation, so a
|
||||
configuration file is only needed when it is necessary to deviate from
|
||||
those defaults. By default, the configuration file in /etc/systemd/
|
||||
contains commented out entries showing the defaults as a guide to the
|
||||
administrator. This file can be edited to create local overrides.
|
||||
|
||||
When packages need to customize the configuration, they can install
|
||||
configuration snippets in /usr/lib/systemd/*.conf.d/. Files in /etc/
|
||||
are reserved for the local administrator, who may use this logic to
|
||||
override the configuration files installed by vendor packages. The main
|
||||
configuration file is read before any of the configuration directories,
|
||||
and has the lowest precedence; entries in a file in any configuration
|
||||
directory override entries in the single configuration file. Files in
|
||||
the *.conf.d/ configuration subdirectories are sorted by their filename
|
||||
in lexicographic order, regardless of which of the subdirectories they
|
||||
reside in. When multiple files specify the same option, for options
|
||||
which accept just a single value, the entry in the file with the
|
||||
lexicographically latest name takes precedence. For options which
|
||||
accept a list of values, entries are collected as they occur in files
|
||||
sorted lexicographically. It is recommended to prefix all filenames in
|
||||
those subdirectories with a two-digit number and a dash, to simplify
|
||||
the ordering of the files.
|
||||
|
||||
To disable a configuration file supplied by the vendor, the recommended
|
||||
way is to place a symlink to /dev/null in the configuration directory
|
||||
in /etc/, with the same filename as the vendor configuration file.
|
||||
|
||||
OPTIONS
|
||||
The following settings are configured in the "[Time]" section:
|
||||
|
||||
NTP=
|
||||
A space-separated list of NTP server host names or IP addresses.
|
||||
During runtime this list is combined with any per-interface NTP
|
||||
servers acquired from systemd-networkd.service(8).
|
||||
systemd-timesyncd will contact all configured system or
|
||||
per-interface servers in turn until one is found that responds.
|
||||
When the empty string is assigned, the list of NTP servers is
|
||||
reset, and all assignments prior to this one will have no effect.
|
||||
This setting defaults to an empty list.
|
||||
|
||||
FallbackNTP=
|
||||
A space-separated list of NTP server host names or IP addresses to
|
||||
be used as the fallback NTP servers. Any per-interface NTP servers
|
||||
obtained from systemd-networkd.service(8) take precedence over this
|
||||
setting, as do any servers set via NTP= above. This setting is
|
||||
hence only used if no other NTP server information is known. When
|
||||
the empty string is assigned, the list of NTP servers is reset, and
|
||||
all assignments prior to this one will have no effect. If this
|
||||
option is not given, a compiled-in list of NTP servers is used
|
||||
instead.
|
||||
|
||||
RootDistanceMaxSec=
|
||||
Maximum acceptable root distance. Takes a time value (in seconds).
|
||||
Defaults to 5 seconds.
|
||||
|
||||
PollIntervalMinSec=, PollIntervalMaxSec=
|
||||
The minimum and maximum poll intervals for NTP messages. Each
|
||||
setting takes a time value (in seconds). PollIntervalMinSec= must
|
||||
not be smaller than 16 seconds. PollIntervalMaxSec= must be larger
|
||||
than PollIntervalMinSec=. PollIntervalMinSec= defaults to 32
|
||||
seconds, and PollIntervalMaxSec= defaults to 2048 seconds.
|
||||
|
||||
SEE ALSO
|
||||
systemd(1), systemd-timesyncd.service(8), systemd-networkd.service(8)
|
||||
|
||||
systemd 241 TIMESYNCD.CONF(5)
|
109
projects/L4T/packages/systemd/config/tmpfiles.d/README
Normal file
109
projects/L4T/packages/systemd/config/tmpfiles.d/README
Normal file
@ -0,0 +1,109 @@
|
||||
Name
|
||||
|
||||
tmpfiles.d — Configuration for creation, deletion and cleaning of volatile and temporary files
|
||||
|
||||
Synopsis
|
||||
|
||||
/etc/tmpfiles.d/*.conf
|
||||
|
||||
/run/tmpfiles.d/*.conf
|
||||
|
||||
/usr/lib/tmpfiles.d/*.conf
|
||||
|
||||
Description
|
||||
|
||||
systemd-tmpfiles uses the configuration files from the above directories to describe the creation, cleaning and removal of volatile and temporary files and directories which usually reside in directories such as /run or /tmp.
|
||||
Configuration Format
|
||||
|
||||
Each configuration file shall be named in the style of <program>.conf. Files in /etc/ override files with the same name in /usr/lib/ and /run/. Files in /run/ override files with the same name in /usr/lib/. Packages should install their configuration files in /usr/lib/. Files in /etc/ are reserved for the local administrator, who may use this logic to override the configuration files installed by vendor packages. All configuration files are sorted by their filename in alphabetical order, regardless in which of the directories they reside, to guarantee that a specific configuration file takes precedence over another file with an alphabetically later name.
|
||||
|
||||
If the administrator wants to disable a configuration file supplied by the vendor the recommended way is to place a symlink to /dev/null in /etc/tmpfiles.d/ bearing the same filename.
|
||||
|
||||
The configuration format is one line per path containing action, path, mode, ownership, age and argument fields:
|
||||
|
||||
Type Path Mode UID GID Age Argument
|
||||
d /run/user 0755 root root 10d -
|
||||
L /tmp/foobar - - - - /dev/null
|
||||
|
||||
Type
|
||||
|
||||
f
|
||||
Create a file if it doesn't exist yet (optionally writing a short string into it, if the argument parameter is passed)
|
||||
|
||||
F
|
||||
Create or truncate a file (optionally writing a short string into it, if the argument parameter is passed)
|
||||
|
||||
w
|
||||
Write the argument parameter to a file, if the file exists. Lines of this type accept shell-style globs in place of normal path names. The argument parameter will be written without a trailing newline. C-style backslash escapes are interpreted.
|
||||
|
||||
d
|
||||
Create a directory if it doesn't exist yet
|
||||
|
||||
D
|
||||
Create or empty a directory
|
||||
|
||||
p
|
||||
Create a named pipe (FIFO) if it doesn't exist yet
|
||||
|
||||
L
|
||||
Create a symlink if it doesn't exist yet
|
||||
|
||||
c
|
||||
Create a character device node if it doesn't exist yet
|
||||
|
||||
b
|
||||
Create a block device node if it doesn't exist yet
|
||||
|
||||
x
|
||||
Ignore a path during cleaning. Use this type to exclude paths from clean-up as controlled with the Age parameter. Note that lines of this type do not influence the effect of r or R lines. Lines of this type accept shell-style globs in place of normal path names.
|
||||
|
||||
X
|
||||
Ignore a path during cleanup. Use this type to prevent path removal as controlled with the Age parameter. Note that if path is a directory, content of a directory is not excluded from clean-up, only directory itself. Lines of this type accept shell-style globs in place of normal path names.
|
||||
|
||||
r
|
||||
Remove a file or directory if it exists. This may not be used to remove non-empty directories, use R for that. Lines of this type accept shell-style globs in place of normal path names.
|
||||
|
||||
R
|
||||
Recursively remove a path and all its subdirectories (if it is a directory). Lines of this type accept shell-style globs in place of normal path names.
|
||||
|
||||
z
|
||||
Restore SELinux security context label and set ownership and access mode of a file or directory if it exists. Lines of this type accept shell-style globs in place of normal path names.
|
||||
|
||||
Z
|
||||
Recursively restore SELinux security context label and set ownership and access mode of a path and all its subdirectories (if it is a directory). Lines of this type accept shell-style globs in place of normal path names.
|
||||
|
||||
Mode
|
||||
|
||||
The file access mode to use when creating this file or directory. If omitted or when set to - the default is used: 0755 for directories, 0644 for all other file objects. For z, Z lines if omitted or when set to - the file access mode will not be modified. This parameter is ignored for x, r, R, L lines.
|
||||
UID, GID
|
||||
|
||||
The user and group to use for this file or directory. This may either be a numeric user/group ID or a user or group name. If omitted or when set to - the default 0 (root) is used. For z, Z lines when omitted or when set to - the file ownership will not be modified. These parameters are ignored for x, r, R, L lines.
|
||||
Age
|
||||
|
||||
The date field, when set, is used to decide what files to delete when cleaning. If a file or directory is older than the current time minus the age field it is deleted. The field format is a series of integers each followed by one of the following postfixes for the respective time units:
|
||||
|
||||
s, min, h, d, w, ms, m, us
|
||||
|
||||
If multiple integers and units are specified the time values are summed up. If an integer is given without a unit, s is assumed.
|
||||
|
||||
When the age is set to zero, the files are cleaned unconditionally.
|
||||
|
||||
The age field only applies to lines starting with d, D and x. If omitted or set to - no automatic clean-up is done.
|
||||
|
||||
If the age field starts with a tilde character (~) the clean-up is only applied to files and directories one level inside the directory specified, but not the files and directories immediately inside it.
|
||||
Argument
|
||||
|
||||
For L lines determines the destination path of the symlink. For c, b determines the major/minor of the device node, with major and minor formatted as integers, separated by :, e.g. "1:3". For f, F, w may be used to specify a short string that is written to the file, suffixed by a newline. Ignored for all other lines.
|
||||
Example
|
||||
|
||||
Example 1. /etc/tmpfiles.d/screen.conf example
|
||||
|
||||
screen needs two directories created at boot with specific modes and ownership.
|
||||
|
||||
d /var/run/screens 1777 root root 10d
|
||||
d /var/run/uscreens 0755 root root 10d12h
|
||||
|
||||
|
||||
See Also
|
||||
|
||||
systemd(1), systemd-tmpfiles(8), systemd-delta(1)
|
25
projects/L4T/packages/systemd/config/udev.rules.d/README
Normal file
25
projects/L4T/packages/systemd/config/udev.rules.d/README
Normal file
@ -0,0 +1,25 @@
|
||||
The files in this directory are read by udev(7) and used when events
|
||||
are performed by the kernel. The udev daemon watches this directory
|
||||
with inotify so that changes to these files are automatically picked
|
||||
up, for this reason they must be files and not symlinks to another
|
||||
location as in the case in Debian.
|
||||
|
||||
Packages do not generally install rules here, this directory is for
|
||||
local rules. If you want to override behaviour of package-supplied
|
||||
rules, which can be found in /usr/lib/udev/rules.d, you can do one of
|
||||
two things:
|
||||
|
||||
1) Write your own rules in this directory that assign the name,
|
||||
symlinks, permissions, etc. that you want. Pick a number higher
|
||||
than the rules you want to override, and yours will be used.
|
||||
|
||||
2) Copy the file from /usr/lib/udev/rules.d and edit it here; you
|
||||
should generally only do this if you want to prevent a program
|
||||
from being run.
|
||||
|
||||
|
||||
If the ordering of files in this directory are not important to you,
|
||||
it's recommended that you simply name your files "descriptive-name.rules"
|
||||
such that they are processed AFTER all numbered rules in both this
|
||||
directory and /usr/lib/udev/rules.d and thus override anything set there.
|
||||
|
@ -0,0 +1,8 @@
|
||||
# o2.cz bluetooth remote
|
||||
evdev:input:b0005v0217p0000e0110*
|
||||
KEYBOARD_KEY_c0041=enter # OK button
|
||||
|
||||
# osmcrf25 remote
|
||||
evdev:input:b0003v2017p1689*
|
||||
KEYBOARD_KEY_7002e=f10 # volume up
|
||||
KEYBOARD_KEY_7002d=f9 # volume down
|
296
projects/L4T/packages/systemd/package.mk
Normal file
296
projects/L4T/packages/systemd/package.mk
Normal file
@ -0,0 +1,296 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2016 Stephan Raue (stephan@openelec.tv)
|
||||
# Copyright (C) 2018-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
PKG_NAME="systemd"
|
||||
PKG_VERSION="247.10"
|
||||
PKG_SHA256="8ce78a664ac0090934ee3b576dc1cfc0a9bbf7fa166aa59c6237915ef2a35b74"
|
||||
PKG_LICENSE="LGPL2.1+"
|
||||
PKG_SITE="http://www.freedesktop.org/wiki/Software/systemd"
|
||||
PKG_URL="https://github.com/systemd/systemd-stable/archive/v${PKG_VERSION}.tar.gz"
|
||||
PKG_DEPENDS_TARGET="toolchain libcap kmod util-linux entropy libidn2 wait-time-sync"
|
||||
PKG_LONGDESC="A system and session manager for Linux, compatible with SysV and LSB init scripts."
|
||||
|
||||
PKG_MESON_OPTS_TARGET="--libdir=/usr/lib \
|
||||
-Drootprefix=/usr \
|
||||
-Dsplit-usr=false \
|
||||
-Dsplit-bin=true \
|
||||
-Ddefault-hierarchy=hybrid \
|
||||
-Dtty-gid=5 \
|
||||
-Dtests=false \
|
||||
-Dseccomp=false \
|
||||
-Dselinux=false \
|
||||
-Dapparmor=false \
|
||||
-Dpolkit=false \
|
||||
-Dacl=false \
|
||||
-Daudit=false \
|
||||
-Dblkid=true \
|
||||
-Dfdisk=false \
|
||||
-Dkmod=true \
|
||||
-Dpam=false \
|
||||
-Dpwquality=false \
|
||||
-Dmicrohttpd=false \
|
||||
-Dlibcryptsetup=false \
|
||||
-Dlibcurl=false \
|
||||
-Dlibidn=false \
|
||||
-Dlibidn2=true \
|
||||
-Dlibiptc=false \
|
||||
-Dqrencode=false \
|
||||
-Dgcrypt=false \
|
||||
-Dgnutls=false \
|
||||
-Dopenssl=false \
|
||||
-Dp11kit=false \
|
||||
-Delfutils=false \
|
||||
-Dzlib=false \
|
||||
-Dbzip2=false \
|
||||
-Dxz=false \
|
||||
-Dlz4=false \
|
||||
-Dxkbcommon=false \
|
||||
-Dpcre2=false \
|
||||
-Dglib=false \
|
||||
-Ddbus=false \
|
||||
-Ddefault-dnssec=no \
|
||||
-Dimportd=false \
|
||||
-Dremote=false \
|
||||
-Dutmp=true \
|
||||
-Dhibernate=false \
|
||||
-Denvironment-d=false \
|
||||
-Dbinfmt=false \
|
||||
-Drepart=false \
|
||||
-Dcoredump=false \
|
||||
-Dresolve=false \
|
||||
-Dlogind=true \
|
||||
-Dhostnamed=true \
|
||||
-Dlocaled=false \
|
||||
-Dmachined=false \
|
||||
-Dportabled=false \
|
||||
-Duserdb=false \
|
||||
-Dhomed=false \
|
||||
-Dnetworkd=false \
|
||||
-Dtimedated=false \
|
||||
-Dtimesyncd=true \
|
||||
-Dfirstboot=false \
|
||||
-Drandomseed=false \
|
||||
-Dbacklight=false \
|
||||
-Dvconsole=false \
|
||||
-Dquotacheck=false \
|
||||
-Dsysusers=false \
|
||||
-Dtmpfiles=true \
|
||||
-Dhwdb=true \
|
||||
-Drfkill=false \
|
||||
-Dldconfig=false \
|
||||
-Defi=false \
|
||||
-Dtpm=false \
|
||||
-Dima=false \
|
||||
-Dsmack=false \
|
||||
-Dgshadow=false \
|
||||
-Didn=false \
|
||||
-Dnss-myhostname=false \
|
||||
-Dnss-mymachines=false \
|
||||
-Dnss-resolve=false \
|
||||
-Dnss-systemd=false \
|
||||
-Dman=false \
|
||||
-Dhtml=false \
|
||||
-Dlink-udev-shared=true \
|
||||
-Dlink-systemctl-shared=true \
|
||||
-Dlink-networkd-shared=false \
|
||||
-Dbashcompletiondir=no \
|
||||
-Dzshcompletiondir=no \
|
||||
-Dkmod-path=/usr/bin/kmod \
|
||||
-Dmount-path=/usr/bin/mount \
|
||||
-Dumount-path=/usr/bin/umount \
|
||||
-Ddebug-tty=${DEBUG_TTY} \
|
||||
-Dversion-tag=${PKG_VERSION}"
|
||||
|
||||
pre_configure_target() {
|
||||
export TARGET_CFLAGS="${TARGET_CFLAGS} -fno-schedule-insns -fno-schedule-insns2 -Wno-format-truncation"
|
||||
export LC_ALL=en_US.UTF-8
|
||||
}
|
||||
|
||||
post_makeinstall_target() {
|
||||
# remove unneeded stuff
|
||||
safe_remove ${INSTALL}/etc/init.d
|
||||
safe_remove ${INSTALL}/etc/systemd/system
|
||||
safe_remove ${INSTALL}/etc/xdg
|
||||
safe_remove ${INSTALL}/etc/X11
|
||||
safe_remove ${INSTALL}/usr/bin/kernel-install
|
||||
safe_remove ${INSTALL}/usr/lib/kernel/install.d
|
||||
safe_remove ${INSTALL}/usr/lib/rpm
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/user
|
||||
safe_remove ${INSTALL}/usr/lib/tmpfiles.d/etc.conf
|
||||
safe_remove ${INSTALL}/usr/lib/tmpfiles.d/home.conf
|
||||
safe_remove ${INSTALL}/usr/share/factory
|
||||
|
||||
# clean up hwdb
|
||||
safe_remove ${INSTALL}/usr/lib/udev/hwdb.d/20-OUI.hwdb
|
||||
safe_remove ${INSTALL}/usr/lib/udev/hwdb.d/20-acpi-vendor.hwdb
|
||||
safe_remove ${INSTALL}/usr/lib/udev/hwdb.d/20-bluetooth-vendor-product.hwdb
|
||||
safe_remove ${INSTALL}/usr/lib/udev/hwdb.d/20-net-ifname.hwdb
|
||||
safe_remove ${INSTALL}/usr/lib/udev/hwdb.d/20-sdio-classes.hwdb
|
||||
safe_remove ${INSTALL}/usr/lib/udev/hwdb.d/20-sdio-vendor-model.hwdb
|
||||
|
||||
# remove Network adaper renaming rule, this is confusing
|
||||
safe_remove ${INSTALL}/usr/lib/udev/rules.d/80-net-setup-link.rules
|
||||
|
||||
safe_remove ${INSTALL}/usr/lib/udev/rules.d/71-seat.rules
|
||||
safe_remove ${INSTALL}/usr/lib/udev/rules.d/73-seat-late.rules
|
||||
|
||||
# remove getty units, we dont want a console
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/autovt@.service
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/console-getty.service
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/container-getty@.service
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/getty.target
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/getty@.service
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/serial-getty@.service
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/*.target.wants/getty.target
|
||||
|
||||
# remove other notused or nonsense stuff (our /etc is ro)
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/systemd-update-done
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/systemd-update-done.service
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/*.target.wants/systemd-update-done.service
|
||||
|
||||
# remove systemd-hwdb-update. we have own hwdb.service
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/systemd-hwdb-update.service
|
||||
|
||||
# remove nspawn
|
||||
safe_remove ${INSTALL}/usr/bin/systemd-nspawn
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/systemd-nspawn@.service
|
||||
|
||||
# remove unneeded generators
|
||||
for gen in ${INSTALL}/usr/lib/systemd/system-generators/*; do
|
||||
case "${gen}" in
|
||||
*/systemd-debug-generator)
|
||||
# keep it
|
||||
;;
|
||||
*)
|
||||
safe_remove "${gen}"
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
# remove catalog
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/catalog
|
||||
|
||||
# remove partition
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/systemd-growfs
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/systemd-makefs
|
||||
|
||||
# distro preset policy
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system-preset/*
|
||||
echo "disable *" > ${INSTALL}/usr/lib/systemd/system-preset/99-default.preset
|
||||
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/user-preset/*
|
||||
echo "disable *" > ${INSTALL}/usr/lib/systemd/user-preset/90-systemd.preset
|
||||
|
||||
# remove networkd
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/network
|
||||
|
||||
# remove systemd-time-wait-sync (not detecting slew time updates, using package wait-time-sync)
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/systemd-time-wait-sync.service
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/systemd-time-wait-sync
|
||||
|
||||
# tune journald.conf
|
||||
sed -e "s,^.*Compress=.*$,Compress=no,g" -i ${INSTALL}/etc/systemd/journald.conf
|
||||
sed -e "s,^.*SplitMode=.*$,SplitMode=none,g" -i ${INSTALL}/etc/systemd/journald.conf
|
||||
sed -e "s,^.*RuntimeMaxUse=.*$,RuntimeMaxUse=2M,g" -i ${INSTALL}/etc/systemd/journald.conf
|
||||
sed -e "s,^.*RuntimeMaxFileSize=.*$,RuntimeMaxFileSize=128K,g" -i ${INSTALL}/etc/systemd/journald.conf
|
||||
sed -e "s,^.*SystemMaxUse=.*$,SystemMaxUse=10M,g" -i ${INSTALL}/etc/systemd/journald.conf
|
||||
|
||||
# tune logind.conf
|
||||
sed -e "s,^.*HandleLidSwitch=.*$,HandleLidSwitch=ignore,g" -i ${INSTALL}/etc/systemd/logind.conf
|
||||
sed -e "s,^.*HandlePowerKey=.*$,HandlePowerKey=ignore,g" -i ${INSTALL}/etc/systemd/logind.conf
|
||||
|
||||
if [ "${DISTRO}" = "Lakka" -a "${PROJECT}" = "RPi" ]; then
|
||||
sed -e "s,^.*HandlePowerKey=.*$,HandlePowerKey=poweroff,g" -i $INSTALL/etc/systemd/logind.conf
|
||||
fi
|
||||
|
||||
# replace systemd-machine-id-setup with ours
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/systemd-machine-id-commit.service
|
||||
safe_remove ${INSTALL}/usr/lib/systemd/system/*.target.wants/systemd-machine-id-commit.service
|
||||
safe_remove ${INSTALL}/usr/bin/systemd-machine-id-setup
|
||||
mkdir -p ${INSTALL}/usr/bin
|
||||
cp ${PKG_DIR}/scripts/systemd-machine-id-setup ${INSTALL}/usr/bin
|
||||
cp ${PKG_DIR}/scripts/userconfig-setup ${INSTALL}/usr/bin
|
||||
cp ${PKG_DIR}/scripts/usercache-setup ${INSTALL}/usr/bin
|
||||
cp ${PKG_DIR}/scripts/environment-setup ${INSTALL}/usr/bin
|
||||
|
||||
# use systemd to set cpufreq governor and tunables
|
||||
find_file_path scripts/cpufreq && cp -PRv ${FOUND_PATH} ${INSTALL}/usr/bin
|
||||
|
||||
mkdir -p ${INSTALL}/usr/sbin
|
||||
cp ${PKG_DIR}/scripts/network-base-setup ${INSTALL}/usr/sbin
|
||||
cp ${PKG_DIR}/scripts/systemd-timesyncd-setup ${INSTALL}/usr/sbin
|
||||
|
||||
# /etc/resolv.conf and /etc/hosts must be writable
|
||||
ln -sf /run/libreelec/resolv.conf ${INSTALL}/etc/resolv.conf
|
||||
ln -sf /run/libreelec/hosts ${INSTALL}/etc/hosts
|
||||
ln -sf /run/libreelec/environment ${INSTALL}/etc/environment
|
||||
|
||||
# provide 'halt', 'shutdown', 'reboot' & co.
|
||||
ln -sf /usr/bin/systemctl ${INSTALL}/usr/sbin/halt
|
||||
ln -sf /usr/bin/systemctl ${INSTALL}/usr/sbin/poweroff
|
||||
ln -sf /usr/bin/systemctl ${INSTALL}/usr/sbin/reboot
|
||||
ln -sf /usr/bin/systemctl ${INSTALL}/usr/sbin/runlevel
|
||||
ln -sf /usr/bin/systemctl ${INSTALL}/usr/sbin/shutdown
|
||||
ln -sf /usr/bin/systemctl ${INSTALL}/usr/sbin/telinit
|
||||
|
||||
# strip
|
||||
debug_strip ${INSTALL}/usr
|
||||
|
||||
# defaults
|
||||
mkdir -p ${INSTALL}/usr/config
|
||||
cp -PR ${PKG_DIR}/config/* ${INSTALL}/usr/config
|
||||
|
||||
safe_remove ${INSTALL}/etc/modules-load.d
|
||||
ln -sf /storage/.config/modules-load.d ${INSTALL}/etc/modules-load.d
|
||||
ln -sf /storage/.config/logind.conf.d ${INSTALL}/etc/systemd/logind.conf.d
|
||||
ln -sf /storage/.config/sleep.conf.d ${INSTALL}/etc/systemd/sleep.conf.d
|
||||
ln -sf /storage/.config/timesyncd.conf.d ${INSTALL}/etc/systemd/timesyncd.conf.d
|
||||
safe_remove ${INSTALL}/etc/sysctl.d
|
||||
ln -sf /storage/.config/sysctl.d ${INSTALL}/etc/sysctl.d
|
||||
safe_remove ${INSTALL}/etc/tmpfiles.d
|
||||
ln -sf /storage/.config/tmpfiles.d ${INSTALL}/etc/tmpfiles.d
|
||||
safe_remove ${INSTALL}/etc/udev/hwdb.d
|
||||
ln -sf /storage/.config/hwdb.d ${INSTALL}/etc/udev/hwdb.d
|
||||
safe_remove ${INSTALL}/etc/udev/rules.d
|
||||
ln -sf /storage/.config/udev.rules.d ${INSTALL}/etc/udev/rules.d
|
||||
|
||||
# journald
|
||||
ln -sf /storage/.cache/journald.conf.d ${INSTALL}/usr/lib/systemd/journald.conf.d
|
||||
}
|
||||
|
||||
post_install() {
|
||||
add_group systemd-journal 190
|
||||
|
||||
add_group systemd-timesync 191
|
||||
add_user systemd-timesync x 191 191 "systemd-timesync" "/" "/bin/false"
|
||||
|
||||
add_group systemd-network 193
|
||||
add_user systemd-network x 193 193 "systemd-network" "/" "/bin/sh"
|
||||
|
||||
add_group audio 63
|
||||
add_group cdrom 11
|
||||
add_group dialout 18
|
||||
add_group disk 6
|
||||
add_group floppy 19
|
||||
add_group kmem 9
|
||||
add_group kvm 10
|
||||
add_group lp 7
|
||||
add_group render 12
|
||||
add_group tape 33
|
||||
add_group tty 5
|
||||
add_group video 39
|
||||
add_group utmp 22
|
||||
add_group input 199
|
||||
|
||||
enable_service machine-id.service
|
||||
enable_service debugconfig.service
|
||||
enable_service userconfig.service
|
||||
enable_service usercache.service
|
||||
enable_service envconfig.service
|
||||
enable_service hwdb.service
|
||||
enable_service cpufreq.service
|
||||
enable_service network-base.service
|
||||
enable_service systemd-timesyncd.service
|
||||
enable_service systemd-timesyncd-setup.service
|
||||
}
|
19
projects/L4T/packages/systemd/patches/systemd-0001-move-etc-systemd-system-to-storage-.config-system.d.patch
Normal file
19
projects/L4T/packages/systemd/patches/systemd-0001-move-etc-systemd-system-to-storage-.config-system.d.patch
Normal file
@ -0,0 +1,19 @@
|
||||
commit 43aba5ffffc6d35ed97db035c5818c76652b06de
|
||||
Author: Matthias Reichl <hias@horus.com>
|
||||
Date: Mon Sep 28 23:55:13 2020 +0200
|
||||
|
||||
move /etc/systemd/system to /storage/.config/system.d
|
||||
|
||||
diff --git a/meson.build b/meson.build
|
||||
index dbbddb68e2..4592cd1094 100644
|
||||
--- a/meson.build
|
||||
+++ b/meson.build
|
||||
@@ -205,7 +205,7 @@ memory_accounting_default = get_option('memory-accounting-default')
|
||||
status_unit_format_default = get_option('status-unit-format-default')
|
||||
|
||||
conf.set_quoted('PKGSYSCONFDIR', pkgsysconfdir)
|
||||
-conf.set_quoted('SYSTEM_CONFIG_UNIT_DIR', join_paths(pkgsysconfdir, 'system'))
|
||||
+conf.set_quoted('SYSTEM_CONFIG_UNIT_DIR', '/storage/.config/system.d')
|
||||
conf.set_quoted('SYSTEM_DATA_UNIT_PATH', systemunitdir)
|
||||
conf.set_quoted('SYSTEM_SYSVINIT_PATH', sysvinit_path)
|
||||
conf.set_quoted('SYSTEM_SYSVRCND_PATH', sysvrcnd_path)
|
@ -0,0 +1,53 @@
|
||||
From bf2776b7f9403057cb82c2697e4fca8b554db4bd Mon Sep 17 00:00:00 2001
|
||||
From: MilhouseVH <milhouseVH.github@nmacleod.com>
|
||||
Date: Thu, 11 Apr 2019 20:00:05 +0100
|
||||
Subject: [PATCH] move hwdb.bin to /run
|
||||
|
||||
---
|
||||
src/libsystemd/sd-hwdb/hwdb-util.c | 2 +-
|
||||
src/libsystemd/sd-hwdb/sd-hwdb.c | 2 +-
|
||||
units/systemd-hwdb-update.service.in | 2 +-
|
||||
3 files changed, 3 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/src/libsystemd/sd-hwdb/hwdb-util.c b/src/libsystemd/sd-hwdb/hwdb-util.c
|
||||
index c83575c..6285f3d 100644
|
||||
--- a/src/libsystemd/sd-hwdb/hwdb-util.c
|
||||
+++ b/src/libsystemd/sd-hwdb/hwdb-util.c
|
||||
@@ -20,7 +20,7 @@
|
||||
#include "strv.h"
|
||||
#include "tmpfile-util.h"
|
||||
|
||||
-static const char *default_hwdb_bin_dir = "/etc/udev";
|
||||
+static const char *default_hwdb_bin_dir = "/run";
|
||||
static const char * const conf_file_dirs[] = {
|
||||
"/etc/udev/hwdb.d",
|
||||
UDEVLIBEXECDIR "/hwdb.d",
|
||||
diff --git a/src/libsystemd/sd-hwdb/sd-hwdb.c b/src/libsystemd/sd-hwdb/sd-hwdb.c
|
||||
index 79fe1a8..0acbf71 100644
|
||||
--- a/src/libsystemd/sd-hwdb/sd-hwdb.c
|
||||
+++ b/src/libsystemd/sd-hwdb/sd-hwdb.c
|
||||
@@ -299,7 +299,7 @@ static int trie_search_f(sd_hwdb *hwdb, const char *search) {
|
||||
|
||||
static const char hwdb_bin_paths[] =
|
||||
"/etc/systemd/hwdb/hwdb.bin\0"
|
||||
- "/etc/udev/hwdb.bin\0"
|
||||
+ "/run/hwdb.bin\0"
|
||||
"/usr/lib/systemd/hwdb/hwdb.bin\0"
|
||||
#if HAVE_SPLIT_USR
|
||||
"/lib/systemd/hwdb/hwdb.bin\0"
|
||||
diff --git a/units/systemd-hwdb-update.service.in b/units/systemd-hwdb-update.service.in
|
||||
index 259fe0d..18d617f 100644
|
||||
--- a/units/systemd-hwdb-update.service.in
|
||||
+++ b/units/systemd-hwdb-update.service.in
|
||||
@@ -16,7 +16,7 @@ After=systemd-remount-fs.service
|
||||
Before=sysinit.target shutdown.target systemd-update-done.service
|
||||
ConditionNeedsUpdate=/etc
|
||||
ConditionPathExists=|!@udevlibexecdir@/hwdb.bin
|
||||
-ConditionPathExists=|/etc/udev/hwdb.bin
|
||||
+ConditionPathExists=|/run/hwdb.bin
|
||||
ConditionDirectoryNotEmpty=|/etc/udev/hwdb.d/
|
||||
|
||||
[Service]
|
||||
--
|
||||
2.14.1
|
||||
|
24
projects/L4T/packages/systemd/patches/systemd-0003-remove-nonexistant-dependency.patch
Normal file
24
projects/L4T/packages/systemd/patches/systemd-0003-remove-nonexistant-dependency.patch
Normal file
@ -0,0 +1,24 @@
|
||||
From 382709612ae03d6f81049ac72ac2dabd7613763d Mon Sep 17 00:00:00 2001
|
||||
From: Stefan Saraev <stefan@saraev.ca>
|
||||
Date: Wed, 18 Feb 2015 18:23:47 +0200
|
||||
Subject: [PATCH 7/8] remove nonexistant dependency
|
||||
|
||||
---
|
||||
units/graphical.target | 1 -
|
||||
1 file changed, 1 deletion(-)
|
||||
|
||||
diff --git a/units/graphical.target b/units/graphical.target
|
||||
index 87be97e..b01b46d 100644
|
||||
--- a/units/graphical.target
|
||||
+++ b/units/graphical.target
|
||||
@@ -9,7 +9,6 @@
|
||||
Description=Graphical Interface
|
||||
Documentation=man:systemd.special(7)
|
||||
Requires=multi-user.target
|
||||
-Wants=display-manager.service
|
||||
Conflicts=rescue.service rescue.target
|
||||
After=multi-user.target rescue.service rescue.target display-manager.service
|
||||
AllowIsolate=yes
|
||||
--
|
||||
1.7.10.4
|
||||
|
30
projects/L4T/packages/systemd/patches/systemd-0200-persist-persistent-timer-stamps.patch
Normal file
30
projects/L4T/packages/systemd/patches/systemd-0200-persist-persistent-timer-stamps.patch
Normal file
@ -0,0 +1,30 @@
|
||||
From c1bcb16c35724404d30fab53017b757c886e9ab7 Mon Sep 17 00:00:00 2001
|
||||
From: MilhouseVH <milhouseVH.github@nmacleod.com>
|
||||
Date: Mon, 8 Jan 2018 13:46:51 +0000
|
||||
Subject: [PATCH] timers: use a persistent filesystem for persistent timers
|
||||
|
||||
---
|
||||
src/core/timer.c | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/src/core/timer.c b/src/core/timer.c
|
||||
index 03935ee..bfd5c02 100644
|
||||
--- a/src/core/timer.c
|
||||
+++ b/src/core/timer.c
|
||||
@@ -154,11 +154,11 @@ static int timer_setup_persistent(Timer *t) {
|
||||
|
||||
if (MANAGER_IS_SYSTEM(UNIT(t)->manager)) {
|
||||
|
||||
- r = unit_require_mounts_for(UNIT(t), "/var/lib/systemd/timers", UNIT_DEPENDENCY_FILE);
|
||||
+ r = unit_require_mounts_for(UNIT(t), "/storage/.cache/systemd/timers", UNIT_DEPENDENCY_FILE);
|
||||
if (r < 0)
|
||||
return r;
|
||||
|
||||
- t->stamp_path = strjoin("/var/lib/systemd/timers/stamp-", UNIT(t)->id);
|
||||
+ t->stamp_path = strjoin("/storage/.cache/systemd/timers/stamp-", UNIT(t)->id);
|
||||
} else {
|
||||
const char *e;
|
||||
|
||||
--
|
||||
2.14.1
|
||||
|
@ -0,0 +1,27 @@
|
||||
From 49285dae6756b22bc6881c04939f7c43c35b5506 Mon Sep 17 00:00:00 2001
|
||||
From: MilhouseVH <milhouseVH.github@nmacleod.com>
|
||||
Date: Sat, 29 Jun 2019 00:26:41 +0100
|
||||
Subject: [PATCH] debug-shell: configure environment, unhide cursor
|
||||
|
||||
---
|
||||
units/debug-shell.service.in | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/units/debug-shell.service.in b/units/debug-shell.service.in
|
||||
index 1127e68..4c3e971 100644
|
||||
--- a/units/debug-shell.service.in
|
||||
+++ b/units/debug-shell.service.in
|
||||
@@ -16,8 +16,8 @@ IgnoreOnIsolate=yes
|
||||
ConditionPathExists=@DEBUGTTY@
|
||||
|
||||
[Service]
|
||||
-Environment=TERM=linux
|
||||
-ExecStart=@SUSHELL@
|
||||
+Environment=ENV=/etc/profile
|
||||
+ExecStart=/bin/sh -c 'echo -en "\033[?25h"; exec /bin/sh'
|
||||
Restart=always
|
||||
RestartSec=0
|
||||
StandardInput=tty
|
||||
--
|
||||
2.14.1
|
||||
|
4
projects/L4T/packages/systemd/profile.d/90-systemd.conf
Normal file
4
projects/L4T/packages/systemd/profile.d/90-systemd.conf
Normal file
@ -0,0 +1,4 @@
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
# Copyright (C) 2016-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
export SYSTEMD_COLORS=0
|
17
projects/L4T/packages/systemd/scripts/cpufreq
Executable file
17
projects/L4T/packages/systemd/scripts/cpufreq
Executable file
@ -0,0 +1,17 @@
|
||||
#!/bin/sh
|
||||
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2015 Stephan Raue (stephan@openelec.tv)
|
||||
# Copyright (C) 2019-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
SYS_CPUFREQ_GOV=$( cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor )
|
||||
SYS_CPUFREQ_DIR="/sys/devices/system/cpu/cpufreq"
|
||||
|
||||
# Configure frequency scaling properties
|
||||
if [ $SYS_CPUFREQ_GOV = "ondemand" ]; then
|
||||
for policy in ${SYS_CPUFREQ_DIR}/ondemand ${SYS_CPUFREQ_DIR}/policy*/; do
|
||||
if [ -e $policy/up_threshold ]; then
|
||||
echo 50 > $policy/up_threshold
|
||||
fi
|
||||
done
|
||||
fi
|
16
projects/L4T/packages/systemd/scripts/environment-setup
Executable file
16
projects/L4T/packages/systemd/scripts/environment-setup
Executable file
@ -0,0 +1,16 @@
|
||||
#!/bin/sh
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
# Copyright (C) 2019-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
# read config files
|
||||
for config in /etc/profile.d/*; do
|
||||
if [ -f "$config" ] ; then
|
||||
. $config
|
||||
fi
|
||||
done
|
||||
|
||||
# generate system-wide environment file
|
||||
cat <<EOF >/run/libreelec/environment
|
||||
PATH=${PATH}
|
||||
LD_LIBRARY_PATH=${LD_LIBRARY_PATH}
|
||||
EOF
|
26
projects/L4T/packages/systemd/scripts/network-base-setup
Executable file
26
projects/L4T/packages/systemd/scripts/network-base-setup
Executable file
@ -0,0 +1,26 @@
|
||||
#!/bin/sh
|
||||
|
||||
# setup hostname
|
||||
if [ -f /storage/.cache/hostname ]; then
|
||||
cat /storage/.cache/hostname > /proc/sys/kernel/hostname
|
||||
fi
|
||||
|
||||
# setup /etc/hosts
|
||||
rm -f /run/libreelec/hosts
|
||||
if [ -f /storage/.config/hosts.conf ]; then
|
||||
cat /storage/.config/hosts.conf > /run/libreelec/hosts
|
||||
fi
|
||||
|
||||
# setup /etc/resolv.conf
|
||||
rm -f /run/libreelec/resolv.conf
|
||||
if [ -f /storage/.config/resolv.conf ]; then
|
||||
cat /storage/.config/resolv.conf > /run/libreelec/resolv.conf
|
||||
elif [ -f /dev/.kernel_ipconfig -a -f /proc/net/pnp ]; then
|
||||
cat /proc/net/pnp > /run/libreelec/resolv.conf
|
||||
else
|
||||
cat << EOF > /run/libreelec/resolv.conf
|
||||
nameserver 8.8.8.8
|
||||
nameserver 8.8.4.4
|
||||
EOF
|
||||
fi
|
||||
|
20
projects/L4T/packages/systemd/scripts/systemd-machine-id-setup
Executable file
20
projects/L4T/packages/systemd/scripts/systemd-machine-id-setup
Executable file
@ -0,0 +1,20 @@
|
||||
#!/bin/bash
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2014 Stephan Raue (stephan@openelec.tv)
|
||||
# Copyright (C) 2018-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
# remove old machine-id file
|
||||
[[ -f "/storage/.cache/machine-id" ]] && rm /storage/.cache/machine-id
|
||||
|
||||
# test systemd-machine-id exists and is 32 hex chars or generate a new uuid
|
||||
MACHINEID="$(cat /storage/.cache/systemd-machine-id 2>/dev/null)"
|
||||
[ "${#MACHINEID}" != "32" ] && MACHINEID=
|
||||
[[ "${MACHINEID//[a-f0-9]/}" != "" ]] && MACHINEID=
|
||||
[ -z "${MACHINEID}" ] && MACHINEID=$(/usr/bin/dbus-uuidgen)
|
||||
|
||||
# For first boot detection systemd may have overmounted the file
|
||||
umount /storage/.cache/systemd-machine-id >/dev/null 2>&1
|
||||
|
||||
# persist uuid
|
||||
mkdir -p /storage/.cache
|
||||
echo "$MACHINEID" > /storage/.cache/systemd-machine-id
|
22
projects/L4T/packages/systemd/scripts/systemd-timesyncd-setup
Executable file
22
projects/L4T/packages/systemd/scripts/systemd-timesyncd-setup
Executable file
@ -0,0 +1,22 @@
|
||||
#!/bin/sh
|
||||
KERNEL_NTP="${1:-/proc/net/ipconfig/ntp_servers}"
|
||||
NTP_SERVERS=""
|
||||
if [ -f /proc/net/ipconfig/ntp_servers ]; then
|
||||
for srv in $(cat /proc/net/ipconfig/ntp_servers); do
|
||||
if [ -n "$srv" -a "$srv" != "0.0.0.0" ]; then
|
||||
if [ -z "$NTP_SERVERS" ]; then
|
||||
NTP_SERVERS="$srv"
|
||||
else
|
||||
NTP_SERVERS="${NTP_SERVERS} $srv"
|
||||
fi
|
||||
fi
|
||||
done
|
||||
if [ -n "$NTP_SERVERS" ]; then
|
||||
mkdir -p /run/systemd/timesyncd.conf.d/
|
||||
cat << EOF > /run/systemd/timesyncd.conf.d/kernel-ntp-servers.conf
|
||||
[Time]
|
||||
NTP=$NTP_SERVERS
|
||||
EOF
|
||||
fi
|
||||
fi
|
||||
|
27
projects/L4T/packages/systemd/scripts/usercache-setup
Executable file
27
projects/L4T/packages/systemd/scripts/usercache-setup
Executable file
@ -0,0 +1,27 @@
|
||||
#!/bin/sh
|
||||
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
# Copyright (C) 2017-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
# Fix bug in older versions creating file /storage/.cache/services
|
||||
[ -f /storage/.cache/services ] && rm /storage/.cache/services && mkdir -p /storage/.cache/services
|
||||
|
||||
# Copy cache files, but don't overwrite
|
||||
false | cp -iRp /usr/cache/* /storage/.cache/ &>/dev/null
|
||||
|
||||
# Merge default and custom shadow file details
|
||||
if [ -f /storage/.cache/shadow -a -f /usr/cache/shadow ]; then
|
||||
# Get existing root details (possibly user defined)
|
||||
userroot="$(grep "^root:" /storage/.cache/shadow)"
|
||||
|
||||
# Overwrite users shadow file with default details, replacing root with any existing value
|
||||
# If current file is garbage (ie. missing root) then replace it
|
||||
if [ -n "${userroot}" ]; then
|
||||
sed -e "s ^root:.* ${userroot} " /usr/cache/shadow >/storage/.cache/shadow
|
||||
else
|
||||
cp -fp /usr/cache/shadow /storage/.cache/shadow
|
||||
fi
|
||||
|
||||
# Make sure we have the correct permission
|
||||
chmod 000 /storage/.cache/shadow
|
||||
fi
|
12
projects/L4T/packages/systemd/scripts/userconfig-setup
Executable file
12
projects/L4T/packages/systemd/scripts/userconfig-setup
Executable file
@ -0,0 +1,12 @@
|
||||
#!/bin/sh
|
||||
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
# Copyright (C) 2017-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
# Remove those sample files that we manage
|
||||
for sample in $(find /storage/.config -name '*.sample' 2>/dev/null); do
|
||||
[ -f /usr/config/${sample:17} ] && rm -f ${sample}
|
||||
done
|
||||
|
||||
# Copy config files, but don't overwrite - this should replace our sample files
|
||||
false | cp -iRp /usr/config/* /storage/.config/ &>/dev/null
|
11
projects/L4T/packages/systemd/system.d/cpufreq.service
Normal file
11
projects/L4T/packages/systemd/system.d/cpufreq.service
Normal file
@ -0,0 +1,11 @@
|
||||
[Unit]
|
||||
Description=Set CPU frequency governor and its tunables
|
||||
ConditionPathExists=/usr/bin/cpufreq
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
ExecStart=/usr/bin/cpufreq
|
||||
RemainAfterExit=yes
|
||||
|
||||
[Install]
|
||||
WantedBy=basic.target
|
14
projects/L4T/packages/systemd/system.d/debugconfig.service
Normal file
14
projects/L4T/packages/systemd/system.d/debugconfig.service
Normal file
@ -0,0 +1,14 @@
|
||||
[Unit]
|
||||
Description=Setup debug config
|
||||
DefaultDependencies=no
|
||||
After=systemd-tmpfiles-setup.service
|
||||
ConditionKernelCommandLine=|debugging
|
||||
ConditionPathExists=|/storage/.cache/debug.libreelec
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
ExecStart=/bin/sh -c 'cp /usr/share/debugconf/*.conf /run/libreelec/debug'
|
||||
RemainAfterExit=yes
|
||||
|
||||
[Install]
|
||||
WantedBy=sysinit.target
|
12
projects/L4T/packages/systemd/system.d/envconfig.service
Normal file
12
projects/L4T/packages/systemd/system.d/envconfig.service
Normal file
@ -0,0 +1,12 @@
|
||||
[Unit]
|
||||
Description=Generate system-wide /etc/environment file
|
||||
DefaultDependencies=no
|
||||
After=systemd-tmpfiles-setup.service
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
ExecStart=/usr/bin/environment-setup
|
||||
RemainAfterExit=yes
|
||||
|
||||
[Install]
|
||||
WantedBy=sysinit.target
|
@ -0,0 +1,2 @@
|
||||
[Unit]
|
||||
DefaultDependencies=no
|
14
projects/L4T/packages/systemd/system.d/hwdb.service
Normal file
14
projects/L4T/packages/systemd/system.d/hwdb.service
Normal file
@ -0,0 +1,14 @@
|
||||
[Unit]
|
||||
Description=Update hwdb.bin
|
||||
DefaultDependencies=no
|
||||
Conflicts=shutdown.target
|
||||
After=systemd-tmpfiles-setup.service
|
||||
Before=sysinit.target shutdown.target systemd-udevd.service
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
RemainAfterExit=yes
|
||||
ExecStart=systemd-hwdb update
|
||||
|
||||
[Install]
|
||||
WantedBy=sysinit.target
|
14
projects/L4T/packages/systemd/system.d/machine-id.service
Normal file
14
projects/L4T/packages/systemd/system.d/machine-id.service
Normal file
@ -0,0 +1,14 @@
|
||||
[Unit]
|
||||
Description=Setup machine-id
|
||||
DefaultDependencies=no
|
||||
Conflicts=shutdown.target
|
||||
Before=systemd-journald.service systemd-tmpfiles-setup-dev.service shutdown.target
|
||||
After=local-fs.target
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
ExecStart=/usr/bin/systemd-machine-id-setup
|
||||
RemainAfterExit=yes
|
||||
|
||||
[Install]
|
||||
WantedBy=sysinit.target
|
12
projects/L4T/packages/systemd/system.d/network-base.service
Normal file
12
projects/L4T/packages/systemd/system.d/network-base.service
Normal file
@ -0,0 +1,12 @@
|
||||
[Unit]
|
||||
Description=Base Network Configuration
|
||||
DefaultDependencies=no
|
||||
After=local-fs.target systemd-tmpfiles-setup.service userconfig.service
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
ExecStart=/usr/sbin/network-base-setup
|
||||
RemainAfterExit=yes
|
||||
|
||||
[Install]
|
||||
WantedBy=network.target
|
@ -0,0 +1,2 @@
|
||||
[Unit]
|
||||
DefaultDependencies=no
|
@ -0,0 +1,12 @@
|
||||
[Unit]
|
||||
Description=Setup NTP servers for timesyncd
|
||||
DefaultDependencies=no
|
||||
After=systemd-remount-fs.service systemd-sysusers.service
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
ExecStart=/usr/sbin/systemd-timesyncd-setup
|
||||
RemainAfterExit=yes
|
||||
|
||||
[Install]
|
||||
WantedBy=sysinit.target
|
3
projects/L4T/packages/systemd/system.d/systemd-timesyncd.service.d/depend-on-kernel-ip-config.conf
Normal file
3
projects/L4T/packages/systemd/system.d/systemd-timesyncd.service.d/depend-on-kernel-ip-config.conf
Normal file
@ -0,0 +1,3 @@
|
||||
[Unit]
|
||||
ConditionPathExists=/dev/.kernel_ipconfig
|
||||
After=systemd-timesyncd-setup.service network-base.service
|
12
projects/L4T/packages/systemd/system.d/usercache.service
Normal file
12
projects/L4T/packages/systemd/system.d/usercache.service
Normal file
@ -0,0 +1,12 @@
|
||||
[Unit]
|
||||
Description=Setup User cache dir
|
||||
DefaultDependencies=no
|
||||
After=systemd-tmpfiles-setup.service
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
ExecStart=/usr/bin/usercache-setup
|
||||
RemainAfterExit=yes
|
||||
|
||||
[Install]
|
||||
WantedBy=sysinit.target
|
12
projects/L4T/packages/systemd/system.d/userconfig.service
Normal file
12
projects/L4T/packages/systemd/system.d/userconfig.service
Normal file
@ -0,0 +1,12 @@
|
||||
[Unit]
|
||||
Description=Setup User config dir
|
||||
DefaultDependencies=no
|
||||
After=systemd-tmpfiles-setup.service
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
ExecStart=/usr/bin/userconfig-setup
|
||||
RemainAfterExit=yes
|
||||
|
||||
[Install]
|
||||
WantedBy=sysinit.target
|
@ -0,0 +1,5 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2014 Stephan Raue (stephan@openelec.tv)
|
||||
|
||||
d /run/libreelec 0755 root root - -
|
||||
d /run/libreelec/debug 0755 root root - -
|
@ -0,0 +1,2 @@
|
||||
SUBSYSTEM=="input", ATTRS{name}=="aml_keypad", ENV{ID_INPUT_JOYSTICK}=="?*", ENV{ID_INPUT_JOYSTICK}=""
|
||||
SUBSYSTEM=="input", ATTRS{name}=="Remote+", ENV{ID_INPUT_JOYSTICK}=="?*", ENV{ID_INPUT_JOYSTICK}=""
|
2
projects/L4T/packages/systemd/udev.d/80-clock.rules
Normal file
2
projects/L4T/packages/systemd/udev.d/80-clock.rules
Normal file
@ -0,0 +1,2 @@
|
||||
ACTION=="add", SUBSYSTEM=="rtc", RUN+="/sbin/hwclock --hctosys --utc --rtc=/dev/%k"
|
||||
ACTION=="add", ENV{MAJOR}=="10", ENV{MINOR}=="135", RUN+="/sbin/hwclock --hctosys --utc --rtc=/dev/%k"
|
6
projects/L4T/packages/util-linux/config/swap.conf
Normal file
6
projects/L4T/packages/util-linux/config/swap.conf
Normal file
@ -0,0 +1,6 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2014 Stephan Raue (stephan@openelec.tv)
|
||||
|
||||
SWAPFILE="$HOME/.cache/swapfile"
|
||||
SWAPFILESIZE="@SWAPFILESIZE@"
|
||||
SWAP_ENABLED="@SWAP_ENABLED_DEFAULT@"
|
105
projects/L4T/packages/util-linux/package.mk
Normal file
105
projects/L4T/packages/util-linux/package.mk
Normal file
@ -0,0 +1,105 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2016 Stephan Raue (stephan@openelec.tv)
|
||||
# Copyright (C) 2018-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
PKG_NAME="util-linux"
|
||||
PKG_VERSION="2.36.1"
|
||||
PKG_SHA256="09fac242172cd8ec27f0739d8d192402c69417617091d8c6e974841568f37eed"
|
||||
PKG_LICENSE="GPL"
|
||||
PKG_URL="http://www.kernel.org/pub/linux/utils/util-linux/v$(get_pkg_version_maj_min)/${PKG_NAME}-${PKG_VERSION}.tar.xz"
|
||||
PKG_DEPENDS_HOST="ccache:host autoconf:host automake:host intltool:host libtool:host pkg-config:host"
|
||||
PKG_DEPENDS_TARGET="toolchain"
|
||||
PKG_DEPENDS_INIT="toolchain"
|
||||
PKG_LONGDESC="A large variety of low-level system utilities that are necessary for a Linux system to function."
|
||||
PKG_TOOLCHAIN="autotools"
|
||||
PKG_BUILD_FLAGS="+pic:host"
|
||||
|
||||
UTILLINUX_CONFIG_DEFAULT="--disable-gtk-doc \
|
||||
--disable-nls \
|
||||
--disable-rpath \
|
||||
--enable-tls \
|
||||
--disable-all-programs \
|
||||
--enable-chsh-only-listed \
|
||||
--disable-bash-completion \
|
||||
--disable-colors-default \
|
||||
--disable-pylibmount \
|
||||
--disable-pg-bell \
|
||||
--disable-use-tty-group \
|
||||
--disable-makeinstall-chown \
|
||||
--disable-makeinstall-setuid \
|
||||
--with-gnu-ld \
|
||||
--without-selinux \
|
||||
--without-audit \
|
||||
--without-udev \
|
||||
--without-ncurses \
|
||||
--without-ncursesw \
|
||||
--without-readline \
|
||||
--without-slang \
|
||||
--without-tinfo \
|
||||
--without-utempter \
|
||||
--without-util \
|
||||
--without-libz \
|
||||
--without-user \
|
||||
--without-systemd \
|
||||
--without-smack \
|
||||
--without-python \
|
||||
--without-systemdsystemunitdir"
|
||||
|
||||
if [ "${DEVICE}" = "Switch" ]; then
|
||||
UTILLINUX_CONFIG_DEFAULT=${UTILLINUX_CONFIG_DEFAULT/--disable-all-programs/}
|
||||
fi
|
||||
|
||||
PKG_CONFIGURE_OPTS_TARGET="${UTILLINUX_CONFIG_DEFAULT} \
|
||||
--enable-libuuid \
|
||||
--enable-libblkid \
|
||||
--enable-libmount \
|
||||
--enable-libsmartcols \
|
||||
--enable-losetup \
|
||||
--enable-fsck \
|
||||
--enable-fstrim \
|
||||
--enable-blkid \
|
||||
--enable-lscpu"
|
||||
|
||||
if [ "${SWAP_SUPPORT}" = "yes" ]; then
|
||||
PKG_CONFIGURE_OPTS_TARGET+=" --enable-swapon"
|
||||
fi
|
||||
|
||||
PKG_CONFIGURE_OPTS_HOST="--enable-static \
|
||||
--disable-shared \
|
||||
${UTILLINUX_CONFIG_DEFAULT} \
|
||||
--enable-uuidgen \
|
||||
--enable-libuuid"
|
||||
|
||||
PKG_CONFIGURE_OPTS_INIT="${UTILLINUX_CONFIG_DEFAULT} \
|
||||
--enable-libblkid \
|
||||
--enable-libmount \
|
||||
--enable-fsck"
|
||||
|
||||
if [ "${INITRAMFS_PARTED_SUPPORT}" = "yes" ]; then
|
||||
PKG_CONFIGURE_OPTS_INIT+=" --enable-mkfs --enable-libuuid"
|
||||
fi
|
||||
|
||||
post_makeinstall_target() {
|
||||
if [ "${SWAP_SUPPORT}" = "yes" ]; then
|
||||
mkdir -p ${INSTALL}/usr/lib/libreelec
|
||||
cp -PR ${PKG_DIR}/scripts/mount-swap ${INSTALL}/usr/lib/libreelec
|
||||
|
||||
mkdir -p ${INSTALL}/etc
|
||||
cat ${PKG_DIR}/config/swap.conf | \
|
||||
sed -e "s,@SWAPFILESIZE@,${SWAPFILESIZE},g" \
|
||||
-e "s,@SWAP_ENABLED_DEFAULT@,${SWAP_ENABLED_DEFAULT},g" \
|
||||
> ${INSTALL}/etc/swap.conf
|
||||
fi
|
||||
|
||||
if [ "${DEVICE}" = "Switch" ]; then
|
||||
rm -r ${INSTALL}/usr/bin/*
|
||||
mv ${INSTALL}/usr/sbin/agetty ${INSTALL}/usr/bin/
|
||||
fi
|
||||
|
||||
}
|
||||
|
||||
post_install () {
|
||||
if [ "${SWAP_SUPPORT}" = "yes" ]; then
|
||||
enable_service swap.service
|
||||
fi
|
||||
}
|
@ -0,0 +1,75 @@
|
||||
From 4856beb5186760419bafd1f5686d6492d2d36907 Mon Sep 17 00:00:00 2001
|
||||
From: Stefan Saraev <stefan@saraev.ca>
|
||||
Date: Sat, 16 Aug 2014 13:40:57 +0300
|
||||
Subject: [PATCH] fix pkgconf
|
||||
|
||||
---
|
||||
libblkid/blkid.pc.in | 6 +++---
|
||||
libmount/mount.pc.in | 6 +++---
|
||||
libsmartcols/smartcols.pc.in | 6 +++---
|
||||
libuuid/uuid.pc.in | 6 +++---
|
||||
4 files changed, 12 insertions(+), 12 deletions(-)
|
||||
|
||||
diff --git a/libblkid/blkid.pc.in b/libblkid/blkid.pc.in
|
||||
index 40ec8a9..056ae64 100644
|
||||
--- a/libblkid/blkid.pc.in
|
||||
+++ b/libblkid/blkid.pc.in
|
||||
@@ -1,7 +1,7 @@
|
||||
prefix=@prefix@
|
||||
-exec_prefix=@exec_prefix@
|
||||
-libdir=@usrlib_execdir@
|
||||
-includedir=@includedir@
|
||||
+exec_prefix=${prefix}
|
||||
+libdir=${exec_prefix}/lib
|
||||
+includedir=${prefix}/include
|
||||
|
||||
Name: blkid
|
||||
Description: Block device id library
|
||||
diff --git a/libmount/mount.pc.in b/libmount/mount.pc.in
|
||||
index 2c32797..c8112c6 100644
|
||||
--- a/libmount/mount.pc.in
|
||||
+++ b/libmount/mount.pc.in
|
||||
@@ -1,7 +1,7 @@
|
||||
prefix=@prefix@
|
||||
-exec_prefix=@exec_prefix@
|
||||
-libdir=@usrlib_execdir@
|
||||
-includedir=@includedir@
|
||||
+exec_prefix=${prefix}
|
||||
+libdir=${exec_prefix}/lib
|
||||
+includedir=${prefix}/include
|
||||
|
||||
Name: mount
|
||||
Description: mount library
|
||||
diff --git a/libsmartcols/smartcols.pc.in b/libsmartcols/smartcols.pc.in
|
||||
index 0b16739..8f474ef 100644
|
||||
--- a/libsmartcols/smartcols.pc.in
|
||||
+++ b/libsmartcols/smartcols.pc.in
|
||||
@@ -1,7 +1,7 @@
|
||||
prefix=@prefix@
|
||||
-exec_prefix=@exec_prefix@
|
||||
-libdir=@usrlib_execdir@
|
||||
-includedir=@includedir@
|
||||
+exec_prefix=${prefix}
|
||||
+libdir=${exec_prefix}/lib
|
||||
+includedir=${prefix}/include
|
||||
|
||||
Name: smartcols
|
||||
Description: table or tree library
|
||||
diff --git a/libuuid/uuid.pc.in b/libuuid/uuid.pc.in
|
||||
index 875de19..ef1009e 100644
|
||||
--- a/libuuid/uuid.pc.in
|
||||
+++ b/libuuid/uuid.pc.in
|
||||
@@ -1,7 +1,7 @@
|
||||
prefix=@prefix@
|
||||
-exec_prefix=@exec_prefix@
|
||||
-libdir=@usrlib_execdir@
|
||||
-includedir=@includedir@
|
||||
+exec_prefix=${prefix}
|
||||
+libdir=${exec_prefix}/lib
|
||||
+includedir=${prefix}/include
|
||||
|
||||
Name: uuid
|
||||
Description: Universally unique id library
|
||||
--
|
||||
1.7.2.5
|
||||
|
@ -0,0 +1,17 @@
|
||||
diff --git a/configure.ac b/configure.ac
|
||||
index a05a294..558851d 100644
|
||||
--- a/configure.ac
|
||||
+++ b/configure.ac
|
||||
@@ -1498,7 +1498,11 @@ UL_REQUIRES_BUILD([lsblk], [libsmartcols])
|
||||
AM_CONDITIONAL([BUILD_LSBLK], [test "x$build_lsblk" = xyes])
|
||||
|
||||
|
||||
-UL_BUILD_INIT([lscpu], [check])
|
||||
+AC_ARG_ENABLE([lscpu],
|
||||
+ AS_HELP_STRING([--disable-lscpu], [do not build lscpu]),
|
||||
+ [], [UL_DEFAULT_ENABLE([lscpu], [check])]
|
||||
+)
|
||||
+UL_BUILD_INIT([lscpu])
|
||||
UL_REQUIRES_LINUX([lscpu])
|
||||
UL_REQUIRES_BUILD([lscpu], [libsmartcols])
|
||||
UL_REQUIRES_HAVE([lscpu], [cpu_set_t], [cpu_set_t type])
|
@ -0,0 +1,66 @@
|
||||
diff --git a/configure.ac b/configure.ac
|
||||
index 1899ec3..e4be942 100644
|
||||
--- a/configure.ac
|
||||
+++ b/configure.ac
|
||||
@@ -1156,7 +1156,11 @@ AS_IF([test "x$build_uuidd" = xyes || test "x$enable_libuuid_force_uuidd" == xye
|
||||
AM_CONDITIONAL([BUILD_UUIDD], [test "x$build_uuidd" = xyes])
|
||||
|
||||
|
||||
-UL_BUILD_INIT([uuidgen], [check])
|
||||
+AC_ARG_ENABLE([uuidgen],
|
||||
+ AS_HELP_STRING([--disable-uuidgen], [do not build uuidgen]),
|
||||
+ [], [UL_DEFAULT_ENABLE([uuidgen], [check])]
|
||||
+)
|
||||
+UL_BUILD_INIT([uuidgen])
|
||||
UL_REQUIRES_BUILD([uuidgen], [libuuid])
|
||||
AM_CONDITIONAL([BUILD_UUIDGEN], [test "x$build_uuidgen" = xyes])
|
||||
|
||||
@@ -1165,7 +1169,11 @@ UL_REQUIRES_BUILD([uuidparse], [libuuid])
|
||||
UL_REQUIRES_BUILD([uuidparse], [libsmartcols])
|
||||
AM_CONDITIONAL([BUILD_UUIDPARSE], [test "x$build_uuidparse" = xyes])
|
||||
|
||||
-UL_BUILD_INIT([blkid], [check])
|
||||
+AC_ARG_ENABLE([blkid],
|
||||
+ AS_HELP_STRING([--disable-blkid], [do not build blkid(8)]),
|
||||
+ [], [UL_DEFAULT_ENABLE([blkid], [check])]
|
||||
+)
|
||||
+UL_BUILD_INIT([blkid])
|
||||
UL_REQUIRES_BUILD([blkid], [libblkid])
|
||||
AM_CONDITIONAL([BUILD_BLKID], [test "x$build_blkid" = xyes])
|
||||
|
||||
@@ -1403,20 +1411,32 @@ UL_REQUIRES_HAVE([hwclock], [io, linuxdummy], [ioperm iopl function or Linux])
|
||||
AM_CONDITIONAL([BUILD_HWCLOCK], [test "x$build_hwclock" = xyes])
|
||||
|
||||
|
||||
-UL_BUILD_INIT([mkfs], [yes])
|
||||
+AC_ARG_ENABLE([mkfs],
|
||||
+ AS_HELP_STRING([--disable-mkfs], [do not build mkfs(8)]),
|
||||
+ [], [UL_DEFAULT_ENABLE([mkfs], [check])]
|
||||
+)
|
||||
+UL_BUILD_INIT([mkfs])
|
||||
AM_CONDITIONAL([BUILD_MKFS], [test "x$build_mkfs" = xyes])
|
||||
|
||||
UL_BUILD_INIT([isosize], [yes])
|
||||
AM_CONDITIONAL([BUILD_ISOSIZE], [test "x$build_isosize" = xyes])
|
||||
|
||||
|
||||
-UL_BUILD_INIT([fstrim], [check])
|
||||
+AC_ARG_ENABLE([fstrim],
|
||||
+ AS_HELP_STRING([--disable-fstrim], [do not build fstrim(8)]),
|
||||
+ [], [UL_DEFAULT_ENABLE([fstrim], [check])]
|
||||
+)
|
||||
+UL_BUILD_INIT([fstrim])
|
||||
UL_REQUIRES_LINUX([fstrim])
|
||||
UL_REQUIRES_BUILD([fstrim], [libmount])
|
||||
AM_CONDITIONAL([BUILD_FSTRIM], [test "x$build_fstrim" = xyes])
|
||||
|
||||
|
||||
-UL_BUILD_INIT([swapon], [check])
|
||||
+AC_ARG_ENABLE([swapon],
|
||||
+ AS_HELP_STRING([--disable-swapon], [do not build swapon(8) and swapoff(8)]),
|
||||
+ [], [UL_DEFAULT_ENABLE([swapon], [check])]
|
||||
+)
|
||||
+UL_BUILD_INIT([swapon])
|
||||
UL_REQUIRES_LINUX([swapon])
|
||||
UL_REQUIRES_BUILD([swapon], [libblkid])
|
||||
UL_REQUIRES_BUILD([swapon], [libmount])
|
43
projects/L4T/packages/util-linux/scripts/mount-swap
Executable file
43
projects/L4T/packages/util-linux/scripts/mount-swap
Executable file
@ -0,0 +1,43 @@
|
||||
#!/bin/sh
|
||||
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2014 Stephan Raue (stephan@openelec.tv)
|
||||
|
||||
. /etc/swap.conf
|
||||
. /etc/profile
|
||||
|
||||
if [ -f /storage/.config/swap.conf ]; then
|
||||
. /storage/.config/swap.conf
|
||||
fi
|
||||
|
||||
if [ -e /dev/.storage_netboot ] ; then
|
||||
logger -t Boot "### netbooting... swap disabled ###"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
if [ ! "$SWAP_ENABLED" = yes ] ; then
|
||||
logger -t Boot "### swap disabled via configfile ###"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
SWAP=`blkid -t TYPE="swap" -o device`
|
||||
|
||||
case $1 in
|
||||
create)
|
||||
if [ -z "$SWAP" -a ! -f "$SWAPFILE" ]; then
|
||||
mkdir -p `dirname $SWAPFILE`
|
||||
dd if=/dev/zero of=$SWAPFILE bs=1M count=$SWAPFILESIZE
|
||||
chmod 0600 $SWAPFILE
|
||||
mkswap $SWAPFILE
|
||||
fi
|
||||
;;
|
||||
mount)
|
||||
[ -z "$SWAP" -a -f "$SWAPFILE" ] && SWAP=$SWAPFILE
|
||||
for i in $SWAP; do
|
||||
swapon -p 10000 $i
|
||||
done
|
||||
;;
|
||||
unmount)
|
||||
swapoff -a
|
||||
;;
|
||||
esac
|
@ -0,0 +1 @@
|
||||
vm.swappiness=10
|
21
projects/L4T/packages/util-linux/system.d/swap.service
Normal file
21
projects/L4T/packages/util-linux/system.d/swap.service
Normal file
@ -0,0 +1,21 @@
|
||||
[Unit]
|
||||
Description=Mounting swapfile
|
||||
DefaultDependencies=false
|
||||
|
||||
Before=swap.target shutdown.target
|
||||
Conflicts=shutdown.target
|
||||
Wants=swap.target
|
||||
|
||||
ConditionPathExists=/proc/swaps
|
||||
ConditionKernelCommandLine=!noswap
|
||||
ConditionKernelCommandLine=!installer
|
||||
|
||||
[Service]
|
||||
Environment=HOME=/storage
|
||||
Type=oneshot
|
||||
ExecStartPre=/usr/lib/libreelec/mount-swap create
|
||||
ExecStart=/usr/lib/libreelec/mount-swap mount
|
||||
RemainAfterExit=yes
|
||||
|
||||
[Install]
|
||||
WantedBy=basic.target
|
1
projects/L4T/packages/xorg-server/debug.d/xorg.conf
Normal file
1
projects/L4T/packages/xorg-server/debug.d/xorg.conf
Normal file
@ -0,0 +1 @@
|
||||
XORG_DEBUG="-logverbose 6 -verbose 6"
|
158
projects/L4T/packages/xorg-server/package.mk
Normal file
158
projects/L4T/packages/xorg-server/package.mk
Normal file
@ -0,0 +1,158 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2016 Stephan Raue (stephan@openelec.tv)
|
||||
# Copyright (C) 2018-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
PKG_NAME="xorg-server"
|
||||
PKG_VERSION="1.20.11"
|
||||
PKG_SHA256="914c796e3ffabe1af48071d40ccc85e92117c97a9082ed1df29e4d64e3c34c49"
|
||||
PKG_LICENSE="OSS"
|
||||
PKG_SITE="http://www.X.org"
|
||||
PKG_URL="http://xorg.freedesktop.org/archive/individual/xserver/${PKG_NAME}-${PKG_VERSION}.tar.bz2"
|
||||
PKG_DEPENDS_TARGET="toolchain util-macros font-util xorgproto libpciaccess libX11 libXfont2 libXinerama libxshmfence libxkbfile libdrm openssl freetype pixman systemd xorg-launch-helper"
|
||||
PKG_NEED_UNPACK="$(get_pkg_directory xf86-video-nvidia) $(get_pkg_directory xf86-video-nvidia-legacy)"
|
||||
PKG_LONGDESC="Xorg is a full featured X server running on Intel x86 hardware."
|
||||
PKG_TOOLCHAIN="autotools"
|
||||
|
||||
get_graphicdrivers
|
||||
|
||||
if [ "${COMPOSITE_SUPPORT}" = "yes" ]; then
|
||||
PKG_DEPENDS_TARGET+=" libXcomposite"
|
||||
XORG_COMPOSITE="--enable-composite"
|
||||
else
|
||||
XORG_COMPOSITE="--disable-composite"
|
||||
fi
|
||||
|
||||
if [ ! "${OPENGL}" = "no" ]; then
|
||||
PKG_DEPENDS_TARGET+=" ${OPENGL} libepoxy"
|
||||
if [ ! "${PROJECT}" = "L4T" ]; then
|
||||
XORG_MESA="--enable-glx --enable-dri --enable-glamor"
|
||||
else
|
||||
XORG_MESA="--enable-glx --enable-dri --disable-glamor"
|
||||
fi
|
||||
else
|
||||
XORG_MESA="--disable-glx --disable-dri --disable-glamor"
|
||||
fi
|
||||
|
||||
PKG_CONFIGURE_OPTS_TARGET="--disable-debug \
|
||||
--disable-silent-rules \
|
||||
--disable-strict-compilation \
|
||||
--enable-largefile \
|
||||
--enable-visibility \
|
||||
--disable-unit-tests \
|
||||
--disable-sparkle \
|
||||
--disable-xselinux \
|
||||
${XORG_COMPOSITE} \
|
||||
--enable-mitshm \
|
||||
--enable-xres \
|
||||
--enable-record \
|
||||
--enable-xv \
|
||||
--disable-xvmc \
|
||||
--enable-dga \
|
||||
--disable-screensaver \
|
||||
--disable-xdmcp \
|
||||
--disable-xdm-auth-1 \
|
||||
${XORG_MESA} \
|
||||
--enable-dri2 \
|
||||
--enable-dri3 \
|
||||
--enable-present \
|
||||
--enable-xinerama \
|
||||
--enable-xf86vidmode \
|
||||
--disable-xace \
|
||||
--disable-xselinux \
|
||||
--disable-xcsecurity \
|
||||
--enable-dbe \
|
||||
--disable-xf86bigfont \
|
||||
--enable-dpms \
|
||||
--enable-config-udev \
|
||||
--enable-config-udev-kms \
|
||||
--disable-config-hal \
|
||||
--disable-config-wscons \
|
||||
--enable-xfree86-utils \
|
||||
--enable-vgahw \
|
||||
--enable-vbe \
|
||||
--enable-int10-module \
|
||||
--disable-windowswm \
|
||||
--enable-libdrm \
|
||||
--enable-clientids \
|
||||
--enable-pciaccess \
|
||||
--disable-linux-acpi \
|
||||
--disable-linux-apm \
|
||||
--disable-systemd-logind \
|
||||
--enable-xorg \
|
||||
--disable-dmx \
|
||||
--disable-xvfb \
|
||||
--disable-xnest \
|
||||
--disable-xquartz \
|
||||
--disable-standalone-xpbproxy \
|
||||
--disable-xwin \
|
||||
--disable-kdrive \
|
||||
--disable-xephyr \
|
||||
--disable-libunwind \
|
||||
--enable-xshmfence \
|
||||
--disable-install-setuid \
|
||||
--enable-unix-transport \
|
||||
--disable-tcp-transport \
|
||||
--disable-ipv6 \
|
||||
--disable-local-transport \
|
||||
--disable-secure-rpc \
|
||||
--enable-input-thread \
|
||||
--enable-xtrans-send-fds \
|
||||
--disable-docs \
|
||||
--disable-devel-docs \
|
||||
--with-int10=x86emu \
|
||||
--with-gnu-ld \
|
||||
--with-sha1=libcrypto \
|
||||
--without-systemd-daemon \
|
||||
--with-os-vendor=LibreELEC.tv \
|
||||
--with-module-dir=${XORG_PATH_MODULES} \
|
||||
--with-xkb-path=${XORG_PATH_XKB} \
|
||||
--with-xkb-output=/var/cache/xkb \
|
||||
--with-log-dir=/var/log \
|
||||
--with-fontrootdir=/usr/share/fonts \
|
||||
--with-default-font-path=/usr/share/fonts/misc,built-ins \
|
||||
--with-serverconfig-path=/usr/lib/xserver \
|
||||
--without-xmlto \
|
||||
--without-fop"
|
||||
|
||||
if [ "${PROJECT}" = "L4T" ]; then
|
||||
PKG_CONFIGURE_OPTS_TARGET+=" --disable-strip \
|
||||
--enable-glx-tls \
|
||||
--enable-aiglx"
|
||||
fi
|
||||
|
||||
pre_configure_target() {
|
||||
# hack to prevent a build error
|
||||
CFLAGS=$(echo ${CFLAGS} | sed -e "s|-O3|-O2|" -e "s|-Ofast|-O2|")
|
||||
LDFLAGS=$(echo ${LDFLAGS} | sed -e "s|-O3|-O2|" -e "s|-Ofast|-O2|")
|
||||
if [ "${PROJECT}" = "L4T" ]; then
|
||||
CFLAGS+=" -g"
|
||||
fi
|
||||
}
|
||||
|
||||
post_makeinstall_target() {
|
||||
rm -rf ${INSTALL}/var/cache/xkb
|
||||
|
||||
mkdir -p ${INSTALL}/usr/lib/xorg
|
||||
cp -P ${PKG_DIR}/scripts/xorg-configure ${INSTALL}/usr/lib/xorg
|
||||
sed -i -e "s|@NVIDIA_VERSION@|$(get_pkg_version xf86-video-nvidia)|g" ${INSTALL}/usr/lib/xorg/xorg-configure
|
||||
sed -i -e "s|@NVIDIA_LEGACY_VERSION@|$(get_pkg_version xf86-video-nvidia-legacy)|g" ${INSTALL}/usr/lib/xorg/xorg-configure
|
||||
|
||||
if [ ! "${OPENGL}" = "no" ]; then
|
||||
if [ ! "$PROJECT" = "L4T" ]; then
|
||||
if [ -f ${INSTALL}/usr/lib/xorg/modules/extensions/libglx.so ]; then
|
||||
mv ${INSTALL}/usr/lib/xorg/modules/extensions/libglx.so \
|
||||
${INSTALL}/usr/lib/xorg/modules/extensions/libglx_mesa.so # rename for cooperate with nvidia drivers
|
||||
ln -sf /var/lib/libglx.so ${INSTALL}/usr/lib/xorg/modules/extensions/libglx.so
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
mkdir -p ${INSTALL}/etc/X11
|
||||
if find_file_path config/xorg.conf; then
|
||||
cp ${FOUND_PATH} ${INSTALL}/etc/X11
|
||||
fi
|
||||
}
|
||||
|
||||
post_install() {
|
||||
enable_service xorg.service
|
||||
}
|
51
projects/L4T/packages/xorg-server/patches/xorg-server-0001-sdksyms.sh-Make-sdksyms.sh-work-with-gcc5.patch
Normal file
51
projects/L4T/packages/xorg-server/patches/xorg-server-0001-sdksyms.sh-Make-sdksyms.sh-work-with-gcc5.patch
Normal file
@ -0,0 +1,51 @@
|
||||
From 612eb45a2e7a0b35cc3790870e6d0cc42eb50c74 Mon Sep 17 00:00:00 2001
|
||||
From: Hans de Goede <hdegoede@redhat.com>
|
||||
Date: Wed, 11 Feb 2015 16:26:40 +0100
|
||||
Subject: [PATCH] sdksyms.sh: Make sdksyms.sh work with gcc5.
|
||||
|
||||
gcc5's cpp inserts patterns like this:
|
||||
|
||||
extern
|
||||
__attribute__((visibility("default")))
|
||||
int WaitForSomething(int *
|
||||
);
|
||||
|
||||
This patch make sdksyms.sh work with this. Note my awk skills are weak, so
|
||||
there likely is a better way to deal with this.
|
||||
|
||||
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
||||
---
|
||||
hw/xfree86/sdksyms.sh | 17 +++++++++++++++++
|
||||
1 file changed, 17 insertions(+)
|
||||
|
||||
diff --git a/hw/xfree86/sdksyms.sh b/hw/xfree86/sdksyms.sh
|
||||
index 2305073..99b0cae 100755
|
||||
--- a/hw/xfree86/sdksyms.sh
|
||||
+++ b/hw/xfree86/sdksyms.sh
|
||||
@@ -350,6 +350,23 @@ BEGIN {
|
||||
if (sdk) {
|
||||
n = 3;
|
||||
|
||||
+ # detect the following gcc5 cpp pattern and skip it:
|
||||
+ # extern
|
||||
+ # # 320 "../../include/os.h" 3 4
|
||||
+ # __attribute__((visibility("default")))
|
||||
+ # # 320 "../../include/os.h"
|
||||
+ # Note in this case the "extern " or "extern void " always has
|
||||
+ # a trailing space
|
||||
+ if ($0 ~ "^extern.* $") {
|
||||
+ getline;
|
||||
+ getline;
|
||||
+ getline;
|
||||
+ getline;
|
||||
+ n = 1;
|
||||
+ while ($n == " ")
|
||||
+ n++;
|
||||
+ }
|
||||
+
|
||||
# skip attribute, if any
|
||||
while ($n ~ /^(__attribute__|__global)/ ||
|
||||
# skip modifiers, if any
|
||||
--
|
||||
2.1.0
|
||||
|
@ -0,0 +1,13 @@
|
||||
diff -Naur xorg-server-1.8.2-old/xorg-server.m4 xorg-server-1.8.2-new/xorg-server.m4
|
||||
--- xorg-server-1.8.2-old/xorg-server.m4 2010-07-01 10:35:53.000000000 -0700
|
||||
+++ xorg-server-1.8.2-new/xorg-server.m4 2010-07-01 10:36:36.000000000 -0700
|
||||
@@ -31,7 +31,8 @@
|
||||
AC_DEFUN([XORG_DRIVER_CHECK_EXT],[
|
||||
AC_REQUIRE([PKG_PROG_PKG_CONFIG])
|
||||
SAVE_CFLAGS="$CFLAGS"
|
||||
- CFLAGS="$CFLAGS -I`$PKG_CONFIG --variable=sdkdir xorg-server`"
|
||||
+ m4_pattern_allow([^PKG_CONFIG_SYSROOT_DIR$])
|
||||
+ CFLAGS="$CFLAGS -I$PKG_CONFIG_SYSROOT_DIR`$PKG_CONFIG --variable=sdkdir xorg-server`"
|
||||
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
||||
#include "xorg-server.h"
|
||||
#if !defined $1
|
@ -0,0 +1,12 @@
|
||||
diff -Naur xorg-server-1.12.2-old/hw/xfree86/common/xf86pciBus.c xorg-server-1.12.2-new/hw/xfree86/common/xf86pciBus.c
|
||||
--- xorg-server-1.12.2-old/hw/xfree86/common/xf86pciBus.c 2012-05-17 10:09:03.000000000 -0700
|
||||
+++ xorg-server-1.12.2-new/hw/xfree86/common/xf86pciBus.c 2012-05-29 18:55:16.000000000 -0700
|
||||
@@ -1107,7 +1107,7 @@
|
||||
driverList[0] = "ast";
|
||||
break;
|
||||
case 0x1002:
|
||||
- driverList[0] = "ati";
|
||||
+ driverList[0] = "radeon";
|
||||
break;
|
||||
case 0x102c:
|
||||
driverList[0] = "chips";
|
85
projects/L4T/packages/xorg-server/patches/xorg-server-1.12.4-20_extra_modelines_fromxorg.patch
Normal file
85
projects/L4T/packages/xorg-server/patches/xorg-server-1.12.4-20_extra_modelines_fromxorg.patch
Normal file
@ -0,0 +1,85 @@
|
||||
From: Adam Jackson <ajax@redhat.com>
|
||||
Date: Sun, 28 Oct 2007 09:37:52 +0100
|
||||
Subject: [PATCH] Fedora extra modes list
|
||||
|
||||
---
|
||||
Index: xorg-server/hw/xfree86/common/extramodes
|
||||
===================================================================
|
||||
--- xorg-server.orig/hw/xfree86/common/extramodes
|
||||
+++ xorg-server/hw/xfree86/common/extramodes
|
||||
@@ -3,16 +3,75 @@
|
||||
//
|
||||
// $XFree86: xc/programs/Xserver/hw/xfree86/etc/extramodes,v 1.5 2002/06/05 19:43:05 dawes Exp $
|
||||
//
|
||||
+// NOTE: Please keep all video modes sorted in order of X res, then Y res for
|
||||
+// ease of maintenance and readability.
|
||||
|
||||
# 832x624 @ 75Hz (74.55Hz) (fix if the official/Apple spec is different) hsync: 49.725kHz
|
||||
ModeLine "832x624" 57.284 832 864 928 1152 624 625 628 667 -Hsync -Vsync
|
||||
|
||||
+# 1152x864 @ 60.00 Hz (GTF) hsync: 53.70 kHz; pclk: 81.62 MHz
|
||||
+Modeline "1152x864" 81.62 1152 1216 1336 1520 864 865 868 895 -HSync +Vsync
|
||||
+
|
||||
+# 1152x864 @ 70.00 Hz (GTF) hsync: 63.00 kHz; pclk: 96.77 MHz
|
||||
+Modeline "1152x864" 96.77 1152 1224 1344 1536 864 865 868 900 -HSync +Vsync
|
||||
+
|
||||
+# 1152x864 @ 75.00 Hz (GTF) hsync: 67.65 kHz; pclk: 104.99 MHz
|
||||
+Modeline "1152x864" 104.99 1152 1224 1352 1552 864 865 868 902 -HSync +Vsync
|
||||
+
|
||||
+# 1152x864 @ 85.00 Hz (GTF) hsync: 77.10 kHz; pclk: 119.65 MHz
|
||||
+Modeline "1152x864" 119.65 1152 1224 1352 1552 864 865 868 907 -HSync +Vsync
|
||||
+
|
||||
+# 1152x864 @ 85Hz (Red Hat custom modeline)
|
||||
+ModeLine "1152x864" 121.5 1152 1216 1344 1568 864 865 868 911 +hsync -vsync
|
||||
+
|
||||
+# 1152x864 @ 100.00 Hz (GTF) hsync: 91.50 kHz; pclk: 143.47 MHz
|
||||
+Modeline "1152x864" 143.47 1152 1232 1360 1568 864 865 868 915 -HSync +Vsync
|
||||
+
|
||||
+# 1360x768 59.96 Hz (CVT) hsync: 47.37 kHz; pclk: 72.00 MHz
|
||||
+Modeline "1360x768" 72.00 1360 1408 1440 1520 768 771 781 790 +hsync -vsync
|
||||
+
|
||||
+# 1360x768 59.80 Hz (CVT) hsync: 47.72 kHz; pclk: 84.75 MHz
|
||||
+Modeline "1360x768" 84.75 1360 1432 1568 1776 768 771 781 798 -hsync +vsync
|
||||
+
|
||||
# 1400x1050 @ 60Hz (VESA GTF) hsync: 65.5kHz
|
||||
ModeLine "1400x1050" 122.0 1400 1488 1640 1880 1050 1052 1064 1082 +hsync +vsync
|
||||
|
||||
+# 1400x1050 @ 70.00 Hz (GTF) hsync: 76.51 kHz; pclk: 145.06 MHz
|
||||
+Modeline "1400x1050" 145.06 1400 1496 1648 1896 1050 1051 1054 1093 -HSync +Vsync
|
||||
+
|
||||
# 1400x1050 @ 75Hz (VESA GTF) hsync: 82.2kHz
|
||||
ModeLine "1400x1050" 155.8 1400 1464 1784 1912 1050 1052 1064 1090 +hsync +vsync
|
||||
|
||||
+# 1400x1050 @ 85.00 Hz (GTF) hsync: 93.76 kHz; pclk: 179.26 MHz
|
||||
+Modeline "1400x1050" 179.26 1400 1504 1656 1912 1050 1051 1054 1103 -HSync +Vsync
|
||||
+
|
||||
+# 1440x900 @ 60.00 Hz (CVT) field rate 59.89 Hz; hsync: 55.93 kHz; pclk: 106.50 MHz
|
||||
+Modeline "1440x900" 106.50 1440 1520 1672 1904 900 903 909 934 -HSync +Vsync
|
||||
+
|
||||
+# 1600x1024 for SGI 1600 SW
|
||||
+ModeLine "1600x1024" 103.125 1600 1600 1656 1664 1024 1024 1029 1030 +Hsync +Vsync
|
||||
+
|
||||
+# 1680x1050 59.88 Hz (CVT 1.76MA-R) hsync: 64.67 kHz; pclk: 119.00 MHz
|
||||
+Modeline "1680x1050" 119.00 1680 1728 1760 1840 1050 1053 1059 1080 +hsync -vsync
|
||||
+
|
||||
+# 1680x1050 59.95 Hz (CVT 1.76MA) hsync: 65.29 kHz; pclk: 146.25 MHz
|
||||
+Modeline "1680x1050" 146.25 1680 1784 1960 2240 1050 1053 1059 1089 -hsync +vsync
|
||||
+
|
||||
+# 1680x1050 69.88 Hz (CVT) hsync: 76.58 kHz; pclk: 174.00 MHz
|
||||
+Modeline "1680x1050" 174.00 1680 1800 1976 2272 1050 1053 1059 1096 -hsync +vsync
|
||||
+
|
||||
+# 1680x1050 74.89 Hz (CVT 1.76MA) hsync: 82.31 kHz; pclk: 187.00 MHz
|
||||
+Modeline "1680x1050" 187.00 1680 1800 1976 2272 1050 1053 1059 1099 -hsync +vsync
|
||||
+
|
||||
+# 1680x1050 84.94 Hz (CVT 1.76MA) hsync: 93.86 kHz; pclk: 214.75 MHz
|
||||
+Modeline "1680x1050" 214.75 1680 1808 1984 2288 1050 1053 1059 1105 -hsync +vsync
|
||||
+
|
||||
+# 1920x1080 59.93 Hz (CVT 2.07M9-R) hsync: 66.59 kHz; pclk: 138.50 MHz
|
||||
+Modeline "1920x1080" 138.50 1920 1968 2000 2080 1080 1083 1088 1111 +hsync -vsync
|
||||
+
|
||||
+# 1920x1200 59.95 Hz (CVT 2.30MA-R) hsync: 74.04 kHz; pclk: 154.00 MHz
|
||||
+Modeline "1920x1200" 154.00 1920 1968 2000 2080 1200 1203 1209 1235 +hsync -vsync
|
||||
+
|
||||
# 1920x1440 @ 85Hz (VESA GTF) hsync: 128.5kHz
|
||||
Modeline "1920x1440" 341.35 1920 2072 2288 2656 1440 1441 1444 1512 -hsync +vsync
|
||||
|
97
projects/L4T/packages/xorg-server/patches/xorg-server-1.18.0-add_prime_support-1.patch
Normal file
97
projects/L4T/packages/xorg-server/patches/xorg-server-1.18.0-add_prime_support-1.patch
Normal file
@ -0,0 +1,97 @@
|
||||
Submitted By: Armin K. <krejzi at email dot com>
|
||||
Date: 2012-12-30
|
||||
Initial Package Version: 1.13.1
|
||||
Upstream Status: Not submitted.
|
||||
Origin: Upstream mailing list.
|
||||
Comment: Rediffed for Package Version 1.17.2 by
|
||||
Fernando de Oliveira <famobr at yahoo dot com dot br>
|
||||
Description: Adds PRIME support to Xorg Server to make GPU offloading work.
|
||||
|
||||
diff -Naur xorg-server-1.17.2.orig/hw/xfree86/common/xf86Init.c xorg-server-1.17.2/hw/xfree86/common/xf86Init.c
|
||||
--- xorg-server-1.17.2.orig/hw/xfree86/common/xf86Init.c 2015-06-05 12:19:40.000000000 -0300
|
||||
+++ xorg-server-1.17.2/hw/xfree86/common/xf86Init.c 2015-06-17 11:35:07.227581436 -0300
|
||||
@@ -340,6 +340,16 @@
|
||||
return ret;
|
||||
}
|
||||
|
||||
+extern void xf86AutoConfigOutputDevice(ScrnInfoPtr pScrn, ScrnInfoPtr master);
|
||||
+static void
|
||||
+xf86AutoConfigOutputDevices(void)
|
||||
+{
|
||||
+ int i;
|
||||
+
|
||||
+ for (i = 0; i < xf86NumGPUScreens; i++)
|
||||
+ xf86AutoConfigOutputDevice(xf86GPUScreens[i], xf86Screens[0]);
|
||||
+}
|
||||
+
|
||||
static void
|
||||
InstallSignalHandlers(void)
|
||||
{
|
||||
@@ -929,6 +939,8 @@
|
||||
for (i = 0; i < xf86NumGPUScreens; i++)
|
||||
AttachUnboundGPU(xf86Screens[0]->pScreen, xf86GPUScreens[i]->pScreen);
|
||||
|
||||
+ xf86AutoConfigOutputDevices();
|
||||
+
|
||||
xf86VGAarbiterWrapFunctions();
|
||||
if (sigio_blocked)
|
||||
OsReleaseSIGIO();
|
||||
diff -Naur xorg-server-1.17.2.orig/hw/xfree86/common/xf86platformBus.c xorg-server-1.17.2/hw/xfree86/common/xf86platformBus.c
|
||||
--- xorg-server-1.17.2.orig/hw/xfree86/common/xf86platformBus.c 2015-06-16 12:21:07.000000000 -0300
|
||||
+++ xorg-server-1.17.2/hw/xfree86/common/xf86platformBus.c 2015-06-17 11:35:07.227581436 -0300
|
||||
@@ -469,6 +469,8 @@
|
||||
return foundScreen;
|
||||
}
|
||||
|
||||
+extern void xf86AutoConfigOutputDevice(ScrnInfoPtr pScrn, ScrnInfoPtr master);
|
||||
+
|
||||
int
|
||||
xf86platformAddDevice(int index)
|
||||
{
|
||||
@@ -537,6 +539,7 @@
|
||||
}
|
||||
/* attach unbound to 0 protocol screen */
|
||||
AttachUnboundGPU(xf86Screens[0]->pScreen, xf86GPUScreens[i]->pScreen);
|
||||
+ xf86AutoConfigOutputDevice(xf86GPUScreens[i], xf86Screens[0]);
|
||||
|
||||
RRResourcesChanged(xf86Screens[0]->pScreen);
|
||||
RRTellChanged(xf86Screens[0]->pScreen);
|
||||
diff -Naur xorg-server-1.17.2.orig/hw/xfree86/modes/xf86Crtc.c xorg-server-1.17.2/hw/xfree86/modes/xf86Crtc.c
|
||||
--- xorg-server-1.17.2.orig/hw/xfree86/modes/xf86Crtc.c 2015-06-16 10:55:48.000000000 -0300
|
||||
+++ xorg-server-1.17.2/hw/xfree86/modes/xf86Crtc.c 2015-06-17 11:35:07.230581367 -0300
|
||||
@@ -3387,3 +3387,35 @@
|
||||
crtc->x = crtc->y = 0;
|
||||
}
|
||||
}
|
||||
+
|
||||
+
|
||||
+void xf86AutoConfigOutputDevice(ScrnInfoPtr pScrn, ScrnInfoPtr master)
|
||||
+{
|
||||
+ RRProviderPtr master_provider;
|
||||
+ xf86CrtcConfigPtr config = XF86_CRTC_CONFIG_PTR(master);
|
||||
+ xf86CrtcConfigPtr slave_config = XF86_CRTC_CONFIG_PTR(pScrn);
|
||||
+ Bool unbound = FALSE;
|
||||
+
|
||||
+ if (!config || !slave_config)
|
||||
+ return;
|
||||
+
|
||||
+ master_provider = config->randr_provider;
|
||||
+
|
||||
+ if ((master->capabilities & RR_Capability_SinkOffload) &&
|
||||
+ pScrn->capabilities & RR_Capability_SourceOffload) {
|
||||
+ /* source offload */
|
||||
+
|
||||
+ DetachUnboundGPU(pScrn->pScreen);
|
||||
+ unbound = TRUE;
|
||||
+ AttachOffloadGPU(master->pScreen, pScrn->pScreen);
|
||||
+ slave_config->randr_provider->offload_sink = master_provider;
|
||||
+ }
|
||||
+ if ((master->capabilities & RR_Capability_SourceOutput) &&
|
||||
+ pScrn->capabilities & RR_Capability_SinkOutput) {
|
||||
+ /* sink offload */
|
||||
+ if (!unbound)
|
||||
+ DetachUnboundGPU(pScrn->pScreen);
|
||||
+ AttachOutputGPU(master->pScreen, pScrn->pScreen);
|
||||
+ slave_config->randr_provider->output_source = master_provider;
|
||||
+ }
|
||||
+}
|
@ -0,0 +1,6 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2014 Stephan Raue (stephan@openelec.tv)
|
||||
|
||||
DISPLAY=":0.0"
|
||||
export DISPLAY
|
||||
|
104
projects/L4T/packages/xorg-server/scripts/xorg-configure
Executable file
104
projects/L4T/packages/xorg-server/scripts/xorg-configure
Executable file
@ -0,0 +1,104 @@
|
||||
#!/bin/sh
|
||||
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2014 Stephan Raue (stephan@openelec.tv)
|
||||
# Copyright (C) 2019-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
################################################################################
|
||||
# creating needed directories and symlinks
|
||||
################################################################################
|
||||
|
||||
if [ ! "${1}" = "switch" ]; then
|
||||
mkdir -p /var/lib
|
||||
fi
|
||||
mkdir -p /var/run
|
||||
|
||||
# HACK. we have xorg-configure@%. so nice race
|
||||
# can happen on multi-gpu setups
|
||||
if [ -e /var/run/xorg-configure.done ] ; then
|
||||
exit 0
|
||||
fi
|
||||
|
||||
touch /var/run/xorg-configure.done
|
||||
logger -t Xorg "creating needed directories and symlinks for driver: "${1}""
|
||||
|
||||
##############################################################################
|
||||
# setup xorg.conf paths
|
||||
##############################################################################
|
||||
|
||||
logger -t Xorg "### setup xorg.conf paths ###"
|
||||
|
||||
XORG_CONF_USER="/storage/.config/xorg.conf"
|
||||
XORG_CONF_USER_DRV="/storage/.config/xorg-${1}.conf"
|
||||
XORG_CONF_DEFAULT="/etc/X11/xorg.conf"
|
||||
XORG_CONF_DEFAULT_DRV="/etc/X11/xorg-${1}.conf"
|
||||
|
||||
##############################################################################
|
||||
# creating start options
|
||||
##############################################################################
|
||||
|
||||
logger -t Xorg "### creating start options ###"
|
||||
|
||||
XORG_ARGS="-s 0 -noreset -allowMouseOpenFail"
|
||||
|
||||
# load user defined xorg.conf, if exist
|
||||
if [ -f "${XORG_CONF_USER}" ]; then
|
||||
XORG_ARGS="${XORG_ARGS} -config ${XORG_CONF_USER}"
|
||||
elif [ -f "${XORG_CONF_USER_DRV}" ]; then
|
||||
XORG_ARGS="${XORG_ARGS} -config ${XORG_CONF_USER_DRV}"
|
||||
elif [ -f "${XORG_CONF_DEFAULT}" ]; then
|
||||
XORG_ARGS="${XORG_ARGS} -config ${XORG_CONF_DEFAULT}"
|
||||
elif [ -f "$XORG_CONF_DEFAULT_DRV" ]; then
|
||||
XORG_ARGS="${XORG_ARGS} -config ${XORG_CONF_DEFAULT_DRV}"
|
||||
fi
|
||||
|
||||
##############################################################################
|
||||
# creating needed directories and symlinks
|
||||
##############################################################################
|
||||
|
||||
logger -t Xorg "### creating needed directories and symlinks ###"
|
||||
|
||||
if [ ! "${1}" = "switch" ]; then
|
||||
# Used to support GeForce 600 Series & newer
|
||||
if [ "${1}" = "nvidia" ]; then
|
||||
ln -sf /usr/lib/libGL_glvnd.so.1 /var/lib/libGL.so
|
||||
ln -sf /usr/lib/xorg/modules/extensions/libglx_nvidia.so /var/lib/libglx.so
|
||||
ln -sf /usr/lib/libnvidia-ml.so.@NVIDIA_VERSION@ /var/lib/libnvidia-ml.so.1
|
||||
ln -sf /usr/lib/xorg/modules/drivers/nvidia-main_drv.so /var/lib/nvidia_drv.so
|
||||
ln -sf /usr/lib/nvidia/nvidia.ko /var/lib/nvidia.ko
|
||||
ln -sf /usr/lib/vdpau/libvdpau_nvidia-main.so.1 /var/lib/libvdpau_nvidia.so.1
|
||||
ln -sf /usr/lib/vdpau/libvdpau_nvidia-main.so.1 /var/lib/libvdpau_nvidia.so
|
||||
ln -sf /usr/bin/nvidia-main-smi /var/lib/nvidia-smi
|
||||
ln -sf /usr/bin/nvidia-main-xconfig /var/lib/nvidia-xconfig
|
||||
insmod /var/lib/nvidia.ko
|
||||
XORG_ARGS="${XORG_ARGS} -ignoreABI"
|
||||
# Used to support GeForce 500 Series & older
|
||||
elif [ "${1}" = "nvidia-legacy" ]; then
|
||||
ln -sf /usr/lib/libGL_nvidia-legacy.so.1 /var/lib/libGL.so
|
||||
ln -sf /usr/lib/xorg/modules/extensions/libglx_nvidia-legacy.so /var/lib/libglx.so
|
||||
ln -sf /usr/lib/libnvidia-ml.so.@NVIDIA_LEGACY_VERSION@ /var/lib/libnvidia-ml.so.1
|
||||
ln -sf /usr/lib/xorg/modules/drivers/nvidia-legacy_drv.so /var/lib/nvidia_drv.so
|
||||
ln -sf /usr/lib/nvidia-legacy/nvidia.ko /var/lib/nvidia.ko
|
||||
ln -sf /usr/lib/vdpau/libvdpau_nvidia-legacy.so.1 /var/lib/libvdpau_nvidia.so.1
|
||||
ln -sf /usr/lib/vdpau/libvdpau_nvidia-legacy.so.1 /var/lib/libvdpau_nvidia.so
|
||||
ln -sf /usr/bin/nvidia-legacy-smi /var/lib/nvidia-smi
|
||||
ln -sf /usr/bin/nvidia-legacy-xconfig /var/lib/nvidia-xconfig
|
||||
insmod /var/lib/nvidia.ko
|
||||
XORG_ARGS="${XORG_ARGS} -ignoreABI"
|
||||
# Used for AMD & Intel GPUs supported by MESA 3D
|
||||
else
|
||||
ln -sf /usr/lib/libGL_glvnd.so.1 /var/lib/libGL.so
|
||||
ln -sf /usr/lib/xorg/modules/extensions/libglx_mesa.so /var/lib/libglx.so
|
||||
fi
|
||||
else
|
||||
XORG_ARGS="${XORG_ARGS} -ignoreABI"
|
||||
fi
|
||||
|
||||
################################################################################
|
||||
# setup xorg-settings.conf
|
||||
################################################################################
|
||||
|
||||
logger -t Xorg "### starting Xorg with '${DISPLAY} vt01 ${XORG_ARGS}' ###"
|
||||
mkdir -p /run/libreelec
|
||||
echo "XORG_ARGS=\"${XORG_ARGS}\"" > /run/libreelec/xorg-settings.conf
|
||||
|
@ -0,0 +1,9 @@
|
||||
[Unit]
|
||||
Description=configure Xorg Server for %i
|
||||
|
||||
ConditionKernelCommandLine=!installer
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
ExecStart=/usr/lib/xorg/xorg-configure %i
|
||||
RemainAfterExit=yes
|
16
projects/L4T/packages/xorg-server/system.d/xorg.service
Normal file
16
projects/L4T/packages/xorg-server/system.d/xorg.service
Normal file
@ -0,0 +1,16 @@
|
||||
[Unit]
|
||||
Description=Xorg Server
|
||||
Before=graphical.target kodi.service
|
||||
After=multi-user.target
|
||||
ConditionKernelCommandLine=!installer
|
||||
|
||||
[Service]
|
||||
Type=notify
|
||||
EnvironmentFile=-/run/libreelec/debug/xorg.conf
|
||||
ExecStart=/usr/bin/xorg-launch -nolisten tcp vt01 $XORG_DEBUG
|
||||
Restart=always
|
||||
RestartSec=2
|
||||
StartLimitInterval=0
|
||||
|
||||
[Install]
|
||||
WantedBy=graphical.target
|
@ -0,0 +1,4 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2014 Stephan Raue (stephan@openelec.tv)
|
||||
|
||||
d /var/cache/xkb 0755 root root - -
|
19
projects/L4T/packages/xorg-server/udev.d/97-xorg.rules
Normal file
19
projects/L4T/packages/xorg-server/udev.d/97-xorg.rules
Normal file
@ -0,0 +1,19 @@
|
||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||
# Copyright (C) 2009-2014 Stephan Raue (stephan@openelec.tv)
|
||||
|
||||
ACTION!="add|change", GOTO="end_video"
|
||||
|
||||
# xorg_start only does something for subsystem "pci" and "video" class.
|
||||
SUBSYSTEM=="pci", ATTR{class}=="0x030000", GOTO="subsystem_pci"
|
||||
GOTO="end_video"
|
||||
|
||||
# check for drivers using the pci substem
|
||||
LABEL="subsystem_pci"
|
||||
DRIVER=="i915", ENV{xorg_driver}="i915", TAG+="systemd", ENV{SYSTEMD_WANTS}+="xorg-configure@i915.service"
|
||||
DRIVER=="amdgpu", ENV{xorg_driver}="amdgpu", TAG+="systemd", ENV{SYSTEMD_WANTS}+="xorg-configure@amdgpu.service"
|
||||
DRIVER=="radeon", ENV{xorg_driver}="radeon", TAG+="systemd", ENV{SYSTEMD_WANTS}+="xorg-configure@radeon.service"
|
||||
DRIVER=="vmwgfx", ENV{xorg_driver}="vmware", TAG+="systemd", ENV{SYSTEMD_WANTS}+="xorg-configure@vmware.service"
|
||||
DRIVER=="virtio-pci", ENV{xorg_driver}="modesetting", TAG+="systemd", ENV{SYSTEMD_WANTS}+="xorg-configure@modesetting.service"
|
||||
GOTO="end_video"
|
||||
|
||||
LABEL="end_video"
|
Reference in New Issue
Block a user