Add doc8 to pep8 check for cyborg project

This patch adds a doc8 check of .rst files to the current pep8 check.
It includes fixes to the .rst files that didn't pass the check.

Change-Id: Ib7a63d1e579f77039172aa4f99d26a3ceeef83d7
This commit is contained in:
Nguyen Van Trung 2018-05-10 09:30:49 +07:00
parent 3670bbb83a
commit 38c1618e60
17 changed files with 288 additions and 245 deletions

View File

@ -7,10 +7,11 @@ Before you commit your code run tox against your patch using the command.
tox . tox .
If any of the tests fail correct the error and try again. If your code is valid Python If any of the tests fail correct the error and try again. If your code is valid
but not valid pep8 you may find autopep8 from pip useful. Python but not valid pep8 you may find autopep8 from pip useful.
Once you submit a patch integration tests will run and those may fail, -1'ing your patch Once you submit a patch integration tests will run and those may fail,
you can make a gerrit comment 'recheck ci' if you have reviewed the logs from the jobs -1'ing your patch you can make a gerrit comment 'recheck ci' if you have
by clicking on the job name in gerrit and concluded that the failure was spurious or otherwise reviewed the logs from the jobs by clicking on the job name in gerrit and
not related to your patch. If problems persist contact people on #openstack-cyborg or #openstack-infra. concluded that the failure was spurious or otherwise not related to your patch.
If problems persist contact people on #openstack-cyborg or #openstack-infra.

View File

@ -5,19 +5,19 @@ General Information
=================== ===================
This document describes the basic REST API operation that Cyborg supports This document describes the basic REST API operation that Cyborg supports
for Pike release. for Pike release::
+--------+-----------------------+-------------------------------------------------------------------------------+ +--------+-----------------------+-----------------------------------------------------------+
| Verb | URI | Description | | Verb | URI | Description |
+========+=======================+===============================================================================+ +========+=======================+===========================================================+
| GET | /accelerators | Return a list of accelerators | | GET | /accelerators | Return a list of accelerators |
+--------+-----------------------+-------------------------------------------------------------------------------+ +--------+-----------------------+-----------------------------------------------------------+
| GET | /accelerators/{uuid} | Retrieve a certain accelerator info identified by `{uuid}` | | GET | /accelerators/{uuid} | Retrieve a certain accelerator info identified by `{uuid}`|
+--------+-----------------------+-------------------------------------------------------------------------------+ +--------+-----------------------+-----------------------------------------------------------+
| POST | /accelerators | Create a new accelerator. | | POST | /accelerators | Create a new accelerator. |
+--------+-----------------------+-------------------------------------------------------------------------------+ +--------+-----------------------+-----------------------------------------------------------+
| PUT | /accelerators/{uuid} | Update the spec for the accelerator identified by `{uuid}` | | PUT | /accelerators/{uuid} | Update the spec for the accelerator identified by `{uuid}`|
+--------+-----------------------+-------------------------------------------------------------------------------+ +--------+-----------------------+-----------------------------------------------------------+
| DELETE | /accelerators/{uuid} | Delete the accelerator identified by `{uuid}` | | DELETE | /accelerators/{uuid} | Delete the accelerator identified by `{uuid}` |
+--------+-----------------------+-------------------------------------------------------------------------------+ +--------+-----------------------+-----------------------------------------------------------+

View File

@ -135,10 +135,11 @@ Finally, push the patch for review using,
Adding functionality Adding functionality
-------------------- --------------------
If you are adding new functionality to Cyborg please add testing for that functionality If you are adding new functionality to Cyborg please add testing for that
and provide a detailed commit message outlining the goals of your commit and how you functionality and provide a detailed commit message outlining the goals of
achived them. your commit and how you achived them.
If the functionality you wish to add doesn't fix in an existing part of the Cyborg If the functionality you wish to add doesn't fix in an existing part of the
achitecture diagram drop by our team meetings to disscuss how it could be implemented Cyborg achitecture diagram drop by our team meetings to disscuss how it
could be implemented

View File

@ -119,7 +119,8 @@ It will speed up your installation if you have a local GIT_BASE.
##### Command line ##### Command line
You can `source openrc YOUR_USER YOUR_USER (e.g. source openrc admin admin)` in You can `source openrc YOUR_USER YOUR_USER (e.g. source openrc admin admin)` in
your shell, and then use the `openstack` command line tool to manage your devstack. your shell, and then use the `openstack` command line tool to manage your
devstack.
##### Horizon ##### Horizon

View File

@ -6,8 +6,10 @@ Background Story
OpenStack Acceleration Discussion Started from Telco Requirements: OpenStack Acceleration Discussion Started from Telco Requirements:
* High level requirements first drafted in the standard organization ETSI NFV ISG * High level requirements first drafted in the standard organization
* High level requirements transformed into detailed requirements in OPNFV DPACC project. ETSI NFV ISG
* High level requirements transformed into detailed requirements in
OPNFV DPACC project.
* New project called Nomad established to address the requirements. * New project called Nomad established to address the requirements.
* BoF discussions back in OpenStack Austin Summit. * BoF discussions back in OpenStack Austin Summit.

View File

