Add systemd/dtrace probes for DBus APIs

When debugging libvirt it is helpful to set probes around RPC
calls. We already have probes for libvirt's native RPC layer,
so it makes sense to add them for the DBus RPC layer too.
This commit is contained in:
Daniel P. Berrange 2014-11-11 18:39:19 +00:00
parent 318df5a05f
commit d83ce91fd4
2 changed files with 28 additions and 3 deletions

View File

@ -15,6 +15,11 @@ provider libvirt {
probe event_poll_run(int nfds, int timeout); probe event_poll_run(int nfds, int timeout);
# file: src/util/virdbus.c
# prefix: dbus
probe dbus_method_call(const char *interface, const char *member, const char *object, const char *destination);
probe dbus_method_error(const char *interface, const char *member, const char *object, const char *destination, const char *name, const char *message);
probe dbus_method_reply(const char *interface, const char *member, const char *object, const char *destination);
# file: src/util/virobject.c # file: src/util/virobject.c
# prefix: object # prefix: object

View File

@ -27,6 +27,7 @@
#include "virlog.h" #include "virlog.h"
#include "virthread.h" #include "virthread.h"
#include "virstring.h" #include "virstring.h"
#include "virprobe.h"
#define VIR_FROM_THIS VIR_FROM_DBUS #define VIR_FROM_THIS VIR_FROM_DBUS
@ -1521,20 +1522,35 @@ static int
virDBusCall(DBusConnection *conn, virDBusCall(DBusConnection *conn,
DBusMessage *call, DBusMessage *call,
DBusMessage **replyout, DBusMessage **replyout,
DBusError *error, DBusError *error)
const char *member)
{ {
DBusMessage *reply = NULL; DBusMessage *reply = NULL;
DBusError localerror; DBusError localerror;
int ret = -1; int ret = -1;
const char *iface, *member, *path, *dest;
if (!error) if (!error)
dbus_error_init(&localerror); dbus_error_init(&localerror);
iface = dbus_message_get_interface(call);
member = dbus_message_get_member(call);
path = dbus_message_get_path(call);
dest = dbus_message_get_destination(call);
PROBE(DBUS_METHOD_CALL,
"'%s.%s' on '%s' at '%s'",
iface, member, path, dest);
if (!(reply = dbus_connection_send_with_reply_and_block(conn, if (!(reply = dbus_connection_send_with_reply_and_block(conn,
call, call,
VIR_DBUS_METHOD_CALL_TIMEOUT_MILLIS, VIR_DBUS_METHOD_CALL_TIMEOUT_MILLIS,
error ? error : &localerror))) { error ? error : &localerror))) {
PROBE(DBUS_METHOD_ERROR,
"'%s.%s' on '%s' at '%s' error %s: %s",
iface, member, path, dest,
error ? error->name : localerror.name,
error ? error->message : localerror.message);
if (error) { if (error) {
ret = 0; ret = 0;
} else { } else {
@ -1544,6 +1560,10 @@ virDBusCall(DBusConnection *conn,
goto cleanup; goto cleanup;
} }
PROBE(DBUS_METHOD_REPLY,
"'%s.%s' on '%s' at '%s'",
iface, member, path, dest);
ret = 0; ret = 0;
cleanup: cleanup:
@ -1616,7 +1636,7 @@ int virDBusCallMethod(DBusConnection *conn,
ret = -1; ret = -1;
ret = virDBusCall(conn, call, replyout, error, member); ret = virDBusCall(conn, call, replyout, error);
cleanup: cleanup:
if (call) if (call)