|
|
efa7a1 |
From 83c72d9bf9d6a9ccf6939b4ebd0028b62673a78a Mon Sep 17 00:00:00 2001
|
|
|
efa7a1 |
From: "Richard W.M. Jones" <rjones@redhat.com>
|
|
|
efa7a1 |
Date: Thu, 12 Dec 2019 10:57:52 +0000
|
|
|
efa7a1 |
Subject: [PATCH] server: Add -D nbdkit.backend.controlpath and -D
|
|
|
efa7a1 |
nbdkit.backend.datapath.
|
|
|
efa7a1 |
|
|
|
efa7a1 |
These can be used to suppress verbose debugging messages from the
|
|
|
efa7a1 |
backend.
|
|
|
efa7a1 |
|
|
|
efa7a1 |
BugLink: https://bugzilla.redhat.com/1782868
|
|
|
efa7a1 |
|
|
|
efa7a1 |
Cherry picked from commit 231717e8cd5f27d76631be6651062d5a5ccf7fdc.
|
|
|
efa7a1 |
Remove use of nofilter from the test.
|
|
|
efa7a1 |
---
|
|
|
efa7a1 |
docs/nbdkit.pod | 35 ++++++++++++-
|
|
|
efa7a1 |
server/backend.c | 83 ++++++++++++++++++------------
|
|
|
efa7a1 |
tests/Makefile.am | 4 ++
|
|
|
efa7a1 |
tests/test-nbdkit-backend-debug.sh | 70 +++++++++++++++++++++++++
|
|
|
efa7a1 |
4 files changed, 158 insertions(+), 34 deletions(-)
|
|
|
efa7a1 |
create mode 100755 tests/test-nbdkit-backend-debug.sh
|
|
|
efa7a1 |
|
|
|
efa7a1 |
diff --git a/docs/nbdkit.pod b/docs/nbdkit.pod
|
|
|
efa7a1 |
index 346d833..38e6bfc 100644
|
|
|
efa7a1 |
--- a/docs/nbdkit.pod
|
|
|
efa7a1 |
+++ b/docs/nbdkit.pod
|
|
|
efa7a1 |
@@ -182,7 +182,7 @@ value C<N>. See L<nbdkit-plugin(3)/Debug Flags>.
|
|
|
efa7a1 |
=item B<--debug> nbdkit.FLAG=N
|
|
|
efa7a1 |
|
|
|
efa7a1 |
Set the nbdkit server Debug Flag called C<FLAG> to the integer value
|
|
|
efa7a1 |
-C<N>.
|
|
|
efa7a1 |
+C<N>. See L</SERVER DEBUG FLAGS> below.
|
|
|
efa7a1 |
|
|
|
efa7a1 |
=item B<--dump-config>
|
|
|
efa7a1 |
|
|
|
efa7a1 |
@@ -527,6 +527,39 @@ languages. The file should be executable. For example:
|
|
|
efa7a1 |
|
|
|
efa7a1 |
(see L<nbdkit-perl-plugin(3)> for a full example).
|
|
|
efa7a1 |
|
|
|
efa7a1 |
+=head1 SERVER DEBUG FLAGS
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+As well as enabling or disabling debugging in the server using
|
|
|
efa7a1 |
+I<--verbose> you can control extra debugging in the server using the
|
|
|
efa7a1 |
+C<-D nbdkit.*> flags listed in this section. Note these flags are an
|
|
|
efa7a1 |
+internal implementation detail of the server and may be changed or
|
|
|
efa7a1 |
+removed at any time in the future.
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+=over 4
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+=item B<-D nbdkit.backend.controlpath=0>
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+=item B<-D nbdkit.backend.controlpath=1>
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+=item B<-D nbdkit.backend.datapath=0>
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+=item B<-D nbdkit.backend.datapath=1>
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+These flags control the verbosity of nbdkit backend debugging messages
|
|
|
efa7a1 |
+(the ones which show every request processed by the server). The
|
|
|
efa7a1 |
+default for both settings is C<1> (normal debugging) but you can set
|
|
|
efa7a1 |
+them to C<0> to suppress these messages.
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+C<-D nbdkit.backend.datapath=0> is the more useful setting which lets you
|
|
|
efa7a1 |
+suppress messages about pread, pwrite, zero, trim, etc. commands.
|
|
|
efa7a1 |
+When transferring large amounts of data these messages are numerous
|
|
|
efa7a1 |
+and not usually very interesting.
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+C<-D nbdkit.backend.controlpath=0> suppresses the non-datapath
|
|
|
efa7a1 |
+commands (config, open, close, can_write, etc.)
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+=back
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
=head1 SIGNALS
|
|
|
efa7a1 |
|
|
|
efa7a1 |
nbdkit responds to the following signals:
|
|
|
efa7a1 |
diff --git a/server/backend.c b/server/backend.c
|
|
|
efa7a1 |
index b9fe2a2..208c07b 100644
|
|
|
efa7a1 |
--- a/server/backend.c
|
|
|
efa7a1 |
+++ b/server/backend.c
|
|
|
efa7a1 |
@@ -46,6 +46,22 @@
|
|
|
efa7a1 |
|
|
|
efa7a1 |
/* Helpers for registering a new backend. */
|
|
|
efa7a1 |
|
|
|
efa7a1 |
+/* Use:
|
|
|
efa7a1 |
+ * -D nbdkit.backend.controlpath=0 to suppress control path debugging.
|
|
|
efa7a1 |
+ * -D nbdkit.backend.datapath=0 to suppress data path debugging.
|
|
|
efa7a1 |
+ */
|
|
|
efa7a1 |
+int nbdkit_debug_backend_controlpath = 1;
|
|
|
efa7a1 |
+int nbdkit_debug_backend_datapath = 1;
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+#define controlpath_debug(fs, ...) \
|
|
|
efa7a1 |
+ do { \
|
|
|
efa7a1 |
+ if (nbdkit_debug_backend_controlpath) debug ((fs), ##__VA_ARGS__); \
|
|
|
efa7a1 |
+ } while (0)
|
|
|
efa7a1 |
+#define datapath_debug(fs, ...) \
|
|
|
efa7a1 |
+ do { \
|
|
|
efa7a1 |
+ if (nbdkit_debug_backend_datapath) debug ((fs), ##__VA_ARGS__); \
|
|
|
efa7a1 |
+ } while (0)
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
void
|
|
|
efa7a1 |
backend_init (struct backend *b, struct backend *next, size_t index,
|
|
|
efa7a1 |
const char *filename, void *dl, const char *type)
|
|
|
efa7a1 |
@@ -108,7 +124,7 @@ backend_load (struct backend *b, const char *name, void (*load) (void))
|
|
|
efa7a1 |
apply_debug_flags (b->dl, name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
/* Call the on-load callback if it exists. */
|
|
|
efa7a1 |
- debug ("%s: load", name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: load", name);
|
|
|
efa7a1 |
if (load)
|
|
|
efa7a1 |
load ();
|
|
|
efa7a1 |
}
|
|
|
efa7a1 |
@@ -121,7 +137,7 @@ backend_unload (struct backend *b, void (*unload) (void))
|
|
|
efa7a1 |
*/
|
|
|
efa7a1 |
lock_unload ();
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: unload %s", b->name, b->type);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: unload %s", b->name, b->type);
|
|
|
efa7a1 |
if (unload)
|
|
|
efa7a1 |
unload ();
|
|
|
efa7a1 |
|
|
|
efa7a1 |
@@ -139,7 +155,7 @@ backend_open (struct backend *b, struct connection *conn, int readonly)
|
|
|
efa7a1 |
{
|
|
|
efa7a1 |
struct b_conn_handle *h = &conn->handles[b->i];
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: open readonly=%d", b->name, readonly);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: open readonly=%d", b->name, readonly);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
assert (h->handle == NULL);
|
|
|
efa7a1 |
assert ((h->state & HANDLE_OPEN) == 0);
|
|
|
efa7a1 |
@@ -151,7 +167,7 @@ backend_open (struct backend *b, struct connection *conn, int readonly)
|
|
|
efa7a1 |
* inner-to-outer ordering.
|
|
|
efa7a1 |
*/
|
|
|
efa7a1 |
h->handle = b->open (b, conn, readonly);
|
|
|
efa7a1 |
- debug ("%s: open returned handle %p", b->name, h->handle);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: open returned handle %p", b->name, h->handle);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
if (h->handle == NULL) {
|
|
|
efa7a1 |
if (b->i) /* Do not strand backend if this layer failed */
|
|
|
efa7a1 |
@@ -179,7 +195,7 @@ backend_prepare (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
if (b->i && backend_prepare (b->next, conn) == -1)
|
|
|
efa7a1 |
return -1;
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: prepare readonly=%d", b->name, h->can_write == 0);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: prepare readonly=%d", b->name, h->can_write == 0);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
if (b->prepare (b, conn, h->handle, h->can_write == 0) == -1)
|
|
|
efa7a1 |
return -1;
|
|
|
efa7a1 |
@@ -196,7 +212,7 @@ backend_finalize (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
* filter furthest away from the plugin, and matching .close order.
|
|
|
efa7a1 |
*/
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: finalize", b->name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: finalize", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
/* Once finalize fails, we can do nothing further on this connection */
|
|
|
efa7a1 |
if (h->state & HANDLE_FAILED)
|
|
|
efa7a1 |
@@ -223,7 +239,7 @@ backend_close (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
struct b_conn_handle *h = &conn->handles[b->i];
|
|
|
efa7a1 |
|
|
|
efa7a1 |
/* outer-to-inner order, opposite .open */
|
|
|
efa7a1 |
- debug ("%s: close", b->name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: close", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
if (h->handle) {
|
|
|
efa7a1 |
assert (h->state & HANDLE_OPEN);
|
|
|
efa7a1 |
@@ -252,7 +268,7 @@ backend_valid_range (struct backend *b, struct connection *conn,
|
|
|
efa7a1 |
int
|
|
|
efa7a1 |
backend_reopen (struct backend *b, struct connection *conn, int readonly)
|
|
|
efa7a1 |
{
|
|
|
efa7a1 |
- debug ("%s: reopen readonly=%d", b->name, readonly);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: reopen readonly=%d", b->name, readonly);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
if (backend_finalize (b, conn) == -1)
|
|
|
efa7a1 |
return -1;
|
|
|
efa7a1 |
@@ -274,7 +290,7 @@ backend_get_size (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
{
|
|
|
efa7a1 |
struct b_conn_handle *h = &conn->handles[b->i];
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: get_size", b->name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: get_size", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
assert (h->handle && (h->state & HANDLE_CONNECTED));
|
|
|
efa7a1 |
if (h->exportsize == -1)
|
|
|
efa7a1 |
@@ -287,7 +303,7 @@ backend_can_write (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
{
|
|
|
efa7a1 |
struct b_conn_handle *h = &conn->handles[b->i];
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: can_write", b->name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: can_write", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
assert (h->handle && (h->state & HANDLE_CONNECTED));
|
|
|
efa7a1 |
if (h->can_write == -1)
|
|
|
efa7a1 |
@@ -300,7 +316,7 @@ backend_can_flush (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
{
|
|
|
efa7a1 |
struct b_conn_handle *h = &conn->handles[b->i];
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: can_flush", b->name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: can_flush", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
assert (h->handle && (h->state & HANDLE_CONNECTED));
|
|
|
efa7a1 |
if (h->can_flush == -1)
|
|
|
efa7a1 |
@@ -313,7 +329,7 @@ backend_is_rotational (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
{
|
|
|
efa7a1 |
struct b_conn_handle *h = &conn->handles[b->i];
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: is_rotational", b->name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: is_rotational", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
assert (h->handle && (h->state & HANDLE_CONNECTED));
|
|
|
efa7a1 |
if (h->is_rotational == -1)
|
|
|
efa7a1 |
@@ -327,7 +343,7 @@ backend_can_trim (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
struct b_conn_handle *h = &conn->handles[b->i];
|
|
|
efa7a1 |
int r;
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: can_trim", b->name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: can_trim", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
assert (h->handle && (h->state & HANDLE_CONNECTED));
|
|
|
efa7a1 |
if (h->can_trim == -1) {
|
|
|
efa7a1 |
@@ -347,7 +363,7 @@ backend_can_zero (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
struct b_conn_handle *h = &conn->handles[b->i];
|
|
|
efa7a1 |
int r;
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: can_zero", b->name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: can_zero", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
assert (h->handle && (h->state & HANDLE_CONNECTED));
|
|
|
efa7a1 |
if (h->can_zero == -1) {
|
|
|
efa7a1 |
@@ -367,7 +383,7 @@ backend_can_fast_zero (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
struct b_conn_handle *h = &conn->handles[b->i];
|
|
|
efa7a1 |
int r;
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: can_fast_zero", b->name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: can_fast_zero", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
assert (h->handle && (h->state & HANDLE_CONNECTED));
|
|
|
efa7a1 |
if (h->can_fast_zero == -1) {
|
|
|
efa7a1 |
@@ -386,7 +402,7 @@ backend_can_extents (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
{
|
|
|
efa7a1 |
struct b_conn_handle *h = &conn->handles[b->i];
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: can_extents", b->name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: can_extents", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
assert (h->handle && (h->state & HANDLE_CONNECTED));
|
|
|
efa7a1 |
if (h->can_extents == -1)
|
|
|
efa7a1 |
@@ -400,7 +416,7 @@ backend_can_fua (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
struct b_conn_handle *h = &conn->handles[b->i];
|
|
|
efa7a1 |
int r;
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: can_fua", b->name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: can_fua", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
assert (h->handle && (h->state & HANDLE_CONNECTED));
|
|
|
efa7a1 |
if (h->can_fua == -1) {
|
|
|
efa7a1 |
@@ -420,7 +436,7 @@ backend_can_multi_conn (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
struct b_conn_handle *h = &conn->handles[b->i];
|
|
|
efa7a1 |
|
|
|
efa7a1 |
assert (h->handle && (h->state & HANDLE_CONNECTED));
|
|
|
efa7a1 |
- debug ("%s: can_multi_conn", b->name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: can_multi_conn", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
if (h->can_multi_conn == -1)
|
|
|
efa7a1 |
h->can_multi_conn = b->can_multi_conn (b, conn, h->handle);
|
|
|
efa7a1 |
@@ -432,7 +448,7 @@ backend_can_cache (struct backend *b, struct connection *conn)
|
|
|
efa7a1 |
{
|
|
|
efa7a1 |
struct b_conn_handle *h = &conn->handles[b->i];
|
|
|
efa7a1 |
|
|
|
efa7a1 |
- debug ("%s: can_cache", b->name);
|
|
|
efa7a1 |
+ controlpath_debug ("%s: can_cache", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
assert (h->handle && (h->state & HANDLE_CONNECTED));
|
|
|
efa7a1 |
if (h->can_cache == -1)
|
|
|
efa7a1 |
@@ -451,8 +467,8 @@ backend_pread (struct backend *b, struct connection *conn,
|
|
|
efa7a1 |
assert (h->handle && (h->state & HANDLE_CONNECTED));
|
|
|
efa7a1 |
assert (backend_valid_range (b, conn, offset, count));
|
|
|
efa7a1 |
assert (flags == 0);
|
|
|
efa7a1 |
- debug ("%s: pread count=%" PRIu32 " offset=%" PRIu64,
|
|
|
efa7a1 |
- b->name, count, offset);
|
|
|
efa7a1 |
+ datapath_debug ("%s: pread count=%" PRIu32 " offset=%" PRIu64,
|
|
|
efa7a1 |
+ b->name, count, offset);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
r = b->pread (b, conn, h->handle, buf, count, offset, flags, err);
|
|
|
efa7a1 |
if (r == -1)
|
|
|
efa7a1 |
@@ -475,8 +491,8 @@ backend_pwrite (struct backend *b, struct connection *conn,
|
|
|
efa7a1 |
assert (!(flags & ~NBDKIT_FLAG_FUA));
|
|
|
efa7a1 |
if (fua)
|
|
|
efa7a1 |
assert (h->can_fua > NBDKIT_FUA_NONE);
|
|
|
efa7a1 |
- debug ("%s: pwrite count=%" PRIu32 " offset=%" PRIu64 " fua=%d",
|
|
|
efa7a1 |
- b->name, count, offset, fua);
|
|
|
efa7a1 |
+ datapath_debug ("%s: pwrite count=%" PRIu32 " offset=%" PRIu64 " fua=%d",
|
|
|
efa7a1 |
+ b->name, count, offset, fua);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
r = b->pwrite (b, conn, h->handle, buf, count, offset, flags, err);
|
|
|
efa7a1 |
if (r == -1)
|
|
|
efa7a1 |
@@ -494,7 +510,7 @@ backend_flush (struct backend *b, struct connection *conn,
|
|
|
efa7a1 |
assert (h->handle && (h->state & HANDLE_CONNECTED));
|
|
|
efa7a1 |
assert (h->can_flush == 1);
|
|
|
efa7a1 |
assert (flags == 0);
|
|
|
efa7a1 |
- debug ("%s: flush", b->name);
|
|
|
efa7a1 |
+ datapath_debug ("%s: flush", b->name);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
r = b->flush (b, conn, h->handle, flags, err);
|
|
|
efa7a1 |
if (r == -1)
|
|
|
efa7a1 |
@@ -518,8 +534,8 @@ backend_trim (struct backend *b, struct connection *conn,
|
|
|
efa7a1 |
assert (!(flags & ~NBDKIT_FLAG_FUA));
|
|
|
efa7a1 |
if (fua)
|
|
|
efa7a1 |
assert (h->can_fua > NBDKIT_FUA_NONE);
|
|
|
efa7a1 |
- debug ("%s: trim count=%" PRIu32 " offset=%" PRIu64 " fua=%d",
|
|
|
efa7a1 |
- b->name, count, offset, fua);
|
|
|
efa7a1 |
+ datapath_debug ("%s: trim count=%" PRIu32 " offset=%" PRIu64 " fua=%d",
|
|
|
efa7a1 |
+ b->name, count, offset, fua);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
r = b->trim (b, conn, h->handle, count, offset, flags, err);
|
|
|
efa7a1 |
if (r == -1)
|
|
|
efa7a1 |
@@ -547,9 +563,10 @@ backend_zero (struct backend *b, struct connection *conn,
|
|
|
efa7a1 |
assert (h->can_fua > NBDKIT_FUA_NONE);
|
|
|
efa7a1 |
if (fast)
|
|
|
efa7a1 |
assert (h->can_fast_zero == 1);
|
|
|
efa7a1 |
- debug ("%s: zero count=%" PRIu32 " offset=%" PRIu64
|
|
|
efa7a1 |
- " may_trim=%d fua=%d fast=%d",
|
|
|
efa7a1 |
- b->name, count, offset, !!(flags & NBDKIT_FLAG_MAY_TRIM), fua, fast);
|
|
|
efa7a1 |
+ datapath_debug ("%s: zero count=%" PRIu32 " offset=%" PRIu64
|
|
|
efa7a1 |
+ " may_trim=%d fua=%d fast=%d",
|
|
|
efa7a1 |
+ b->name, count, offset,
|
|
|
efa7a1 |
+ !!(flags & NBDKIT_FLAG_MAY_TRIM), fua, fast);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
r = b->zero (b, conn, h->handle, count, offset, flags, err);
|
|
|
efa7a1 |
if (r == -1) {
|
|
|
efa7a1 |
@@ -572,8 +589,8 @@ backend_extents (struct backend *b, struct connection *conn,
|
|
|
efa7a1 |
assert (h->can_extents >= 0);
|
|
|
efa7a1 |
assert (backend_valid_range (b, conn, offset, count));
|
|
|
efa7a1 |
assert (!(flags & ~NBDKIT_FLAG_REQ_ONE));
|
|
|
efa7a1 |
- debug ("%s: extents count=%" PRIu32 " offset=%" PRIu64 " req_one=%d",
|
|
|
efa7a1 |
- b->name, count, offset, !!(flags & NBDKIT_FLAG_REQ_ONE));
|
|
|
efa7a1 |
+ datapath_debug ("%s: extents count=%" PRIu32 " offset=%" PRIu64 " req_one=%d",
|
|
|
efa7a1 |
+ b->name, count, offset, !!(flags & NBDKIT_FLAG_REQ_ONE));
|
|
|
efa7a1 |
|
|
|
efa7a1 |
if (h->can_extents == 0) {
|
|
|
efa7a1 |
/* By default it is safe assume that everything in the range is
|
|
|
efa7a1 |
@@ -602,8 +619,8 @@ backend_cache (struct backend *b, struct connection *conn,
|
|
|
efa7a1 |
assert (h->can_cache > NBDKIT_CACHE_NONE);
|
|
|
efa7a1 |
assert (backend_valid_range (b, conn, offset, count));
|
|
|
efa7a1 |
assert (flags == 0);
|
|
|
efa7a1 |
- debug ("%s: cache count=%" PRIu32 " offset=%" PRIu64,
|
|
|
efa7a1 |
- b->name, count, offset);
|
|
|
efa7a1 |
+ datapath_debug ("%s: cache count=%" PRIu32 " offset=%" PRIu64,
|
|
|
efa7a1 |
+ b->name, count, offset);
|
|
|
efa7a1 |
|
|
|
efa7a1 |
if (h->can_cache == NBDKIT_CACHE_EMULATE) {
|
|
|
efa7a1 |
static char buf[MAX_REQUEST_SIZE]; /* data sink, never read */
|
|
|
efa7a1 |
diff --git a/tests/Makefile.am b/tests/Makefile.am
|
|
|
efa7a1 |
index 0134197..d225cc6 100644
|
|
|
efa7a1 |
--- a/tests/Makefile.am
|
|
|
efa7a1 |
+++ b/tests/Makefile.am
|
|
|
efa7a1 |
@@ -135,6 +135,7 @@ EXTRA_DIST = \
|
|
|
efa7a1 |
test-nbd-extents.sh \
|
|
|
efa7a1 |
test-nbd-tls.sh \
|
|
|
efa7a1 |
test-nbd-tls-psk.sh \
|
|
|
efa7a1 |
+ test-nbdkit-backend-debug.sh \
|
|
|
efa7a1 |
test-nozero.sh \
|
|
|
efa7a1 |
test-null-extents.sh \
|
|
|
efa7a1 |
test_ocaml_plugin.ml \
|
|
|
efa7a1 |
@@ -746,6 +747,9 @@ endif HAVE_VDDK
|
|
|
efa7a1 |
# zero plugin test.
|
|
|
efa7a1 |
TESTS += test-zero.sh
|
|
|
efa7a1 |
|
|
|
efa7a1 |
+# -D nbdkit.backend.* settings.
|
|
|
efa7a1 |
+TESTS += test-nbdkit-backend-debug.sh
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
#----------------------------------------------------------------------
|
|
|
efa7a1 |
# Tests of language plugins.
|
|
|
efa7a1 |
|
|
|
efa7a1 |
diff --git a/tests/test-nbdkit-backend-debug.sh b/tests/test-nbdkit-backend-debug.sh
|
|
|
efa7a1 |
new file mode 100755
|
|
|
efa7a1 |
index 0000000..69a69a7
|
|
|
efa7a1 |
--- /dev/null
|
|
|
efa7a1 |
+++ b/tests/test-nbdkit-backend-debug.sh
|
|
|
efa7a1 |
@@ -0,0 +1,70 @@
|
|
|
efa7a1 |
+#!/usr/bin/env bash
|
|
|
efa7a1 |
+# nbdkit
|
|
|
efa7a1 |
+# Copyright (C) 2019 Red Hat Inc.
|
|
|
efa7a1 |
+#
|
|
|
efa7a1 |
+# Redistribution and use in source and binary forms, with or without
|
|
|
efa7a1 |
+# modification, are permitted provided that the following conditions are
|
|
|
efa7a1 |
+# met:
|
|
|
efa7a1 |
+#
|
|
|
efa7a1 |
+# * Redistributions of source code must retain the above copyright
|
|
|
efa7a1 |
+# notice, this list of conditions and the following disclaimer.
|
|
|
efa7a1 |
+#
|
|
|
efa7a1 |
+# * Redistributions in binary form must reproduce the above copyright
|
|
|
efa7a1 |
+# notice, this list of conditions and the following disclaimer in the
|
|
|
efa7a1 |
+# documentation and/or other materials provided with the distribution.
|
|
|
efa7a1 |
+#
|
|
|
efa7a1 |
+# * Neither the name of Red Hat nor the names of its contributors may be
|
|
|
efa7a1 |
+# used to endorse or promote products derived from this software without
|
|
|
efa7a1 |
+# specific prior written permission.
|
|
|
efa7a1 |
+#
|
|
|
efa7a1 |
+# THIS SOFTWARE IS PROVIDED BY RED HAT AND CONTRIBUTORS ''AS IS'' AND
|
|
|
efa7a1 |
+# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
|
|
|
efa7a1 |
+# THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
|
|
|
efa7a1 |
+# PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL RED HAT OR
|
|
|
efa7a1 |
+# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
efa7a1 |
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
efa7a1 |
+# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
|
|
|
efa7a1 |
+# USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
|
efa7a1 |
+# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
|
efa7a1 |
+# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
|
|
|
efa7a1 |
+# OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
efa7a1 |
+# SUCH DAMAGE.
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+source ./functions.sh
|
|
|
efa7a1 |
+set -x
|
|
|
efa7a1 |
+set -e
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+requires qemu-img --version
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+out="test-nbdkit-backend-debug.out"
|
|
|
efa7a1 |
+debug="test-nbdkit-backend-debug.debug"
|
|
|
efa7a1 |
+files="$out $debug"
|
|
|
efa7a1 |
+rm -f $files
|
|
|
efa7a1 |
+cleanup_fn rm -f $files
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+nbdkit -U - \
|
|
|
efa7a1 |
+ -v \
|
|
|
efa7a1 |
+ memory 10M \
|
|
|
efa7a1 |
+ --run "qemu-img convert \$nbd $out" |& tee $debug
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+# Should contain all debugging messages.
|
|
|
efa7a1 |
+grep '^nbdkit:.*debug: memory: open' $debug
|
|
|
efa7a1 |
+grep '^nbdkit:.*debug: memory: pread' $debug
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+nbdkit -U - \
|
|
|
efa7a1 |
+ -v -D nbdkit.backend.controlpath=0 \
|
|
|
efa7a1 |
+ memory 10M \
|
|
|
efa7a1 |
+ --run "qemu-img convert \$nbd $out" |& tee $debug
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+# Should contain only datapath messages.
|
|
|
efa7a1 |
+grep -v '^nbdkit:.*debug: memory: open' $debug
|
|
|
efa7a1 |
+grep '^nbdkit:.*debug: memory: pread' $debug
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+nbdkit -U - \
|
|
|
efa7a1 |
+ -v -D nbdkit.backend.datapath=0 \
|
|
|
efa7a1 |
+ memory 10M \
|
|
|
efa7a1 |
+ --run "qemu-img convert \$nbd $out" |& tee $debug
|
|
|
efa7a1 |
+
|
|
|
efa7a1 |
+# Should contain only controlpath messages.
|
|
|
efa7a1 |
+grep '^nbdkit:.*debug: memory: open' $debug
|
|
|
efa7a1 |
+grep -v '^nbdkit:.*debug: memory: pread' $debug
|
|
|
efa7a1 |
--
|
|
|
efa7a1 |
2.18.2
|
|
|
efa7a1 |
|