@ -28,42 +28,44 @@ Use of accelerators attached to virtual machine instances in OpenStack
Proposed change Proposed change
=============== ===============
Cyborg Agent resides on various compute hosts and monitors them for accelerators. Cyborg Agent resides on various compute hosts and monitors them for
On it's first run Cyborg Agent will run the detect accelerator functions of all accelerators. On it's first run Cyborg Agent will run the detect
it's installed drivers. The resulting list of accelerators available on the host accelerator functions of all it's installed drivers. The resulting list
will be reported to the conductor where it will be stored into the database and of accelerators available on the host will be reported to the conductor
listed during API requests. By default accelerators will be inserted into the where it will be stored into the database and listed during API requests.
database in a inactive state. It will be up to the operators to manually set By default accelerators will be inserted into the database in a inactive
an accelerator to 'ready' at which point cyborg agent will be responsible for state. It will be up to the operators to manually set an accelerator to
calling the drivers install function and ensuring that the accelerator is ready 'ready' at which point cyborg agent will be responsible for calling the
for use. drivers install function and ensuring that the accelerator is ready for use.
In order to mirror the current Nova model of using the placement API each Agent In order to mirror the current Nova model of using the placement API each Agent
will send updates on it's resources directly to the placement API endpoint as well will send updates on it's resources directly to the placement API endpoint
as to the conductor for usage aggregation. This should keep placement API up to date as well as to the conductor for usage aggregation. This should keep placement
on accelerators and their usage. API up to date on accelerators and their usage.
Alternatives Alternatives
------------ ------------
There are lots of alternate ways to lay out the communication between the Agent There are lots of alternate ways to lay out the communication between the Agent
and the API endpoint or the driver. Almost all of them involving exactly where we and the API endpoint or the driver. Almost all of them involving exactly where
draw the line between the driver, Conductor , and Agent. I've written my proposal we draw the line between the driver, Conductor , and Agent. I've written my
with the goal of having the Agent act mostly as a monitoring tool, reporting to proposal with the goal of having the Agent act mostly as a monitoring tool,
the cloud operator or other Cyborg components to take action. A more active role reporting to the cloud operator or other Cyborg components to take action.
for Cyborg Agent is possible but either requires significant synchronization with A more active role for Cyborg Agent is possible but either requires significant
the Conductor or potentially steps on the toes of operators. synchronization with the Conductor or potentially steps on the toes of
operators.
Data model impact Data model impact
----------------- -----------------
Cyborg Agent will create new entries in the database for accelerators it detects Cyborg Agent will create new entries in the database for accelerators it
it will also update those entries with the current status of the accelerator detects it will also update those entries with the current status of the
at a high level. More temporary data like the current usage of a given accelerator accelerator at a high level. More temporary data like the current usage of
will be broadcast via a message passing system and won't be stored. a given accelerator will be broadcast via a message passing system and won't
be stored.
Cyborg Agent will retain a local cache of this data with the goal of not losing accelerator Cyborg Agent will retain a local cache of this data with the goal of not losing
state on system interruption or loss of connection. accelerator state on system interruption or loss of connection.
REST API impact REST API impact

View File

