Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
3a7b528d
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看板
提交
3a7b528d
编写于
5月 15, 2008
作者:
D
Daniel P. Berrange
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add support for Xen input device in QEMU driver for xenner
上级
2c37f479
变更
8
隐藏空白更改
内联
并排
Showing
8 changed file
with
81 addition
and
21 deletion
+81
-21
ChangeLog
ChangeLog
+10
-0
src/qemu_conf.c
src/qemu_conf.c
+41
-19
src/qemu_conf.h
src/qemu_conf.h
+2
-1
src/qemu_driver.c
src/qemu_driver.c
+1
-1
tests/qemuxml2argvdata/qemuxml2argv-input-xen.args
tests/qemuxml2argvdata/qemuxml2argv-input-xen.args
+1
-0
tests/qemuxml2argvdata/qemuxml2argv-input-xen.xml
tests/qemuxml2argvdata/qemuxml2argv-input-xen.xml
+24
-0
tests/qemuxml2argvtest.c
tests/qemuxml2argvtest.c
+1
-0
tests/qemuxml2xmltest.c
tests/qemuxml2xmltest.c
+1
-0
未找到文件。
ChangeLog
浏览文件 @
3a7b528d
Thu May 15 12:08:08 EST 2008 Daniel P. Berrange <berrange@redhat.com>
Support paravirt framebuffer input configuration for xenner guests
* src/qemu_drive.c, src/qemu_conf.c, src/qemu_conf.h: Add support
for 'xen' input device type for Xenner PVFB
* tests/qemuxml2argv-input-xen.{args,xml}: Test case data
files for xen input devices
* tests/qemuxml2argvtest.c, tests/qemuxml2xmltest.c: Add
test case for xen input devices
Thu May 15 11:57:08 EST 2008 Daniel P. Berrange <berrange@redhat.com>
Support paravirt disk configuration for xenner guests
...
...
src/qemu_conf.c
浏览文件 @
3a7b528d
...
...
@@ -1365,6 +1365,7 @@ cleanup:
/* Parse the XML definition for a network interface */
static
int
qemudParseInputXML
(
virConnectPtr
conn
,
const
struct
qemud_vm_def
*
vm
,
struct
qemud_vm_input_def
*
input
,
xmlNodePtr
node
)
{
xmlChar
*
type
=
NULL
;
...
...
@@ -1391,26 +1392,46 @@ static int qemudParseInputXML(virConnectPtr conn,
}
if
(
bus
)
{
if
(
STREQ
((
const
char
*
)
bus
,
"ps2"
))
{
/* Only allow mouse */
if
(
input
->
type
==
QEMU_INPUT_TYPE_TABLET
)
{
if
(
STREQ
(
vm
->
os
.
type
,
"hvm"
))
{
if
(
STREQ
((
const
char
*
)
bus
,
"ps2"
))
{
/* Only allow mouse */
if
(
input
->
type
!=
QEMU_INPUT_TYPE_MOUSE
)
{
qemudReportError
(
conn
,
NULL
,
NULL
,
VIR_ERR_INTERNAL_ERROR
,
_
(
"ps2 bus does not support %s input device"
),
(
const
char
*
)
type
);
goto
error
;
}
input
->
bus
=
QEMU_INPUT_BUS_PS2
;
}
else
if
(
STREQ
((
const
char
*
)
bus
,
"usb"
))
{
/* Allow mouse & tablet */
input
->
bus
=
QEMU_INPUT_BUS_USB
;
}
else
{
qemudReportError
(
conn
,
NULL
,
NULL
,
VIR_ERR_INTERNAL_ERROR
,
_
(
"ps2 bus does not support %s input device"
),
(
const
char
*
)
type
);
_
(
"unsupported input bus %s"
),
(
const
char
*
)
bus
);
goto
error
;
}
input
->
bus
=
QEMU_INPUT_BUS_PS2
;
}
else
if
(
STREQ
((
const
char
*
)
bus
,
"usb"
))
{
/* Allow mouse & keyboard */
input
->
bus
=
QEMU_INPUT_BUS_USB
;
}
else
{
qemudReportError
(
conn
,
NULL
,
NULL
,
VIR_ERR_INTERNAL_ERROR
,
_
(
"unsupported input bus %s"
),
(
const
char
*
)
bus
);
goto
error
;
if
(
STREQ
((
const
char
*
)
bus
,
"xen"
))
{
/* Allow mouse only */
input
->
bus
=
QEMU_INPUT_BUS_XEN
;
if
(
input
->
type
!=
QEMU_INPUT_TYPE_MOUSE
)
{
qemudReportError
(
conn
,
NULL
,
NULL
,
VIR_ERR_INTERNAL_ERROR
,
_
(
"xen bus does not support %s input device"
),
(
const
char
*
)
type
);
goto
error
;
}
}
else
{
qemudReportError
(
conn
,
NULL
,
NULL
,
VIR_ERR_INTERNAL_ERROR
,
_
(
"unsupported input bus %s"
),
(
const
char
*
)
bus
);
goto
error
;
}
}
}
else
{
if
(
input
->
type
==
QEMU_INPUT_TYPE_MOUSE
)
input
->
bus
=
QEMU_INPUT_BUS_PS2
;
else
input
->
bus
=
QEMU_INPUT_BUS_USB
;
if
(
!
strcmp
(
vm
->
os
.
type
,
"hvm"
))
{
if
(
input
->
type
==
QEMU_INPUT_TYPE_MOUSE
)
input
->
bus
=
QEMU_INPUT_BUS_PS2
;
else
input
->
bus
=
QEMU_INPUT_BUS_USB
;
}
else
{
input
->
bus
=
QEMU_INPUT_BUS_XEN
;
}
}
xmlFree
(
type
);
...
...
@@ -1998,7 +2019,7 @@ static struct qemud_vm_def *qemudParseXML(virConnectPtr conn,
"%s"
,
_
(
"failed to allocate space for input string"
));
goto
error
;
}
if
(
qemudParseInputXML
(
conn
,
input
,
obj
->
nodesetval
->
nodeTab
[
i
])
<
0
)
{
if
(
qemudParseInputXML
(
conn
,
def
,
input
,
obj
->
nodesetval
->
nodeTab
[
i
])
<
0
)
{
free
(
input
);
goto
error
;
}
...
...
@@ -2852,7 +2873,7 @@ static int qemudSaveConfig(virConnectPtr conn,
struct
qemud_vm_device_def
*
qemudParseVMDeviceDef
(
virConnectPtr
conn
,
struct
qemud_driver
*
driver
ATTRIBUTE_UNUSED
,
const
struct
qemud_vm_def
*
def
,
const
char
*
xmlStr
)
{
xmlDocPtr
xml
;
...
...
@@ -2880,7 +2901,7 @@ qemudParseVMDeviceDef(virConnectPtr conn,
qemudParseInterfaceXML
(
conn
,
&
(
dev
->
data
.
net
),
node
);
}
else
if
(
xmlStrEqual
(
node
->
name
,
BAD_CAST
"input"
))
{
dev
->
type
=
QEMUD_DEVICE_DISK
;
qemudParseInputXML
(
conn
,
&
(
dev
->
data
.
input
),
node
);
qemudParseInputXML
(
conn
,
def
,
&
(
dev
->
data
.
input
),
node
);
}
else
if
(
xmlStrEqual
(
node
->
name
,
BAD_CAST
"sound"
))
{
dev
->
type
=
QEMUD_DEVICE_SOUND
;
qemudParseSoundXML
(
conn
,
&
(
dev
->
data
.
sound
),
node
);
...
...
@@ -3950,14 +3971,15 @@ char *qemudGenerateXML(virConnectPtr conn,
input
=
def
->
inputs
;
while
(
input
)
{
if
(
input
->
bus
!=
QEMU_INPUT_BUS_PS2
)
if
(
input
->
bus
==
QEMU_INPUT_BUS_USB
)
virBufferVSprintf
(
&
buf
,
" <input type='%s' bus='usb'/>
\n
"
,
input
->
type
==
QEMU_INPUT_TYPE_MOUSE
?
"mouse"
:
"tablet"
);
input
=
input
->
next
;
}
/* If graphics is enable, add implicit mouse */
if
(
def
->
graphicsType
!=
QEMUD_GRAPHICS_NONE
)
virBufferAddLit
(
&
buf
,
" <input type='mouse' bus='ps2'/>
\n
"
);
virBufferVSprintf
(
&
buf
,
" <input type='mouse' bus='%s'/>
\n
"
,
STREQ
(
def
->
os
.
type
,
"hvm"
)
?
"ps2"
:
"xen"
);
switch
(
def
->
graphicsType
)
{
case
QEMUD_GRAPHICS_VNC
:
...
...
src/qemu_conf.h
浏览文件 @
3a7b528d
...
...
@@ -189,6 +189,7 @@ enum qemu_vm_input_type {
enum
qemu_vm_input_bus
{
QEMU_INPUT_BUS_PS2
,
QEMU_INPUT_BUS_USB
,
QEMU_INPUT_BUS_XEN
,
};
struct
qemud_vm_input_def
{
...
...
@@ -474,7 +475,7 @@ void qemudRemoveInactiveVM (struct qemud_driver *driver,
struct
qemud_vm_device_def
*
qemudParseVMDeviceDef
(
virConnectPtr
conn
,
struct
qemud_driver
*
driver
,
const
struct
qemud_vm_def
*
def
,
const
char
*
xmlStr
);
struct
qemud_vm_def
*
...
...
src/qemu_driver.c
浏览文件 @
3a7b528d
...
...
@@ -2516,7 +2516,7 @@ static int qemudDomainAttachDevice(virDomainPtr dom,
return
-
1
;
}
dev
=
qemudParseVMDeviceDef
(
dom
->
conn
,
driver
,
xml
);
dev
=
qemudParseVMDeviceDef
(
dom
->
conn
,
vm
->
def
,
xml
);
if
(
dev
==
NULL
)
{
return
-
1
;
}
...
...
tests/qemuxml2argvdata/qemuxml2argv-input-xen.args
0 → 100644
浏览文件 @
3a7b528d
/usr/bin/xenner -M xenner -m 214 -smp 1 -monitor pty -no-acpi -boot c -hda /dev/HostVG/QEMUGuest1 -net none -serial none -parallel none -usb -vnc :-5901
\ No newline at end of file
tests/qemuxml2argvdata/qemuxml2argv-input-xen.xml
0 → 100644
浏览文件 @
3a7b528d
<domain
type=
'kvm'
>
<name>
QEMUGuest1
</name>
<uuid>
c7a5fdbd-edaf-9455-926a-d65c16db1809
</uuid>
<memory>
219200
</memory>
<currentMemory>
219200
</currentMemory>
<vcpu>
1
</vcpu>
<os>
<type>
xen
</type>
<boot
dev=
'hd'
/>
</os>
<clock
offset=
'utc'
/>
<on_poweroff>
destroy
</on_poweroff>
<on_reboot>
restart
</on_reboot>
<on_crash>
destroy
</on_crash>
<devices>
<emulator>
/usr/bin/xenner
</emulator>
<disk
type=
'block'
device=
'disk'
>
<source
dev=
'/dev/HostVG/QEMUGuest1'
/>
<target
dev=
'hda'
bus=
'ide'
/>
</disk>
<input
type=
'mouse'
bus=
'xen'
/>
<graphics
type=
'vnc'
port=
'-1'
/>
</devices>
</domain>
tests/qemuxml2argvtest.c
浏览文件 @
3a7b528d
...
...
@@ -158,6 +158,7 @@ main(int argc, char **argv)
DO_TEST
(
"graphics-sdl"
,
0
);
DO_TEST
(
"input-usbmouse"
,
0
);
DO_TEST
(
"input-usbtablet"
,
0
);
DO_TEST
(
"input-xen"
,
0
);
DO_TEST
(
"misc-acpi"
,
0
);
DO_TEST
(
"misc-no-reboot"
,
0
);
DO_TEST
(
"net-user"
,
0
);
...
...
tests/qemuxml2xmltest.c
浏览文件 @
3a7b528d
...
...
@@ -107,6 +107,7 @@ main(int argc, char **argv)
DO_TEST
(
"graphics-sdl"
);
DO_TEST
(
"input-usbmouse"
);
DO_TEST
(
"input-usbtablet"
);
DO_TEST
(
"input-xen"
);
DO_TEST
(
"misc-acpi"
);
DO_TEST
(
"misc-no-reboot"
);
DO_TEST
(
"net-user"
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录