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: plugin_audio.py
Close
from . import hotplug from .decorators import * import tuned.logs from tuned.utils.commands import commands import os import errno import struct import glob log = tuned.logs.get() cmd = commands() class AudioPlugin(hotplug.Plugin): """ `audio`:: Sets audio cards power saving options. The plug-in sets the auto suspend timeout for audio codecs to the value specified by the [option]`timeout` option. + Currently, the `snd_hda_intel` and `snd_ac97_codec` codecs are supported and the [option]`timeout` value is in seconds. To disable auto suspend for these codecs, set the [option]`timeout` value to `0`. To enforce the controller reset, set the option [option]`reset_controller` to `true`. Note that power management is supported per module. Hence, the kernel module names are used as device names. + .Set the timeout value to 10s and enforce the controller reset ==== ---- [audio] timeout=10 reset_controller=true ---- ==== """ def _init_devices(self): self._devices_supported = True self._assigned_devices = set() self._free_devices = set() for device in self._hardware_inventory.get_devices("sound").match_sys_name("card*"): module_name = self._device_module_name(device) if module_name in ["snd_hda_intel", "snd_ac97_codec"]: self._free_devices.add(module_name) def _instance_init(self, instance): instance._has_static_tuning = True instance._has_dynamic_tuning = False def _instance_cleanup(self, instance): pass def _device_module_name(self, device): try: return device.parent.driver except: return None @classmethod def _get_config_options(cls): return { "timeout": 0, "reset_controller": True, } def _timeout_path(self, device): return "/sys/module/%s/parameters/power_save" % device def _reset_controller_path(self, device): return "/sys/module/%s/parameters/power_save_controller" % device @command_set("timeout", per_device = True) def _set_timeout(self, value, device, sim, remove): try: timeout = int(value) except ValueError: log.error("timeout value '%s' is not integer" % value) return None if timeout >= 0: sys_file = self._timeout_path(device) if not sim: cmd.write_to_file(sys_file, "%d" % timeout, \ no_error = [errno.ENOENT] if remove else False) return timeout else: return None @command_get("timeout") def _get_timeout(self, device, ignore_missing=False): sys_file = self._timeout_path(device) value = cmd.read_file(sys_file, no_error=ignore_missing) if len(value) > 0: return value return None @command_set("reset_controller", per_device = True) def _set_reset_controller(self, value, device, sim, remove): v = cmd.get_bool(value) sys_file = self._reset_controller_path(device) if os.path.exists(sys_file): if not sim: cmd.write_to_file(sys_file, v, \ no_error = [errno.ENOENT] if remove else False) return v return None @command_get("reset_controller") def _get_reset_controller(self, device, ignore_missing=False): sys_file = self._reset_controller_path(device) if os.path.exists(sys_file): value = cmd.read_file(sys_file) if len(value) > 0: return cmd.get_bool(value) return None