@ -23,11 +23,11 @@ Use Cases
--------- ---------
* As a user I want to be able to spawn VM with dedicated hardware, so * As a user I want to be able to spawn VM with dedicated hardware, so
that I can utilize provided hardware. that I can utilize provided hardware.
* As a compute service I need to know how requested resource should be * As a compute service I need to know how requested resource should be
attached to the VM. attached to the VM.
* As a scheduler service I'd like to know on which resource provider * As a scheduler service I'd like to know on which resource provider
requested resource can be found. requested resource can be found.
Proposed change Proposed change
=============== ===============
@ -38,26 +38,28 @@ for Cyborg.
Life Cycle Management Phases Life Cycle Management Phases
---------------------------- ----------------------------
For cyborg, LCM phases include typical create, retrieve, update, delete operations. For cyborg, LCM phases include typical create, retrieve, update, delete
One thing should be noted that deprovisioning mainly refers to detach(delete) operation operations. One thing should be noted that deprovisioning mainly refers to
which deactivate an acceleration capability but preserve the resource itself detach(delete) operation which deactivate an acceleration capability but
for future usage. For Cyborg, from functional point of view, the LCM includes provision, preserve the resource itself for future usage. For Cyborg, from functional
attach,update,list, and detach. There is no notion of deprovisioning for Cyborg API point of view, the LCM includes provision, attach,update,list, and detach.
in a sense that we decomission or disconnect an entire accelerator device from There is no notion of deprovisioning for Cyborg API in a sense that we
the bus. decomission or disconnect an entire accelerator device from the bus.
Difference between Provision and Attach/Detach Difference between Provision and Attach/Detach
---------------------------------------------- ----------------------------------------------
Noted that while the APIs support provisioning via CRUD operations, attach/detach Noted that while the APIs support provisioning via CRUD operations,
are considered different: attach/detach are considered different:
* Provision operations (create) will involve api-> * Provision operations (create) will involve api->
conductor->agent->driver workflow, where as attach/detach (update/delete) could be taken conductor->agent->driver workflow, where as attach/detach (update/delete)
care of at the driver layer without the involvement of the pre-mentioned workflow. This could be taken care of at the driver layer without the involvement of the
is similar to the difference between create a volume and attach/detach a volume in Cinder. pre-mentioned workflow. This is similar to the difference between create a
volume and attach/detach a volume in Cinder.
* The attach/detach in Cyborg API will mainly involved in DB status modification. * The attach/detach in Cyborg API will mainly involved in DB status
modification.
Difference between Attach/Detach To VM and Host Difference between Attach/Detach To VM and Host
----------------------------------------------- -----------------------------------------------
@ -66,23 +68,23 @@ Moreover there are also differences when we attach an accelerator to a VM or
a host, similar to Cinder. a host, similar to Cinder.
* When the attachment happens to a VM, we are expecting that Nova could call * When the attachment happens to a VM, we are expecting that Nova could call
the virt driver to perform the action for the instance. In this case Nova the virt driver to perform the action for the instance. In this case Nova
needs to support the acc-attach and acc-detach action. needs to support the acc-attach and acc-detach action.
* When the attachment happens to a host, we are expecting that Cyborg could * When the attachment happens to a host, we are expecting that Cyborg could
take care of the action itself via Cyborg driver. Althrough currently there take care of the action itself via Cyborg driver. Althrough currently there
is the generic driver to accomplish the job, we should consider a os-brick is the generic driver to accomplish the job, we should consider a os-brick
like standalone lib for accelerator attach/detach operations. like standalone lib for accelerator attach/detach operations.
Alternatives Alternatives
------------ ------------
* For attaching an accelerator to a VM, we could let Cyborg perform the action * For attaching an accelerator to a VM, we could let Cyborg perform the action
itself, however it runs into the risk of tight-coupling with Nova of which Cyborg itself, however it runs into the risk of tight-coupling with Nova of which
needs to get instance related information. Cyborg needs to get instance related information.
* For attaching an accelerator to a host, we could consider to use Ironic drivers * For attaching an accelerator to a host, we could consider to use Ironic
however it might not bode well with the standalone accelerator rack scenarios where drivers however it might not bode well with the standalone accelerator rack
accelerators are not attached to server at all. scenarios where accelerators are not attached to server at all.
Data model impact Data model impact
----------------- -----------------
@ -177,7 +179,7 @@ Example message body of the response to the GET operation::
} }
'GET /accelerators/{uuid}' 'GET /accelerators/{uuid}'
************************* **************************
Retrieve a certain accelerator info indetified by '{uuid}' Retrieve a certain accelerator info indetified by '{uuid}'
@ -210,7 +212,7 @@ If the accelerator does not exist a `404 Not Found` must be
returned. returned.
'POST /accelerators/{uuid}' 'POST /accelerators/{uuid}'
******************* ***************************
Create a new accelerator Create a new accelerator
@ -252,7 +254,7 @@ A `409 Conflict` response code will be returned if another accelerator
exists with the provided name. exists with the provided name.
'PUT /accelerators/{uuid}/{acc_spec}' 'PUT /accelerators/{uuid}/{acc_spec}'
************************* *************************************
Update the spec for the accelerator identified by `{uuid}`. Update the spec for the accelerator identified by `{uuid}`.
@ -289,7 +291,7 @@ The returned HTTP response code will be one of the following:
'PUT /accelerators/{uuid}' 'PUT /accelerators/{uuid}'
************************* **************************
Attach the accelerator identified by `{uuid}`. Attach the accelerator identified by `{uuid}`.
@ -322,11 +324,13 @@ The body of the request and the response is empty.
The returned HTTP response code will be one of the following: The returned HTTP response code will be one of the following:
* `204 No Content` if the request was successful and the accelerator was detached. * `204 No Content` if the request was successful and the accelerator was
detached.
* `404 Not Found` if the accelerator identified by `{uuid}` was * `404 Not Found` if the accelerator identified by `{uuid}` was
not found. not found.
* `409 Conflict` if there exist allocations records for any of the * `409 Conflict` if there exist allocations records for any of the
accelerator resource that would be detached as a result of detaching the accelerator. accelerator resource that would be detached as a result of detaching
the accelerator.
Security impact Security impact
@ -373,7 +377,7 @@ Work Items
* Implement the APIs specified in this spec * Implement the APIs specified in this spec
* Proposal to Nova about the new accelerator * Proposal to Nova about the new accelerator
attach/detach api attach/detach api
* Implement the DB specified in this spec * Implement the DB specified in this spec

View File

@ -30,23 +30,24 @@ Proposed change
Cyborg Conductor will reside on the control node and will be Cyborg Conductor will reside on the control node and will be
responsible for stateful actions taken by Cyborg. Acting as both a cache to responsible for stateful actions taken by Cyborg. Acting as both a cache to
the database and as a method of combining reads and writes to the database. the database and as a method of combining reads and writes to the database.
All other Cyborg components will go through the conductor for database operations. All other Cyborg components will go through the conductor for database
operations.
Alternatives Alternatives
------------ ------------
Having each Cyborg Agent instance hit the database on it's own is a possible Having each Cyborg Agent instance hit the database on it's own is a possible
alternative, and it may even be feasible if the accelerator load monitoring rate is alternative, and it may even be feasible if the accelerator load monitoring
very low and the vast majority of operations are reads. But since we intend to store rate is very low and the vast majority of operations are reads. But since we
metadata about accelerator usage updated regularly this model probably will not scale intend to store metadata about accelerator usage updated regularly this model
well. probably will not scale well.
Data model impact Data model impact
----------------- -----------------
Using the conductor 'properly' will result in little or no per instance state and stateful Using the conductor 'properly' will result in little or no per instance state
operations moving through the conductor with the exception of some local caching where it and stateful operations moving through the conductor with the exception of
can be garunteed to work well. some local caching where it can be garunteed to work well.
REST API impact REST API impact
--------------- ---------------
@ -120,8 +121,8 @@ CI using the dummy driver.
Documentation Impact Documentation Impact
==================== ====================
Some configuration values tuning save out rate and other parameters on the controller Some configuration values tuning save out rate and other parameters on the
will need to be documented for end users controller will need to be documented for end users
References References
========== ==========

