Introducing a plug-in for the Nokia N900 (untested)
This commit is contained in:
parent
5a3b1b052d
commit
f7cf632a17
1
Makefile
1
Makefile
@ -100,6 +100,7 @@ dist:
|
|||||||
$(PACKAGE)-$(VERSION)/src/plugins/engineering.c \
|
$(PACKAGE)-$(VERSION)/src/plugins/engineering.c \
|
||||||
$(PACKAGE)-$(VERSION)/src/plugins/gprs.c \
|
$(PACKAGE)-$(VERSION)/src/plugins/gprs.c \
|
||||||
$(PACKAGE)-$(VERSION)/src/plugins/locker.c \
|
$(PACKAGE)-$(VERSION)/src/plugins/locker.c \
|
||||||
|
$(PACKAGE)-$(VERSION)/src/plugins/n900.c \
|
||||||
$(PACKAGE)-$(VERSION)/src/plugins/openmoko.c \
|
$(PACKAGE)-$(VERSION)/src/plugins/openmoko.c \
|
||||||
$(PACKAGE)-$(VERSION)/src/plugins/oss.c \
|
$(PACKAGE)-$(VERSION)/src/plugins/oss.c \
|
||||||
$(PACKAGE)-$(VERSION)/src/plugins/panel.c \
|
$(PACKAGE)-$(VERSION)/src/plugins/panel.c \
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
SUBDIRS = 16x16 24x24 32x32 48x48
|
SUBDIRS = 16x16 24x24 32x32 48x48
|
||||||
TARGETS = blacklist.so debug.so engineering.so gprs.so locker.so openmoko.so oss.so panel.so profiles.so smscrypt.so
|
TARGETS = blacklist.so debug.so engineering.so gprs.so locker.so n900.so openmoko.so oss.so panel.so profiles.so smscrypt.so
|
||||||
PREFIX = /usr/local
|
PREFIX = /usr/local
|
||||||
DESTDIR =
|
DESTDIR =
|
||||||
LIBDIR = $(PREFIX)/lib
|
LIBDIR = $(PREFIX)/lib
|
||||||
@ -57,6 +57,13 @@ locker_LDFLAGS = $(LDFLAGSF) $(LDFLAGS)
|
|||||||
locker.so: $(locker_OBJS)
|
locker.so: $(locker_OBJS)
|
||||||
$(LD) -o locker.so $(locker_OBJS) $(locker_LDFLAGS)
|
$(LD) -o locker.so $(locker_OBJS) $(locker_LDFLAGS)
|
||||||
|
|
||||||
|
n900_OBJS = n900.o
|
||||||
|
n900_CFLAGS = $(CPPFLAGSF) $(CPPFLAGS) $(CFLAGSF) $(CFLAGS)
|
||||||
|
n900_LDFLAGS = $(LDFLAGSF) $(LDFLAGS)
|
||||||
|
|
||||||
|
n900.so: $(n900_OBJS)
|
||||||
|
$(LD) -o n900.so $(n900_OBJS) $(n900_LDFLAGS)
|
||||||
|
|
||||||
openmoko_OBJS = openmoko.o
|
openmoko_OBJS = openmoko.o
|
||||||
openmoko_CFLAGS = $(CPPFLAGSF) $(CPPFLAGS) -I../modems $(CFLAGSF) $(CFLAGS) `pkg-config --cflags alsa`
|
openmoko_CFLAGS = $(CPPFLAGSF) $(CPPFLAGS) -I../modems $(CFLAGSF) $(CFLAGS) `pkg-config --cflags alsa`
|
||||||
openmoko_LDFLAGS = $(LDFLAGSF) $(LDFLAGS) `pkg-config --libs alsa`
|
openmoko_LDFLAGS = $(LDFLAGSF) $(LDFLAGS) `pkg-config --libs alsa`
|
||||||
@ -107,6 +114,9 @@ gprs.o: gprs.c ../../include/Phone.h
|
|||||||
locker.o: locker.c ../../include/Phone.h
|
locker.o: locker.c ../../include/Phone.h
|
||||||
$(CC) $(locker_CFLAGS) -c locker.c
|
$(CC) $(locker_CFLAGS) -c locker.c
|
||||||
|
|
||||||
|
n900.o: n900.c ../../include/Phone.h
|
||||||
|
$(CC) $(n900_CFLAGS) -c n900.c
|
||||||
|
|
||||||
openmoko.o: openmoko.c ../../include/Phone.h
|
openmoko.o: openmoko.c ../../include/Phone.h
|
||||||
$(CC) $(openmoko_CFLAGS) -c openmoko.c
|
$(CC) $(openmoko_CFLAGS) -c openmoko.c
|
||||||
|
|
||||||
@ -124,11 +134,11 @@ smscrypt.o: smscrypt.c ../../include/Phone.h
|
|||||||
|
|
||||||
clean:
|
clean:
|
||||||
@for i in $(SUBDIRS); do (cd $$i && $(MAKE) clean) || exit; done
|
@for i in $(SUBDIRS); do (cd $$i && $(MAKE) clean) || exit; done
|
||||||
$(RM) -- $(blacklist_OBJS) $(debug_OBJS) $(engineering_OBJS) $(gprs_OBJS) $(locker_OBJS) $(openmoko_OBJS) $(oss_OBJS) $(panel_OBJS) $(profiles_OBJS) $(smscrypt_OBJS)
|
$(RM) -- $(blacklist_OBJS) $(debug_OBJS) $(engineering_OBJS) $(gprs_OBJS) $(locker_OBJS) $(n900_OBJS) $(openmoko_OBJS) $(oss_OBJS) $(panel_OBJS) $(profiles_OBJS) $(smscrypt_OBJS)
|
||||||
|
|
||||||
distclean:
|
distclean:
|
||||||
@for i in $(SUBDIRS); do (cd $$i && $(MAKE) distclean) || exit; done
|
@for i in $(SUBDIRS); do (cd $$i && $(MAKE) distclean) || exit; done
|
||||||
$(RM) -- $(blacklist_OBJS) $(debug_OBJS) $(engineering_OBJS) $(gprs_OBJS) $(locker_OBJS) $(openmoko_OBJS) $(oss_OBJS) $(panel_OBJS) $(profiles_OBJS) $(smscrypt_OBJS)
|
$(RM) -- $(blacklist_OBJS) $(debug_OBJS) $(engineering_OBJS) $(gprs_OBJS) $(locker_OBJS) $(n900_OBJS) $(openmoko_OBJS) $(oss_OBJS) $(panel_OBJS) $(profiles_OBJS) $(smscrypt_OBJS)
|
||||||
$(RM) -- $(TARGETS)
|
$(RM) -- $(TARGETS)
|
||||||
|
|
||||||
install: $(TARGETS)
|
install: $(TARGETS)
|
||||||
@ -144,6 +154,8 @@ install: $(TARGETS)
|
|||||||
$(MKDIR) $(DESTDIR)$(LIBDIR)/Phone/plugins
|
$(MKDIR) $(DESTDIR)$(LIBDIR)/Phone/plugins
|
||||||
$(INSTALL) -m 0644 -- locker.so $(DESTDIR)$(LIBDIR)/Phone/plugins/locker.so
|
$(INSTALL) -m 0644 -- locker.so $(DESTDIR)$(LIBDIR)/Phone/plugins/locker.so
|
||||||
$(MKDIR) $(DESTDIR)$(LIBDIR)/Phone/plugins
|
$(MKDIR) $(DESTDIR)$(LIBDIR)/Phone/plugins
|
||||||
|
$(INSTALL) -m 0644 -- n900.so $(DESTDIR)$(LIBDIR)/Phone/plugins/n900.so
|
||||||
|
$(MKDIR) $(DESTDIR)$(LIBDIR)/Phone/plugins
|
||||||
$(INSTALL) -m 0644 -- openmoko.so $(DESTDIR)$(LIBDIR)/Phone/plugins/openmoko.so
|
$(INSTALL) -m 0644 -- openmoko.so $(DESTDIR)$(LIBDIR)/Phone/plugins/openmoko.so
|
||||||
$(MKDIR) $(DESTDIR)$(LIBDIR)/Phone/plugins
|
$(MKDIR) $(DESTDIR)$(LIBDIR)/Phone/plugins
|
||||||
$(INSTALL) -m 0644 -- panel.so $(DESTDIR)$(LIBDIR)/Phone/plugins/panel.so
|
$(INSTALL) -m 0644 -- panel.so $(DESTDIR)$(LIBDIR)/Phone/plugins/panel.so
|
||||||
@ -159,6 +171,7 @@ uninstall:
|
|||||||
$(RM) -- $(DESTDIR)$(LIBDIR)/Phone/plugins/engineering.so
|
$(RM) -- $(DESTDIR)$(LIBDIR)/Phone/plugins/engineering.so
|
||||||
$(RM) -- $(DESTDIR)$(LIBDIR)/Phone/plugins/gprs.so
|
$(RM) -- $(DESTDIR)$(LIBDIR)/Phone/plugins/gprs.so
|
||||||
$(RM) -- $(DESTDIR)$(LIBDIR)/Phone/plugins/locker.so
|
$(RM) -- $(DESTDIR)$(LIBDIR)/Phone/plugins/locker.so
|
||||||
|
$(RM) -- $(DESTDIR)$(LIBDIR)/Phone/plugins/n900.so
|
||||||
$(RM) -- $(DESTDIR)$(LIBDIR)/Phone/plugins/openmoko.so
|
$(RM) -- $(DESTDIR)$(LIBDIR)/Phone/plugins/openmoko.so
|
||||||
$(RM) -- $(DESTDIR)$(LIBDIR)/Phone/plugins/panel.so
|
$(RM) -- $(DESTDIR)$(LIBDIR)/Phone/plugins/panel.so
|
||||||
$(RM) -- $(DESTDIR)$(LIBDIR)/Phone/plugins/profiles.so
|
$(RM) -- $(DESTDIR)$(LIBDIR)/Phone/plugins/profiles.so
|
||||||
|
126
src/plugins/n900.c
Normal file
126
src/plugins/n900.c
Normal file
@ -0,0 +1,126 @@
|
|||||||
|
/* $Id$ */
|
||||||
|
/* Copyright (c) 2011 Pierre Pronchery <khorben@defora.org> */
|
||||||
|
/* This file is part of DeforaOS Desktop Phone */
|
||||||
|
/* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, version 3 of the License.
|
||||||
|
*
|
||||||
|
* 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, see <http://www.gnu.org/licenses/>. */
|
||||||
|
/* This code is inspired by existing work by Sebastian Reichel <sre@debian.org>,
|
||||||
|
* see https://elektranox.org/n900/libisi */
|
||||||
|
/* TODO:
|
||||||
|
* - test on actual hardware */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <gtk/gtk.h>
|
||||||
|
#include <System.h>
|
||||||
|
#include "Phone.h"
|
||||||
|
|
||||||
|
|
||||||
|
/* N900 */
|
||||||
|
/* prototypes */
|
||||||
|
/* plug-in */
|
||||||
|
static int _n900_event(PhonePlugin * plugin, PhoneEvent * event);
|
||||||
|
|
||||||
|
|
||||||
|
/* public */
|
||||||
|
/* variables */
|
||||||
|
PhonePlugin plugin =
|
||||||
|
{
|
||||||
|
NULL,
|
||||||
|
"Nokia N900",
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
|
_n900_event,
|
||||||
|
NULL,
|
||||||
|
NULL
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* private */
|
||||||
|
/* n900_event */
|
||||||
|
static int _event_power_on(PhonePlugin * plugin, gboolean power);
|
||||||
|
|
||||||
|
static int _n900_event(PhonePlugin * plugin, PhoneEvent * event)
|
||||||
|
{
|
||||||
|
switch(event->type)
|
||||||
|
{
|
||||||
|
case PHONE_EVENT_TYPE_OFFLINE:
|
||||||
|
_event_power_on(plugin, FALSE);
|
||||||
|
break;
|
||||||
|
case PHONE_EVENT_TYPE_ONLINE:
|
||||||
|
_event_power_on(plugin, TRUE);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int _event_power_on(PhonePlugin * plugin, gboolean power)
|
||||||
|
{
|
||||||
|
int ret = 0;
|
||||||
|
char const root[] = "/sys/devices/platform/gpio-switch";
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
char const * name;
|
||||||
|
int enable;
|
||||||
|
int disable;
|
||||||
|
unsigned int delay;
|
||||||
|
} commands[] = {
|
||||||
|
{ "cmt_apeslpx", 0, 0, 0 },
|
||||||
|
{ "cmt_rst_rq", 0, 0, 0 },
|
||||||
|
{ "cmt_bsi", 0, -1, 0 },
|
||||||
|
{ "cmt_rst", 0, 0, 0 },
|
||||||
|
{ "cmt_en", 1, 0, 0 },
|
||||||
|
{ "cmt_rst", 1, 1, 0 },
|
||||||
|
{ "cmt_rst_eq", 1, -1, 0 },
|
||||||
|
{ "cmt_en", 1, -1, 5 },
|
||||||
|
};
|
||||||
|
size_t i;
|
||||||
|
int fd;
|
||||||
|
char path[256];
|
||||||
|
char buf[256];
|
||||||
|
int len;
|
||||||
|
|
||||||
|
for(i = 0; i < sizeof(commands) / sizeof(*commands) && ret == 0; i++)
|
||||||
|
{
|
||||||
|
if((power ? commands[i].enable : commands[i].disable) < 0)
|
||||||
|
continue;
|
||||||
|
if(commands[i].delay > 0)
|
||||||
|
/* FIXME freezes the application for as long */
|
||||||
|
sleep(commands[i].delay);
|
||||||
|
snprintf(path, sizeof(path), "%s/%s/%s", root, commands[i].name,
|
||||||
|
"state");
|
||||||
|
if((fd = open(path, O_WRONLY)) < 0)
|
||||||
|
{
|
||||||
|
snprintf(buf, sizeof(buf), "%s: %s", path, strerror(
|
||||||
|
errno));
|
||||||
|
ret = plugin->helper->error(NULL, buf, 1);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
len = snprintf(buf, sizeof(buf), "%s", power ? "active"
|
||||||
|
: "inactive");
|
||||||
|
if(write(fd, buf, len) != len)
|
||||||
|
{
|
||||||
|
snprintf(buf, sizeof(buf), "%s: %s", path,
|
||||||
|
strerror(errno));
|
||||||
|
ret = plugin->helper->error(NULL, buf, 1);
|
||||||
|
}
|
||||||
|
close(fd);
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
subdirs=16x16,24x24,32x32,48x48
|
subdirs=16x16,24x24,32x32,48x48
|
||||||
targets=blacklist,debug,engineering,gprs,locker,openmoko,oss,panel,profiles,smscrypt
|
targets=blacklist,debug,engineering,gprs,locker,n900,openmoko,oss,panel,profiles,smscrypt
|
||||||
cppflags_force=-I ../../include
|
cppflags_force=-I ../../include
|
||||||
cppflags=
|
cppflags=
|
||||||
cflags_force=-W `pkg-config --cflags libSystem gtk+-2.0`
|
cflags_force=-W `pkg-config --cflags libSystem gtk+-2.0`
|
||||||
@ -46,6 +46,14 @@ install=$(LIBDIR)/Phone/plugins
|
|||||||
[locker.c]
|
[locker.c]
|
||||||
depends=../../include/Phone.h
|
depends=../../include/Phone.h
|
||||||
|
|
||||||
|
[n900]
|
||||||
|
type=plugin
|
||||||
|
sources=n900.c
|
||||||
|
install=$(LIBDIR)/Phone/plugins
|
||||||
|
|
||||||
|
[n900.c]
|
||||||
|
depends=../../include/Phone.h
|
||||||
|
|
||||||
[openmoko]
|
[openmoko]
|
||||||
type=plugin
|
type=plugin
|
||||||
sources=openmoko.c
|
sources=openmoko.c
|
||||||
|
Loading…
Reference in New Issue
Block a user