Skip to content

Commit

Permalink
CI/patches: Optimize (#121)
Browse files Browse the repository at this point in the history
* patches: Optimize scripts

* Better compatibility and conditional judgment statements

* CI: Fix error in Make AnyKernel3

One divides into two
  • Loading branch information
bxySo authored Jan 7, 2024
1 parent bafc956 commit 9e3799e
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 36 deletions.
41 changes: 24 additions & 17 deletions .github/workflows/build-kernel.yml
Original file line number Diff line number Diff line change
Expand Up @@ -255,28 +255,35 @@ jobs:
fi
- name: Make Anykernel3
if: env.CHECK_FILE_IS_OK == 'true'
if: env.CHECK_FILE_IS_OK == 'true' && env.USE_CUSTOM_ANYKERNEL3 != 'true'
run: |
cd $GITHUB_WORKSPACE/kernel_workspace
if [ ${{ env.USE_CUSTOM_ANYKERNEL3 }} = true ]; then
if [[ ${{ env.CUSTOM_ANYKERNEL3_SOURCE }} =~ git ]]; then
if [[ ${{ env.CUSTOM_ANYKERNEL3_SOURCE }} == *'.tar.gz' ]]; then
wget -O AnyKernel3.tar.gz ${{ env.CUSTOM_ANYKERNEL3_SOURCE }}
mkdir AnyKernel3
tar -C AnyKernel3/ -zxvf AnyKernel3.tar.gz
else
git clone ${{ env.CUSTOM_ANYKERNEL3_SOURCE }} -b ${{ env.CUSTOM_ANYKERNEL3_BRANCH }} --depth=1 AnyKernel3
fi
else
wget -O AnyKernel3.zip ${{ env.CUSTOM_ANYKERNEL3_SOURCE }}
git clone https://github.com/osm0sis/AnyKernel3 --depth=1 AnyKernel3
sed -i 's/do.devicecheck=1/do.devicecheck=0/g' AnyKernel3/anykernel.sh
sed -i 's!block=/dev/block/platform/omap/omap_hsmmc.0/by-name/boot;!block=auto;!g' AnyKernel3/anykernel.sh
sed -i 's/is_slot_device=0;/is_slot_device=auto;/g' AnyKernel3/anykernel.sh
cp android-kernel/out/arch/${{ env.ARCH }}/boot/${{ env.KERNEL_IMAGE_NAME }} AnyKernel3/
if [ ${{ env.CHECK_DTBO_IS_OK }} = true ]; then
cp android-kernel/out/arch/${{ env.ARCH }}/boot/dtbo.img AnyKernel3/
fi
rm -rf AnyKernel3/.git* AnyKernel3/README.md
- name: Make Custom-Anykernel3
if: env.CHECK_FILE_IS_OK == 'true' && env.USE_CUSTOM_ANYKERNEL3 == 'true'
run: |
cd $GITHUB_WORKSPACE/kernel_workspace
if [[ ${{ env.CUSTOM_ANYKERNEL3_SOURCE }} =~ git ]]; then
if [[ ${{ env.CUSTOM_ANYKERNEL3_SOURCE }} == *'.tar.gz' ]]; then
wget -O AnyKernel3.tar.gz ${{ env.CUSTOM_ANYKERNEL3_SOURCE }}
mkdir AnyKernel3
unzip AnyKernel3.zip -d AnyKernel3/
tar -C AnyKernel3/ -zxvf AnyKernel3.tar.gz
else
git clone ${{ env.CUSTOM_ANYKERNEL3_SOURCE }} -b ${{ env.CUSTOM_ANYKERNEL3_BRANCH }} --depth=1 AnyKernel3
fi
else
git clone https://github.com/osm0sis/AnyKernel3 --depth=1 AnyKernel3
sed -i 's/do.devicecheck=1/do.devicecheck=0/g' AnyKernel3/anykernel.sh
sed -i 's!block=/dev/block/platform/omap/omap_hsmmc.0/by-name/boot;!block=auto;!g' AnyKernel3/anykernel.sh
sed -i 's/is_slot_device=0;/is_slot_device=auto;/g' AnyKernel3/anykernel.sh
wget -O AnyKernel3.zip ${{ env.CUSTOM_ANYKERNEL3_SOURCE }}
mkdir AnyKernel3
unzip AnyKernel3.zip -d AnyKernel3/
fi
cp android-kernel/out/arch/${{ env.ARCH }}/boot/${{ env.KERNEL_IMAGE_NAME }} AnyKernel3/
if [ ${{ env.CHECK_DTBO_IS_OK }} = true ]; then
Expand Down
37 changes: 18 additions & 19 deletions patches/patches.sh
Original file line number Diff line number Diff line change
@@ -1,51 +1,50 @@
# Patches author: weishu <[email protected]>
# Shell authon: xiaoleGun <[email protected]>
# 20240106
# 20240107

# fs/ changes
## exec.c
if [ -z "$(grep "/\* exec.c is ok" fs/exec.c)" ]; then
if [ -z "$(grep "ksu" fs/exec.c)" ]; then
sed -i '/static int do_execveat_common/i\extern bool ksu_execveat_hook __read_mostly;\nextern int ksu_handle_execveat(int *fd, struct filename **filename_ptr, void *argv,\n void *envp, int *flags);\nextern int ksu_handle_execveat_sucompat(int *fd, struct filename **filename_ptr,\n void *argv, void *envp, int *flags);' fs/exec.c
sed -i '/if (IS_ERR(filename))/i\ if (unlikely(ksu_execveat_hook))\n ksu_handle_execveat(&fd, &filename, &argv, &envp, &flags);\n else\n ksu_handle_execveat_sucompat(&fd, &filename, &argv, &envp, &flags);\n' fs/exec.c
echo "/* exec.c is ok" >> fs/exec.c
if grep -q "return __do_execve_file(fd, filename, argv, envp, flags, NULL);" fs/exec.c; then
sed -i '/return __do_execve_file(fd, filename, argv, envp, flags, NULL);/i\ if (unlikely(ksu_execveat_hook))\n ksu_handle_execveat(&fd, &filename, &argv, &envp, &flags);\n else\n ksu_handle_execveat_sucompat(&fd, &filename, &argv, &envp, &flags);' fs/exec.c
else
sed -i '/if (IS_ERR(filename))/i\ if (unlikely(ksu_execveat_hook))\n ksu_handle_execveat(&fd, &filename, &argv, &envp, &flags);\n else\n ksu_handle_execveat_sucompat(&fd, &filename, &argv, &envp, &flags);\n' fs/exec.c
fi
fi

## open.c
if [ -z "$(grep "/* open.c is ok" fs/open.c)" ]; then
if grep -q "SYSCALL_DEFINE3(faccessat, int, dfd, const char __user \*, filename, int, mode)" fs/open.c; then
sed -i '/SYSCALL_DEFINE3(faccessat, int, dfd, const char __user \*, filename, int, mode)/i\extern int ksu_handle_faccessat(int *dfd, const char __user **filename_user, int *mode,\n int *flags);' fs/open.c
sed -i '/if (mode & ~S_IRWXO)/i\\n ksu_handle_faccessat(&dfd, &filename, &mode, NULL);\n' fs/open.c
else
if [ -z "$(grep "ksu" fs/open.c)" ]; then
if grep -q "long do_faccessat(int dfd, const char __user \*filename, int mode)" fs/open.c; then
sed -i '/long do_faccessat(int dfd, const char __user \*filename, int mode)/i\extern int ksu_handle_faccessat(int *dfd, const char __user **filename_user, int *mode,\n int *flags);' fs/open.c
sed -i '/if (mode & ~S_IRWXO)/i\\n ksu_handle_faccessat(&dfd, &filename, &mode, NULL);\n' fs/open.c
else
sed -i '/SYSCALL_DEFINE3(faccessat, int, dfd, const char __user \*, filename, int, mode)/i\extern int ksu_handle_faccessat(int *dfd, const char __user **filename_user, int *mode,\n int *flags);' fs/open.c
fi
echo "/* open.c is ok" >> fs/open.c
sed -i '/if (mode & ~S_IRWXO)/i\ ksu_handle_faccessat(&dfd, &filename, &mode, NULL);\n' fs/open.c
fi

## read_write.c
if [ -z "$(grep "/* read_write.c is ok" fs/read_write.c)" ]; then
if [ -z "$(grep "ksu" fs/read_write.c)" ]; then
sed -i '/ssize_t vfs_read(struct file/i\extern bool ksu_vfs_read_hook __read_mostly;\nextern int ksu_handle_vfs_read(struct file **file_ptr, char __user **buf_ptr,\n size_t *count_ptr, loff_t **pos);' fs/read_write.c
sed -i '/if (unlikely(!access_ok(VERIFY_WRITE, buf, count)))/i\ if (unlikely(ksu_vfs_read_hook))\n ksu_handle_vfs_read(&file, &buf, &count, &pos);' fs/read_write.c
echo "/* read_write.c is ok" >> fs/read_write.c
fi

## stat.c
if [ -z "$(grep "/* stat.c is ok" fs/stat.c)" ]; then
if [ -z "$(grep "ksu" fs/stat.c)" ]; then
if grep -q "int vfs_statx(int dfd, const char __user \*filename, int flags," fs/stat.c; then
sed -i '/int vfs_statx(int dfd, const char __user \*filename, int flags,/i\extern int ksu_handle_stat(int *dfd, const char __user **filename_user, int *flags);' fs/stat.c
sed -i '/unsigned int lookup_flags = LOOKUP_FOLLOW | LOOKUP_AUTOMOUNT;/i\ ksu_handle_stat(&dfd, &filename, &flags);' fs/stat.c
sed -i '/unsigned int lookup_flags = LOOKUP_FOLLOW | LOOKUP_AUTOMOUNT;/a\\n ksu_handle_stat(&dfd, &filename, &flags);' fs/stat.c
else
sed -i '/int vfs_fstatat(int dfd, const char __user \*filename, struct kstat *stat,/i\extern int ksu_handle_stat(int *dfd, const char __user **filename_user, int *flags);' fs/stat.c
sed -i '/if ((flag & ~(AT_SYMLINK_NOFOLLOW | AT_NO_AUTOMOUNT |/i\ ksu_handle_stat(&dfd, &filename, &flag);\n' fs/stat.c
sed -i '/if ((flag & ~(AT_SYMLINK_NOFOLLOW | AT_NO_AUTOMOUNT |/i\\n ksu_handle_stat(&dfd, &filename, &flag);\n' fs/stat.c
fi
echo "/* stat.c is ok" >> fs/stat.c
fi

# drivers/input changes
if [ -z "$(grep "/* drivers/input is ok" drivers/input/input.c)" ]; then
## input.c
if [ -z "$(grep "ksu" drivers/input/input.c)" ]; then
sed -i '/static void input_handle_event/i\extern bool ksu_input_hook __read_mostly;\nextern int ksu_handle_input_handle_event(unsigned int *type, unsigned int *code, int *value);' drivers/input/input.c
sed -i '/if (disposition != INPUT_IGNORE_EVENT && type != EV_SYN)/i\ if (unlikely(ksu_input_hook))\n ksu_handle_input_handle_event(&type, &code, &value);' drivers/input/input.c
echo "/* drivers/input is ok" >> drivers/input/input.c
fi

echo "Patch kernel is ok"

0 comments on commit 9e3799e

Please sign in to comment.