* [PATCH 2/3] Add Palm Pre plugin
@ 2009-11-10 6:30 Andrzej Zaborowski
2009-11-10 8:15 ` Marcel Holtmann
2009-11-10 22:27 ` Denis Kenzior
0 siblings, 2 replies; 3+ messages in thread
From: Andrzej Zaborowski @ 2009-11-10 6:30 UTC (permalink / raw)
To: ofono
[-- Attachment #1: Type: text/plain, Size: 6718 bytes --]
---
Makefile.am | 3 +
plugins/modemconf.c | 3 +-
plugins/palmpre.c | 219 +++++++++++++++++++++++++++++++++++++++++++++++++++
3 files changed, 224 insertions(+), 1 deletions(-)
create mode 100644 plugins/palmpre.c
diff --git a/Makefile.am b/Makefile.am
index c3e06b4..0e08349 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -168,6 +168,9 @@ builtin_sources += plugins/novatel.c
builtin_modules += hfp
builtin_sources += plugins/hfp.c
+
+builtin_modules += palmpre
+builtin_sources += plugins/palmpre.c
endif
if MAINTAINER_MODE
diff --git a/plugins/modemconf.c b/plugins/modemconf.c
index 4b66590..39a62b8 100644
--- a/plugins/modemconf.c
+++ b/plugins/modemconf.c
@@ -127,7 +127,8 @@ static struct ofono_modem *create_modem(GKeyFile *keyfile, const char *group)
if (!g_strcmp0(driver, "atgen") || !g_strcmp0(driver, "g1") ||
!g_strcmp0(driver, "calypso") ||
- !g_strcmp0(driver, "hfp"))
+ !g_strcmp0(driver, "hfp") ||
+ !g_strcmp0(driver, "palmpre"))
set_device(modem, keyfile, group);
g_free(driver);
diff --git a/plugins/palmpre.c b/plugins/palmpre.c
new file mode 100644
index 0000000..37cb7b6
--- /dev/null
+++ b/plugins/palmpre.c
@@ -0,0 +1,219 @@
+/*
+ *
+ * oFono - Open Source Telephony
+ *
+ * Copyright (C) 2008-2009 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 <config.h>
+#endif
+
+#include <errno.h>
+#include <stdlib.h>
+
+#include <glib.h>
+#include <gatchat.h>
+#include <gattty.h>
+
+#define OFONO_API_SUBJECT_TO_CHANGE
+#include <ofono/plugin.h>
+#include <ofono/log.h>
+#include <ofono/modem.h>
+#include <ofono/devinfo.h>
+#include <ofono/message-waiting.h>
+#include <ofono/netreg.h>
+#include <ofono/sim.h>
+#include <ofono/phonebook.h>
+#include <ofono/voicecall.h>
+#include <ofono/gprs.h>
+#include <ofono/gprs-context.h>
+
+#include <drivers/atmodem/vendor.h>
+
+struct palmpre_data {
+ GAtChat *chat;
+};
+
+static int palmpre_probe(struct ofono_modem *modem)
+{
+ struct palmpre_data *data;
+
+ DBG("%p", modem);
+
+ data = g_try_new0(struct palmpre_data, 1);
+ if (!data)
+ return -ENOMEM;
+
+ ofono_modem_set_data(modem, data);
+
+ return 0;
+}
+
+static void palmpre_remove(struct ofono_modem *modem)
+{
+ struct palmpre_data *data = ofono_modem_get_data(modem);
+
+ DBG("%p", modem);
+
+ g_free(data);
+ ofono_modem_set_data(modem, NULL);
+}
+
+static void palmpre_debug(const char *str, void *user_data)
+{
+ ofono_info("%s", str);
+}
+
+static void cfun_set_on_cb(gboolean ok, GAtResult *result, gpointer user_data)
+{
+ struct ofono_modem *modem = user_data;
+
+ DBG("");
+
+ ofono_modem_set_powered(modem, ok);
+}
+
+static int palmpre_enable(struct ofono_modem *modem)
+{
+ struct palmpre_data *data = ofono_modem_get_data(modem);
+ GIOChannel *io;
+ GAtSyntax *syntax;
+ const char *device;
+ GHashTable *options;
+
+ DBG("%p", modem);
+
+ device = ofono_modem_get_string(modem, "Device");
+ if (!device)
+ device = "/dev/modem0";
+
+ options = g_hash_table_new(g_str_hash, g_str_equal);
+ if (!options)
+ return -ENOMEM;
+
+ g_hash_table_insert(options, "Baud", "115200");
+
+ io = g_at_tty_open(device, options);
+ g_hash_table_destroy(options);
+
+ if (!io)
+ return -EIO;
+
+ syntax = g_at_syntax_new_gsm_permissive();
+ data->chat = g_at_chat_new(io, syntax);
+ g_io_channel_unref(io);
+ g_at_syntax_unref(syntax);
+
+ if (!data->chat)
+ return -ENOMEM;
+
+ if (getenv("OFONO_AT_DEBUG"))
+ g_at_chat_set_debug(data->chat, palmpre_debug, NULL);
+
+ /* Ensure terminal is in a known state */
+ g_at_chat_send(data->chat, "ATZ E0 +CMEE=1", NULL, NULL, NULL, NULL);
+
+ /* Power modem up */
+ g_at_chat_send(data->chat, "AT+CFUN=1", NULL,
+ cfun_set_on_cb, modem, NULL);
+
+ return 0;
+}
+
+static void cfun_set_off_cb(gboolean ok, GAtResult *result, gpointer user_data)
+{
+ GAtChat *chat = user_data;
+
+ DBG("");
+
+ g_at_chat_unref(chat);
+}
+
+static int palmpre_disable(struct ofono_modem *modem)
+{
+ struct palmpre_data *data = ofono_modem_get_data(modem);
+
+ DBG("%p", modem);
+
+ /* Power modem down */
+ g_at_chat_send(data->chat, "AT+CFUN=0", NULL,
+ cfun_set_off_cb, data->chat, NULL);
+
+ ofono_modem_set_powered(modem, FALSE);
+
+ data->chat = NULL;
+
+ return 0;
+}
+
+static void palmpre_pre_sim(struct ofono_modem *modem)
+{
+ struct palmpre_data *data = ofono_modem_get_data(modem);
+
+ DBG("%p", modem);
+
+ ofono_devinfo_create(modem, 0, "atmodem", data->chat);
+ ofono_sim_create(modem, OFONO_VENDOR_MSM, "atmodem", data->chat);
+ ofono_voicecall_create(modem, 0, "atmodem", data->chat);
+}
+
+static void palmpre_post_sim(struct ofono_modem *modem)
+{
+ struct palmpre_data *data = ofono_modem_get_data(modem);
+ struct ofono_message_waiting *mw;
+ struct ofono_gprs *gprs;
+ struct ofono_gprs_context *gc;
+
+ DBG("%p", modem);
+
+ ofono_netreg_create(modem, 0, "atmodem", data->chat);
+ ofono_phonebook_create(modem, 0, "atmodem", data->chat);
+
+ gprs = ofono_gprs_create(modem, 0, "atmodem", data->chat);
+ gc = ofono_gprs_context_create(modem, 0, "atmodem", data->chat);
+
+ if (gprs && gc)
+ ofono_gprs_add_context(gprs, gc);
+
+ mw = ofono_message_waiting_create(modem);
+ if (mw)
+ ofono_message_waiting_register(mw);
+}
+
+static struct ofono_modem_driver palmpre_driver = {
+ .name = "palmpre",
+ .probe = palmpre_probe,
+ .remove = palmpre_remove,
+ .enable = palmpre_enable,
+ .disable = palmpre_disable,
+ .pre_sim = palmpre_pre_sim,
+ .post_sim = palmpre_post_sim
+};
+
+static int palmpre_init(void)
+{
+ return ofono_modem_driver_register(&palmpre_driver);
+}
+
+static void palmpre_exit(void)
+{
+ ofono_modem_driver_unregister(&palmpre_driver);
+}
+
+OFONO_PLUGIN_DEFINE(palmpre, "Palm Pre driver", VERSION,
+ OFONO_PLUGIN_PRIORITY_DEFAULT, palmpre_init, palmpre_exit)
--
1.6.1
^ permalink raw reply related [flat|nested] 3+ messages in thread* Re: [PATCH 2/3] Add Palm Pre plugin
2009-11-10 6:30 [PATCH 2/3] Add Palm Pre plugin Andrzej Zaborowski
@ 2009-11-10 8:15 ` Marcel Holtmann
2009-11-10 22:27 ` Denis Kenzior
1 sibling, 0 replies; 3+ messages in thread
From: Marcel Holtmann @ 2009-11-10 8:15 UTC (permalink / raw)
To: ofono
[-- Attachment #1: Type: text/plain, Size: 412 bytes --]
Hi Andrzej,
> +static void palmpre_remove(struct ofono_modem *modem)
> +{
> + struct palmpre_data *data = ofono_modem_get_data(modem);
> +
> + DBG("%p", modem);
> +
> + g_free(data);
> + ofono_modem_set_data(modem, NULL);
> +}
Never ever do it this way. The set_data(..., NULL) must come before
freeing the data. Otherwise it potentially opens a can of race
conditions.
Regards
Marcel
^ permalink raw reply [flat|nested] 3+ messages in thread* Re: [PATCH 2/3] Add Palm Pre plugin
2009-11-10 6:30 [PATCH 2/3] Add Palm Pre plugin Andrzej Zaborowski
2009-11-10 8:15 ` Marcel Holtmann
@ 2009-11-10 22:27 ` Denis Kenzior
1 sibling, 0 replies; 3+ messages in thread
From: Denis Kenzior @ 2009-11-10 22:27 UTC (permalink / raw)
To: ofono
[-- Attachment #1: Type: text/plain, Size: 146 bytes --]
Hi Andrew,
I applied this patch with minor fixes (pointed out by Marcel) and renaming of
MSM quirk to QUALCOMM_MSM.
Regards,
-Denis
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2009-11-10 22:27 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-11-10 6:30 [PATCH 2/3] Add Palm Pre plugin Andrzej Zaborowski
2009-11-10 8:15 ` Marcel Holtmann
2009-11-10 22:27 ` Denis Kenzior
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.