View File

@ -66,14 +66,15 @@ REST API impact
--------------- ---------------
This blueprint proposes to add the following APIs: This blueprint proposes to add the following APIs:
*cyborg install-driver <driver_id>
*cyborg uninstall-driver <driver_id> * cyborg install-driver <driver_id>
*cyborg attach-instance <instance_id> * cyborg uninstall-driver <driver_id>
*cyborg detach-instance <instance_id> * cyborg attach-instance <instance_id>
*cyborg service-list * cyborg detach-instance <instance_id>
*cyborg driver-list * cyborg service-list
*cyborg update-driver <driver_id> * cyborg driver-list
*cyborg discover-services * cyborg update-driver <driver_id>
* cyborg discover-services
Security impact Security impact
--------------- ---------------
@ -119,6 +120,7 @@ Work Items
---------- ----------
This change would entail the following: This change would entail the following:
* Add a feature to identify and discover attached accelerator backends. * Add a feature to identify and discover attached accelerator backends.
* Add a feature to list services running on the backend * Add a feature to list services running on the backend
* Add a feature to attach accelerators to the generic backend. * Add a feature to attach accelerators to the generic backend.

View File

@ -17,10 +17,10 @@ Problem description
A Field Programmable Gate Array(FPGA) is an integrated circuit designed to be A Field Programmable Gate Array(FPGA) is an integrated circuit designed to be
configured by a customer or a designer after manufacturing. The advantage lies configured by a customer or a designer after manufacturing. The advantage lies
in that they are sometimes significantly faster for some applications because of in that they are sometimes significantly faster for some applications because
their parallel nature and optimality in terms of the number of gates used for a of their parallel nature and optimality in terms of the number of gates used
certain process. Hence, using FPGA for application acceleration in cloud has been for a certain process. Hence, using FPGA for application acceleration in cloud
becoming desirable. has been becoming desirable.
There is a management framwork in Cyborg [1]_ for heterogeneous accelerators, There is a management framwork in Cyborg [1]_ for heterogeneous accelerators,
tracking and deploying FPGAs. This spec will add a FPGA driver for Cyborg to tracking and deploying FPGAs. This spec will add a FPGA driver for Cyborg to
@ -30,20 +30,20 @@ Use Cases
--------- ---------
* When Cyborg agent starts or does resource checking periodically, the Cyborg * When Cyborg agent starts or does resource checking periodically, the Cyborg
FPGA driver should enumerate the list of the FPGA devices, and report the FPGA driver should enumerate the list of the FPGA devices, and report the
details of all available FPGA accelerators on the host, such as BDF(Bus, details of all available FPGA accelerators on the host, such as BDF(Bus,
Device, Function), PID(Product id) VID(Vendor id), IMAGE_ID and PF(Physical Device, Function), PID(Product id) VID(Vendor id), IMAGE_ID and PF(Physical
Function)/VF(Virtual Function) type. Function)/VF(Virtual Function) type.
* When user uses empty FPGA regions as their accelerators, Cyborg agent will * When user uses empty FPGA regions as their accelerators, Cyborg agent will
call driver's program() interface. Cyborg agent should provide BDF call driver's program() interface. Cyborg agent should provide BDF
of PF/VF, and local image path to the driver. More details can be found in ref of PF/VF, and local image path to the driver. More details can be found in
[2]_. ref [2]_.
* When there maybe more thant one vendor fpga card on a host, or on different * When there maybe more thant one vendor fpga card on a host, or on different
hosts in the cluster, Cyborg agent can discover the wendors easiy and hosts in the cluster, Cyborg agent can discover the wendors easiy and
intelligently by Cyborg FPGA driver, and call the correct driver to execute intelligently by Cyborg FPGA driver, and call the correct driver to execute
it's operations, such as discover() and program(). it's operations, such as discover() and program().
Proposed changes Proposed changes
@ -54,27 +54,29 @@ discover/program interfaces for FPGA accelerator framework.
The driver should include the follow functions: The driver should include the follow functions:
1. discover() 1. discover()
driver reports devices as following: driver reports devices as following::
[{
"vendor": "0x8086", [{
"product": "bcc0", "vendor": "0x8086",
"pr_num": 1, "product": "bcc0",
"devices": "0000:be:00:0", "pr_num": 1,
"path": "/sys/class/fpga/intel-fpga-dev.0", "devices": "0000:be:00:0",
"regions": [ "path": "/sys/class/fpga/intel-fpga-dev.0",
{"vendor": "0x8086", "regions": [
"product": "bcc1", {"vendor": "0x8086",
"regions": 1, "product": "bcc1",
"devices": "0000:be:00:1", "regions": 1,
"path": "/sys/class/fpga/intel-fpga-dev.1" "devices": "0000:be:00:1",
}] "path": "/sys/class/fpga/intel-fpga-dev.1"
}] }]
pr_num: partial reconfiguration region numbers. }]
pr_num: partial reconfiguration region numbers.
2. program(device_path, image) 2. program(device_path, image)
program the image to a PR region specified by device_path. program the image to a PR region specified by device_path.
device_path: the sys path of accelerator device. device_path: the sys path of accelerator device.
image: The local path of programming image. image: The local path of programming image.
Image Format Image Format
---------------------------- ----------------------------
@ -161,7 +163,7 @@ Testing
* Functional tests will be added to test Cyborg FPGA driver. * Functional tests will be added to test Cyborg FPGA driver.
Documentation Impact Documentation Impact
=================== ====================
Document FPGA driver in the Cyborg project Document FPGA driver in the Cyborg project

