更新PCI设备规格(UpdatePciDeviceSpec)

API请求

URLs
PUT zstack/v1/pci-device-specs/{uuid}/actions
Headers
Authorization: OAuth the-session-uuid
Body
{
  "updatePciDeviceSpec": {
    "name": "MSI_GTX1060",
    "description": "NVIDIA Corporation, GP106 [GeForce GTX 1060 6GB], a1, VGA compatible controller",
    "romContent": "*BASE64 ENCODED ROM CONTENT*",
    "romVersion": "86.06.0E.00.29",
    "abandonSpecRom": false,
    "state": "Enabled"
  },
  "systemTags": [],
  "userTags": []
}
Note: 上述示例中systemTagsuserTags字段可以省略。列出是为了表示body中可以包含这两个字段。
Curl示例
curl -H "Content-Type: application/json;charset=UTF-8" \
-H "Authorization: OAuth b86c9016b4f24953a9edefb53ca0678c" \
-X PUT -d '{"updatePciDeviceSpec":{"name":"MSI_GTX1060","description":"NVIDIA Corporation, GP106 [GeForce GTX 1060 6GB], a1, VGA compatible controller","romContent":"*BASE64 ENCODED ROM CONTENT*","romVersion":"86.06.0E.00.29","abandonSpecRom":false,"state":"Enabled"}}' http://localhost:8080/zstack/v1/pci-device-specs/78ba2350be1e451597c2d42f778d0241/actions
参数列表
名字 类型 位置 描述 可选值 起始版本
uuid String url 资源的UUID,唯一标示该资源 3.5.0
name (可选) String body(包含在updatePciDeviceSpec结构中) 资源名称 3.5.0
description (可选) String body(包含在updatePciDeviceSpec结构中) 资源的详细描述 3.5.0
romContent (可选) String body(包含在updatePciDeviceSpec结构中) BASE64编码后的固件内容 3.5.0
romVersion (可选) String body(包含在updatePciDeviceSpec结构中) 固件版本 3.5.0
abandonSpecRom (可选) boolean body(包含在updatePciDeviceSpec结构中) 删除已有固件 3.5.0
state (可选) String body(包含在updatePciDeviceSpec结构中) PCI设备规格启用状态
  • Enabled
  • Disabled
3.5.0
systemTags (可选) List body 系统标签 3.5.0
userTags (可选) List body 用户标签 3.5.0

API返回

返回示例
{
  "inventory": {
    "uuid": "ff483f5d5bf14587ac2d46a565b0f28f",
    "name": "MSI_GTX1060",
    "description": "NVIDIA Corporation, GP106 [GeForce GTX 1060 6GB], a1, VGA compatible controller",
    "vendorId": "10de",
    "deviceId": "1c03",
    "subvendorId": "1462",
    "subdeviceId": "3283",
    "type": "GPU_Video_Controller",
    "state": "Enabled",
    "romVersion": "86.06.0E.00.28",
    "createDate": "Nov 14, 2017 10:20:57 PM",
    "lastOpDate": "Nov 14, 2017 10:20:57 PM"
  }
}
名字 类型 描述 起始版本
error ErrorCode 错误码,若不为null,则表示操作失败, 操作成功时该字段为null。 详情参考error 3.5.0
inventory PciDeviceSpecInventory 详情参考inventory 3.5.0
#error
名字 类型 描述 起始版本
code String 错误码号,错误的全局唯一标识,例如SYS.1000, HOST.1001 3.5.0
description String 错误的概要描述 3.5.0
details String 错误的详细信息 3.5.0
elaboration String 保留字段,默认为null 3.5.0
opaque LinkedHashMap 保留字段,默认为null 3.5.0
cause ErrorCode 根错误,引发当前错误的源错误,若无原错误,该字段为null 3.5.0
#inventory
名字 类型 描述 起始版本
uuid String 资源的UUID,唯一标示该资源 3.5.0
name String 资源名称 3.5.0
description String 资源的详细描述 3.5.0
vendorId String 供应商ID 3.5.0
deviceId String 设备ID 3.5.0
subvendorId String 子供应商ID 3.5.0
subdeviceId String 子设备ID 3.5.0
ramSize String 显存容量 3.5.0
maxPartNum Integer 最大切分数量 3.5.0
isVirtual Boolean 是否虚拟设备 3.5.0
romVersion String 固件版本 3.5.0
romMd5sum String 固件MD5 3.5.0
createDate Timestamp 创建时间 3.5.0
lastOpDate Timestamp 最后一次修改时间 3.5.0
type PciDeviceType 详情参考type 3.5.0
state PciDeviceSpecState 详情参考state 3.5.0
#type
名字 类型 描述 起始版本
GPU_Video_Controller PciDeviceType GPU显卡控制器 2.1
GPU_Audio_Controller PciDeviceType GPU声卡控制器 2.1
GPU_3D_Controller PciDeviceType GPU 3D控制器 2.1
Moxa_Device PciDeviceType MOXA卡 2.1
Generic PciDeviceType 一般设备 2.1
#state
名字 类型 描述 起始版本
Enabled PciDeviceSpecState 启用 3.5.0
Disabled PciDeviceSpecState 停用 3.5.0

SDK示例

Java SDK
UpdatePciDeviceSpecAction action = new UpdatePciDeviceSpecAction();
action.uuid = "4fd1d8c83d674e7abaa931a3972a37da";
action.name = "MSI_GTX1060";
action.description = "NVIDIA Corporation, GP106 [GeForce GTX 1060 6GB], a1, VGA compatible controller";
action.romContent = "*BASE64 ENCODED ROM CONTENT*";
action.romVersion = "86.06.0E.00.29";
action.abandonSpecRom = false;
action.state = "Enabled";
action.sessionId = "b86c9016b4f24953a9edefb53ca0678c";
UpdatePciDeviceSpecAction.Result res = action.call();
Python SDK
UpdatePciDeviceSpecAction action = UpdatePciDeviceSpecAction()
action.uuid = "12de0d18f2e24fb8b178644cfcad105a"
action.name = "MSI_GTX1060"
action.description = "NVIDIA Corporation, GP106 [GeForce GTX 1060 6GB], a1, VGA compatible controller"
action.romContent = "*BASE64 ENCODED ROM CONTENT*"
action.romVersion = "86.06.0E.00.29"
action.abandonSpecRom = false
action.state = "Enabled"
action.sessionId = "b86c9016b4f24953a9edefb53ca0678c"
UpdatePciDeviceSpecAction.Result res = action.call()