summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMarcel Holtmann <marcel@holtmann.org>2009-01-04 19:02:00 +0100
committerMarcel Holtmann <marcel@holtmann.org>2009-01-04 19:02:00 +0100
commit186c1b8419c70a5649462e35fe0910099501a412 (patch)
treeb83d0b0d2737dc729eddc8a6ac1e796c5e1c1049 /src
parent94fca351c2cd0a75ea6b71462a084dc8ffe2e78d (diff)
downloadconnman-186c1b8419c70a5649462e35fe0910099501a412.tar.gz
connman-186c1b8419c70a5649462e35fe0910099501a412.tar.bz2
connman-186c1b8419c70a5649462e35fe0910099501a412.zip
Add skeleton for storage drivers
Diffstat (limited to 'src')
-rw-r--r--src/connman.h8
-rw-r--r--src/storage.c41
2 files changed, 46 insertions, 3 deletions
diff --git a/src/connman.h b/src/connman.h
index 87fe9278..a87c49f0 100644
--- a/src/connman.h
+++ b/src/connman.h
@@ -39,9 +39,6 @@ DBusMessage *__connman_error_not_supported(DBusMessage *msg);
int __connman_selftest(void);
-int __connman_storage_init(void);
-void __connman_storage_cleanup(void);
-
int __connman_manager_init(DBusConnection *conn, gboolean compat);
void __connman_manager_cleanup(void);
@@ -84,6 +81,11 @@ void __connman_resolver_cleanup(void);
int __connman_resolver_selftest(void);
+#include <connman/storage.h>
+
+int __connman_storage_init(void);
+void __connman_storage_cleanup(void);
+
#include <connman/driver.h>
void __connman_driver_rescan(struct connman_driver *driver);
diff --git a/src/storage.c b/src/storage.c
index 41cfd420..1266fc28 100644
--- a/src/storage.c
+++ b/src/storage.c
@@ -25,6 +25,47 @@
#include "connman.h"
+static GSList *storage_list = NULL;
+
+static gint compare_priority(gconstpointer a, gconstpointer b)
+{
+ const struct connman_storage *storage1 = a;
+ const struct connman_storage *storage2 = b;
+
+ return storage2->priority - storage1->priority;
+}
+
+/**
+ * connman_storage_register:
+ * @storage: storage module
+ *
+ * Register a new storage module
+ *
+ * Returns: %0 on success
+ */
+int connman_storage_register(struct connman_storage *storage)
+{
+ DBG("storage %p name %s", storage, storage->name);
+
+ storage_list = g_slist_insert_sorted(storage_list, storage,
+ compare_priority);
+
+ return 0;
+}
+
+/**
+ * connman_storage_unregister:
+ * @storage: storage module
+ *
+ * Remove a previously registered storage module
+ */
+void connman_storage_unregister(struct connman_storage *storage)
+{
+ DBG("storage %p name %s", storage, storage->name);
+
+ storage_list = g_slist_remove(storage_list, storage);
+}
+
int __connman_storage_init(void)
{
DBG("");