$OpenBSD: patch-src_libtracker-common_tracker-dbus_c,v 1.6 2012/12/18 21:38:12 sthen Exp $
--- src/libtracker-common/tracker-dbus.c.orig	Wed Aug  3 06:53:16 2011
+++ src/libtracker-common/tracker-dbus.c	Fri Dec  7 06:03:18 2012
@@ -23,6 +23,15 @@
 #include <gio/gunixinputstream.h>
 #include <gio/gunixoutputstream.h>
 
+#ifdef __OpenBSD__
+#include <sys/param.h>
+#include <sys/types.h>
+#include <sys/proc.h>
+#include <sys/sysctl.h>
+#include <stdio.h>
+#include <kvm.h>
+#endif
+
 #include "tracker-dbus.h"
 #include "tracker-log.h"
 
@@ -139,6 +148,7 @@ client_data_new (gchar *sender)
 	}
 
 	if (get_binary) {
+#ifndef __OpenBSD__
 		gchar *filename;
 		gchar *pid_str;
 		gchar *contents = NULL;
@@ -171,6 +181,29 @@ client_data_new (gchar *sender)
 
 		g_strfreev (strv);
 		g_free (contents);
+#else
+		int nproc;
+		struct kinfo_proc *kp;
+		kvm_t *kd;
+		char **pargv;
+
+		if ((kd = kvm_openfiles(NULL, NULL, NULL, KVM_NO_FILES, NULL)) == NULL)
+			return cd;
+
+		if ((kp = kvm_getprocs(kd, KERN_PROC_PID, cd->pid, sizeof(*kp), &nproc)) == NULL)
+			goto out;
+
+		if ((kp->p_flag & P_SYSTEM) != 0) 
+			goto out;
+
+		if ((pargv = kvm_getargv(kd, kp, 0)) == NULL)
+			goto out;
+
+		cd->binary = g_path_get_basename(pargv[0]);
+
+out:
+		kvm_close(kd);
+#endif
 	}
 
 	return cd;
