提交 8ede883c 编写于 作者: P Peter Maydell

Merge remote-tracking branch 'remotes/cody/tags/block-pull-request' into staging

# gpg: Signature made Tue 13 Sep 2016 06:41:42 BST
# gpg:                using RSA key 0xBDBE7B27C0DE3057
# gpg: Good signature from "Jeffrey Cody <jcody@redhat.com>"
# gpg:                 aka "Jeffrey Cody <jeff@codyprime.org>"
# gpg:                 aka "Jeffrey Cody <codyprime@gmail.com>"
# Primary key fingerprint: 9957 4B4D 3474 90E7 9D98  D624 BDBE 7B27 C0DE 3057

* remotes/cody/tags/block-pull-request:
  qapi/block-core: add doc describing GlusterServer vs. SocketAddress
  block/gluster: add support to choose libgfapi logfile
Signed-off-by: NPeter Maydell <peter.maydell@linaro.org>
...@@ -30,6 +30,8 @@ ...@@ -30,6 +30,8 @@
#define GLUSTER_DEFAULT_PORT 24007 #define GLUSTER_DEFAULT_PORT 24007
#define GLUSTER_DEBUG_DEFAULT 4 #define GLUSTER_DEBUG_DEFAULT 4
#define GLUSTER_DEBUG_MAX 9 #define GLUSTER_DEBUG_MAX 9
#define GLUSTER_OPT_LOGFILE "logfile"
#define GLUSTER_LOGFILE_DEFAULT "-" /* handled in libgfapi as /dev/stderr */
#define GERR_INDEX_HINT "hint: check in 'server' array index '%d'\n" #define GERR_INDEX_HINT "hint: check in 'server' array index '%d'\n"
...@@ -44,6 +46,7 @@ typedef struct GlusterAIOCB { ...@@ -44,6 +46,7 @@ typedef struct GlusterAIOCB {
typedef struct BDRVGlusterState { typedef struct BDRVGlusterState {
struct glfs *glfs; struct glfs *glfs;
struct glfs_fd *fd; struct glfs_fd *fd;
char *logfile;
bool supports_seek_data; bool supports_seek_data;
int debug_level; int debug_level;
} BDRVGlusterState; } BDRVGlusterState;
...@@ -73,6 +76,11 @@ static QemuOptsList qemu_gluster_create_opts = { ...@@ -73,6 +76,11 @@ static QemuOptsList qemu_gluster_create_opts = {
.type = QEMU_OPT_NUMBER, .type = QEMU_OPT_NUMBER,
.help = "Gluster log level, valid range is 0-9", .help = "Gluster log level, valid range is 0-9",
}, },
{
.name = GLUSTER_OPT_LOGFILE,
.type = QEMU_OPT_STRING,
.help = "Logfile path of libgfapi",
},
{ /* end of list */ } { /* end of list */ }
} }
}; };
...@@ -91,6 +99,11 @@ static QemuOptsList runtime_opts = { ...@@ -91,6 +99,11 @@ static QemuOptsList runtime_opts = {
.type = QEMU_OPT_NUMBER, .type = QEMU_OPT_NUMBER,
.help = "Gluster log level, valid range is 0-9", .help = "Gluster log level, valid range is 0-9",
}, },
{
.name = GLUSTER_OPT_LOGFILE,
.type = QEMU_OPT_STRING,
.help = "Logfile path of libgfapi",
},
{ /* end of list */ } { /* end of list */ }
}, },
}; };
...@@ -341,7 +354,7 @@ static struct glfs *qemu_gluster_glfs_init(BlockdevOptionsGluster *gconf, ...@@ -341,7 +354,7 @@ static struct glfs *qemu_gluster_glfs_init(BlockdevOptionsGluster *gconf,
} }
} }
ret = glfs_set_logging(glfs, "-", gconf->debug_level); ret = glfs_set_logging(glfs, gconf->logfile, gconf->debug_level);
if (ret < 0) { if (ret < 0) {
goto out; goto out;
} }
...@@ -576,7 +589,9 @@ static struct glfs *qemu_gluster_init(BlockdevOptionsGluster *gconf, ...@@ -576,7 +589,9 @@ static struct glfs *qemu_gluster_init(BlockdevOptionsGluster *gconf,
if (ret < 0) { if (ret < 0) {
error_setg(errp, "invalid URI"); error_setg(errp, "invalid URI");
error_append_hint(errp, "Usage: file=gluster[+transport]://" error_append_hint(errp, "Usage: file=gluster[+transport]://"
"[host[:port]]/volume/path[?socket=...]\n"); "[host[:port]]volume/path[?socket=...]"
"[,file.debug=N]"
"[,file.logfile=/path/filename.log]\n");
errno = -ret; errno = -ret;
return NULL; return NULL;
} }
...@@ -586,7 +601,9 @@ static struct glfs *qemu_gluster_init(BlockdevOptionsGluster *gconf, ...@@ -586,7 +601,9 @@ static struct glfs *qemu_gluster_init(BlockdevOptionsGluster *gconf,
error_append_hint(errp, "Usage: " error_append_hint(errp, "Usage: "
"-drive driver=qcow2,file.driver=gluster," "-drive driver=qcow2,file.driver=gluster,"
"file.volume=testvol,file.path=/path/a.qcow2" "file.volume=testvol,file.path=/path/a.qcow2"
"[,file.debug=9],file.server.0.type=tcp," "[,file.debug=9]"
"[,file.logfile=/path/filename.log],"
"file.server.0.type=tcp,"
"file.server.0.host=1.2.3.4," "file.server.0.host=1.2.3.4,"
"file.server.0.port=24007," "file.server.0.port=24007,"
"file.server.1.transport=unix," "file.server.1.transport=unix,"
...@@ -677,7 +694,7 @@ static int qemu_gluster_open(BlockDriverState *bs, QDict *options, ...@@ -677,7 +694,7 @@ static int qemu_gluster_open(BlockDriverState *bs, QDict *options,
BlockdevOptionsGluster *gconf = NULL; BlockdevOptionsGluster *gconf = NULL;
QemuOpts *opts; QemuOpts *opts;
Error *local_err = NULL; Error *local_err = NULL;
const char *filename; const char *filename, *logfile;
opts = qemu_opts_create(&runtime_opts, NULL, 0, &error_abort); opts = qemu_opts_create(&runtime_opts, NULL, 0, &error_abort);
qemu_opts_absorb_qdict(opts, options, &local_err); qemu_opts_absorb_qdict(opts, options, &local_err);
...@@ -700,6 +717,13 @@ static int qemu_gluster_open(BlockDriverState *bs, QDict *options, ...@@ -700,6 +717,13 @@ static int qemu_gluster_open(BlockDriverState *bs, QDict *options,
gconf = g_new0(BlockdevOptionsGluster, 1); gconf = g_new0(BlockdevOptionsGluster, 1);
gconf->debug_level = s->debug_level; gconf->debug_level = s->debug_level;
gconf->has_debug_level = true; gconf->has_debug_level = true;
logfile = qemu_opt_get(opts, GLUSTER_OPT_LOGFILE);
s->logfile = g_strdup(logfile ? logfile : GLUSTER_LOGFILE_DEFAULT);
gconf->logfile = g_strdup(s->logfile);
gconf->has_logfile = true;
s->glfs = qemu_gluster_init(gconf, filename, options, errp); s->glfs = qemu_gluster_init(gconf, filename, options, errp);
if (!s->glfs) { if (!s->glfs) {
ret = -errno; ret = -errno;
...@@ -738,6 +762,7 @@ out: ...@@ -738,6 +762,7 @@ out:
if (!ret) { if (!ret) {
return ret; return ret;
} }
g_free(s->logfile);
if (s->fd) { if (s->fd) {
glfs_close(s->fd); glfs_close(s->fd);
} }
...@@ -769,6 +794,8 @@ static int qemu_gluster_reopen_prepare(BDRVReopenState *state, ...@@ -769,6 +794,8 @@ static int qemu_gluster_reopen_prepare(BDRVReopenState *state,
gconf = g_new0(BlockdevOptionsGluster, 1); gconf = g_new0(BlockdevOptionsGluster, 1);
gconf->debug_level = s->debug_level; gconf->debug_level = s->debug_level;
gconf->has_debug_level = true; gconf->has_debug_level = true;
gconf->logfile = g_strdup(s->logfile);
gconf->has_logfile = true;
reop_s->glfs = qemu_gluster_init(gconf, state->bs->filename, NULL, errp); reop_s->glfs = qemu_gluster_init(gconf, state->bs->filename, NULL, errp);
if (reop_s->glfs == NULL) { if (reop_s->glfs == NULL) {
ret = -errno; ret = -errno;
...@@ -914,6 +941,12 @@ static int qemu_gluster_create(const char *filename, ...@@ -914,6 +941,12 @@ static int qemu_gluster_create(const char *filename,
} }
gconf->has_debug_level = true; gconf->has_debug_level = true;
gconf->logfile = qemu_opt_get_del(opts, GLUSTER_OPT_LOGFILE);
if (!gconf->logfile) {
gconf->logfile = g_strdup(GLUSTER_LOGFILE_DEFAULT);
}
gconf->has_logfile = true;
glfs = qemu_gluster_init(gconf, filename, NULL, errp); glfs = qemu_gluster_init(gconf, filename, NULL, errp);
if (!glfs) { if (!glfs) {
ret = -errno; ret = -errno;
...@@ -1025,6 +1058,7 @@ static void qemu_gluster_close(BlockDriverState *bs) ...@@ -1025,6 +1058,7 @@ static void qemu_gluster_close(BlockDriverState *bs)
{ {
BDRVGlusterState *s = bs->opaque; BDRVGlusterState *s = bs->opaque;
g_free(s->logfile);
if (s->fd) { if (s->fd) {
glfs_close(s->fd); glfs_close(s->fd);
s->fd = NULL; s->fd = NULL;
......
...@@ -2133,6 +2133,18 @@ ...@@ -2133,6 +2133,18 @@
# #
# @tcp: host address and port number # @tcp: host address and port number
# #
# This is similar to SocketAddress, only distinction:
#
# 1. GlusterServer is a flat union, SocketAddress is a simple union.
# A flat union is nicer than simple because it avoids nesting
# (i.e. more {}) on the wire.
#
# 2. GlusterServer lacks case 'fd', since gluster doesn't let you
# pass in a file descriptor.
#
# GlusterServer is actually not Gluster-specific, its a
# compatibility evolved into an alternate for SocketAddress.
#
# Since: 2.7 # Since: 2.7
## ##
{ 'union': 'GlusterServer', { 'union': 'GlusterServer',
...@@ -2154,13 +2166,16 @@ ...@@ -2154,13 +2166,16 @@
# #
# @debug-level: #optional libgfapi log level (default '4' which is Error) # @debug-level: #optional libgfapi log level (default '4' which is Error)
# #
# @logfile: #optional libgfapi log file (default /dev/stderr)
#
# Since: 2.7 # Since: 2.7
## ##
{ 'struct': 'BlockdevOptionsGluster', { 'struct': 'BlockdevOptionsGluster',
'data': { 'volume': 'str', 'data': { 'volume': 'str',
'path': 'str', 'path': 'str',
'server': ['GlusterServer'], 'server': ['GlusterServer'],
'*debug-level': 'int' } } '*debug-level': 'int',
'*logfile': 'str' } }
## ##
# @BlockdevOptions # @BlockdevOptions
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册