Blob: transport.c
Blob id: 527d9ffced216d3e731054bed1e14105d9670d8d
Size: 1.5 KB
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 | // SPDX-License-Identifier: GPL-2.0-or-later /* * * OBEX Server * * Copyright (C) 2007-2010 Marcel Holtmann <marcel@holtmann.org> * * */ #ifdef HAVE_CONFIG_H #include <config.h> #endif #include <stdio.h> #include <errno.h> #include <string.h> #include <stdint.h> #include <stdlib.h> #include <glib.h> #include "obex.h" #include "server.h" #include "transport.h" #include "log.h" static GSList *drivers = NULL; static const struct obex_transport_driver * obex_transport_driver_find(const char *name) { const GSList *l; for (l = drivers; l; l = l->next) { const struct obex_transport_driver *driver = l->data; if (g_strcmp0(name, driver->name) == 0) return driver; } return NULL; } const GSList *obex_transport_driver_list(void) { return drivers; } int obex_transport_driver_register(const struct obex_transport_driver *driver) { if (!driver) { error("Invalid driver"); return -EINVAL; } if (obex_transport_driver_find(driver->name) != NULL) { error("Permission denied: transport %s already registered", driver->name); return -EPERM; } DBG("driver %p transport %s registered", driver, driver->name); drivers = g_slist_prepend(drivers, (gpointer)driver); return 0; } void obex_transport_driver_unregister(const struct obex_transport_driver *driver) { if (!g_slist_find(drivers, driver)) { error("Unable to unregister: No such driver %p", driver); return; } DBG("driver %p transport %s unregistered", driver, driver->name); drivers = g_slist_remove(drivers, driver); } |