sylware / nyanlinux (public) (License: AFFERO GPLv3) (since 2019-09-09) (hash sha1)
scripts for a lean, from scratch, amd hardware, linux distro

/builders/initramfs-busybox-0/builder.sh (b3017221ca9729dd31379e368449da91a6445df5) (2273 bytes) (mode 100644) (type blob)

# XXX
# first param is the kernel release
# second param is the path of the build of the linux kernel (for the cpio bin)
# third param is the mounted EFI xfat partition
# fourth param is an optional suffix to the linux kernel release
shift # remove pkg path
if test -z "$1"; then
	printf 'ERROR:missing linux kernel release\n'
	exit 1
else
	printf "INFO:linux kernel release is \"$1\"\n"
fi
if test -z "$2"; then
	printf 'ERROR:missing path of the linux kernel build\n'
	exit 1
else
	printf "INFO:path of the linux kernel build is \"$2\"\n"
fi
if test -z "$3"; then
	printf 'ERROR:missing efi mounted partition path\n'
	exit 1
else
	printf "INFO:efi mounted partition path is \"$3\"\n"
fi
if test -z "$4"; then
	printf "INFO:using suffix \"$4\" to generate the initramfs\n"
fi
pkg_dir=$pkgs_dir_root/$pkg_name
rm -Rf $pkg_dir
mkdir -p $pkgs_dir_root/$pkg_name
#-------------------------------------------------------------------------------
# AuthenticAMD.bin firmware building
printf 'concatening AMD cpu firmware -- START\n'
firmware_dir=$src_dir_root/linux-firmware/amd-ucode
if test ! -d $firmware_dir; then
	printf "ERROR:missing linux-firmware \"$firmware_dir\"\n"
	exit 1
fi
git_url0=git://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git

cat $(find $firmware_dir -name '*.bin' | sort) >$pkg_dir/AuthenticAMD.bin
printf 'concatening AMD cpu firmware -- END\n'
#-------------------------------------------------------------------------------
# cpio building
printf "cpio building for linux release $1 using $2/usr/gen_init_cpio -- START\n"
sed -r	-e "s:PKG_DIR:$pkg_dir:g" \
	-e "s:LINUX_RELEASE:$1:g" \
	-e "s:BUILDER_DIR:$nyan_root/builders/$pkg_name:g" \
	<$nyan_root/builders/$pkg_name/cpio.txt.in \
	>$pkg_dir/cpio.txt
$2/usr/gen_init_cpio $pkg_dir/cpio.txt >$pkg_dir/$1.cpio
gzip -9 -f -k $pkg_dir/$1.cpio
printf "cpio building for linux release $1 using $2/usr/gen_init_cpio -- END\n"
#-------------------------------------------------------------------------------
printf "installing initramfs cpio $1 in $3 -- START\n"
cp $pkg_dir/$1.cpio.gz $3/${1}${4}.cpio.gz
if test ! -e $3/$1.efi; then
	printf "WARNING:no linux kernel \"$1.efi\" found on the EFI partition\n"
fi
printf "installing initramfs cpio $1 in $3 -- END\n"

rm -Rf $pkg_dir


Mode Type Size Ref File
100644 blob 5 8eba6c8dd4dcaf6166bd22285ed34625f38a84ff .gitignore
100755 blob 1587 57fa4264b9ee0ae0a6f678f2527a05d3b22dda78 00-bootstrap-build.sh
100755 blob 848 a30f443bf405d56682efe3b4c5d3a19d5f7eb45d 01-re-bootstrap-build.sh
100644 blob 2142 f19c2d6b293244bb11a3f74ee77c10675cadc7d6 INSTALL
100644 blob 30 c9b735fa1332286f4b3f5f81fa10527fd7506b6e LICENSE
040000 tree - eaf4b05bbb5f027ac86b7eca6067c5a2cf9e4229 builders
100644 blob 1773 ef1551089a803bde37e36edc8d61bb819d06f793 conf.bootstrap.sh
100644 blob 479 8cc15efe46965ac7750fe304460f5a2b0aa4201c conf.sh
040000 tree - 4ac4da038dff9cda576f87f52bc784c0f470dc08 files
100755 blob 333 06859f922e41c1e691c72ada1be3f981ef05f602 pkg-build
100644 blob 22800641 e9e6291054c857401f6835c728f31541dae4311e steam.tar.bz2
100644 blob 173 2047af328b22f9d146585cd9e759edbc18122250 utils.sh
040000 tree - 5994cc1f3a2b92eaa849a3d6e9aee7897c12daea x64
040000 tree - b7a22de7f5cbd97650dd45412ef7d4246e395eb8 x86
Hints:
Before first commit, do not forget to setup your git environment:
git config --global user.name "your_name_here"
git config --global user.email "your@email_here"

Clone this repository using HTTP(S):
git clone https://rocketgit.com/user/sylware/nyanlinux

Clone this repository using ssh (do not forget to upload a key first):
git clone ssh://rocketgit@ssh.rocketgit.com/user/sylware/nyanlinux

Clone this repository using git:
git clone git://git.rocketgit.com/user/sylware/nyanlinux

You are allowed to anonymously push to this repository.
This means that your pushed commits will automatically be transformed into a merge request:
... clone the repository ...
... make some changes and some commits ...
git push origin main