From d2a4c1d4aa53e4d739dbc23959d3b4e5dc8fc9ad Mon Sep 17 00:00:00 2001 From: Xinran Wang Date: Thu, 22 Aug 2019 09:45:00 +0000 Subject: [PATCH] Fill "driver_name" field in Deployable object Currently, driver_name is not filled correctly. In this patch, I have modified FPGA driver and report driver_name in DriverDeployable, which permit to write this field in Cyborg DB. Change-Id: I30acbe9f9c10e41993bfb77a9b5e3e8bf5d2a6fc --- cyborg/accelerator/drivers/fpga/intel/sysinfo.py | 4 ++++ cyborg/objects/deployable.py | 4 +++- cyborg/objects/driver_objects/driver_deployable.py | 6 ++++-- cyborg/tests/unit/fake_deployable.py | 3 ++- 4 files changed, 13 insertions(+), 4 deletions(-) diff --git a/cyborg/accelerator/drivers/fpga/intel/sysinfo.py b/cyborg/accelerator/drivers/fpga/intel/sysinfo.py index 9619d9b8..700fdaf0 100644 --- a/cyborg/accelerator/drivers/fpga/intel/sysinfo.py +++ b/cyborg/accelerator/drivers/fpga/intel/sysinfo.py @@ -55,6 +55,8 @@ RESOURCES = { "fpga": RC_FPGA } +DRIVER_NAME = "intel" + def read_line(filename): with open(filename) as f: @@ -268,6 +270,7 @@ def _generate_dep_list(fpga, pf_has_vf): driver_dep.attach_handle_list = \ [_generate_attach_handle(fpga)] driver_dep.name = fpga["name"] + driver_dep.driver_name = DRIVER_NAME # pf with sriov enabled, may have several regions and several vfs. # For now, there is only region, this maybe improve in next release. else: @@ -277,6 +280,7 @@ def _generate_dep_list(fpga, pf_has_vf): driver_dep.attach_handle_list.append( _generate_attach_handle(vf)) driver_dep.name = vf["name"] + driver_dep.driver_name = DRIVER_NAME return [driver_dep] diff --git a/cyborg/objects/deployable.py b/cyborg/objects/deployable.py index a5e881eb..929f51d7 100644 --- a/cyborg/objects/deployable.py +++ b/cyborg/objects/deployable.py @@ -44,8 +44,10 @@ class Deployable(base.CyborgObject, object_base.VersionedObjectDictCompat): # name of the deployable 'num_accelerators': object_fields.IntegerField(nullable=False), # number of accelerators spawned by this deployable - 'device_id': object_fields.IntegerField(nullable=False) + 'device_id': object_fields.IntegerField(nullable=False), # Foreign key constrain to reference device table + 'driver_name': object_fields.StringField(nullable=True) + # Will change it to non-nullable after other driver report it. } def _get_parent_root_id(self, context): diff --git a/cyborg/objects/driver_objects/driver_deployable.py b/cyborg/objects/driver_objects/driver_deployable.py index ba6d51be..ae38cdd5 100644 --- a/cyborg/objects/driver_objects/driver_deployable.py +++ b/cyborg/objects/driver_objects/driver_deployable.py @@ -37,7 +37,8 @@ class DriverDeployable(base.DriverObjectBase, # TODO: add field related to local_memory or just store in the # attribute list? 'attach_handle_list': object_fields.ListOfObjectsField( - 'DriverAttachHandle', default=[], nullable=True) + 'DriverAttachHandle', default=[], nullable=True), + 'driver_name': object_fields.StringField(nullable=True) } def create(self, context, device_id, cpid_id): @@ -49,7 +50,8 @@ class DriverDeployable(base.DriverObjectBase, deployable_obj = Deployable(context=context, name=self.name, num_accelerators=self.num_accelerators, - device_id=device_id + device_id=device_id, + driver_name=self.driver_name ) deployable_obj.create(context) # create attribute_list for this deployable diff --git a/cyborg/tests/unit/fake_deployable.py b/cyborg/tests/unit/fake_deployable.py index b1ecb7f9..75897dd6 100644 --- a/cyborg/tests/unit/fake_deployable.py +++ b/cyborg/tests/unit/fake_deployable.py @@ -30,7 +30,8 @@ def fake_db_deployable(**updates): 'parent_id': None, 'root_id': 1, 'num_accelerators': 4, - 'device_id': 0 + 'device_id': 0, + 'driver_name': "fake-driver-name" } for name, field in objects.Deployable.fields.items():