Hi Guillaume, On 05/06/2011 09:01 AM, Guillaume Zajac wrote: > --- > Makefile.am | 7 ++-- > src/ofono.h | 6 +++ > src/private-network.c | 89 +++++++++++++++++++++++++++++++++++++++++++++++++ > 3 files changed, 99 insertions(+), 3 deletions(-) > create mode 100644 src/private-network.c > > diff --git a/Makefile.am b/Makefile.am > index a413a47..e1eaf15 100644 > --- a/Makefile.am > +++ b/Makefile.am > @@ -16,8 +16,8 @@ pkginclude_HEADERS = include/log.h include/plugin.h include/history.h \ > include/cdma-sms.h include/sim-auth.h \ > include/gprs-provision.h include/emulator.h \ > include/location-reporting.h \ > - include/cdma-connman.h \ > - include/gnss.h > + include/cdma-connman.h include/gnss.h \ > + include/private-network.h As mentioned previously, this one belongs in the previous commit. > > nodist_pkginclude_HEADERS = include/version.h > > @@ -387,7 +387,8 @@ src_ofonod_SOURCES = $(gdbus_sources) $(builtin_sources) src/ofono.ver \ > src/message.h src/message.c src/gprs-provision.c \ > src/emulator.c src/location-reporting.c \ > src/cdma-connman.c src/gnss.c \ > - src/gnssagent.c src/gnssagent.h > + src/gnssagent.c src/gnssagent.h \ > + src/private-network.c > > src_ofonod_LDADD = $(builtin_libadd) @GLIB_LIBS@ @DBUS_LIBS@ @CAPNG_LIBS@ -ldl > > diff --git a/src/ofono.h b/src/ofono.h > index 82d7e34..7353022 100644 > --- a/src/ofono.h > +++ b/src/ofono.h > @@ -468,3 +468,9 @@ void __ofono_gprs_provision_free_settings( > > #include > #include > +#include > + > +void __ofono_private_network_release(int id); > +ofono_bool_t __ofono_private_network_request(ofono_private_network_cb_t cb, > + void *data, int *id); > + > diff --git a/src/private-network.c b/src/private-network.c > new file mode 100644 > index 0000000..03204a5 > --- /dev/null > +++ b/src/private-network.c > @@ -0,0 +1,89 @@ > +/* > + * > + * oFono - Open Source Telephony > + * > + * Copyright (C) 2008-2011 Intel Corporation. All rights reserved. > + * > + * This program is free software; you can redistribute it and/or modify > + * it under the terms of the GNU General Public License version 2 as > + * published by the Free Software Foundation. > + * > + * This program is distributed in the hope that it will be useful, > + * but WITHOUT ANY WARRANTY; without even the implied warranty of > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the > + * GNU General Public License for more details. > + * > + * You should have received a copy of the GNU General Public License > + * along with this program; if not, write to the Free Software > + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA > + * > + */ > + > +#ifdef HAVE_CONFIG_H > +#include > +#endif > + > +#include > +#include > +#include "ofono.h" > + > +static GSList *g_drivers = NULL; > + > +void __ofono_private_network_release(int id) > +{ > + GSList *d; > + > + DBG(""); > + > + for (d = g_drivers; d; d = d->next) { > + const struct ofono_private_network_driver *driver = d->data; > + > + if (g_strcmp0(driver->name, "ConnMan Private Network")) > + continue; > + What exactly is the purpose of the above statement? Also, for now I'd just assume that you can only ever have a single private network driver to make things simpler. > + driver->release(id); > + > + break; > + } > +} > + > +ofono_bool_t __ofono_private_network_request(ofono_private_network_cb_t cb, > + void *data, int *id) > +{ > + GSList *d; > + > + DBG(""); > + > + for (d = g_drivers; d; d = d->next) { > + const struct ofono_private_network_driver *driver = d->data; > + > + if (g_strcmp0(driver->name, "ConnMan Private Network")) > + continue; > + > + *id = driver->request(cb, data); In general it is good form not to assign to an out variable unless the function returns successfully. > + if (*id < 0) > + continue; You might want to always return > 0 for successful cases, and leave 0 as a sentinel value. > + > + return TRUE; > + } > + > + return FALSE; > +} > + > +int ofono_private_network_driver_register( > + const struct ofono_private_network_driver *d) > +{ > + DBG("driver: %p, name: %s", d, d->name); > + > + g_drivers = g_slist_prepend(g_drivers, (void *) d); > + > + return 0; > +} > + > +void ofono_private_network_driver_unregister( > + const struct ofono_private_network_driver *d) > +{ > + DBG("driver: %p, name: %s", d, d->name); > + > + g_drivers = g_slist_remove(g_drivers, (void *) d); > +} Regards, -Denis