Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
fa12d7c3
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
fa12d7c3
编写于
8月 11, 2014
作者:
T
Taowei
提交者:
Michal Privoznik
8月 15, 2014
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
vbox: Rewrite vboxDomainDetachDevice
上级
6be94596
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
190 addition
and
136 deletion
+190
-136
src/vbox/vbox_common.c
src/vbox/vbox_common.c
+101
-0
src/vbox/vbox_tmpl.c
src/vbox/vbox_tmpl.c
+85
-136
src/vbox/vbox_uniformed_api.h
src/vbox/vbox_uniformed_api.h
+4
-0
未找到文件。
src/vbox/vbox_common.c
浏览文件 @
fa12d7c3
...
@@ -4179,3 +4179,104 @@ int vboxDomainUpdateDeviceFlags(virDomainPtr dom, const char *xml,
...
@@ -4179,3 +4179,104 @@ int vboxDomainUpdateDeviceFlags(virDomainPtr dom, const char *xml,
return
vboxDomainAttachDeviceImpl
(
dom
,
xml
,
1
);
return
vboxDomainAttachDeviceImpl
(
dom
,
xml
,
1
);
}
}
int
vboxDomainDetachDevice
(
virDomainPtr
dom
,
const
char
*
xml
)
{
VBOX_OBJECT_CHECK
(
dom
->
conn
,
int
,
-
1
);
IMachine
*
machine
=
NULL
;
vboxIIDUnion
iid
;
PRUint32
state
;
virDomainDefPtr
def
=
NULL
;
virDomainDeviceDefPtr
dev
=
NULL
;
nsresult
rc
;
VBOX_IID_INITIALIZE
(
&
iid
);
if
(
VIR_ALLOC
(
def
)
<
0
)
return
ret
;
if
(
VIR_STRDUP
(
def
->
os
.
type
,
"hvm"
)
<
0
)
goto
cleanup
;
dev
=
virDomainDeviceDefParse
(
xml
,
def
,
data
->
caps
,
data
->
xmlopt
,
VIR_DOMAIN_XML_INACTIVE
);
if
(
dev
==
NULL
)
goto
cleanup
;
if
(
openSessionForMachine
(
data
,
dom
->
uuid
,
&
iid
,
&
machine
,
false
)
<
0
)
goto
cleanup
;
if
(
!
machine
)
goto
cleanup
;
gVBoxAPI
.
UIMachine
.
GetState
(
machine
,
&
state
);
if
(
gVBoxAPI
.
machineStateChecker
.
Running
(
state
)
||
gVBoxAPI
.
machineStateChecker
.
Paused
(
state
))
{
rc
=
gVBoxAPI
.
UISession
.
OpenExisting
(
data
,
&
iid
,
machine
);
}
else
{
rc
=
gVBoxAPI
.
UISession
.
Open
(
data
,
&
iid
,
machine
);
}
if
(
NS_FAILED
(
rc
))
goto
cleanup
;
rc
=
gVBoxAPI
.
UISession
.
GetMachine
(
data
->
vboxSession
,
&
machine
);
if
(
NS_SUCCEEDED
(
rc
)
&&
machine
)
{
/* ret = -VIR_ERR_ARGUMENT_UNSUPPORTED means the current device don't support hotplug. */
ret
=
-
VIR_ERR_ARGUMENT_UNSUPPORTED
;
if
(
dev
->
type
==
VIR_DOMAIN_DEVICE_DISK
)
{
if
(
gVBoxAPI
.
oldMediumInterface
)
{
int
type
=
virDomainDiskGetType
(
dev
->
data
.
disk
);
if
(
dev
->
data
.
disk
->
device
==
VIR_DOMAIN_DISK_DEVICE_CDROM
)
{
if
(
type
==
VIR_STORAGE_TYPE_FILE
)
{
ret
=
gVBoxAPI
.
detachDVD
(
machine
);
}
else
if
(
type
==
VIR_STORAGE_TYPE_BLOCK
)
{
}
}
else
if
(
dev
->
data
.
disk
->
device
==
VIR_DOMAIN_DISK_DEVICE_FLOPPY
)
{
if
(
type
==
VIR_STORAGE_TYPE_FILE
)
{
ret
=
gVBoxAPI
.
detachFloppy
(
machine
);
}
else
if
(
type
==
VIR_STORAGE_TYPE_BLOCK
)
{
}
}
}
}
else
if
(
dev
->
type
==
VIR_DOMAIN_DEVICE_NET
)
{
}
else
if
(
dev
->
type
==
VIR_DOMAIN_DEVICE_HOSTDEV
)
{
if
(
dev
->
data
.
hostdev
->
mode
==
VIR_DOMAIN_HOSTDEV_MODE_SUBSYS
)
{
if
(
dev
->
data
.
hostdev
->
source
.
subsys
.
type
==
VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_USB
)
{
}
}
}
else
if
(
dev
->
type
==
VIR_DOMAIN_DEVICE_FS
&&
dev
->
data
.
fs
->
type
==
VIR_DOMAIN_FS_TYPE_MOUNT
)
{
PRUnichar
*
nameUtf16
;
VBOX_UTF8_TO_UTF16
(
dev
->
data
.
fs
->
dst
,
&
nameUtf16
);
rc
=
gVBoxAPI
.
UIMachine
.
RemoveSharedFolder
(
machine
,
nameUtf16
);
if
(
NS_FAILED
(
rc
))
{
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
_
(
"could not detach shared folder '%s', rc=%08x"
),
dev
->
data
.
fs
->
dst
,
(
unsigned
)
rc
);
}
else
{
ret
=
0
;
}
VBOX_UTF16_FREE
(
nameUtf16
);
}
gVBoxAPI
.
UIMachine
.
SaveSettings
(
machine
);
VBOX_RELEASE
(
machine
);
if
(
ret
==
-
VIR_ERR_ARGUMENT_UNSUPPORTED
)
{
virReportError
(
VIR_ERR_ARGUMENT_UNSUPPORTED
,
_
(
"Unsupported device type %d"
),
dev
->
type
);
ret
=
-
1
;
}
}
gVBoxAPI
.
UISession
.
Close
(
data
->
vboxSession
);
cleanup:
vboxIIDUnalloc
(
&
iid
);
virDomainDefFree
(
def
);
virDomainDeviceDefFree
(
dev
);
return
ret
;
}
src/vbox/vbox_tmpl.c
浏览文件 @
fa12d7c3
...
@@ -1451,142 +1451,6 @@ _vboxAttachDrivesOld(virDomainDefPtr def ATTRIBUTE_UNUSED,
...
@@ -1451,142 +1451,6 @@ _vboxAttachDrivesOld(virDomainDefPtr def ATTRIBUTE_UNUSED,
#endif
/* VBOX_API_VERSION >= 4000000 */
#endif
/* VBOX_API_VERSION >= 4000000 */
static
int
vboxDomainDetachDevice
(
virDomainPtr
dom
,
const
char
*
xml
)
{
VBOX_OBJECT_CHECK
(
dom
->
conn
,
int
,
-
1
);
IMachine
*
machine
=
NULL
;
vboxIID
iid
=
VBOX_IID_INITIALIZER
;
PRUint32
state
=
MachineState_Null
;
virDomainDefPtr
def
=
NULL
;
virDomainDeviceDefPtr
dev
=
NULL
;
nsresult
rc
;
if
(
VIR_ALLOC
(
def
)
<
0
)
return
ret
;
if
(
VIR_STRDUP
(
def
->
os
.
type
,
"hvm"
)
<
0
)
goto
cleanup
;
dev
=
virDomainDeviceDefParse
(
xml
,
def
,
data
->
caps
,
data
->
xmlopt
,
VIR_DOMAIN_XML_INACTIVE
);
if
(
dev
==
NULL
)
goto
cleanup
;
vboxIIDFromUUID
(
&
iid
,
dom
->
uuid
);
rc
=
VBOX_OBJECT_GET_MACHINE
(
iid
.
value
,
&
machine
);
if
(
NS_FAILED
(
rc
))
{
virReportError
(
VIR_ERR_NO_DOMAIN
,
"%s"
,
_
(
"no domain with matching uuid"
));
goto
cleanup
;
}
if
(
machine
)
{
machine
->
vtbl
->
GetState
(
machine
,
&
state
);
if
((
state
==
MachineState_Running
)
||
(
state
==
MachineState_Paused
))
{
rc
=
VBOX_SESSION_OPEN_EXISTING
(
iid
.
value
,
machine
);
}
else
{
rc
=
VBOX_SESSION_OPEN
(
iid
.
value
,
machine
);
}
if
(
NS_SUCCEEDED
(
rc
))
{
rc
=
data
->
vboxSession
->
vtbl
->
GetMachine
(
data
->
vboxSession
,
&
machine
);
if
(
NS_SUCCEEDED
(
rc
)
&&
machine
)
{
if
(
dev
->
type
==
VIR_DOMAIN_DEVICE_DISK
)
{
#if VBOX_API_VERSION < 3001000
int
type
=
virDomainDiskGetType
(
dev
->
data
.
disk
);
if
(
dev
->
data
.
disk
->
device
==
VIR_DOMAIN_DISK_DEVICE_CDROM
)
{
if
(
type
==
VIR_STORAGE_TYPE_FILE
)
{
IDVDDrive
*
dvdDrive
=
NULL
;
/* Currently CDROM/DVD Drive is always IDE
* Secondary Master so neglecting the following
* parameter dev->data.disk->bus
*/
machine
->
vtbl
->
GetDVDDrive
(
machine
,
&
dvdDrive
);
if
(
dvdDrive
)
{
rc
=
dvdDrive
->
vtbl
->
Unmount
(
dvdDrive
);
if
(
NS_FAILED
(
rc
))
{
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
_
(
"could not de-attach the mounted ISO, rc=%08x"
),
(
unsigned
)
rc
);
}
else
{
ret
=
0
;
}
VBOX_RELEASE
(
dvdDrive
);
}
}
else
if
(
type
==
VIR_STORAGE_TYPE_BLOCK
)
{
}
}
else
if
(
dev
->
data
.
disk
->
device
==
VIR_DOMAIN_DISK_DEVICE_FLOPPY
)
{
if
(
type
==
VIR_STORAGE_TYPE_FILE
)
{
IFloppyDrive
*
floppyDrive
;
machine
->
vtbl
->
GetFloppyDrive
(
machine
,
&
floppyDrive
);
if
(
floppyDrive
)
{
PRBool
enabled
=
PR_FALSE
;
floppyDrive
->
vtbl
->
GetEnabled
(
floppyDrive
,
&
enabled
);
if
(
enabled
)
{
rc
=
floppyDrive
->
vtbl
->
Unmount
(
floppyDrive
);
if
(
NS_FAILED
(
rc
))
{
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
_
(
"could not attach the file "
"to floppy drive, rc=%08x"
),
(
unsigned
)
rc
);
}
else
{
ret
=
0
;
}
}
else
{
/* If you are here means floppy drive is already unmounted
* so don't flag error, just say everything is fine and quit
*/
ret
=
0
;
}
VBOX_RELEASE
(
floppyDrive
);
}
}
else
if
(
type
==
VIR_STORAGE_TYPE_BLOCK
)
{
}
}
#else
/* VBOX_API_VERSION >= 3001000 */
#endif
/* VBOX_API_VERSION >= 3001000 */
}
else
if
(
dev
->
type
==
VIR_DOMAIN_DEVICE_NET
)
{
}
else
if
(
dev
->
type
==
VIR_DOMAIN_DEVICE_HOSTDEV
)
{
if
(
dev
->
data
.
hostdev
->
mode
==
VIR_DOMAIN_HOSTDEV_MODE_SUBSYS
)
{
if
(
dev
->
data
.
hostdev
->
source
.
subsys
.
type
==
VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_USB
)
{
}
}
}
else
if
(
dev
->
type
==
VIR_DOMAIN_DEVICE_FS
&&
dev
->
data
.
fs
->
type
==
VIR_DOMAIN_FS_TYPE_MOUNT
)
{
PRUnichar
*
nameUtf16
;
VBOX_UTF8_TO_UTF16
(
dev
->
data
.
fs
->
dst
,
&
nameUtf16
);
rc
=
machine
->
vtbl
->
RemoveSharedFolder
(
machine
,
nameUtf16
);
if
(
NS_FAILED
(
rc
))
{
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
_
(
"could not detach shared folder '%s', rc=%08x"
),
dev
->
data
.
fs
->
dst
,
(
unsigned
)
rc
);
}
else
{
ret
=
0
;
}
VBOX_UTF16_FREE
(
nameUtf16
);
}
machine
->
vtbl
->
SaveSettings
(
machine
);
VBOX_RELEASE
(
machine
);
}
VBOX_SESSION_CLOSE
();
}
}
cleanup:
vboxIIDUnalloc
(
&
iid
);
virDomainDefFree
(
def
);
virDomainDeviceDefFree
(
dev
);
return
ret
;
}
static
int
static
int
vboxDomainDetachDeviceFlags
(
virDomainPtr
dom
,
const
char
*
xml
,
vboxDomainDetachDeviceFlags
(
virDomainPtr
dom
,
const
char
*
xml
,
unsigned
int
flags
)
unsigned
int
flags
)
...
@@ -7635,6 +7499,33 @@ _attachDVD(vboxGlobalData *data, IMachine *machine, const char *src)
...
@@ -7635,6 +7499,33 @@ _attachDVD(vboxGlobalData *data, IMachine *machine, const char *src)
return
ret
;
return
ret
;
}
}
static
int
_detachDVD
(
IMachine
*
machine
)
{
IDVDDrive
*
dvdDrive
=
NULL
;
int
ret
=
-
1
;
nsresult
rc
;
/* Currently CDROM/DVD Drive is always IDE
* Secondary Master so neglecting the following
* parameter dev->data.disk->bus
*/
machine
->
vtbl
->
GetDVDDrive
(
machine
,
&
dvdDrive
);
if
(
!
dvdDrive
)
return
ret
;
rc
=
dvdDrive
->
vtbl
->
Unmount
(
dvdDrive
);
if
(
NS_FAILED
(
rc
))
{
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
_
(
"could not de-attach the mounted ISO, rc=%08x"
),
(
unsigned
)
rc
);
}
else
{
ret
=
0
;
}
VBOX_RELEASE
(
dvdDrive
);
return
ret
;
}
static
void
static
void
_dumpFloppy
(
virDomainDefPtr
def
,
_dumpFloppy
(
virDomainDefPtr
def
,
vboxGlobalData
*
data
,
vboxGlobalData
*
data
,
...
@@ -7753,6 +7644,41 @@ _attachFloppy(vboxGlobalData *data, IMachine *machine, const char *src)
...
@@ -7753,6 +7644,41 @@ _attachFloppy(vboxGlobalData *data, IMachine *machine, const char *src)
return
ret
;
return
ret
;
}
}
static
int
_detachFloppy
(
IMachine
*
machine
)
{
IFloppyDrive
*
floppyDrive
;
int
ret
=
-
1
;
nsresult
rc
;
machine
->
vtbl
->
GetFloppyDrive
(
machine
,
&
floppyDrive
);
if
(
!
floppyDrive
)
return
ret
;
PRBool
enabled
=
PR_FALSE
;
floppyDrive
->
vtbl
->
GetEnabled
(
floppyDrive
,
&
enabled
);
if
(
enabled
)
{
rc
=
floppyDrive
->
vtbl
->
Unmount
(
floppyDrive
);
if
(
NS_FAILED
(
rc
))
{
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
_
(
"could not attach the file "
"to floppy drive, rc=%08x"
),
(
unsigned
)
rc
);
}
else
{
ret
=
0
;
}
}
else
{
/* If you are here means floppy drive is already unmounted
* so don't flag error, just say everything is fine and quit
*/
ret
=
0
;
}
VBOX_RELEASE
(
floppyDrive
);
return
ret
;
}
#else
/* VBOX_API_VERSION >= 3001000 */
#else
/* VBOX_API_VERSION >= 3001000 */
static
void
static
void
...
@@ -7780,6 +7706,13 @@ _attachDVD(vboxGlobalData *data ATTRIBUTE_UNUSED,
...
@@ -7780,6 +7706,13 @@ _attachDVD(vboxGlobalData *data ATTRIBUTE_UNUSED,
return
0
;
return
0
;
}
}
static
int
_detachDVD
(
IMachine
*
machine
ATTRIBUTE_UNUSED
)
{
vboxUnsupported
();
return
0
;
}
static
void
static
void
_dumpFloppy
(
virDomainDefPtr
def
ATTRIBUTE_UNUSED
,
_dumpFloppy
(
virDomainDefPtr
def
ATTRIBUTE_UNUSED
,
vboxGlobalData
*
data
ATTRIBUTE_UNUSED
,
vboxGlobalData
*
data
ATTRIBUTE_UNUSED
,
...
@@ -7797,6 +7730,13 @@ _attachFloppy(vboxGlobalData *data ATTRIBUTE_UNUSED,
...
@@ -7797,6 +7730,13 @@ _attachFloppy(vboxGlobalData *data ATTRIBUTE_UNUSED,
return
0
;
return
0
;
}
}
static
int
_detachFloppy
(
IMachine
*
machine
ATTRIBUTE_UNUSED
)
{
vboxUnsupported
();
return
0
;
}
#endif
/* VBOX_API_VERSION >= 3001000 */
#endif
/* VBOX_API_VERSION >= 3001000 */
static
void
_pfnUninitialize
(
vboxGlobalData
*
data
)
static
void
_pfnUninitialize
(
vboxGlobalData
*
data
)
...
@@ -8081,6 +8021,12 @@ _machineCreateSharedFolder(IMachine *machine, PRUnichar *name,
...
@@ -8081,6 +8021,12 @@ _machineCreateSharedFolder(IMachine *machine, PRUnichar *name,
#endif
/* VBOX_API_VERSION >= 4000000 */
#endif
/* VBOX_API_VERSION >= 4000000 */
}
}
static
nsresult
_machineRemoveSharedFolder
(
IMachine
*
machine
,
PRUnichar
*
name
)
{
return
machine
->
vtbl
->
RemoveSharedFolder
(
machine
,
name
);
}
static
nsresult
static
nsresult
_machineLaunchVMProcess
(
vboxGlobalData
*
data
,
_machineLaunchVMProcess
(
vboxGlobalData
*
data
,
IMachine
*
machine
ATTRIBUTE_UNUSED
,
IMachine
*
machine
ATTRIBUTE_UNUSED
,
...
@@ -9246,6 +9192,7 @@ static vboxUniformedIMachine _UIMachine = {
...
@@ -9246,6 +9192,7 @@ static vboxUniformedIMachine _UIMachine = {
.
GetStorageControllerByName
=
_machineGetStorageControllerByName
,
.
GetStorageControllerByName
=
_machineGetStorageControllerByName
,
.
AttachDevice
=
_machineAttachDevice
,
.
AttachDevice
=
_machineAttachDevice
,
.
CreateSharedFolder
=
_machineCreateSharedFolder
,
.
CreateSharedFolder
=
_machineCreateSharedFolder
,
.
RemoveSharedFolder
=
_machineRemoveSharedFolder
,
.
LaunchVMProcess
=
_machineLaunchVMProcess
,
.
LaunchVMProcess
=
_machineLaunchVMProcess
,
.
GetAccessible
=
_machineGetAccessible
,
.
GetAccessible
=
_machineGetAccessible
,
.
GetState
=
_machineGetState
,
.
GetState
=
_machineGetState
,
...
@@ -9450,8 +9397,10 @@ void NAME(InstallUniformedAPI)(vboxUniformedAPI *pVBoxAPI)
...
@@ -9450,8 +9397,10 @@ void NAME(InstallUniformedAPI)(vboxUniformedAPI *pVBoxAPI)
pVBoxAPI
->
dumpIDEHDDsOld
=
_dumpIDEHDDsOld
;
pVBoxAPI
->
dumpIDEHDDsOld
=
_dumpIDEHDDsOld
;
pVBoxAPI
->
dumpDVD
=
_dumpDVD
;
pVBoxAPI
->
dumpDVD
=
_dumpDVD
;
pVBoxAPI
->
attachDVD
=
_attachDVD
;
pVBoxAPI
->
attachDVD
=
_attachDVD
;
pVBoxAPI
->
detachDVD
=
_detachDVD
;
pVBoxAPI
->
dumpFloppy
=
_dumpFloppy
;
pVBoxAPI
->
dumpFloppy
=
_dumpFloppy
;
pVBoxAPI
->
attachFloppy
=
_attachFloppy
;
pVBoxAPI
->
attachFloppy
=
_attachFloppy
;
pVBoxAPI
->
detachFloppy
=
_detachFloppy
;
pVBoxAPI
->
UPFN
=
_UPFN
;
pVBoxAPI
->
UPFN
=
_UPFN
;
pVBoxAPI
->
UIID
=
_UIID
;
pVBoxAPI
->
UIID
=
_UIID
;
pVBoxAPI
->
UArray
=
_UArray
;
pVBoxAPI
->
UArray
=
_UArray
;
...
...
src/vbox/vbox_uniformed_api.h
浏览文件 @
fa12d7c3
...
@@ -201,6 +201,7 @@ typedef struct {
...
@@ -201,6 +201,7 @@ typedef struct {
nsresult
(
*
CreateSharedFolder
)(
IMachine
*
machine
,
PRUnichar
*
name
,
nsresult
(
*
CreateSharedFolder
)(
IMachine
*
machine
,
PRUnichar
*
name
,
PRUnichar
*
hostPath
,
PRBool
writable
,
PRUnichar
*
hostPath
,
PRBool
writable
,
PRBool
automount
);
PRBool
automount
);
nsresult
(
*
RemoveSharedFolder
)(
IMachine
*
machine
,
PRUnichar
*
name
);
nsresult
(
*
LaunchVMProcess
)(
vboxGlobalData
*
data
,
IMachine
*
machine
,
nsresult
(
*
LaunchVMProcess
)(
vboxGlobalData
*
data
,
IMachine
*
machine
,
vboxIIDUnion
*
iidu
,
vboxIIDUnion
*
iidu
,
PRUnichar
*
sessionType
,
PRUnichar
*
env
,
PRUnichar
*
sessionType
,
PRUnichar
*
env
,
...
@@ -434,8 +435,10 @@ typedef struct {
...
@@ -434,8 +435,10 @@ typedef struct {
void
(
*
dumpIDEHDDsOld
)(
virDomainDefPtr
def
,
vboxGlobalData
*
data
,
IMachine
*
machine
);
void
(
*
dumpIDEHDDsOld
)(
virDomainDefPtr
def
,
vboxGlobalData
*
data
,
IMachine
*
machine
);
void
(
*
dumpDVD
)(
virDomainDefPtr
def
,
vboxGlobalData
*
data
,
IMachine
*
machine
);
void
(
*
dumpDVD
)(
virDomainDefPtr
def
,
vboxGlobalData
*
data
,
IMachine
*
machine
);
int
(
*
attachDVD
)(
vboxGlobalData
*
data
,
IMachine
*
machine
,
const
char
*
src
);
int
(
*
attachDVD
)(
vboxGlobalData
*
data
,
IMachine
*
machine
,
const
char
*
src
);
int
(
*
detachDVD
)(
IMachine
*
machine
);
void
(
*
dumpFloppy
)(
virDomainDefPtr
def
,
vboxGlobalData
*
data
,
IMachine
*
machine
);
void
(
*
dumpFloppy
)(
virDomainDefPtr
def
,
vboxGlobalData
*
data
,
IMachine
*
machine
);
int
(
*
attachFloppy
)(
vboxGlobalData
*
data
,
IMachine
*
machine
,
const
char
*
src
);
int
(
*
attachFloppy
)(
vboxGlobalData
*
data
,
IMachine
*
machine
,
const
char
*
src
);
int
(
*
detachFloppy
)(
IMachine
*
machine
);
vboxUniformedPFN
UPFN
;
vboxUniformedPFN
UPFN
;
vboxUniformedIID
UIID
;
vboxUniformedIID
UIID
;
vboxUniformedArray
UArray
;
vboxUniformedArray
UArray
;
...
@@ -529,6 +532,7 @@ int vboxDomainAttachDeviceFlags(virDomainPtr dom, const char *xml,
...
@@ -529,6 +532,7 @@ int vboxDomainAttachDeviceFlags(virDomainPtr dom, const char *xml,
unsigned
int
flags
);
unsigned
int
flags
);
int
vboxDomainUpdateDeviceFlags
(
virDomainPtr
dom
,
const
char
*
xml
,
int
vboxDomainUpdateDeviceFlags
(
virDomainPtr
dom
,
const
char
*
xml
,
unsigned
int
flags
);
unsigned
int
flags
);
int
vboxDomainDetachDevice
(
virDomainPtr
dom
,
const
char
*
xml
);
/* Version specified functions for installing uniformed API */
/* Version specified functions for installing uniformed API */
void
vbox22InstallUniformedAPI
(
vboxUniformedAPI
*
pVBoxAPI
);
void
vbox22InstallUniformedAPI
(
vboxUniformedAPI
*
pVBoxAPI
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录