summaryrefslogtreecommitdiff
authorllornkcor <llornkcor>2002-04-24 19:37:47 (UTC)
committer llornkcor <llornkcor>2002-04-24 19:37:47 (UTC)
commitfeaa245515b0746f6f70f590411c38e0a54c88ee (patch) (side-by-side diff)
tree352ab6e61ea8e773d9f08f77db0ca36984c62c1d
parent17eb865ad8248b1f47c565b074b9b6bbbd44935b (diff)
downloadopie-feaa245515b0746f6f70f590411c38e0a54c88ee.zip
opie-feaa245515b0746f6f70f590411c38e0a54c88ee.tar.gz
opie-feaa245515b0746f6f70f590411c38e0a54c88ee.tar.bz2
enable keyclicks and touchsound on zaurus
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--library/custom-sharp.h33
1 files changed, 18 insertions, 15 deletions
diff --git a/library/custom-sharp.h b/library/custom-sharp.h
index f65d474..08f8a6f 100644
--- a/library/custom-sharp.h
+++ b/library/custom-sharp.h
@@ -18,130 +18,133 @@
**
**********************************************************************/
#define QPE_OWNAPM
#define QPE_HAVE_TOGGLELIGHT
#define QPE_NOCIBAUD
#define QPE_STARTMENU
#include <asm/sharp_apm.h>
#ifndef APM_IOC_BATTERY_BACK_CHK
#define APM_IOC_BATTERY_BACK_CHK _IO(APM_IOC_MAGIC, 32)
#endif
#ifndef APM_IOC_BATTERY_MAIN_CHK
#define APM_IOC_BATTERY_MAIN_CHK _IO(APM_IOC_MAGIC, 33)
#endif
#include <unistd.h>
#include <stdio.h>
#include <signal.h>
#include <fcntl.h>
#include <sys/ioctl.h>
#define SHARP_DEV_IOCTL_COMMAND_START 0x5680
/* --- for SHARP_BUZZER device --- */
-#define SHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START)
+#define SHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START)
#define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START)
#define SHARP_BUZZER_SETVOLUME (SHARP_BUZZER_IOCTL_START+1)
#define SHARP_BUZZER_GETVOLUME (SHARP_BUZZER_IOCTL_START+2)
#define SHARP_BUZZER_ISSUPPORTED (SHARP_BUZZER_IOCTL_START+3)
#define SHARP_BUZZER_SETMUTE (SHARP_BUZZER_IOCTL_START+4)
#define SHARP_BUZZER_STOPSOUND (SHARP_BUZZER_IOCTL_START+5)
#define SHARP_BUZ_TOUCHSOUND 1 /* touch panel sound */
#define SHARP_BUZ_KEYSOUND 2 /* key sound */
#define SHARP_PDA_ILLCLICKSOUND 3 /* illegal click */
#define SHARP_PDA_WARNSOUND 4 /* warning occurred */
#define SHARP_PDA_ERRORSOUND 5 /* error occurred */
#define SHARP_PDA_CRITICALSOUND 6 /* critical error occurred */
#define SHARP_PDA_SYSSTARTSOUND 7 /* system start */
#define SHARP_PDA_SYSTEMENDSOUND 8 /* system shutdown */
#define SHARP_PDA_APPSTART 9 /* application start */
#define SHARP_PDA_APPQUIT 10 /* application ends */
#define SHARP_BUZ_SCHEDULE_ALARM 11 /* schedule alarm */
#define SHARP_BUZ_DAILY_ALARM 12 /* daily alarm */
#define SHARP_BUZ_GOT_PHONE_CALL 13 /* phone call sound */
#define SHARP_BUZ_GOT_MAIL 14 /* mail sound */
#define CUSTOM_BUZZER( sound ) \
{ \
static int fd = open( "/dev/sharp_buz", O_RDWR|O_NONBLOCK ); \
ioctl( fd, SHARP_BUZZER_MAKESOUND, sound ); \
}
#define CUSTOM_SOUND_ALARM CUSTOM_BUZZER( SHARP_BUZ_SCHEDULE_ALARM )
+#define CUSTOM_SOUND_KEYCLICK CUSTOM_BUZZER( SHARP_BUZ_KEYSOUND )
+#define CUSTOM_SOUND_TOUCH CUSTOM_BUZZER( SHARP_BUZ_TOUCHSOUND )
+
#include <sys/ioctl.h>
#include <asm/sharp_char.h>
// a bit awkward, as this value is defined in emailclient.cpp aswell...
#define LED_MAIL 0
#define SHARP_LED_MAIL 9
#define CUSTOM_LEDS( led, status ) \
{ \
if ( led == LED_MAIL ) \
led = SHARP_LED_MAIL; \
static int fd = open( "/dev/sharp_led", O_RDWR|O_NONBLOCK ); \
sharp_led_status leds; \
memset(&leds, 0, sizeof(leds)); \
leds.which = led; \
leds.status = status; \
ioctl( fd, SHARP_LED_SETSTATUS, (char*)&leds ); \
}
#define QPE_HAVE_MEMALERTER
#define QPE_MEMALERTER_IMPL \
static void sig_handler(int sig) \
{ \
switch (sig) { \
case SIGHUP: \
- memstate = VeryLow; \
- break; \
+ memstate = VeryLow; \
+ break; \
case SIGUSR1: \
- memstate = Normal; \
- break; \
+ memstate = Normal; \
+ break; \
case SIGUSR2: \
- memstate = Low; \
- break; \
+ memstate = Low; \
+ break; \
} \
} \
static void initMemalerter() \
{ \
struct sigaction sa; \
memset(&sa, '\0', sizeof sa); \
sa.sa_handler = sig_handler; \
sa.sa_flags = SA_RESTART; \
if (sigaction(SIGHUP, &sa, NULL) < 0) { \
- return; \
+ return; \
} \
if (sigaction(SIGUSR1, &sa, NULL) < 0) { \
- return; \
+ return; \
} \
if (sigaction(SIGUSR2, &sa, NULL) < 0) { \
- return; \
+ return; \
} \
FILE *fo = fopen("/proc/sys/vm/freepg_signal_proc", "w"); \
\
if (!fo) \
return; \
fprintf(fo, "qpe\n"); \
fclose(fo); \
}
#define QPE_INITIAL_NUMLOCK_STATE \
{ \
bool numLock = FALSE; \
sharp_kbdctl_modifstat st; \
int dev = ::open("/dev/sharp_kbdctl", O_RDWR); \
if( dev >= 0 ) { \
- memset(&st, 0, sizeof(st)); \
- st.which = 3; \
+ memset(&st, 0, sizeof(st)); \
+ st.which = 3; \
int ret = ioctl(dev, SHARP_KBDCTL_GETMODIFSTAT, (char*)&st); \
- if( !ret ) \
- numLock = (bool)st.stat; \
- ::close(dev); \
+ if( !ret ) \
+ numLock = (bool)st.stat; \
+ ::close(dev); \
} \
return numLock; \
}