|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH 10 of 21 RESEND] blktap3/drivers: Introduce back-end driver abstraction
This patch copies the back-end driver abstraction layer from blktap2, with
changes coming from blktap2.5.
Signed-off-by: Thanos Makatos <thanos.makatos@xxxxxxxxxx>
diff --git a/tools/blktap2/drivers/tapdisk-driver.c
b/tools/blktap3/drivers/tapdisk-driver.c
copy from tools/blktap2/drivers/tapdisk-driver.c
copy to tools/blktap3/drivers/tapdisk-driver.c
--- a/tools/blktap2/drivers/tapdisk-driver.c
+++ b/tools/blktap3/drivers/tapdisk-driver.c
@@ -25,14 +25,49 @@
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
+
#include <stdlib.h>
+#include <stdio.h>
#include "tapdisk-driver.h"
#include "tapdisk-server.h"
#include "tapdisk-disktype.h"
+#include "tapdisk-stats.h"
+
+static void
+tapdisk_driver_log_flush(td_driver_t * driver, const char *__caller)
+{
+ td_loglimit_t *rl = &driver->loglimit;
+
+ if (rl->dropped) {
+ tlog_syslog(LOG_WARNING,
+ "%s: %s: %d messages suppressed",
+ driver->name, __caller, rl->dropped);
+ rl->dropped = 0;
+ }
+}
+
+int tapdisk_driver_log_pass(td_driver_t * driver, const char *__caller)
+{
+ td_loglimit_t *rl = &driver->loglimit;
+ int dropping = rl->dropped;
+
+ if (tapdisk_loglimit_pass(rl)) {
+ tapdisk_driver_log_flush(driver, __caller);
+ return 1;
+ }
+
+ if (!dropping)
+ tlog_syslog(LOG_WARNING,
+ "%s: %s: too many errors, dropped.",
+ driver->name, __caller);
+
+ return 0;
+}
td_driver_t *
-tapdisk_driver_allocate(int type, char *name, td_flag_t flags, int storage)
+tapdisk_driver_allocate(int type, const char *name,
+ td_flag_t flags)
{
int err;
td_driver_t *driver;
@@ -52,7 +87,7 @@ tapdisk_driver_allocate(int type, char *
driver->ops = ops;
driver->type = type;
- driver->storage = storage;
+ driver->storage = -1;
driver->data = calloc(1, ops->private_data_size);
if (!driver->data)
goto fail;
@@ -60,6 +95,9 @@ tapdisk_driver_allocate(int type, char *
if (td_flag_test(flags, TD_OPEN_RDONLY))
td_flag_set(driver->state, TD_DRIVER_RDONLY);
+ tapdisk_loglimit_init(&driver->loglimit, 16 /* msgs */ ,
+ 90 * 1000 /* ms */ );
+
return driver;
fail:
@@ -82,13 +120,16 @@ tapdisk_driver_free(td_driver_t *driver)
EPRINTF("freeing open driver %s (state 0x%08x)\n",
driver->name, driver->state);
+ tapdisk_driver_log_flush(driver, __func__);
+
free(driver->name);
free(driver->data);
free(driver);
}
void
-tapdisk_driver_queue_tiocb(td_driver_t *driver, struct tiocb *tiocb)
+tapdisk_driver_queue_tiocb(td_driver_t *driver __attribute__((unused)),
+ struct tiocb *tiocb)
{
tapdisk_server_queue_tiocb(tiocb);
}
@@ -99,3 +140,21 @@ tapdisk_driver_debug(td_driver_t *driver
if (driver->ops->td_debug)
driver->ops->td_debug(driver);
}
+
+void tapdisk_driver_stats(td_driver_t * driver, td_stats_t * st)
+{
+ const disk_info_t *info;
+
+ tapdisk_stats_field(st, "type", "d", driver->type);
+
+ info = tapdisk_disk_types[driver->type];
+ tapdisk_stats_field(st, "name", "s", info->name);
+
+ if (driver->ops->td_stats) {
+ tapdisk_stats_field(st, "status", "{");
+ driver->ops->td_stats(driver, st);
+ tapdisk_stats_leave(st, '}');
+ } else
+ tapdisk_stats_field(st, "status", NULL);
+
+}
diff --git a/tools/blktap2/drivers/tapdisk-driver.h
b/tools/blktap3/drivers/tapdisk-driver.h
copy from tools/blktap2/drivers/tapdisk-driver.h
copy to tools/blktap3/drivers/tapdisk-driver.h
--- a/tools/blktap2/drivers/tapdisk-driver.h
+++ b/tools/blktap3/drivers/tapdisk-driver.h
@@ -31,6 +31,7 @@
#include "tapdisk.h"
#include "scheduler.h"
#include "tapdisk-queue.h"
+#include "tapdisk-loglimit.h"
#define TD_DRIVER_OPEN 0x0001
#define TD_DRIVER_RDONLY 0x0002
@@ -49,14 +50,19 @@ struct td_driver_handle {
void *data;
const struct tap_disk *ops;
- struct list_head next;
+ td_loglimit_t loglimit;
+ TAILQ_ENTRY(td_driver_handle) next;
};
-td_driver_t *tapdisk_driver_allocate(int, char *, td_flag_t, int);
+td_driver_t *tapdisk_driver_allocate(int, const char *, td_flag_t);
void tapdisk_driver_free(td_driver_t *);
void tapdisk_driver_queue_tiocb(td_driver_t *, struct tiocb *);
void tapdisk_driver_debug(td_driver_t *);
+void tapdisk_driver_stats(td_driver_t *, td_stats_t *);
+
+int tapdisk_driver_log_pass(td_driver_t *, const char *caller);
+
#endif
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |