404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@18.217.141.236: ~ $
from . import base
import glob
import re
import os.path
from .decorators import *
import tuned.logs
import tuned.consts as consts
from subprocess import *
from tuned.utils.commands import commands

log = tuned.logs.get()

class SysfsPlugin(base.Plugin):
	"""
	`sysfs`::
	
	Sets various `sysfs` settings specified by the plug-in options.
	+
	The syntax is `_name_=_value_`, where
	`_name_` is the `sysfs` path to use and `_value_` is
	the value to write. The `sysfs` path supports the shell-style
	wildcard characters (see `man 7 glob` for additional detail).
	+
	Use this plugin in case you need to change some settings that are
	not covered by other plug-ins. Prefer specific plug-ins if they
	cover the required settings.
	+
	.Ignore corrected errors and associated scans that cause latency spikes
	====
	----
	[sysfs]
	/sys/devices/system/machinecheck/machinecheck*/ignore_ce=1
	----
	====
	"""

	# TODO: resolve possible conflicts with sysctl settings from other plugins

	def __init__(self, *args, **kwargs):
		super(SysfsPlugin, self).__init__(*args, **kwargs)
		self._has_dynamic_options = True
		self._cmd = commands()

	def _instance_init(self, instance):
		instance._has_dynamic_tuning = False
		instance._has_static_tuning = True

		instance._sysfs = dict([(os.path.normpath(key_value[0]), key_value[1]) for key_value in list(instance.options.items())])
		instance._sysfs_original = {}

	def _instance_cleanup(self, instance):
		pass

	def _instance_apply_static(self, instance):
		for key, value in list(instance._sysfs.items()):
			v = self._variables.expand(value)
			for f in glob.iglob(key):
				if self._check_sysfs(f):
					instance._sysfs_original[f] = self._read_sysfs(f)
					self._write_sysfs(f, v)
				else:
					log.error("rejecting write to '%s' (not inside /sys)" % f)

	def _instance_verify_static(self, instance, ignore_missing, devices):
		ret = True
		for key, value in list(instance._sysfs.items()):
			v = self._variables.expand(value)
			for f in glob.iglob(key):
				if self._check_sysfs(f):
					curr_val = self._read_sysfs(f)
					if self._verify_value(f, v, curr_val, ignore_missing) == False:
						ret = False
		return ret

	def _instance_unapply_static(self, instance, rollback = consts.ROLLBACK_SOFT):
		for key, value in list(instance._sysfs_original.items()):
			self._write_sysfs(key, value)

	def _check_sysfs(self, sysfs_file):
		return re.match(r"^/sys/.*", sysfs_file)

	def _read_sysfs(self, sysfs_file):
		data = self._cmd.read_file(sysfs_file).strip()
		if len(data) > 0:
			return self._cmd.get_active_option(data, False)
		else:
			return None

	def _write_sysfs(self, sysfs_file, value):
		return self._cmd.write_to_file(sysfs_file, value)

Filemanager

Name Type Size Permission Actions
__pycache__ Folder 0755
instance Folder 0755
__init__.py File 49 B 0644
base.py File 21.89 KB 0644
decorators.py File 983 B 0644
exceptions.py File 99 B 0644
hotplug.py File 3.84 KB 0644
plugin_acpi.py File 2.39 KB 0644
plugin_audio.py File 3.13 KB 0644
plugin_bootloader.py File 25.31 KB 0644
plugin_cpu.py File 27.56 KB 0644
plugin_disk.py File 16.46 KB 0644
plugin_eeepc_she.py File 2.88 KB 0644
plugin_irqbalance.py File 3.47 KB 0644
plugin_modules.py File 4.81 KB 0644
plugin_mounts.py File 5.45 KB 0644
plugin_net.py File 22.71 KB 0644
plugin_rtentsk.py File 1.08 KB 0644
plugin_scheduler.py File 54.94 KB 0644
plugin_script.py File 3.76 KB 0644
plugin_scsi_host.py File 3.08 KB 0644
plugin_selinux.py File 2.27 KB 0644
plugin_service.py File 10.47 KB 0644
plugin_sysctl.py File 6.74 KB 0644
plugin_sysfs.py File 2.63 KB 0644
plugin_systemd.py File 5.3 KB 0644
plugin_uncore.py File 4.61 KB 0644
plugin_usb.py File 1.97 KB 0644
plugin_video.py File 3.72 KB 0644
plugin_vm.py File 3.48 KB 0644
repository.py File 1.49 KB 0644