Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
89e991a2
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看板
提交
89e991a2
编写于
3月 02, 2015
作者:
J
Ján Tomko
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Assign an address when hotplugging a virtio-serial device
上级
ee0d97a7
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
20 addition
and
3 deletion
+20
-3
src/qemu/qemu_hotplug.c
src/qemu/qemu_hotplug.c
+19
-2
tests/qemuhotplugtest.c
tests/qemuhotplugtest.c
+1
-1
未找到文件。
src/qemu/qemu_hotplug.c
浏览文件 @
89e991a2
...
...
@@ -1541,6 +1541,8 @@ int qemuDomainAttachChrDevice(virQEMUDriverPtr driver,
virDomainDefPtr
vmdef
=
vm
->
def
;
char
*
devstr
=
NULL
;
char
*
charAlias
=
NULL
;
bool
need_release
=
false
;
bool
allowZero
=
false
;
if
(
!
virQEMUCapsGet
(
priv
->
qemuCaps
,
QEMU_CAPS_DEVICE
))
{
virReportError
(
VIR_ERR_OPERATION_INVALID
,
"%s"
,
...
...
@@ -1551,6 +1553,16 @@ int qemuDomainAttachChrDevice(virQEMUDriverPtr driver,
if
(
qemuAssignDeviceChrAlias
(
vmdef
,
chr
,
-
1
)
<
0
)
goto
cleanup
;
if
(
chr
->
deviceType
==
VIR_DOMAIN_CHR_DEVICE_TYPE_CONSOLE
&&
chr
->
targetType
==
VIR_DOMAIN_CHR_CONSOLE_TARGET_TYPE_VIRTIO
)
allowZero
=
true
;
if
(
virDomainVirtioSerialAddrAutoAssign
(
priv
->
vioserialaddrs
,
&
chr
->
info
,
allowZero
)
<
0
)
goto
cleanup
;
need_release
=
true
;
if
(
qemuBuildChrDeviceStr
(
&
devstr
,
vm
->
def
,
chr
,
priv
->
qemuCaps
)
<
0
)
goto
cleanup
;
...
...
@@ -1582,6 +1594,8 @@ int qemuDomainAttachChrDevice(virQEMUDriverPtr driver,
cleanup:
if
(
ret
<
0
&&
virDomainObjIsActive
(
vm
))
qemuDomainChrInsertPreAllocCleanup
(
vm
->
def
,
chr
);
if
(
ret
<
0
&&
need_release
)
virDomainVirtioSerialAddrRelease
(
priv
->
vioserialaddrs
,
&
chr
->
info
);
VIR_FREE
(
charAlias
);
VIR_FREE
(
devstr
);
return
ret
;
...
...
@@ -4120,10 +4134,13 @@ int qemuDomainDetachChrDevice(virQEMUDriverPtr driver,
goto
cleanup
;
rc
=
qemuDomainWaitForDeviceRemoval
(
vm
);
if
(
rc
==
0
||
rc
==
1
)
if
(
rc
==
0
||
rc
==
1
)
{
virDomainVirtioSerialAddrRelease
(
priv
->
vioserialaddrs
,
&
tmpChr
->
info
);
ret
=
qemuDomainRemoveChrDevice
(
driver
,
vm
,
tmpChr
);
else
}
else
{
ret
=
0
;
}
cleanup:
qemuDomainResetDeviceRemoval
(
vm
);
...
...
tests/qemuhotplugtest.c
浏览文件 @
89e991a2
...
...
@@ -86,7 +86,7 @@ qemuHotplugCreateObjects(virDomainXMLOptionPtr xmlopt,
if
(
event
)
virQEMUCapsSet
(
priv
->
qemuCaps
,
QEMU_CAPS_DEVICE_DEL_EVENT
);
if
(
qemuDomainAssign
PCI
Addresses
((
*
vm
)
->
def
,
priv
->
qemuCaps
,
*
vm
)
<
0
)
if
(
qemuDomainAssignAddresses
((
*
vm
)
->
def
,
priv
->
qemuCaps
,
*
vm
)
<
0
)
goto
cleanup
;
if
(
qemuAssignDeviceAliases
((
*
vm
)
->
def
,
priv
->
qemuCaps
)
<
0
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录