Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
da196338
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看板
提交
da196338
编写于
8月 27, 2008
作者:
D
Daniel P. Berrange
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix QEMU domain creation by allowing virExec to preserve certain FDs
上级
2875ed81
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
32 addition
and
9 deletion
+32
-9
src/lxc_driver.c
src/lxc_driver.c
+11
-3
src/qemu_driver.c
src/qemu_driver.c
+9
-2
src/storage_backend.c
src/storage_backend.c
+4
-2
src/util.c
src/util.c
+6
-2
src/util.h
src/util.h
+2
-0
未找到文件。
src/lxc_driver.c
浏览文件 @
da196338
...
...
@@ -621,6 +621,10 @@ static int lxcControllerStart(virConnectPtr conn,
const
char
**
largv
=
NULL
;
pid_t
child
;
int
status
;
fd_set
keepfd
;
char
appPtyStr
[
30
];
FD_ZERO
(
&
keepfd
);
#define ADD_ARG_SPACE \
do { \
...
...
@@ -644,11 +648,13 @@ static int lxcControllerStart(virConnectPtr conn,
goto no_memory; \
} while (0)
snprintf
(
appPtyStr
,
sizeof
(
appPtyStr
),
"%d"
,
appPty
);
ADD_ARG_LIT
(
vm
->
def
->
emulator
);
ADD_ARG_LIT
(
"--name"
);
ADD_ARG_LIT
(
vm
->
def
->
name
);
ADD_ARG_LIT
(
"--console"
);
ADD_ARG_LIT
(
"0"
);
/* Passing console master PTY as FD 0 */
ADD_ARG_LIT
(
appPtyStr
);
ADD_ARG_LIT
(
"--background"
);
for
(
i
=
0
;
i
<
nveths
;
i
++
)
{
...
...
@@ -658,10 +664,12 @@ static int lxcControllerStart(virConnectPtr conn,
ADD_ARG
(
NULL
);
vm
->
stdin_fd
=
appPty
;
/* Passing console master PTY as FD 0 */
vm
->
stdin_fd
=
-
1
;
vm
->
stdout_fd
=
vm
->
stderr_fd
=
logfd
;
if
(
virExec
(
conn
,
largv
,
NULL
,
&
child
,
FD_SET
(
appPty
,
&
keepfd
);
if
(
virExec
(
conn
,
largv
,
NULL
,
&
keepfd
,
&
child
,
vm
->
stdin_fd
,
&
vm
->
stdout_fd
,
&
vm
->
stderr_fd
,
VIR_EXEC_NONE
)
<
0
)
goto
cleanup
;
...
...
src/qemu_driver.c
浏览文件 @
da196338
...
...
@@ -847,6 +847,9 @@ static int qemudStartVMDaemon(virConnectPtr conn,
int
*
tapfds
=
NULL
;
int
ntapfds
=
0
;
int
qemuCmdFlags
;
fd_set
keepfd
;
FD_ZERO
(
&
keepfd
);
if
(
virDomainIsActive
(
vm
))
{
qemudReportError
(
conn
,
NULL
,
NULL
,
VIR_ERR_INTERNAL_ERROR
,
...
...
@@ -950,7 +953,10 @@ static int qemudStartVMDaemon(virConnectPtr conn,
vm
->
stdout_fd
=
-
1
;
vm
->
stderr_fd
=
-
1
;
ret
=
virExec
(
conn
,
argv
,
NULL
,
&
vm
->
pid
,
for
(
i
=
0
;
i
<
ntapfds
;
i
++
)
FD_SET
(
tapfds
[
i
],
&
keepfd
);
ret
=
virExec
(
conn
,
argv
,
NULL
,
&
keepfd
,
&
vm
->
pid
,
vm
->
stdin_fd
,
&
vm
->
stdout_fd
,
&
vm
->
stderr_fd
,
VIR_EXEC_NONBLOCK
);
if
(
ret
==
0
)
{
...
...
@@ -1219,7 +1225,8 @@ dhcpStartDhcpDaemon(virConnectPtr conn,
if
(
qemudBuildDnsmasqArgv
(
conn
,
network
,
&
argv
)
<
0
)
return
-
1
;
ret
=
virExec
(
conn
,
argv
,
NULL
,
&
network
->
dnsmasqPid
,
-
1
,
NULL
,
NULL
,
VIR_EXEC_NONBLOCK
);
ret
=
virExec
(
conn
,
argv
,
NULL
,
NULL
,
&
network
->
dnsmasqPid
,
-
1
,
NULL
,
NULL
,
VIR_EXEC_NONBLOCK
);
for
(
i
=
0
;
argv
[
i
];
i
++
)
VIR_FREE
(
argv
[
i
]);
...
...
src/storage_backend.c
浏览文件 @
da196338
...
...
@@ -403,7 +403,8 @@ virStorageBackendRunProgRegex(virConnectPtr conn,
/* Run the program and capture its output */
if
(
virExec
(
conn
,
prog
,
NULL
,
&
child
,
-
1
,
&
fd
,
NULL
,
VIR_EXEC_NONE
)
<
0
)
{
if
(
virExec
(
conn
,
prog
,
NULL
,
NULL
,
&
child
,
-
1
,
&
fd
,
NULL
,
VIR_EXEC_NONE
)
<
0
)
{
goto
cleanup
;
}
...
...
@@ -537,7 +538,8 @@ virStorageBackendRunProgNul(virConnectPtr conn,
v
[
i
]
=
NULL
;
/* Run the program and capture its output */
if
(
virExec
(
conn
,
prog
,
NULL
,
&
child
,
-
1
,
&
fd
,
NULL
,
VIR_EXEC_NONE
)
<
0
)
{
if
(
virExec
(
conn
,
prog
,
NULL
,
NULL
,
&
child
,
-
1
,
&
fd
,
NULL
,
VIR_EXEC_NONE
)
<
0
)
{
goto
cleanup
;
}
...
...
src/util.c
浏览文件 @
da196338
...
...
@@ -132,6 +132,7 @@ int
virExec
(
virConnectPtr
conn
,
const
char
*
const
*
argv
,
const
char
*
const
*
envp
,
const
fd_set
*
keepfd
,
int
*
retpid
,
int
infd
,
int
*
outfd
,
int
*
errfd
,
int
flags
)
{
...
...
@@ -293,7 +294,9 @@ virExec(virConnectPtr conn,
if
(
i
!=
infd
&&
i
!=
null
&&
i
!=
childout
&&
i
!=
childerr
)
i
!=
childerr
&&
(
!
keepfd
||
!
FD_ISSET
(
i
,
keepfd
)))
close
(
i
);
if
(
flags
&
VIR_EXEC_DAEMON
)
{
...
...
@@ -403,7 +406,8 @@ virRun(virConnectPtr conn,
int
*
status
)
{
int
childpid
,
exitstatus
,
ret
;
if
((
ret
=
virExec
(
conn
,
argv
,
NULL
,
&
childpid
,
-
1
,
NULL
,
NULL
,
VIR_EXEC_NONE
))
<
0
)
if
((
ret
=
virExec
(
conn
,
argv
,
NULL
,
NULL
,
&
childpid
,
-
1
,
NULL
,
NULL
,
VIR_EXEC_NONE
))
<
0
)
return
ret
;
while
((
ret
=
waitpid
(
childpid
,
&
exitstatus
,
0
)
==
-
1
)
&&
errno
==
EINTR
);
...
...
src/util.h
浏览文件 @
da196338
...
...
@@ -26,6 +26,7 @@
#include "util-lib.h"
#include "verify.h"
#include <sys/select.h>
enum
{
VIR_EXEC_NONE
=
0
,
...
...
@@ -36,6 +37,7 @@ enum {
int
virExec
(
virConnectPtr
conn
,
const
char
*
const
*
argv
,
const
char
*
const
*
envp
,
const
fd_set
*
keepfd
,
int
*
retpid
,
int
infd
,
int
*
outfd
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录