added my Recipes
This commit is contained in:
@@ -0,0 +1,26 @@
|
||||
# STARTUP
|
||||
::sysinit:/bin/mount -t proc proc /proc
|
||||
::sysinit:/bin/mount -t sysfs sysfs /sys
|
||||
::sysinit:/bin/mount -t devtmpfs devtmpfs /dev
|
||||
::sysinit:/bin/mount -o remount,rw /
|
||||
::sysinit:/bin/mkdir -p /dev/pts
|
||||
::sysinit:/bin/mount -t devpts devpts /dev/pts
|
||||
::sysinit:/bin/mount -a
|
||||
|
||||
::sysinit:/bin/ln -sf /proc/self/fd /dev/fd
|
||||
::sysinit:/bin/ln -sf /proc/self/fd/0 /dev/stdin
|
||||
::sysinit:/bin/ln -sf /proc/self/fd/1 /dev/stdout
|
||||
::sysinit:/bin/ln -sf /proc/self/fd/2 /dev/stderr
|
||||
|
||||
::sysinit:/bin/hostname -F /etc/hostname
|
||||
|
||||
::sysinit:/etc/init.d/rcS
|
||||
|
||||
# REBOOT
|
||||
::ctrlaltdel:/sbin/reboot
|
||||
::shutdown:/etc/init.d/rcK
|
||||
::shutdown:/bin/umount -a -r
|
||||
|
||||
# RESTART INIT
|
||||
::restart:/sbin/init
|
||||
|
||||
@@ -0,0 +1,26 @@
|
||||
#!/bin/sh
|
||||
|
||||
# Stop all init scripts in /etc/rc6.d
|
||||
# executing them in numerical order.
|
||||
#
|
||||
for i in /etc/rc6.d/K??*; do
|
||||
|
||||
# Ignore dangling symlinks (if any).
|
||||
[ ! -f "$i" ] && continue
|
||||
|
||||
case "$i" in
|
||||
*.sh)
|
||||
# Source shell script for speed.
|
||||
(
|
||||
trap - INT QUIT TSTP
|
||||
set stop
|
||||
. $i
|
||||
)
|
||||
;;
|
||||
*)
|
||||
# No sh extension, so fork subprocess.
|
||||
$i stop
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
@@ -0,0 +1,27 @@
|
||||
#!/bin/sh
|
||||
|
||||
# Start all init scripts in /etc/rcS.d and /etc/rc5.d
|
||||
# executing them in numerical order.
|
||||
#
|
||||
|
||||
for i in /etc/rcS.d/S??* /etc/rc5.d/S??* ;do
|
||||
|
||||
# Ignore dangling symlinks (if any).
|
||||
[ ! -f "$i" ] && continue
|
||||
|
||||
case "$i" in
|
||||
*.sh)
|
||||
# Source shell script for speed.
|
||||
(
|
||||
trap - INT QUIT TSTP
|
||||
set start
|
||||
. $i
|
||||
)
|
||||
;;
|
||||
*)
|
||||
# No sh extension, so fork subprocess.
|
||||
$i start
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
@@ -0,0 +1,64 @@
|
||||
SUMMARY = "Toybox Inittab Configuration"
|
||||
LICENSE = "0BSD"
|
||||
LIC_FILES_CHKSUM = "file://${COREBASE}/meta/files/common-licenses/0BSD;md5=f667a3c3830a55a17ec3067709f4526c"
|
||||
|
||||
# Unpack to ${S}/orig
|
||||
#
|
||||
SRC_URI = "\
|
||||
file://inittab;subdir=${BP}/orig \
|
||||
file://rcK;subdir=${BP}/orig \
|
||||
file://rcS;subdir=${BP}/orig \
|
||||
"
|
||||
|
||||
PACKAGE_ARCH = "${MACHINE_ARCH}"
|
||||
|
||||
RCONFLICTS:${PN} = "\
|
||||
busybox-inittab \
|
||||
sysvinit-inittab \
|
||||
"
|
||||
|
||||
# Just being sure.
|
||||
B = "${S}"
|
||||
|
||||
# most users may want to have getty enabled by default
|
||||
PACKAGECONFIG ??= "getty"
|
||||
|
||||
PACKAGECONFIG[getty] = "\
|
||||
enable_getty \
|
||||
"
|
||||
|
||||
do_patch[noexec] = "1"
|
||||
|
||||
do_configure() {
|
||||
# copy over files now to have a fresh start on each config
|
||||
cp orig/* .
|
||||
|
||||
for config in ${PACKAGECONFIG_CONFARGS}; do
|
||||
if [[ ${config} == "enable_getty" ]]; then
|
||||
echo "# generated by bitbake recipe ${PN}" >> ${S}/inittab
|
||||
for console in "${SERIAL_CONSOLES}"; do
|
||||
param=$(echo ${console} | sed s/\;/\ /g)
|
||||
name=$(echo ${param} | cut -d' ' -f2)
|
||||
echo "$name::respawn:${base_sbindir}/getty ${param}" >> ${S}/inittab
|
||||
done
|
||||
fi
|
||||
done
|
||||
}
|
||||
|
||||
do_compile[noexec] = "1"
|
||||
|
||||
do_install() {
|
||||
install -d ${D}${sysconfdir}
|
||||
install -D -m 0644 ${S}/inittab ${D}${sysconfdir}/inittab
|
||||
|
||||
install -d ${D}${sysconfdir}/init.d
|
||||
install -D -m 0744 ${S}/rcK ${D}${sysconfdir}/init.d/rcK
|
||||
install -D -m 0744 ${S}/rcS ${D}${sysconfdir}/init.d/rcS
|
||||
}
|
||||
|
||||
FILES:${PN} = "\
|
||||
${sysconfdir}/inittab \
|
||||
${sysconfdir}/init.d/rcK \
|
||||
${sysconfdir}/init.d/rcS \
|
||||
"
|
||||
|
||||
@@ -0,0 +1,37 @@
|
||||
From 7284c7ae0df9aa5a9c8aa0a81a018e17289fe2c4 Mon Sep 17 00:00:00 2001
|
||||
From: Khem Raj <raj.khem@gmail.com>
|
||||
Date: Thu, 8 Sep 2022 07:22:26 -0700
|
||||
Subject: [PATCH] portability: Fix timer_settime_wrap for 32bit systems with
|
||||
64bit time_t
|
||||
|
||||
glibc does not define SYS_timer_settime if the 32bit syscall is not
|
||||
available, new architectures like riscv32 has defaulted to 64bit time_t
|
||||
from get go and avoided wiring 32bit syscall, therefore alias it to
|
||||
64bit version here
|
||||
|
||||
Upstream-Status: Submitted [https://github.com/landley/toybox/pull/373]
|
||||
Signed-off-by: Khem Raj <raj.khem@gmail.com>
|
||||
---
|
||||
lib/portability.c | 6 ++++++
|
||||
1 file changed, 6 insertions(+)
|
||||
|
||||
diff --git a/lib/portability.c b/lib/portability.c
|
||||
index d955d081..4baa9367 100644
|
||||
--- a/lib/portability.c
|
||||
+++ b/lib/portability.c
|
||||
@@ -711,6 +711,12 @@ int timer_create_wrap(clockid_t c, struct sigevent *se, timer_t *t)
|
||||
return 0;
|
||||
}
|
||||
|
||||
+#if !defined(SYS_timer_settime) && defined(SYS_timer_settime64)
|
||||
+// glibc does not define defines SYS_timer_settime on 32-bit systems
|
||||
+// with 64-bit time_t defaults e.g. riscv32
|
||||
+#define SYS_timer_settime SYS_timer_settime64
|
||||
+#endif
|
||||
+
|
||||
int timer_settime_wrap(timer_t t, int flags, struct itimerspec *val,
|
||||
struct itimerspec *old)
|
||||
{
|
||||
--
|
||||
2.37.3
|
||||
|
||||
115
meta-openembedded/meta-oe/recipes-core/toybox/toybox_0.8.8.bb
Normal file
115
meta-openembedded/meta-oe/recipes-core/toybox/toybox_0.8.8.bb
Normal file
@@ -0,0 +1,115 @@
|
||||
SUMMARY = "Toybox combines common utilities together into a single executable."
|
||||
HOMEPAGE = "http://www.landley.net/toybox/"
|
||||
DEPENDS = "attr virtual/crypt"
|
||||
|
||||
LICENSE = "0BSD"
|
||||
LIC_FILES_CHKSUM = "file://LICENSE;md5=78659a599b9325da368f2f1eb88f19c7"
|
||||
|
||||
inherit cml1 update-alternatives
|
||||
|
||||
SRC_URI = "http://www.landley.net/toybox/downloads/${BPN}-${PV}.tar.gz \
|
||||
file://0001-portability-Fix-timer_settime_wrap-for-32bit-systems.patch \
|
||||
"
|
||||
SRC_URI[sha256sum] = "dafd41978d40f02a61cf1be99a2b4a25812bbfb9c3157e679ee7611202d6ac58"
|
||||
|
||||
SECTION = "base"
|
||||
|
||||
RDEPENDS:${PN} = "${@["", "toybox-inittab"][(d.getVar('VIRTUAL-RUNTIME_init_manager') == 'toybox')]}"
|
||||
|
||||
TOYBOX_BIN = "generated/unstripped/toybox"
|
||||
|
||||
# Toybox is strict on what CC, CFLAGS and CROSS_COMPILE variables should contain.
|
||||
# Fix CC, CFLAGS, CROSS_COMPILE to match expectations.
|
||||
# CC = compiler name
|
||||
# CFLAGS = only compiler flags
|
||||
# CROSS_COMPILE = compiler prefix
|
||||
CFLAGS += "${TOOLCHAIN_OPTIONS} ${TUNE_CCARGS}"
|
||||
|
||||
COMPILER:toolchain-clang = "clang"
|
||||
COMPILER ?= "gcc"
|
||||
|
||||
PACKAGECONFIG ??= "no-iconv no-getconf"
|
||||
|
||||
PACKAGECONFIG[no-iconv] = ",,"
|
||||
PACKAGECONFIG[no-getconf] = ",,"
|
||||
|
||||
EXTRA_OEMAKE = 'CROSS_COMPILE="${HOST_PREFIX}" \
|
||||
CC="${COMPILER}" \
|
||||
STRIP="strip" \
|
||||
CFLAGS="${CFLAGS}" \
|
||||
HOSTCC="${BUILD_CC}" CPUS=${@oe.utils.cpu_count()} V=1'
|
||||
|
||||
do_configure() {
|
||||
# allow user to define their own defconfig in bbappend, taken from kernel.bbclass
|
||||
if [ "${S}" != "${B}" ] && [ -f "${S}/.config" ] && [ ! -f "${B}/.config" ]; then
|
||||
mv "${S}/.config" "${B}/.config"
|
||||
fi
|
||||
|
||||
# Copy defconfig to .config if .config does not exist. This allows
|
||||
# recipes to manage the .config themselves in do_configure:prepend().
|
||||
if [ -f "${WORKDIR}/defconfig" ] && [ ! -f "${B}/.config" ]; then
|
||||
cp "${WORKDIR}/defconfig" "${B}/.config"
|
||||
fi
|
||||
|
||||
oe_runmake oldconfig || oe_runmake defconfig
|
||||
|
||||
# Disable killall5 as it isn't managed by update-alternatives
|
||||
sed -e 's/CONFIG_KILLALL5=y/# CONFIG_KILLALL5 is not set/' -i .config
|
||||
|
||||
# Disable swapon as it doesn't handle the '-a' argument used during boot
|
||||
sed -e 's/CONFIG_SWAPON=y/# CONFIG_SWAPON is not set/' -i .config
|
||||
|
||||
# Enable init if toybox was set as init manager
|
||||
if ${@bb.utils.contains('VIRTUAL-RUNTIME_init_manager','toybox','true','false',d)}; then
|
||||
sed -e 's/# CONFIG_INIT is not set/CONFIG_INIT=y/' -i .config
|
||||
fi
|
||||
}
|
||||
|
||||
do_compile() {
|
||||
oe_runmake ${TOYBOX_BIN}
|
||||
|
||||
# Create a list of links needed
|
||||
${BUILD_CC} -I . scripts/install.c -o generated/instlist
|
||||
./generated/instlist long | sed -e 's#^#/#' > toybox.links
|
||||
if ${@bb.utils.contains('PACKAGECONFIG','no-iconv','true','false',d)}; then
|
||||
sed -i -e '/iconv$/d' toybox.links
|
||||
fi
|
||||
if ${@bb.utils.contains('PACKAGECONFIG','no-getconf','true','false',d)}; then
|
||||
sed -i -e '/getconf$/d' toybox.links
|
||||
fi
|
||||
}
|
||||
|
||||
do_install() {
|
||||
# Install manually instead of using 'make install'
|
||||
install -d ${D}${base_bindir}
|
||||
if grep -q "CONFIG_TOYBOX_SUID=y" ${B}/.config; then
|
||||
install -m 4755 ${B}/${TOYBOX_BIN} ${D}${base_bindir}/toybox
|
||||
else
|
||||
install -m 0755 ${B}/${TOYBOX_BIN} ${D}${base_bindir}/toybox
|
||||
fi
|
||||
|
||||
install -d ${D}${sysconfdir}
|
||||
install -m 0644 ${B}/toybox.links ${D}${sysconfdir}
|
||||
}
|
||||
|
||||
# If you've chosen to install toybox you probably want it to take precedence
|
||||
# over busybox where possible but not over other packages
|
||||
ALTERNATIVE_PRIORITY = "60"
|
||||
|
||||
python do_package:prepend () {
|
||||
# Read links from /etc/toybox.links and create appropriate
|
||||
# update-alternatives variables
|
||||
|
||||
dvar = d.getVar('D')
|
||||
pn = d.getVar('PN')
|
||||
target = d.expand("${base_bindir}/toybox")
|
||||
|
||||
f = open('%s/etc/toybox.links' % (dvar), 'r')
|
||||
for alt_link_name in f:
|
||||
alt_link_name = alt_link_name.strip()
|
||||
alt_name = os.path.basename(alt_link_name)
|
||||
d.appendVar('ALTERNATIVE:%s' % (pn), ' ' + alt_name)
|
||||
d.setVarFlag('ALTERNATIVE_LINK_NAME', alt_name, alt_link_name)
|
||||
d.setVarFlag('ALTERNATIVE_TARGET', alt_name, target)
|
||||
f.close()
|
||||
}
|
||||
Reference in New Issue
Block a user