View File

@ -11,32 +11,35 @@
Blueprint url is not available yet Blueprint url is not available yet
https://blueprints.launchpad.net/openstack-cyborg/+spec/cyborg-fpga-modelling https://blueprints.launchpad.net/openstack-cyborg/+spec/cyborg-fpga-modelling
This spec proposes the DB modelling schema for tracking reprogrammable resources This spec proposes the DB modelling schema for tracking reprogrammable
resources
Problem description Problem description
=================== ===================
A field-programmable gate array (FPGA) is an integrated circuit designed to be A field-programmable gate array (FPGA) is an integrated circuit designed to be
configured by a customer or a designer after manufacturing. Their advantage lies configured by a customer or a designer after manufacturing. Their advantage
in that they are sometimes significantly faster for some applications because of lies in that they are sometimes significantly faster for some applications
their parallel nature and optimality in terms of the number of gates used for a because of their parallel nature and optimality in terms of the number of gates
certain process. Hence, using FPGA for application acceleration in cloud has been used for a certain process. Hence, using FPGA for application acceleration in
becoming desirable. Cyborg as a management framwork for heterogeneous accelerators cloud has been becoming desirable. Cyborg as a management framwork for
,tracking and deploying FPGAs are much needed features. heterogeneous accelerators, tracking and deploying FPGAs are much needed
features.
Use Cases Use Cases
--------- ---------
When user requests FPGA resources, scheduler will use placement agent [1]_ to select When user requests FPGA resources, scheduler will use placement agent [1]_ to
appropriate hosts that have the requested FPGA resources. select appropriate hosts that have the requested FPGA resources.
When a FPGA type resource is allocated to a VM, Cyborg needs to track down which When a FPGA type resource is allocated to a VM, Cyborg needs to track down
exact device has been assigned in the database. On the other hand, when the which exact device has been assigned in the database. On the other hand, when
resource is released, Cyborg will need to be detached and free the exact resource. the resource is released, Cyborg will need to be detached and free the exact
resource.
When a new device is plugged in to the system(host), Cyborg needs to discover it When a new device is plugged in to the system(host), Cyborg needs to discover
and store it into the database it and store it into the database
Proposed change Proposed change
=============== ===============
@ -45,13 +48,14 @@ We need to add 2 more tables to Cyborg database, one for tracking all the
deployables and one for arbitrary key-value pairs of deplyable associated deployables and one for arbitrary key-value pairs of deplyable associated
attirbutes. These tables are named as Deployables and Attributes. attirbutes. These tables are named as Deployables and Attributes.
Deployables table consists of all the common attributes columns as well as a parent_id Deployables table consists of all the common attributes columns as well as
and a root_id. The parent_id will point to the associated parent deployable and the a parent_id and a root_id. The parent_id will point to the associated parent
root_id will point to the associated root deployable. By doing this, we can form a deployable and the root_id will point to the associated root deployable.
nested tree structure to represent different hierarchies. In addition, there will a By doing this, we can form a nested tree structure to represent different
foreign key named accelerator_id reference to the accelerators table. For the case hierarchies. In addition, there will a foreign key named accelerator_id
where FPGA has not been loaded any bitstreams on it, they will still be tracked as reference to the accelerators table. For the case where FPGA has not been
a Deployable but no other Deployables referencing to it. For instance, a network of loaded any bitstreams on it, they will still be tracked as a Deployable but
no other Deployables referencing to it. For instance, a network of
FPGA hierarchies can be formed using deployables in following scheme:: FPGA hierarchies can be formed using deployables in following scheme::
------------------- -------------------
@ -71,17 +75,18 @@ FPGA hierarchies can be formed using deployables in following scheme::
----------------- ----------------- ----------------- -----------------
Attributes table consists of a key and a value columns to represent arbitrary k-v pairs. Attributes table consists of a key and a value columns to represent arbitrary
k-v pairs.
For instance, bitstream_id and function kpi can be tracked in this table.In addition, For instance, bitstream_id and function kpi can be tracked in this table.
a foreign key deployable_id refers to the Deployables table and a parent_attribute_id In addition, a foreign key deployable_id refers to the Deployables table and
to form nested structured attribute relationships. a parent_attribute_id to form nested structured attribute relationships.
Cyborg needs to have object classes to represent different types of deployables(e.g. Cyborg needs to have object classes to represent different types of
FPGA, Physical Functions, Virtual Functions etc). deployables(e.g. FPGA, Physical Functions, Virtual Functions etc).
Cyborg Agent needs to add feature to discover the FPGA resources from FPGA driver Cyborg Agent needs to add feature to discover the FPGA resources from FPGA
and report them to the Cyborg DB through the conductor. driver and report them to the Cyborg DB through the conductor.
Conductor needs to add couple of sets of APIs for different types of deployable Conductor needs to add couple of sets of APIs for different types of deployable
resources. resources.
@ -89,21 +94,23 @@ resources.
Alternatives Alternatives
------------ ------------
Alternativly, instead of having a flat table to track arbitrary hierarchies, we can use Alternativly, instead of having a flat table to track arbitrary hierarchies, we
two different tables in Cyborg database, one for physical functions and one for virtual can use two different tables in Cyborg database, one for physical functions and
functions. physical_functions should have a foreign key constraint to reference the id in one for virtual functions. physical_functions should have a foreign key
Accelerators table. In addition, virtual_functions should have a foreign key constraint constraint to reference the id in Accelerators table. In addition,
to reference the id in physical_functions. virtual_functions should have a foreign key constraint to reference the id
in physical_functions.
The problems with this design are as follows. First, it can only track up to 3 hierarchies The problems with this design are as follows. First, it can only track up to
of resources. In case we need to add another layer, a lot of migaration work will 3 hierarchies of resources. In case we need to add another layer, a lot of
be required. Second, even if we only need to add some new attribute to the existing migaration work will be required. Second, even if we only need to add some new
resource type, we need to create new migration scripts for them. Overall the maintenance attribute to the existing resource type, we need to create new migration
work is tedious. scripts for them. Overall the maintenance work is tedious.
Data model impact Data model impact
----------------- -----------------
As discussed in previous sections, two tables will be added: Deployables and Attributes:: As discussed in previous sections, two tables will be added: Deployables and
Attributes::
CREATE TABLE Deployables CREATE TABLE Deployables
@ -143,7 +150,8 @@ As discussed in previous sections, two tables will be added: Deployables and Att
RPC API impact RPC API impact
--------------- ---------------
Two sets of conductor APIs need to be added. 1 set for physical functions, 1 set for virtual functions Two sets of conductor APIs need to be added. 1 set for physical functions,
1 set for virtual functions
Physical function apis:: Physical function apis::
@ -161,9 +169,9 @@ Virtual function apis::
REST API impact REST API impact
--------------- ---------------
Since these tables are not exposed to users for modifying/adding/deleting, Cyborg Since these tables are not exposed to users for modifying/adding/deleting,
will only add two extra REST APIs to allow user query information related to Cyborg will only add two extra REST APIs to allow user query information
deployables and their attributes. related to deployables and their attributes.
API for retrieving Deployable's information:: API for retrieving Deployable's information::

