From: Wei Liu Date: Mon, 30 Nov 2015 15:37:12 +0000 (+0000) Subject: fsdev: 9p-marshal: introduce V9fsBlob X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=7ccdac95d0bf78c99ce5f36d4ff551186da95d4b;p=people%2Fliuw%2Fqemu.git fsdev: 9p-marshal: introduce V9fsBlob Introduce a concept of blob. It will be used to pack / unpack xattr value. With this change there is no need to expose v9fs_pack to device code anymore. Signed-off-by: Wei Liu --- v3: use 'd' to encode / decode blob size --- diff --git a/fsdev/9p-iov-marshal.c b/fsdev/9p-iov-marshal.c index 08d783ca11..1f9edf3510 100644 --- a/fsdev/9p-iov-marshal.c +++ b/fsdev/9p-iov-marshal.c @@ -140,6 +140,21 @@ ssize_t v9fs_iov_vunmarshal(struct iovec *out_sg, int out_num, size_t offset, } break; } + case 'B': { + V9fsBlob *blob = va_arg(ap, V9fsBlob *); + copied = v9fs_iov_unmarshal(out_sg, out_num, offset, bswap, + "d", &blob->size); + if (copied > 0) { + offset += copied; + blob->data = g_malloc(blob->size); + copied = v9fs_unpack(blob->data, out_sg, out_num, offset, + blob->size); + if (copied < 0) { + v9fs_blob_free(blob); + } + } + break; + } case 'Q': { V9fsQID *qidp = va_arg(ap, V9fsQID *); copied = v9fs_iov_unmarshal(out_sg, out_num, offset, bswap, @@ -253,6 +268,17 @@ ssize_t v9fs_iov_vmarshal(struct iovec *in_sg, int in_num, size_t offset, } break; } + case 'B': { + V9fsBlob *blob = va_arg(ap, V9fsBlob *); + copied = v9fs_iov_marshal(in_sg, in_num, offset, bswap, + "d", blob->size); + if (copied > 0) { + offset += copied; + copied = v9fs_pack(in_sg, in_num, offset, blob->data, + blob->size); + } + break; + } case 'Q': { V9fsQID *qidp = va_arg(ap, V9fsQID *); copied = v9fs_iov_marshal(in_sg, in_num, offset, bswap, "bdq", diff --git a/fsdev/9p-marshal.c b/fsdev/9p-marshal.c index 991e35d242..a9142445b5 100644 --- a/fsdev/9p-marshal.c +++ b/fsdev/9p-marshal.c @@ -54,3 +54,10 @@ void v9fs_string_copy(V9fsString *lhs, V9fsString *rhs) v9fs_string_free(lhs); v9fs_string_sprintf(lhs, "%s", rhs->data); } + +void v9fs_blob_free(V9fsBlob *blob) +{ + g_free(blob->data); + blob->data = NULL; + blob->size = 0; +} diff --git a/fsdev/9p-marshal.h b/fsdev/9p-marshal.h index e91b24e9ca..54148f46f5 100644 --- a/fsdev/9p-marshal.h +++ b/fsdev/9p-marshal.h @@ -7,6 +7,12 @@ typedef struct V9fsString char *data; } V9fsString; +typedef struct V9fsBlob +{ + uint32_t size; + void *data; +} V9fsBlob; + typedef struct V9fsQID { int8_t type; @@ -81,4 +87,12 @@ extern void v9fs_string_null(V9fsString *str); extern void v9fs_string_sprintf(V9fsString *str, const char *fmt, ...); extern void v9fs_string_copy(V9fsString *lhs, V9fsString *rhs); +static inline void v9fs_blob_init(V9fsBlob *blob) +{ + blob->data = NULL; + blob->size = 0; +} + +extern void v9fs_blob_free(V9fsBlob *blob); + #endif