rel 1.0.0
This commit is contained in:
parent
0553608cc7
commit
d12fa88c40
3
.gitignore
vendored
3
.gitignore
vendored
@ -1,4 +1,5 @@
|
||||
grunt.bin.old
|
||||
*.bin*
|
||||
build/
|
||||
|
||||
# Prerequisites
|
||||
*.d
|
||||
|
@ -1,11 +1,16 @@
|
||||
#!/bin/sh
|
||||
|
||||
VERSION="1.0.0"
|
||||
|
||||
printf "\033]input:on\a"
|
||||
printf "\033[?25h"
|
||||
|
||||
bash /installbins
|
||||
rm -rf /init
|
||||
|
||||
clear
|
||||
echo "PicoShim PoC without frecon restart"
|
||||
echo "shell is pid 1, exit = kern panic"
|
||||
echo "PicoShim $VERSION"
|
||||
echo "this shell is PID 1 - exiting will crash your chromebook"
|
||||
|
||||
tty=/dev/pts/0
|
||||
setsid bash -c "exec script -afqc 'while :; do /bin/bash || :; done' /dev/null <${tty} >>${tty} 2>&1"
|
||||
|
40
builder/buildables/vboot_reference/build.sh
Normal file
40
builder/buildables/vboot_reference/build.sh
Normal file
@ -0,0 +1,40 @@
|
||||
#!/bin/bash
|
||||
SCRIPT_DIR=$(realpath "$(dirname "$0")")
|
||||
REPO_DIR="vboot_reference"
|
||||
BRANCH="release-R133-16151.B"
|
||||
|
||||
echo "This script was made to work with Ubuntu 22.04."
|
||||
echo "By pressing ENTER, you acknowledge this"
|
||||
echo "By pressing CTRL-C, you will deny this"
|
||||
read -r
|
||||
|
||||
sudo apt install -y git wget libuuid1
|
||||
|
||||
if [[ ! -d "$SCRIPT_DIR/$REPO_DIR" ]]; then
|
||||
git clone https://chromium.googlesource.com/chromiumos/platform/vboot_reference -b "$BRANCH" "$SCRIPT_DIR/$REPO_DIR"
|
||||
else
|
||||
echo "Repository already exists. Skipping clone."
|
||||
fi
|
||||
|
||||
|
||||
cd "$SCRIPT_DIR/$REPO_DIR" || exit 1
|
||||
git apply ../vboot_reference.patch
|
||||
CFLAGS="-fPIC" CXXFLAGS="-fPIC" make STATIC=1 TPM2_MODE=1 USE_FLASHROM=0
|
||||
|
||||
echo "Would you like to clean up the directory?"
|
||||
read -rep "[Y/n] " cleanupChoice
|
||||
|
||||
if [[ "$cleanupChoice" == "y" || "$cleanupChoice" == "Y" || "$cleanupChoice" == "" ]]; then
|
||||
if [[ -d "$SCRIPT_DIR/build" ]]; then
|
||||
rm -rf "$SCRIPT_DIR/build"
|
||||
fi
|
||||
if [[ -d "$SCRIPT_DIR/$REPO_DIR/build" ]]; then
|
||||
mv "$SCRIPT_DIR/$REPO_DIR/build" "$SCRIPT_DIR"
|
||||
fi
|
||||
|
||||
find "$SCRIPT_DIR/build" -name '*.o*' -type f -delete
|
||||
find "$SCRIPT_DIR/build" -type d -empty -delete
|
||||
rm -rf "$SCRIPT_DIR/$REPO_DIR"
|
||||
echo "Cleaned! Final build files are at $SCRIPT_DIR/build"
|
||||
fi
|
||||
|
12
builder/buildables/vboot_reference/vboot_reference.patch
Normal file
12
builder/buildables/vboot_reference/vboot_reference.patch
Normal file
@ -0,0 +1,12 @@
|
||||
diff --git a/Makefile b/Makefile
|
||||
index ff3f88d1..94b1cee3 100644
|
||||
--- a/Makefile
|
||||
+++ b/Makefile
|
||||
@@ -533,7 +533,6 @@ ALL_OBJS += ${UTILLIB_OBJS}
|
||||
|
||||
# Externally exported library for some target userspace apps to link with
|
||||
# (cryptohome, updater, etc.)
|
||||
-HOSTLIB = ${BUILD}/libvboot_host.so
|
||||
HOSTLIB_STATIC = ${BUILD}/libvboot_host.a
|
||||
|
||||
# For testing purposes files contianing some libvboot_host symbols.
|
@ -93,7 +93,7 @@ extract_initramfs_full() {
|
||||
copy_kernel $shim_path $kernel_dir
|
||||
|
||||
echo "extracting initramfs from kernel (this may take a while)"
|
||||
if [ "$arch" = "arm64" ]; then
|
||||
if [ "$arch" = "aarch64" ]; then
|
||||
extract_initramfs_arm $kernel_dir/kernel.bin $kernel_dir $rootfs_dir
|
||||
else
|
||||
extract_initramfs $kernel_dir/kernel.bin $kernel_dir $rootfs_dir
|
||||
|
@ -45,13 +45,17 @@ state_size="1"
|
||||
rm -rf /tmp/kernel*
|
||||
losetup -D
|
||||
|
||||
rm -rf $initramfs # cleanup previous instances of picoshim, if they existed.
|
||||
# cleanup previous instances of picoshim, if they existed
|
||||
umount -R $initramfs > /dev/null 2>&1
|
||||
rm -rf $initramfs
|
||||
mkdir -p $initramfs
|
||||
|
||||
rm -rf $rootfs_mnt # cleanup previous instances of picoshim, if they existed.
|
||||
umount -R $rootfs_mnt > /dev/null 2>&1
|
||||
rm -rf $rootfs_mnt
|
||||
mkdir -p $rootfs_mnt
|
||||
|
||||
rm -rf $state_mnt # cleanup previous instances of picoshim, if they existed.
|
||||
umount -R $state_mnt > /dev/null 2>&1
|
||||
rm -rf $state_mnt
|
||||
mkdir -p $state_mnt
|
||||
|
||||
rm -rf /tmp/loop0
|
||||
@ -116,16 +120,26 @@ echo "bootstrapping rootfs..."
|
||||
noarchfolders=$(ls "${SCRIPT_DIR}/bootstrap/noarch/")
|
||||
for folder in $noarchfolders; do
|
||||
cp -r "${SCRIPT_DIR}/bootstrap/noarch/${folder}" "$rootfs_mnt"
|
||||
files=$(find "${SCRIPT_DIR}/bootstrap/noarch/${folder}" -type f)
|
||||
for file in $files; do
|
||||
chmod +x $file
|
||||
done
|
||||
done
|
||||
|
||||
archfolders=$(ls "${SCRIPT_DIR}/bootstrap/$arch/")
|
||||
for folder in $archfolders; do
|
||||
cp -r "${SCRIPT_DIR}/bootstrap/${arch}/${folder}" "$rootfs_mnt"
|
||||
files=$(find "${SCRIPT_DIR}/bootstrap/${arch}/${folder}" -type f)
|
||||
for file in $files; do
|
||||
chmod +x $file
|
||||
done
|
||||
done
|
||||
|
||||
printf "#!/bin/busybox sh \n /bin/busybox --install /bin" > "$rootfs_mnt"/installbins
|
||||
chmod +x "$rootfs_mnt"/installbins
|
||||
chroot "$rootfs_mnt" "/installbins"
|
||||
|
||||
# we do this inside the init script now
|
||||
# chroot "$rootfs_mnt" "/installbins"
|
||||
|
||||
create_stateful "$loopdev"
|
||||
mount "$loopdev"p1 "$state_mnt"
|
||||
|
Loading…
x
Reference in New Issue
Block a user