View File

@ -71,6 +71,8 @@ Driver 'POST /discovery'
Trigger the discovery and setup process for a specific driver Trigger the discovery and setup process for a specific driver
.. code_block:: init
Content-Type: application/json Content-Type: application/json
{ {
@ -85,6 +87,8 @@ ready to use entires available by the public API. Hardware are
physical devices on nodes that may or may not be ready to use or physical devices on nodes that may or may not be ready to use or
even fully supported. even fully supported.
.. code_block:: init
200 OK 200 OK
Content-Type: application/json Content-Type: application/json
@ -125,6 +129,8 @@ Driver 'POST /hello'
Registers that a driver has been installed on the machine and is ready to use. Registers that a driver has been installed on the machine and is ready to use.
As well as it's endpoint and hardware support. As well as it's endpoint and hardware support.
.. code_block:: init
Content-Type: application/json Content-Type: application/json
{ {
@ -154,6 +160,8 @@ Conductor 'POST /hello'
Registers that an Agent has been installed on the machine and is ready to use. Registers that an Agent has been installed on the machine and is ready to use.
.. code_block:: init
Content-Type: application/json Content-Type: application/json
{ {

View File

@ -13,10 +13,10 @@ https://blueprints.launchpad.net/cyborg/+spec/cyborg-nova-interaction
Cyborg, as a service for managing accelerators of any kind needs to cooperate Cyborg, as a service for managing accelerators of any kind needs to cooperate
with Nova on two planes: Cyborg should be able to inform Nova about the with Nova on two planes: Cyborg should be able to inform Nova about the
resources through placement API[1], so that scheduler can leverage user resources through placement API[1], so that scheduler can leverage user
requests for particular functionality into assignment of specific resource using requests for particular functionality into assignment of specific resource
resource provider which possess an accelerator, and second, Cyborg should be using resource provider which possess an accelerator, and second, Cyborg should
able to provide information on how Nova compute can attach particular resource be able to provide information on how Nova compute can attach particular
to VM. resource to VM.
In a nutshell, this blueprint will define how information between Nova and In a nutshell, this blueprint will define how information between Nova and
Cyborg will be exchanged. Cyborg will be exchanged.
@ -24,14 +24,14 @@ Cyborg will be exchanged.
Problem description Problem description
=================== ===================
Currently in OpenStack the use of non-standard accelerator hardware is supported Currently in OpenStack the use of non-standard accelerator hardware is
in that features exist across many of the core servers that allow these resources supported in that features exist across many of the core servers that allow
to be allocated, passed through, and eventually used. these resources to be allocated, passed through, and eventually used.
What remains a challenge though is the lack of an integrated workflow; there is no What remains a challenge though is the lack of an integrated workflow; there
way to configure many of the accelerator features without significant by hand effort is no way to configure many of the accelerator features without significant
and service disruptions that go against the goals of having a easy, stable, and by hand effort and service disruptions that go against the goals of having
flexible cloud. a easy, stable, and flexible cloud.
Cyborg exists to bring these disjoint efforts together into a more standard Cyborg exists to bring these disjoint efforts together into a more standard
workflow. While many components of this workflow already exist, some don't workflow. While many components of this workflow already exist, some don't
@ -53,7 +53,7 @@ used:
Proposed Workflow Proposed Workflow
=============== =================
Using a method not relevant to this proposal Cyborg Agent inspects hardware Using a method not relevant to this proposal Cyborg Agent inspects hardware
and finds accelerators that it is interested in setting up for use. and finds accelerators that it is interested in setting up for use.
@ -66,21 +66,25 @@ One of the primary responsibilities of the Cyborg conductor is to keep the
placement API in sync with reality. For example if here is a device with placement API in sync with reality. For example if here is a device with
a virtual function or a FPGA with a given program Cyborg may be tasked with a virtual function or a FPGA with a given program Cyborg may be tasked with
changing the virtual function on the NIC or the program on the FPGA. At which changing the virtual function on the NIC or the program on the FPGA. At which
point the previously specified traits and resources need to be updated. Likewise point the previously specified traits and resources need to be updated.
Cyborg will be watching monitoring Nova's instances to ensure that doing this Likewise Cyborg will be watching monitoring Nova's instances to ensure that
doesn't pull resources out from under an allocated instance. doing this doesn't pull resources out from under an allocated instance.
At a high level what we need to be able to do is the following At a high level what we need to be able to do is the following
1. Add a PCI device to Nova's whitelist live (config only / needs implementation) 1. Add a PCI device to Nova's whitelist live
2. Add information about this device to the placement API (existing / being worked) (config only / needs implementation)
3. Hotplug and unplug PCI devices from instances (existing / not sure how well maintained) 2. Add information about this device to the placement API
(existing / being worked)
3. Hotplug and unplug PCI devices from instances
(existing / not sure how well maintained)
Alternatives Alternatives
------------ ------------
Don't use Cyborg, struggle with bouncing services and grub config changes yourself. Don't use Cyborg, struggle with bouncing services and grub config changes
yourself.
Data model impact Data model impact
----------------- -----------------
@ -146,8 +150,8 @@ Dependencies
This design depends on the changes which may or may not be accepted in Nova This design depends on the changes which may or may not be accepted in Nova
project. Other than that is ongoing work on Nested resource providers: project. Other than that is ongoing work on Nested resource providers:
http://specs.openstack.org/openstack/nova-specs/specs/ocata/approved/nested-resource-providers.html http://specs.openstack.org/openstack/nova-specs/specs/ocata/approved/nested-resource-providers.html
Which would be an essential feature in Placement API, which will be leveraged by Which would be an essential feature in Placement API, which will be leveraged
Cyborg. by Cyborg.
Testing Testing

View File

@ -24,14 +24,14 @@ Use Cases
--------- ---------
* When Cinder uses Ceph as its backend, the user should be able to * When Cinder uses Ceph as its backend, the user should be able to
use the Cyborg SPDK driver to discover the SPDK accelerator backend, use the Cyborg SPDK driver to discover the SPDK accelerator backend,
enumerate the list of the Ceph nodes that have installed the SPDK. enumerate the list of the Ceph nodes that have installed the SPDK.
* When Cinder directly uses SPDK's BlobStore as its backend, the user * When Cinder directly uses SPDK's BlobStore as its backend, the user
should be able to accomplish the same life cycle management operations should be able to accomplish the same life cycle management operations
for SPDK as mentioned above. After enumerating the SPDK, the user can for SPDK as mentioned above. After enumerating the SPDK, the user can
attach (install) SPDK on that node. When the task completes, the user attach (install) SPDK on that node. When the task completes, the user
can also detach the SPDK from the node. Last but not least the user can also detach the SPDK from the node. Last but not least the user
should be able to update the latest and available SPDK. should be able to update the latest and available SPDK.
Proposed change Proposed change
=============== ===============
@ -42,18 +42,18 @@ discover/list/update/attach/detach operations for SPDK framework.
SPDK framework SPDK framework
-------------- --------------
The SPDK framework comprises of the following components: The SPDK framework comprises of the following components::
+-----------userspace--------+ +--------------+ +-----------userspace--------+ +--------------+
| +------+ +------+ +------+ | | +-----------+ | | +------+ +------+ +------+ | | +-----------+ |
+---+ | |DPDK | |NVMe | |NVMe | | | | Ceph | | +---+ | |DPDK | |NVMe | |NVMe | | | | Ceph | |
| N +-+-+NIC | |Target| |Driver+-+-+ |NVMe Device| | | N +-+-+NIC | |Target| |Driver+-+-+ |NVMe Device| |
| I | | |Driver| | | | | | | +-----------+ | | I | | |Driver| | | | | | | +-----------+ |
| C | | +------+ +------+ +------+ | | +-----------+ | | C | | +------+ +------+ +------+ | | +-----------+ |
+---+ | +------------------------+ | | | Blobstore | | +---+ | +------------------------+ | | | Blobstore | |
| | DPDK Libraries | | | |NVMe Device| | | | DPDK Libraries | | | |NVMe Device| |
| +------------------------+ | | +-----------+ | | +------------------------+ | | +-----------+ |
+----------------------------+ +---------------+ +----------------------------+ +---------------+
BlobStore NVMe Device Format BlobStore NVMe Device Format
---------------------------- ----------------------------
@ -87,25 +87,25 @@ avoids the filesystem, which improves efficiency.
Life Cycle Management Phases Life Cycle Management Phases
---------------------------- ----------------------------
* We should be able to add a judgement whether the backend node has SPDK kit * We should be able to add a judgement whether the backend node has SPDK kit
in generic driver module. If true, initialize the DPDK environment (such as in generic driver module. If true, initialize the DPDK environment (such as
hugepage). hugepage).
* Import the generic driver module, and then we should be able to * Import the generic driver module, and then we should be able to
discover (probe) the system for SPDK. discover (probe) the system for SPDK.
* Determined by the backend storage scenario, enumerate (list) the optimal * Determined by the backend storage scenario, enumerate (list) the optimal
SPDK node, returning a boolean value to judge whether the SPDK should be SPDK node, returning a boolean value to judge whether the SPDK should be
attached. attached.
* After the node where SPDK will be running is attached, we can now send a * After the node where SPDK will be running is attached, we can now send a
request about the information of namespaces, and then create an I/O queue request about the information of namespaces, and then create an I/O queue
pair to submit read/write requests to a namespace. pair to submit read/write requests to a namespace.
* When Ceph is used as the backend, as the latest Ceph (such as Luminous) * When Ceph is used as the backend, as the latest Ceph (such as Luminous)
uses the BlueStore to be the storage engine, BlueStore and BlobStore are uses the BlueStore to be the storage engine, BlueStore and BlobStore are
very similar things. We will not be able to use BlobStore to accelerate very similar things. We will not be able to use BlobStore to accelerate
Ceph, but we can use Ioat and poller to boost speed for storage. Ceph, but we can use Ioat and poller to boost speed for storage.
* When SPDK is used as the backend, we should be able to use BlobStore to * When SPDK is used as the backend, we should be able to use BlobStore to
improve performance. improve performance.
* Whenever user requests, we should be able to detach the SPDK device. * Whenever user requests, we should be able to detach the SPDK device.
* Whenever user requests, we should be able to update SPDK to the latest and * Whenever user requests, we should be able to update SPDK to the latest and
stable release. stable release.
Alternatives Alternatives
------------ ------------
@ -116,19 +116,20 @@ Data model impact
----------------- -----------------
* The Cyborg SPDK driver will notify Cyborg Agent to update the database * The Cyborg SPDK driver will notify Cyborg Agent to update the database
when discover/list/update/attach/detach operations take place. when discover/list/update/attach/detach operations take place.
REST API impact REST API impact
--------------- ---------------
This blueprint proposes to add the following APIs: This blueprint proposes to add the following APIs:
*cyborg discover-driverdriver_type
*cyborg driver-list(driver_type) * cyborg discover-driverdriver_type
*cyborg install-driver(driver_id, driver_type) * cyborg driver-list(driver_type)
*cyborg attach-instance <instance_id> * cyborg install-driver(driver_id, driver_type)
*cyborg detach-instance <instance_id> * cyborg attach-instance <instance_id>
*cyborg uninstall-driver(driver_id, driver_type) * cyborg detach-instance <instance_id>
*cyborg update-driver <driver_id, driver_type> * cyborg uninstall-driver(driver_id, driver_type)
* cyborg update-driver <driver_id, driver_type>
Security impact Security impact
--------------- ---------------
@ -176,7 +177,7 @@ Work Items
* Implement the cyborg-spdk-driver in this spec. * Implement the cyborg-spdk-driver in this spec.
* Propose SPDK to py-spdk. The py-spdk is designed as a SPDK client * Propose SPDK to py-spdk. The py-spdk is designed as a SPDK client
which provides the python binding. which provides the python binding.
Dependencies Dependencies
@ -192,10 +193,10 @@ Testing
* Unit tests will be added to test Cyborg SPDK driver. * Unit tests will be added to test Cyborg SPDK driver.
* Functional tests will be added to test Cyborg SPDK driver. For example: * Functional tests will be added to test Cyborg SPDK driver. For example:
discover-->list-->attachwhether the workflow can be passed successfully. discover-->list-->attachwhether the workflow can be passed successfully.
Documentation Impact Documentation Impact
=================== ====================
Document SPDK driver in the Cyborg project Document SPDK driver in the Cyborg project

View File

@ -99,8 +99,8 @@ If this is one part of a larger effort make it clear where this piece ends. In
other words, what's the scope of this effort? other words, what's the scope of this effort?
At this point, if you would like to just get feedback on if the problem and At this point, if you would like to just get feedback on if the problem and
proposed change fit in Cyborg, you can stop here and post this for review to get proposed change fit in Cyborg, you can stop here and post this for review to
preliminary feedback. If so please say: get preliminary feedback. If so please say:
Posting to get preliminary feedback on the scope of this spec. Posting to get preliminary feedback on the scope of this spec.
Alternatives Alternatives

View File

@ -20,3 +20,4 @@ sphinxcontrib-seqdiag # BSD
reno # Apache-2.0 reno # Apache-2.0
os-api-ref # Apache-2.0 os-api-ref # Apache-2.0
tempest # Apache-2.0 tempest # Apache-2.0
doc8>=0.6.0 # Apache-2.0

View File

@ -31,6 +31,7 @@ commands =
[testenv:pep8] [testenv:pep8]
commands = pep8 {posargs} commands = pep8 {posargs}
doc8 {posargs}
[testenv:pep8-constraints] [testenv:pep8-constraints]
install_command = {[testenv:common-constraints]install_command} install_command = {[testenv:common-constraints]install_command}
@ -42,6 +43,10 @@ commands = {posargs}
[testenv:cover] [testenv:cover]
commands = python setup.py testr --coverage --testr-args='{posargs}' commands = python setup.py testr --coverage --testr-args='{posargs}'
[doc8]
ignore-path = .venv,.git,.tox,*cyborg/locale*,*lib/python*,*cyborg.egg*,api-ref/build,doc/build,doc/source/contributor/api
[testenv:docs] [testenv:docs]
commands = commands =
python setup.py build_sphinx python setup.py build_sphinx