OXIESEC PANEL
- Current Dir:
/
/
lib
/
python3.9
/
site-packages
/
tuned
/
plugins
Server IP: 2a02:4780:11:1594:0:ef5:22d7:a
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
02/13/2025 09:25:13 PM
rwxr-xr-x
📄
__init__.py
49 bytes
08/07/2024 08:09:40 PM
rw-r--r--
📁
__pycache__
-
02/13/2025 09:25:13 PM
rwxr-xr-x
📄
base.py
22.56 KB
12/02/2024 09:49:28 AM
rw-r--r--
📄
decorators.py
983 bytes
08/07/2024 08:09:40 PM
rw-r--r--
📄
exceptions.py
99 bytes
08/07/2024 08:09:40 PM
rw-r--r--
📄
hotplug.py
3.84 KB
08/07/2024 08:09:40 PM
rw-r--r--
📁
instance
-
02/13/2025 09:25:13 PM
rwxr-xr-x
📄
plugin_acpi.py
2.39 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_audio.py
3.13 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_bootloader.py
25.33 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_cpu.py
29.42 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_disk.py
16.69 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_eeepc_she.py
3.02 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_irq.py
9.74 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_irqbalance.py
3.56 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_modules.py
4.82 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_mounts.py
5.45 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_net.py
22.77 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_rtentsk.py
1.08 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_scheduler.py
54.72 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_script.py
3.94 KB
12/02/2024 09:49:28 AM
rw-r--r--
📄
plugin_scsi_host.py
3.08 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_selinux.py
2.27 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_service.py
10.47 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_sysctl.py
6.03 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_sysfs.py
2.65 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_systemd.py
5.3 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_uncore.py
5.88 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_usb.py
1.97 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_video.py
5.93 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
plugin_vm.py
3.49 KB
08/07/2024 08:09:40 PM
rw-r--r--
📄
repository.py
1.49 KB
08/07/2024 08:09:40 PM
rw-r--r--
Editing: hotplug.py
Close
from . import base import tuned.consts as consts import tuned.logs log = tuned.logs.get() class Plugin(base.Plugin): """ Base class for plugins with device hotpluging support. """ def __init__(self, *args, **kwargs): super(Plugin, self).__init__(*args, **kwargs) def cleanup(self): super(Plugin, self).cleanup() self._hardware_events_cleanup() def _hardware_events_init(self): pass def _hardware_events_cleanup(self): pass def _init_devices(self): self._hardware_events_init() def _hardware_events_callback(self, event, device): if event == "add": log.info("device '%s' added" % device.sys_name) self._add_device(device.sys_name) elif event == "remove": log.info("device '%s' removed" % device.sys_name) self._remove_device(device.sys_name) def _add_device_process(self, instance, device_name): log.info("instance %s: adding new device %s" % (instance.name, device_name)) self._assigned_devices.add(device_name) self._call_device_script(instance, instance.script_pre, "apply", [device_name]) self._added_device_apply_tuning(instance, device_name) self._call_device_script(instance, instance.script_post, "apply", [device_name]) instance.processed_devices.add(device_name) def _add_device(self, device_name): if device_name in (self._assigned_devices | self._free_devices): return for instance_name, instance in list(self._instances.items()): if len(self._get_matching_devices(instance, [device_name])) == 1: self._add_device_process(instance, device_name) break else: log.debug("no instance wants %s" % device_name) self._free_devices.add(device_name) def _add_devices_nocheck(self, instance, device_names): """ Add devices specified by the set to the instance, no check is performed. """ for dev in device_names: self._add_device_process(instance, dev) # This can be a bit racy (we can overcount), # but it shouldn't affect the boolean result instance.active = len(instance.processed_devices) \ + len(instance.assigned_devices) > 0 def _remove_device_process(self, instance, device_name): if device_name in instance.processed_devices: self._call_device_script(instance, instance.script_post, "unapply", [device_name]) self._removed_device_unapply_tuning(instance, device_name) self._call_device_script(instance, instance.script_pre, "unapply", [device_name]) instance.processed_devices.remove(device_name) # This can be a bit racy (we can overcount), # but it shouldn't affect the boolean result instance.active = len(instance.processed_devices) \ + len(instance.assigned_devices) > 0 self._assigned_devices.remove(device_name) return True return False def _remove_device(self, device_name): """Remove device from the instance Parameters: device_name -- name of the device """ if device_name not in (self._assigned_devices | self._free_devices): return for instance in list(self._instances.values()): if self._remove_device_process(instance, device_name): break else: self._free_devices.remove(device_name) def _remove_devices_nocheck(self, instance, device_names): """ Remove devices specified by the set from the instance, no check is performed. """ for dev in device_names: self._remove_device_process(instance, dev) def _added_device_apply_tuning(self, instance, device_name): self._execute_all_device_commands(instance, [device_name]) if instance.has_dynamic_tuning and self._global_cfg.get(consts.CFG_DYNAMIC_TUNING, consts.CFG_DEF_DYNAMIC_TUNING): self._instance_apply_dynamic(instance, device_name) def _removed_device_unapply_tuning(self, instance, device_name): if instance.has_dynamic_tuning and self._global_cfg.get(consts.CFG_DYNAMIC_TUNING, consts.CFG_DEF_DYNAMIC_TUNING): self._instance_unapply_dynamic(instance, device_name) self._cleanup_all_device_commands(instance, [device_name], remove = True)