summaryrefslogtreecommitdiff
path: root/qga/vss-win32.c
diff options
context:
space:
mode:
authorMarkus Armbruster <armbru@redhat.com>2015-06-19 20:44:54 +0200
committerMarkus Armbruster <armbru@redhat.com>2015-09-10 13:48:06 +0200
commite7cf59e84767e30b507b6bd7c1347072ec12b636 (patch)
tree140bae85557c3e5e13a9fb61ac3734d5f2e6512b /qga/vss-win32.c
parenta9499ddd82a99c66cc72a08e72427c423acfea1c (diff)
downloadqemu-e7cf59e84767e30b507b6bd7c1347072ec12b636.tar.gz
qemu-e7cf59e84767e30b507b6bd7c1347072ec12b636.tar.bz2
qemu-e7cf59e84767e30b507b6bd7c1347072ec12b636.zip
qga: Clean up unnecessarily dirty casts
qga_vss_fsfreeze() casts error_set_win32() from void (*)(Error **, int, ErrorClass, const char *, ...) to void (*)(void **, int, int, const char *, ...) The result is later called. Since the two types are not compatible, the call is undefined behavior. It works in practice anyway. However, there's no real need for trickery here. Clean it up as follows: * Declare struct Error, and fix the first parameter. * Switch to error_setg_win32(). This gets rid of the troublesome ErrorClass parameter. Requires converting error_setg_win32() from macro to function, but that's trivially easy, because this is the only user of error_set_win32(). Signed-off-by: Markus Armbruster <armbru@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com>
Diffstat (limited to 'qga/vss-win32.c')
-rw-r--r--qga/vss-win32.c5
1 files changed, 2 insertions, 3 deletions
diff --git a/qga/vss-win32.c b/qga/vss-win32.c
index 0e4095736e..e1f539835c 100644
--- a/qga/vss-win32.c
+++ b/qga/vss-win32.c
@@ -150,9 +150,8 @@ void qga_vss_fsfreeze(int *nr_volume, Error **errp, bool freeze)
const char *func_name = freeze ? "requester_freeze" : "requester_thaw";
QGAVSSRequesterFunc func;
ErrorSet errset = {
- .error_set = (ErrorSetFunc)error_set_win32,
- .errp = (void **)errp,
- .err_class = ERROR_CLASS_GENERIC_ERROR
+ .error_setg_win32 = error_setg_win32,
+ .errp = errp,
};
func = (QGAVSSRequesterFunc)GetProcAddress(provider_lib, func_name);