__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
/*
* eset_rtp (ESET Real-time file system protection module)
* Copyright (C) 1992-2025 ESET, spol. s r.o.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*
* In case of any questions, you can contact us at ESET, spol. s r.o., Einsteinova 24, 851 01 Bratislava, Slovakia.
*/
#include "ertp_excludes.h"
#include <linux/rwsem.h>
#include <linux/slab.h>
#include <linux/version.h>
#include "ertp_logs.h"
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 8, 0)
#include <linux/mmap_lock.h>
#endif
struct ertp_excludes_path {
struct ertp_excludes_path *next;
char *path_name;
size_t path_len;
};
struct ertp_excludes_container {
struct ertp_excludes_path *list;
struct rw_semaphore lock;
};
static struct ertp_excludes_container ertp_excludes_proc_default;
static struct ertp_excludes_container ertp_excludes_proc_user;
static struct ertp_excludes_container ertp_excludes_file_default;
static struct ertp_excludes_container ertp_excludes_file_user;
static struct ertp_excludes_path *ertp_excludes_path_alloc(char *path_name) {
struct ertp_excludes_path *path;
if (path_name == NULL || path_name[0] == '\0') return ERR_PTR(-EINVAL);
path = kzalloc(sizeof(struct ertp_excludes_path), GFP_KERNEL);
if (!path) return ERR_PTR(-ENOMEM);
path->next = NULL;
path->path_name = path_name;
path->path_len = strlen(path_name);
return path;
}
static void ertp_excludes_path_free(struct ertp_excludes_path *path) {
if (!path || IS_ERR(path)) return;
while (path) {
struct ertp_excludes_path *next = path->next;
if (path->path_name) kfree(path->path_name);
kfree(path);
path = next;
}
}
static void ertp_excludes_container_init(
struct ertp_excludes_container *excludes) {
excludes->list = NULL;
init_rwsem(&excludes->lock);
}
static void ertp_excludes_container_deinit(
struct ertp_excludes_container *excludes) {
down_write(&excludes->lock);
ertp_excludes_path_free(excludes->list);
excludes->list = NULL;
up_write(&excludes->lock);
}
void ertp_excludes_init(void) {
ertp_excludes_container_init(&ertp_excludes_proc_default);
ertp_excludes_container_init(&ertp_excludes_proc_user);
ertp_excludes_container_init(&ertp_excludes_file_default);
ertp_excludes_container_init(&ertp_excludes_file_user);
}
void ertp_excludes_deinit(void) {
ertp_excludes_container_deinit(&ertp_excludes_proc_default);
ertp_excludes_container_deinit(&ertp_excludes_proc_user);
ertp_excludes_container_deinit(&ertp_excludes_file_default);
ertp_excludes_container_deinit(&ertp_excludes_file_user);
}
#ifdef ERTP_DEBUG
static void print_list_items(const struct ertp_excludes_path *excl_list) {
const struct ertp_excludes_path *path = excl_list;
while (path) {
ertp_pr_trace(ERTP_LOG_EXCLUSIONS, "%s", path->path_name);
path = path->next;
}
}
#endif
static void ertp_excludes_swap(struct ertp_excludes_path **old_list,
struct ertp_excludes_path **new_list) {
struct ertp_excludes_path *tmp = *old_list;
#ifdef ERTP_DEBUG
ertp_pr_trace(ERTP_LOG_EXCLUSIONS, "excluded paths (old):");
print_list_items(*old_list);
#endif
*old_list = *new_list;
*new_list = tmp;
#ifdef ERTP_DEBUG
ertp_pr_trace(ERTP_LOG_EXCLUSIONS, "excluded paths (new):");
print_list_items(*old_list);
#endif
}
static int ertp_excl_add_paths(char **buf, uint32_t size,
struct ertp_excludes_container *excludes) {
int err = 0;
int i;
struct ertp_excludes_path *tmp_list_head = NULL;
for (i = 0; i < size; ++i) {
struct ertp_excludes_path *item = ertp_excludes_path_alloc(buf[i]);
if (IS_ERR(item)) {
err = PTR_ERR(item);
goto end;
}
buf[i] = NULL;
item->next = tmp_list_head;
tmp_list_head = item;
ertp_pr_edlog("path excluded: \"%s\" ", item->path_name);
}
down_write(&excludes->lock);
ertp_excludes_swap(&excludes->list, &tmp_list_head);
up_write(&excludes->lock);
end:
ertp_excludes_path_free(tmp_list_head);
return err;
}
int ertp_proc_default_excludes_add(char **paths, uint32_t size) {
return ertp_excl_add_paths(paths, size, &ertp_excludes_proc_default);
}
int ertp_proc_user_excludes_add(char **paths, uint32_t size) {
return ertp_excl_add_paths(paths, size, &ertp_excludes_proc_user);
}
int ertp_file_default_excludes_add(char **paths, uint32_t size) {
return ertp_excl_add_paths(paths, size, &ertp_excludes_file_default);
}
int ertp_file_user_excludes_add(char **paths, uint32_t size) {
return ertp_excl_add_paths(paths, size, &ertp_excludes_file_user);
}
static bool ertp_path_excluded(const char *path_name,
struct ertp_excludes_container *excludes) {
const struct ertp_excludes_path *item;
bool found = false;
down_read(&excludes->lock);
item = excludes->list;
while (item) {
if (item->path_len) {
BUG_ON(item->path_name == NULL);
if (item->path_name[item->path_len - 1] == '/') {
if (!strncmp(item->path_name, path_name, item->path_len)) {
found = true;
break;
}
} else if (!strcmp(item->path_name, path_name)) {
found = true;
break;
}
}
item = item->next;
}
up_read(&excludes->lock);
return found;
}
bool ertp_proc_excluded_by_default(const char *process_path) {
BUG_ON(!process_path);
return ertp_path_excluded(process_path, &ertp_excludes_proc_default);
}
bool ertp_proc_excluded(const char *process_path) {
BUG_ON(!process_path);
return ertp_proc_excluded_by_default(process_path) ||
ertp_path_excluded(process_path, &ertp_excludes_proc_user);
}
bool ertp_file_excluded_by_default(const char *file_path) {
BUG_ON(!file_path);
return ertp_path_excluded(file_path, &ertp_excludes_file_default);
}
bool ertp_file_excluded(const char *file_path) {
BUG_ON(!file_path);
return ertp_file_excluded_by_default(file_path) ||
ertp_path_excluded(file_path, &ertp_excludes_file_user);
}
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| .ertp_array.o.cmd | File | 67.01 KB | 0644 |
|
| .ertp_cache.o.cmd | File | 62.05 KB | 0644 |
|
| .ertp_cache_container.o.cmd | File | 51.03 KB | 0644 |
|
| .ertp_debug.o.cmd | File | 61.29 KB | 0644 |
|
| .ertp_dev.o.cmd | File | 70.46 KB | 0644 |
|
| .ertp_event.o.cmd | File | 62.23 KB | 0644 |
|
| .ertp_event_check.o.cmd | File | 62.68 KB | 0644 |
|
| .ertp_excludes.o.cmd | File | 50.98 KB | 0644 |
|
| .ertp_ftrace_hook.o.cmd | File | 88.2 KB | 0644 |
|
| .ertp_ftrace_utils.o.cmd | File | 75.37 KB | 0644 |
|
| .ertp_handlers.o.cmd | File | 88.06 KB | 0644 |
|
| .ertp_handlers_close.o.cmd | File | 88.18 KB | 0644 |
|
| .ertp_handlers_execve.o.cmd | File | 88.54 KB | 0644 |
|
| .ertp_handlers_exit.o.cmd | File | 88.51 KB | 0644 |
|
| .ertp_handlers_mmap.o.cmd | File | 88.69 KB | 0644 |
|
| .ertp_handlers_module.o.cmd | File | 88.39 KB | 0644 |
|
| .ertp_handlers_open.o.cmd | File | 88.58 KB | 0644 |
|
| .ertp_handlers_rename.o.cmd | File | 88.54 KB | 0644 |
|
| .ertp_handlers_unlink.o.cmd | File | 88.54 KB | 0644 |
|
| .ertp_heap.o.cmd | File | 67 KB | 0644 |
|
| .ertp_logs.o.cmd | File | 15.1 KB | 0644 |
|
| .ertp_memory_dev.o.cmd | File | 70.16 KB | 0644 |
|
| .ertp_mod.o.cmd | File | 88.99 KB | 0644 |
|
| .ertp_path.o.cmd | File | 65.63 KB | 0644 |
|
| .ertp_qos.o.cmd | File | 67.84 KB | 0644 |
|
| .ertp_qos_event_data.o.cmd | File | 61.74 KB | 0644 |
|
| .ertp_qos_queue.o.cmd | File | 61.73 KB | 0644 |
|
| .ertp_stats.o.cmd | File | 61.66 KB | 0644 |
|
| .ertp_sysfs.o.cmd | File | 68.08 KB | 0644 |
|
| .eset_rtp.ko.cmd | File | 256 B | 0644 |
|
| .eset_rtp.mod.cmd | File | 612 B | 0644 |
|
| .eset_rtp.mod.o.cmd | File | 67.08 KB | 0644 |
|
| .eset_rtp.o.cmd | File | 139 B | 0644 |
|
| .modules.order.cmd | File | 95 B | 0644 |
|
| Makefile | File | 1.44 KB | 0644 |
|
| ertp.h | File | 2.24 KB | 0644 |
|
| ertp_array.c | File | 4.44 KB | 0644 |
|
| ertp_array.h | File | 2.02 KB | 0644 |
|
| ertp_array.o | File | 37.93 KB | 0644 |
|
| ertp_cache.c | File | 6.42 KB | 0644 |
|
| ertp_cache.h | File | 1.51 KB | 0644 |
|
| ertp_cache.o | File | 152.7 KB | 0644 |
|
| ertp_cache_container.c | File | 4.91 KB | 0644 |
|
| ertp_cache_container.h | File | 1.84 KB | 0644 |
|
| ertp_cache_container.o | File | 38.19 KB | 0644 |
|
| ertp_debug.c | File | 1.32 KB | 0644 |
|
| ertp_debug.h | File | 1.25 KB | 0644 |
|
| ertp_debug.o | File | 14.66 KB | 0644 |
|
| ertp_dev.c | File | 13.64 KB | 0644 |
|
| ertp_dev.o | File | 245.34 KB | 0644 |
|
| ertp_event.c | File | 20.85 KB | 0644 |
|
| ertp_event.h | File | 4.98 KB | 0644 |
|
| ertp_event.o | File | 258.2 KB | 0644 |
|
| ertp_event_check.c | File | 8.15 KB | 0644 |
|
| ertp_event_check.h | File | 1.92 KB | 0644 |
|
| ertp_event_check.o | File | 157.53 KB | 0644 |
|
| ertp_excludes.c | File | 6.42 KB | 0644 |
|
| ertp_excludes.h | File | 1.48 KB | 0644 |
|
| ertp_excludes.o | File | 56.93 KB | 0644 |
|
| ertp_ftrace_hook.c | File | 4.54 KB | 0644 |
|
| ertp_ftrace_hook.h | File | 1.37 KB | 0644 |
|
| ertp_ftrace_hook.o | File | 50.73 KB | 0644 |
|
| ertp_ftrace_utils.c | File | 1.7 KB | 0644 |
|
| ertp_ftrace_utils.h | File | 1.63 KB | 0644 |
|
| ertp_ftrace_utils.o | File | 17.97 KB | 0644 |
|
| ertp_handlers.c | File | 7.86 KB | 0644 |
|
| ertp_handlers.h | File | 1.21 KB | 0644 |
|
| ertp_handlers.o | File | 44.59 KB | 0644 |
|
| ertp_handlers_close.c | File | 3.08 KB | 0644 |
|
| ertp_handlers_close.h | File | 1.72 KB | 0644 |
|
| ertp_handlers_close.o | File | 292.04 KB | 0644 |
|
| ertp_handlers_execve.c | File | 4.37 KB | 0644 |
|
| ertp_handlers_execve.h | File | 1.75 KB | 0644 |
|
| ertp_handlers_execve.o | File | 299.2 KB | 0644 |
|
| ertp_handlers_exit.c | File | 1.97 KB | 0644 |
|
| ertp_handlers_exit.h | File | 1.49 KB | 0644 |
|
| ertp_handlers_exit.o | File | 284.45 KB | 0644 |
|
| ertp_handlers_mmap.c | File | 1.92 KB | 0644 |
|
| ertp_handlers_mmap.h | File | 1.11 KB | 0644 |
|
| ertp_handlers_mmap.o | File | 280.8 KB | 0644 |
|
| ertp_handlers_module.c | File | 4.2 KB | 0644 |
|
| ertp_handlers_module.h | File | 1.53 KB | 0644 |
|
| ertp_handlers_module.o | File | 295.03 KB | 0644 |
|
| ertp_handlers_open.c | File | 3.77 KB | 0644 |
|
| ertp_handlers_open.h | File | 1.72 KB | 0644 |
|
| ertp_handlers_open.o | File | 291.44 KB | 0644 |
|
| ertp_handlers_rename.c | File | 5.14 KB | 0644 |
|
| ertp_handlers_rename.h | File | 1.75 KB | 0644 |
|
| ertp_handlers_rename.o | File | 292.21 KB | 0644 |
|
| ertp_handlers_unlink.c | File | 3.47 KB | 0644 |
|
| ertp_handlers_unlink.h | File | 1.49 KB | 0644 |
|
| ertp_handlers_unlink.o | File | 287.87 KB | 0644 |
|
| ertp_heap.c | File | 9.87 KB | 0644 |
|
| ertp_heap.h | File | 2.04 KB | 0644 |
|
| ertp_heap.o | File | 30 KB | 0644 |
|
| ertp_logs.c | File | 1.14 KB | 0644 |
|
| ertp_logs.h | File | 2.59 KB | 0644 |
|
| ertp_logs.o | File | 10.13 KB | 0644 |
|
| ertp_memory_dev.c | File | 8.34 KB | 0644 |
|
| ertp_memory_dev.h | File | 1.33 KB | 0644 |
|
| ertp_memory_dev.o | File | 224.05 KB | 0644 |
|
| ertp_mod.c | File | 3.18 KB | 0644 |
|
| ertp_mod.o | File | 28.85 KB | 0644 |
|
| ertp_path.c | File | 4.38 KB | 0644 |
|
| ertp_path.h | File | 1.31 KB | 0644 |
|
| ertp_path.o | File | 185.7 KB | 0644 |
|
| ertp_qos.c | File | 17.06 KB | 0644 |
|
| ertp_qos.h | File | 2.18 KB | 0644 |
|
| ertp_qos.o | File | 254.39 KB | 0644 |
|
| ertp_qos_event_data.c | File | 2.41 KB | 0644 |
|
| ertp_qos_event_data.h | File | 1.61 KB | 0644 |
|
| ertp_qos_event_data.o | File | 129.95 KB | 0644 |
|
| ertp_qos_queue.c | File | 4.32 KB | 0644 |
|
| ertp_qos_queue.h | File | 1.98 KB | 0644 |
|
| ertp_qos_queue.o | File | 34.61 KB | 0644 |
|
| ertp_stats.c | File | 8.53 KB | 0644 |
|
| ertp_stats.h | File | 1.53 KB | 0644 |
|
| ertp_stats.o | File | 46.95 KB | 0644 |
|
| ertp_sysfs.c | File | 5.51 KB | 0644 |
|
| ertp_sysfs.o | File | 185.59 KB | 0644 |
|
| ertp_types.h | File | 1.15 KB | 0644 |
|
| eset_rtp.h | File | 4.2 KB | 0644 |
|
| eset_rtp.ko | File | 4.46 MB | 0644 |
|
| eset_rtp.mod | File | 755 B | 0644 |
|
| eset_rtp.mod.c | File | 8.4 KB | 0644 |
|
| eset_rtp.mod.o | File | 159.15 KB | 0644 |
|
| eset_rtp.o | File | 4.29 MB | 0644 |
|
| eset_rtp_sysfs.h | File | 1.26 KB | 0644 |
|
| modules.order | File | 20 B | 0644 |
|