1
0
mirror of https://github.com/ARM-software/workload-automation.git synced 2025-10-26 04:34:04 +00:00

framework: Add feature to mark workloads unsafe for confidential devices

Some workloads, such as Geekbench, may phone home and report data about the
device they are running on. This poses a risk for users that are testing on
unreleased or otherwise confidential devices - perhaps they use a standard
agenda to run a large battery of tests, in which case they may forget to disable
these dangerous workloads.

This provides a mechanism to prevent running those workloads from running by
setting allow_phone_home=False in the user configuration.
This commit is contained in:
Brendan Jackman
2017-10-04 13:25:06 +01:00
parent 188e5d752f
commit 06b451d31b
3 changed files with 31 additions and 0 deletions

View File

@@ -783,6 +783,19 @@ class RunConfiguration(Configuration):
export the output to an exeternal location.
''',
),
ConfigurationPoint(
'allow_phone_home',
kind=bool, default=True,
description='''
Setting this to ``False`` prevents running any workloads that are marked
with 'phones_home', meaning they are at risk of exposing information
about the device to the outside world. For example, some benchmark
applications upload device data to a database owned by the
maintainers.
This can be used to minimise the risk of accidentally running such
workloads when testing confidential devices.
'''),
]
configuration = {cp.name: cp for cp in config_points + meta_data}

View File

@@ -411,6 +411,13 @@ class Runner(object):
self.check_job(job)
def do_run_job(self, job, context):
rc = self.context.cm.run_config
if job.workload.phones_home and not rc.allow_phone_home:
self.logger.warning('Skipping job {} ({}) due to allow_phone_home=False'
.format(job.id, job.workload.name))
job.set_status(Status.SKIPPED)
return
job.set_status(Status.RUNNING)
self.send(signal.JOB_STARTED)

View File

@@ -39,6 +39,17 @@ class Workload(TargetedPlugin):
kind = 'workload'
phones_home = False
"""
Set this to True to mark that this workload poses a risk of exposing
information to the outside world about the device it runs on. An example of
this would be a benchmark application that sends scores and device data to a
database owned by the maintainer.
The user can then set allow_phone_home=False in their configuration to
prevent this workload from being run accidentally.
"""
def init_resources(self, context):
"""
This method may be used to perform early resource discovery and