mirror of
				https://github.com/ARM-software/devlib.git
				synced 2025-10-26 11:33:19 +00:00 
			
		
		
		
	module: sched: add support to get/set scheduler features
Scheduler features are a debbugging mechanism which allows to tune at run-time some (usually experimental) features of the Linux scheduler. Let's add a proper API abstraction to easily access the list of supported features and tune them. Signed-off-by: Patrick Bellasi <patrick.bellasi@arm.com>
This commit is contained in:
		
				
					committed by
					
						 Marc Bonnici
						Marc Bonnici
					
				
			
			
				
	
			
			
			
						parent
						
							5dea9f8bcf
						
					
				
				
					commit
					cc0679e40f
				
			| @@ -21,6 +21,7 @@ from past.builtins import basestring | ||||
|  | ||||
| from devlib.module import Module | ||||
| from devlib.utils.misc import memoized | ||||
| from devlib.utils.types import boolean | ||||
|  | ||||
|  | ||||
| class SchedProcFSNode(object): | ||||
| @@ -305,6 +306,57 @@ class SchedModule(Module): | ||||
|         path = '/proc/sys/kernel/sched_' + attr | ||||
|         self.target.write_value(path, value, verify) | ||||
|  | ||||
|     @property | ||||
|     @memoized | ||||
|     def has_debug(self): | ||||
|         if self.target.config.get('SCHED_DEBUG') != 'y': | ||||
|             return False; | ||||
|         return self.target.file_exists('/sys/kernel/debug/sched_features') | ||||
|  | ||||
|     def get_features(self): | ||||
|         """ | ||||
|         Get the status of each sched feature | ||||
|  | ||||
|         :returns: a dictionary of features and their "is enabled" status | ||||
|         """ | ||||
|         if not self.has_debug: | ||||
|             raise RuntimeError("sched_features not available") | ||||
|         feats = self.target.read_value('/sys/kernel/debug/sched_features') | ||||
|         features = {} | ||||
|         for feat in feats.split(): | ||||
|             value = True | ||||
|             if feat.startswith('NO'): | ||||
|                 feat = feat.replace('NO_', '', 1) | ||||
|                 value = False | ||||
|             features[feat] = value | ||||
|         return features | ||||
|  | ||||
|     def set_feature(self, feature, enable, verify=True): | ||||
|         """ | ||||
|         Set the status of a specified scheduler feature | ||||
|  | ||||
|         :param feature: the feature name to set | ||||
|         :param enable: true to enable the feature, false otherwise | ||||
|  | ||||
|         :raise ValueError: if the specified enable value is not bool | ||||
|         :raise RuntimeError: if the specified feature cannot be set | ||||
|         """ | ||||
|         if not self.has_debug: | ||||
|             raise RuntimeError("sched_features not available") | ||||
|         feature = feature.upper() | ||||
|         feat_value = feature | ||||
|         if not boolean(enable): | ||||
|             feat_value = 'NO_' + feat_value | ||||
|         self.target.write_value('/sys/kernel/debug/sched_features', | ||||
|                                 feat_value, verify=False) | ||||
|         if not verify: | ||||
|             return | ||||
|         msg = 'Failed to set {}, feature not supported?'.format(feat_value) | ||||
|         features = self.get_features() | ||||
|         feat_value = features.get(feature, not enable) | ||||
|         if feat_value != enable: | ||||
|             raise RuntimeError(msg) | ||||
|  | ||||
|     def get_cpu_sd_info(self, cpu): | ||||
|         """ | ||||
|         :returns: An object view of /proc/sys/kernel/sched_domain/cpu<cpu>/* | ||||
|   | ||||
		Reference in New Issue
	
	Block a user