Add checker for kernel module

This commit is contained in:
Vadim Vetrov 2024-09-28 20:23:31 +03:00
parent 98a3fd5acd
commit 6b21e9b3b3
No known key found for this signature in database
GPG Key ID: E8A308689D7A73A5
2 changed files with 99 additions and 67 deletions

View File

@ -77,95 +77,126 @@ jobs:
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
with: with:
name: static-youtubeUnblock-${{ matrix.arch }} name: static-youtubeUnblock-${{ matrix.arch }}
path: ./**/youtubeUnblock*.tar.gz path: ./**/static-youtubeUnblock*.tar.gz
build-kmod: build-kmod:
needs: prepare needs: prepare
name: build-kmod ${{ matrix.arch }} name: build-kmod ${{ matrix.kernel_version }}
runs-on: ubuntu-latest runs-on: ubuntu-latest
strategy: strategy:
matrix: matrix:
arch: [x86_64] include:
branch: [latest-stable] - kernel_version: "6.6.52"
steps: source: "https://cdn.kernel.org/pub/linux/kernel/v6.x/linux-6.6.52.tar.xz"
- name: Checkout container_version: "24.04"
uses: actions/checkout@v4
- name: Build - kernel_version: "5.15.167"
id: build source: "https://cdn.kernel.org/pub/linux/kernel/v5.x/linux-5.15.167.tar.xz"
env: container_version: "24.04"
ARCH: ${{ matrix.arch }}
VERSION: ${{ needs.prepare.outputs.version }}
SHA: ${{ needs.prepare.outputs.sha }}
shell: bash
run: |
make kmake
tar -czvf kmod-youtubeUnblock-$VERSION-$SHA-$PLATFORM-$(uname -r).tar.gz kyoutubeUnblock.ko
- name: Upload artifacts - kernel_version: "5.4.284"
if: steps.build.outcome == 'success' source: "https://cdn.kernel.org/pub/linux/kernel/v5.x/linux-5.4.284.tar.xz"
uses: actions/upload-artifact@v4 container_version: "24.04"
with:
name: kmod-youtubeUnblock-${{ matrix.arch }}
path: ./**/kmod-youtubeUnblock*.tar.gz
build-kmod-20.04: - kernel_version: "4.19.322"
needs: prepare source: "https://cdn.kernel.org/pub/linux/kernel/v4.x/linux-4.19.322.tar.xz"
name: build-kmod ${{ matrix.arch }} container_version: "24.04"
runs-on: ubuntu-latest
strategy:
matrix:
arch: [x86_64]
branch: [latest-stable]
steps:
- name: Checkout
uses: actions/checkout@v4
- name: prepare runner - kernel_version: "4.4.302"
shell: bash source: "https://cdn.kernel.org/pub/linux/kernel/v4.x/linux-4.4.302.tar.xz"
run: | container_version: "24.04"
apt install -y \
bridge-utils \
qemu-kvm \
libvirt-daemon-system \
libvirt-clients \
virtinst \
libguestfs-tools \
wait-for-it \
whois \
sshpass
- name: build virtual machine - kernel_version: "3.10.108"
shell: bash source: "https://cdn.kernel.org/pub/linux/kernel/v3.x/linux-3.10.108.tar.xz"
run: | container_version: "16.04"
virt-builder ubuntu-20.04 \
--network \
--format qcow2 -o "vm_ubuntu.qcow2" \
--update \
--install build-essential \
--run-command "useradd -p '' -s /bin/bash -m -G sudo ubuntu" \
--edit '/etc/sudoers:s/^%sudo.*/%sudo ALL=(ALL) NOPASSWD:ALL/' \
--edit '/etc/default/grub:s/^GRUB_CMDLINE_LINUX_DEFAULT=.*/GRUB_CMDLINE_LINUX_DEFAULT="console=tty0 console=ttyS0,115200n8"/' \
--run-command update-grub
- kernel_version: "3.0.101"
source: "https://cdn.kernel.org/pub/linux/kernel/v3.x/linux-3.0.101.tar.xz"
container_version: "14.04"
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Restore builder from cache
id: cache-restore
uses: actions/cache/restore@v4
with:
path: ~/builder.tar
key: builder-${{ matrix.kernel_version }}
- name: Build - name: Load builder from cache
if: steps.cache-restore.outputs.cache-hit == 'true'
run: |
docker import - builder < ~/builder.tar
- name: Prepare build env
if: steps.cache-restore.outputs.cache-hit != 'true'
run: |
mkdir ~/linux
pwd
ls /
ls ~
- name: Obtain kernel
if: steps.cache-restore.outputs.cache-hit != 'true'
run: |
cd ~/linux
wget ${{ matrix.source }} -O kernel.tar.xz -q
tar -xf kernel.tar.xz
rm -f kernel.tar.xz
/bin/bash -c "mv linux-* linux"
ls
ls linux
- name: Install docker
if: steps.cache-restore.outputs.cache-hit != 'true'
run: |
cd ~/linux
docker pull ubuntu:${{ matrix.container_version }}
docker container create --name ubu_builder -w / ubuntu:${{ matrix.container_version }} tail -f /dev/null
docker container start ubu_builder
docker container exec ubu_builder bash -c "apt update && apt install -y build-essential flex bc bison libelf-dev elfutils libssl-dev"
docker cp ./linux ubu_builder:/linux
- name: Build kernel
if: steps.cache-restore.outputs.cache-hit != 'true'
run: |
cd ~/linux
docker container exec -w /linux ubu_builder bash -c 'make defconfig'
docker container exec -w /linux ubu_builder bash -c 'make -j $(nproc)'
- name: Export container
if: steps.cache-restore.outputs.cache-hit != 'true'
run: |
cd ~/linux
docker container kill ubu_builder
docker container export ubu_builder > ubu_builder.tar
docker container rm ubu_builder
mv ./ubu_builder.tar ~/builder.tar
docker import - builder < ~/builder.tar
- name: Save kernel image to cache
if: steps.cache-restore.outputs.cache-hit != 'true'
id: cache-save
uses: actions/cache/save@v4
with:
path: ~/builder.tar
key: builder-${{ matrix.kernel_version }}
- name: Build kernel module
id: build id: build
env: env:
ARCH: ${{ matrix.arch }}
VERSION: ${{ needs.prepare.outputs.version }} VERSION: ${{ needs.prepare.outputs.version }}
SHA: ${{ needs.prepare.outputs.sha }} SHA: ${{ needs.prepare.outputs.sha }}
shell: bash shell: bash
run: | run: |
make kmake docker run --rm -v ./:/youtubeUnblock -w /youtubeUnblock builder make kmake KERNEL_BUILDER_MAKEDIR:=/linux
tar -czvf kmod-youtubeUnblock-$VERSION-$SHA-$PLATFORM-$(uname -r).tar.gz kyoutubeUnblock.ko tar -czvf kmod-youtubeUnblock-$VERSION-$SHA-linux-${{ matrix.kernel_version }}.tar.gz kyoutubeUnblock.ko
- name: Upload artifacts - name: Upload artifacts
if: steps.build.outcome == 'success' if: steps.build.outcome == 'success'
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
with: with:
name: kmod-youtubeUnblock-${{ matrix.arch }} name: kmod-youtubeUnblock-linux-${{ matrix.kernel_version }}
path: ./**/kmod-youtubeUnblock*.tar.gz path: ./**/kmod-youtubeUnblock*.tar.gz

5
tls.c
View File

@ -275,8 +275,9 @@ int gen_fake_sni(struct fake_type type,
if (type.type == FAKE_PAYLOAD_RANDOM && data_len == 0) { if (type.type == FAKE_PAYLOAD_RANDOM && data_len == 0) {
#ifdef KERNEL_SPACE #ifdef KERNEL_SPACE
// get_random_bytes(&data_len, sizeof(data_len)); get_random_bytes(&data_len, sizeof(data_len));
data_len = get_random_u32() % 1200; data_len = data_len % 1200;
// data_len = get_random_u32() % 1200;
#else #else
data_len = random() % 1200; data_len = random() % 1200;
#endif #endif