Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
0a2cfaf3
L
libvirt
项目概览
openeuler
/
libvirt
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
L
libvirt
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
0a2cfaf3
编写于
4月 26, 2016
作者:
P
Peter Krempa
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
qemu: hotplug: Assume QEMU_CAPS_DEVICE in qemuDomainAttachNetDevice
上级
375a3d75
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
14 addition
and
39 deletion
+14
-39
src/qemu/qemu_hotplug.c
src/qemu/qemu_hotplug.c
+14
-39
未找到文件。
src/qemu/qemu_hotplug.c
浏览文件 @
0a2cfaf3
...
...
@@ -814,7 +814,6 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
char
*
netstr
=
NULL
;
virNetDevVPortProfilePtr
vport
=
NULL
;
int
ret
=
-
1
;
virDevicePCIAddress
guestAddr
;
int
vlan
;
bool
releaseaddr
=
false
;
bool
iface_connected
=
false
;
...
...
@@ -949,10 +948,8 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
goto
cleanup
;
}
if
(
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_DEVICE
))
{
if
(
qemuAssignDeviceNetAlias
(
vm
->
def
,
net
,
-
1
)
<
0
)
goto
cleanup
;
}
if
(
qemuAssignDeviceNetAlias
(
vm
->
def
,
net
,
-
1
)
<
0
)
goto
cleanup
;
if
(
qemuDomainMachineIsS390CCW
(
vm
->
def
)
&&
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_VIRTIO_CCW
))
{
...
...
@@ -964,15 +961,13 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
virReportError
(
VIR_ERR_CONFIG_UNSUPPORTED
,
"%s"
,
_
(
"virtio-s390 net device cannot be hotplugged."
));
goto
cleanup
;
}
else
if
(
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_DEVICE
)
&&
virDomainPCIAddressEnsureAddr
(
priv
->
pciaddrs
,
&
net
->
info
)
<
0
)
{
}
else
if
(
virDomainPCIAddressEnsureAddr
(
priv
->
pciaddrs
,
&
net
->
info
)
<
0
)
{
goto
cleanup
;
}
releaseaddr
=
true
;
if
(
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_NETDEV
)
&&
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_DEVICE
))
{
if
(
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_NETDEV
))
{
vlan
=
-
1
;
}
else
{
vlan
=
qemuDomainNetVLAN
(
net
);
...
...
@@ -998,8 +993,7 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
goto
cleanup
;
}
if
(
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_NETDEV
)
&&
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_DEVICE
))
{
if
(
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_NETDEV
))
{
if
(
!
(
netstr
=
qemuBuildHostNetStr
(
net
,
driver
,
','
,
-
1
,
tapfdName
,
tapfdSize
,
...
...
@@ -1014,8 +1008,7 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
}
qemuDomainObjEnterMonitor
(
driver
,
vm
);
if
(
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_NETDEV
)
&&
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_DEVICE
))
{
if
(
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_NETDEV
))
{
if
(
qemuMonitorAddNetdev
(
priv
->
mon
,
netstr
,
tapfd
,
tapfdName
,
tapfdSize
,
vhostfd
,
vhostfdName
,
vhostfdSize
)
<
0
)
{
...
...
@@ -1040,32 +1033,15 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
for
(
i
=
0
;
i
<
vhostfdSize
;
i
++
)
VIR_FORCE_CLOSE
(
vhostfd
[
i
]);
if
(
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_DEVICE
))
{
if
(
!
(
nicstr
=
qemuBuildNicDevStr
(
vm
->
def
,
net
,
vlan
,
0
,
vhostfdSize
,
priv
->
qemuCaps
)))
goto
try_remove
;
}
else
{
if
(
!
(
nicstr
=
qemuBuildNicStr
(
net
,
NULL
,
vlan
)))
goto
try_remove
;
}
if
(
!
(
nicstr
=
qemuBuildNicDevStr
(
vm
->
def
,
net
,
vlan
,
0
,
vhostfdSize
,
priv
->
qemuCaps
)))
goto
try_remove
;
qemuDomainObjEnterMonitor
(
driver
,
vm
);
if
(
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_DEVICE
))
{
if
(
qemuMonitorAddDevice
(
priv
->
mon
,
nicstr
)
<
0
)
{
ignore_value
(
qemuDomainObjExitMonitor
(
driver
,
vm
));
virDomainAuditNet
(
vm
,
NULL
,
net
,
"attach"
,
false
);
goto
try_remove
;
}
}
else
{
guestAddr
=
net
->
info
.
addr
.
pci
;
if
(
qemuMonitorAddPCINetwork
(
priv
->
mon
,
nicstr
,
&
guestAddr
)
<
0
)
{
ignore_value
(
qemuDomainObjExitMonitor
(
driver
,
vm
));
virDomainAuditNet
(
vm
,
NULL
,
net
,
"attach"
,
false
);
goto
try_remove
;
}
net
->
info
.
type
=
VIR_DOMAIN_DEVICE_ADDRESS_TYPE_PCI
;
memcpy
(
&
net
->
info
.
addr
.
pci
,
&
guestAddr
,
sizeof
(
guestAddr
));
if
(
qemuMonitorAddDevice
(
priv
->
mon
,
nicstr
)
<
0
)
{
ignore_value
(
qemuDomainObjExitMonitor
(
driver
,
vm
));
virDomainAuditNet
(
vm
,
NULL
,
net
,
"attach"
,
false
);
goto
try_remove
;
}
if
(
qemuDomainObjExitMonitor
(
driver
,
vm
)
<
0
)
goto
cleanup
;
...
...
@@ -1160,8 +1136,7 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
goto
cleanup
;
if
(
vlan
<
0
)
{
if
(
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_NETDEV
)
&&
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_DEVICE
))
{
if
(
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_NETDEV
))
{
char
*
netdev_name
;
if
(
virAsprintf
(
&
netdev_name
,
"host%s"
,
net
->
info
.
alias
)
<
0
)
goto
cleanup
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录