mirror of
				https://github.com/ARM-software/workload-automation.git
				synced 2025-10-24 20:54:05 +01:00 
			
		
		
		
	instrument/energy: correct backend param init
As paramters defined by energy_measurement instrument backends were not used in instantiating the backends, but the underlying devlib instrument, the values did not undergo the usual Plugin parameter setting perocedure. In particuar, type conversion would not take place. Make sure backend parameters are validated properly by setting them on an obj_dict before passing them to the devlib instrument.
This commit is contained in:
		| @@ -29,7 +29,7 @@ from wa import Instrument, Parameter | |||||||
| from wa.framework import pluginloader | from wa.framework import pluginloader | ||||||
| from wa.framework.plugin import Plugin | from wa.framework.plugin import Plugin | ||||||
| from wa.framework.exception import ConfigError | from wa.framework.exception import ConfigError | ||||||
| from wa.utils.types import list_of_strings, list_of_ints, list_or_string | from wa.utils.types import list_of_strings, list_of_ints, list_or_string, obj_dict | ||||||
|  |  | ||||||
|  |  | ||||||
| class EnergyInstrumentBackend(Plugin): | class EnergyInstrumentBackend(Plugin): | ||||||
| @@ -214,18 +214,16 @@ class EnergyMeasurement(Instrument): | |||||||
|         self.measurement_csv = None |         self.measurement_csv = None | ||||||
|         self.loader = loader |         self.loader = loader | ||||||
|         self.backend = self.loader.get_plugin(self.instrument) |         self.backend = self.loader.get_plugin(self.instrument) | ||||||
|         self.params = {} |         self.params = obj_dict() | ||||||
|  |  | ||||||
|         if self.backend.instrument.mode != CONTINUOUS: |         if self.backend.instrument.mode != CONTINUOUS: | ||||||
|             msg = '{} instrument does not support continuous measurement collection' |             msg = '{} instrument does not support continuous measurement collection' | ||||||
|             raise ConfigError(msg.format(self.instrument)) |             raise ConfigError(msg.format(self.instrument)) | ||||||
|  |  | ||||||
|         supported_params = self.backend.get_parameters() |         supported_params = self.backend.get_parameters() | ||||||
|         for name, value in supported_params.iteritems(): |         for name, param in supported_params.iteritems(): | ||||||
|             if name in self.instrument_parameters: |             value = self.instrument_parameters.get(name) | ||||||
|                 self.params[name] = self.instrument_parameters[name] |             param.set_value(self.params, value) | ||||||
|             elif value.default: |  | ||||||
|                 self.params[name] = value.default |  | ||||||
|         self.backend.validate_parameters(self.params) |         self.backend.validate_parameters(self.params) | ||||||
|  |  | ||||||
|     def initialize(self, context): |     def initialize(self, context): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user