author | mickeyl <mickeyl> | 2005-01-01 17:34:32 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2005-01-01 17:34:32 (UTC) |
commit | a62cf9bfb9814a6f5ce5aa8d59fbe5b0cfb8414a (patch) (unidiff) | |
tree | ce7f0961815c32782c92009efc197a606b0ab86b | |
parent | 8467a23d6a7f4b52619b60462c8ba80d8a736a9e (diff) | |
download | opie-a62cf9bfb9814a6f5ce5aa8d59fbe5b0cfb8414a.zip opie-a62cf9bfb9814a6f5ce5aa8d59fbe5b0cfb8414a.tar.gz opie-a62cf9bfb9814a6f5ce5aa8d59fbe5b0cfb8414a.tar.bz2 |
clean up a bit and start w/ introducing SL-6000 support
-rw-r--r-- | libopie2/opiecore/device/odevice_zaurus.cpp | 124 | ||||
-rw-r--r-- | libopie2/opiecore/device/odevice_zaurus.h | 47 |
2 files changed, 85 insertions, 86 deletions
diff --git a/libopie2/opiecore/device/odevice_zaurus.cpp b/libopie2/opiecore/device/odevice_zaurus.cpp index ebe1949..1894e15 100644 --- a/libopie2/opiecore/device/odevice_zaurus.cpp +++ b/libopie2/opiecore/device/odevice_zaurus.cpp | |||
@@ -1,12 +1,12 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the Opie Project | 2 | This file is part of the Opie Project |
3 | Copyright (C) The Opie Team <opie-devel@handhelds.org> | 3 | Copyright (C) The Opie Team <opie-devel@handhelds.org> |
4 | =. | 4 | =. Copyright (C) 2003-2005 Michael 'Mickey' Lauer <mickey@Vanille.de> |
5 | .=l. | 5 | .=l. |
6 | .>+-= | 6 | .>+-= |
7 | _;:, .> :=|. This program is free software; you can | 7 | _;:, .> :=|. This program is free software; you can |
8 | .> <`_, > . <= redistribute it and/or modify it under | 8 | .> <`_, > . <= redistribute it and/or modify it under |
9 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 9 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
10 | .="- .-=="i, .._ License as published by the Free Software | 10 | .="- .-=="i, .._ License as published by the Free Software |
11 | - . .-<_> .<> Foundation; either version 2 of the License, | 11 | - . .-<_> .<> Foundation; either version 2 of the License, |
12 | ._= =} : or (at your option) any later version. | 12 | ._= =} : or (at your option) any later version. |
@@ -102,17 +102,18 @@ struct z_button z_buttons_c700 [] = { | |||
102 | "QPE/Dummy", "doNothing()" }, | 102 | "QPE/Dummy", "doNothing()" }, |
103 | }; | 103 | }; |
104 | 104 | ||
105 | // FIXME This gets unnecessary complicated. We should think about splitting the Zaurus | 105 | // FIXME This gets unnecessary complicated. We should think about splitting the Zaurus |
106 | // class up into individual classes. We need three classes | 106 | // class up into individual classes. We need three classes |
107 | // | 107 | // |
108 | // Zaurus-Collie (SA-model w/ 320x240 lcd, for SL5500 and SL5000) | 108 | // Zaurus-Collie (SA-model w/ 320x240 lcd, for SL5500 and SL5000) |
109 | // Zaurus-Poodle (PXA-model w/ 320x240 lcd, for SL5600) | 109 | // Zaurus-Poodle (PXA-model w/ 320x240 lcd, for SL5600) |
110 | // Zaurus-Corgi (PXA-model w/ 640x480 lcd, for C700, C750, C760, and C860) | 110 | // Zaurus-Corgi (PXA-model w/ 640x480 lcd, for C700, C750, C760, C860, C3000) |
111 | // Zaurus-Tosa (PXA-model w/ 480x640 lcd, for SL6000) | ||
111 | // | 112 | // |
112 | // Only question right now is: Do we really need to do it? Because as soon | 113 | // Only question right now is: Do we really need to do it? Because as soon |
113 | // as the OpenZaurus kernel is ready, there will be a unified interface for all | 114 | // as the OpenZaurus kernel is ready, there will be a unified interface for all |
114 | // Zaurus models (concerning apm, backlight, buttons, etc.) | 115 | // Zaurus models (concerning apm, backlight, buttons, etc.) |
115 | // | 116 | // |
116 | // Comments? - mickeyl. | 117 | // Comments? - mickeyl. |
117 | 118 | ||
118 | void Zaurus::init(const QString& cpu_info) | 119 | void Zaurus::init(const QString& cpu_info) |
@@ -129,17 +130,17 @@ void Zaurus::init(const QString& cpu_info) | |||
129 | } | 130 | } |
130 | else | 131 | else |
131 | { | 132 | { |
132 | d->m_vendorstr = "OpenZaurus Team"; | 133 | d->m_vendorstr = "OpenZaurus Team"; |
133 | d->m_systemstr = "OpenZaurus"; | 134 | d->m_systemstr = "OpenZaurus"; |
134 | d->m_system = System_OpenZaurus; | 135 | d->m_system = System_OpenZaurus; |
135 | // sysver already gathered | 136 | // sysver already gathered |
136 | 137 | ||
137 | // Openzaurus sometimes uses the embedix kernel, check if this is one | 138 | // OpenZaurus sometimes uses the embedix kernel, check if this is one |
138 | FILE *uname = popen("uname -r", "r"); | 139 | FILE *uname = popen("uname -r", "r"); |
139 | QFile f; | 140 | QFile f; |
140 | QString line; | 141 | QString line; |
141 | if ( f.open(IO_ReadOnly, uname) ) { | 142 | if ( f.open(IO_ReadOnly, uname) ) { |
142 | QTextStream ts ( &f ); | 143 | QTextStream ts ( &f ); |
143 | line = ts. readLine(); | 144 | line = ts. readLine(); |
144 | int loc = line. find ( "embedix" ); | 145 | int loc = line. find ( "embedix" ); |
145 | if ( loc != -1 ) | 146 | if ( loc != -1 ) |
@@ -162,43 +163,43 @@ void Zaurus::init(const QString& cpu_info) | |||
162 | if ( model == "SHARP Corgi" ) { | 163 | if ( model == "SHARP Corgi" ) { |
163 | d->m_model = Model_Zaurus_SLC7x0; | 164 | d->m_model = Model_Zaurus_SLC7x0; |
164 | d->m_modelstr = "Zaurus SL-C700"; | 165 | d->m_modelstr = "Zaurus SL-C700"; |
165 | } else if ( model == "SHARP Shepherd" ) { | 166 | } else if ( model == "SHARP Shepherd" ) { |
166 | d->m_model = Model_Zaurus_SLC7x0; | 167 | d->m_model = Model_Zaurus_SLC7x0; |
167 | d->m_modelstr = "Zaurus SL-C750"; | 168 | d->m_modelstr = "Zaurus SL-C750"; |
168 | } else if ( model == "SHARP Husky" ) { | 169 | } else if ( model == "SHARP Husky" ) { |
169 | d->m_model = Model_Zaurus_SLC7x0; | 170 | d->m_model = Model_Zaurus_SLC7x0; |
170 | d->m_modelstr = "Zaurus SL-C760"; | 171 | d->m_modelstr = "Zaurus SL-C760 or SL-C860"; |
171 | } else if ( model == "SHARP Poodle" ) { | 172 | } else if ( model == "SHARP Poodle" ) { |
172 | d->m_model = Model_Zaurus_SLB600; | 173 | d->m_model = Model_Zaurus_SLB600; |
173 | d->m_modelstr = "Zaurus SL-B500 or SL-5600"; | 174 | d->m_modelstr = "Zaurus SL-B500 or SL-5600"; |
174 | } else if ( model == "Sharp-Collie" || model == "Collie" ) { | 175 | } else if ( model == "Sharp-Collie" || model == "Collie" ) { |
175 | d->m_model = Model_Zaurus_SL5500; | 176 | d->m_model = Model_Zaurus_SL5500; |
176 | d->m_modelstr = "Zaurus SL-5500 or SL-5000d"; | 177 | d->m_modelstr = "Zaurus SL-5500 or SL-5000d"; |
177 | } else if ( model == "SHARP Tosa" ) { | 178 | } else if ( model == "SHARP Tosa" ) { |
178 | d->m_model = Model_Zaurus_SL6000; | 179 | d->m_model = Model_Zaurus_SL6000; |
179 | d->m_modelstr = "Zaurus SL-6000"; | 180 | d->m_modelstr = "Zaurus SL-6000"; |
180 | } else { | 181 | } else { |
181 | d->m_model = Model_Zaurus_SL5500; | 182 | d->m_model = Model_Zaurus_SL5500; |
182 | d->m_modelstr = "Unkown Zaurus"; | 183 | d->m_modelstr = "Unkown Zaurus"; |
183 | } | 184 | } |
184 | 185 | ||
185 | // set initial rotation | 186 | // set initial rotation |
186 | switch ( d->m_model ) { | 187 | switch( d->m_model ) { |
187 | case Model_Zaurus_SL6000: | 188 | case Model_Zaurus_SL6000: // fallthrough |
188 | case Model_Zaurus_SLA300: | 189 | case Model_Zaurus_SLA300: |
189 | d->m_rotation = Rot0; | 190 | d->m_rotation = Rot0; |
190 | break; | 191 | break; |
191 | case Model_Zaurus_SLC7x0: | 192 | case Model_Zaurus_SLC7x0: |
192 | d->m_rotation = rotation(); | 193 | d->m_rotation = rotation(); |
193 | d->m_direction = direction(); | 194 | d->m_direction = direction(); |
194 | break; | 195 | break; |
195 | case Model_Zaurus_SLB600: | 196 | case Model_Zaurus_SLB600: // fallthrough |
196 | case Model_Zaurus_SL5500: | 197 | case Model_Zaurus_SL5500: // fallthrough |
197 | case Model_Zaurus_SL5000: | 198 | case Model_Zaurus_SL5000: |
198 | default: | 199 | default: |
199 | d->m_rotation = Rot270; | 200 | d->m_rotation = Rot270; |
200 | break; | 201 | break; |
201 | } | 202 | } |
202 | m_leds [0] = Led_Off; | 203 | m_leds [0] = Led_Off; |
203 | } | 204 | } |
204 | 205 | ||
@@ -235,93 +236,32 @@ void Zaurus::initButtons() | |||
235 | zb->fheldaction )); | 236 | zb->fheldaction )); |
236 | 237 | ||
237 | d->m_buttons->append ( b ); | 238 | d->m_buttons->append ( b ); |
238 | } | 239 | } |
239 | 240 | ||
240 | reloadButtonMapping(); | 241 | reloadButtonMapping(); |
241 | } | 242 | } |
242 | 243 | ||
243 | #include <unistd.h> | ||
244 | #include <fcntl.h> | ||
245 | #include <sys/ioctl.h> | ||
246 | |||
247 | //#include <asm/sharp_char.h> // including kernel headers is evil ... | ||
248 | |||
249 | #define SHARP_DEV_IOCTL_COMMAND_START 0x5680 | ||
250 | |||
251 | #defineSHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) | ||
252 | #define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START) | ||
253 | |||
254 | #define SHARP_BUZ_TOUCHSOUND 1 /* touch panel sound */ | ||
255 | #define SHARP_BUZ_KEYSOUND 2 /* key sound */ | ||
256 | #define SHARP_BUZ_SCHEDULE_ALARM 11 /* schedule alarm */ | ||
257 | 244 | ||
258 | /* --- for SHARP_BUZZER device --- */ | ||
259 | |||
260 | //#defineSHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) | ||
261 | //#define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START) | ||
262 | |||
263 | #define SHARP_BUZZER_SETVOLUME (SHARP_BUZZER_IOCTL_START+1) | ||
264 | #define SHARP_BUZZER_GETVOLUME (SHARP_BUZZER_IOCTL_START+2) | ||
265 | #define SHARP_BUZZER_ISSUPPORTED (SHARP_BUZZER_IOCTL_START+3) | ||
266 | #define SHARP_BUZZER_SETMUTE (SHARP_BUZZER_IOCTL_START+4) | ||
267 | #define SHARP_BUZZER_STOPSOUND (SHARP_BUZZER_IOCTL_START+5) | ||
268 | |||
269 | //#define SHARP_BUZ_TOUCHSOUND 1 /* touch panel sound */ | ||
270 | //#define SHARP_BUZ_KEYSOUND 2 /* key sound */ | ||
271 | |||
272 | //#define SHARP_PDA_ILLCLICKSOUND 3 /* illegal click */ | ||
273 | //#define SHARP_PDA_WARNSOUND 4 /* warning occurred */ | ||
274 | //#define SHARP_PDA_ERRORSOUND 5 /* error occurred */ | ||
275 | //#define SHARP_PDA_CRITICALSOUND 6 /* critical error occurred */ | ||
276 | //#define SHARP_PDA_SYSSTARTSOUND 7 /* system start */ | ||
277 | //#define SHARP_PDA_SYSTEMENDSOUND 8 /* system shutdown */ | ||
278 | //#define SHARP_PDA_APPSTART 9 /* application start */ | ||
279 | //#define SHARP_PDA_APPQUIT 10 /* application ends */ | ||
280 | |||
281 | //#define SHARP_BUZ_SCHEDULE_ALARM 11 /* schedule alarm */ | ||
282 | //#define SHARP_BUZ_DAILY_ALARM 12 /* daily alarm */ | ||
283 | //#define SHARP_BUZ_GOT_PHONE_CALL 13 /* phone call sound */ | ||
284 | //#define SHARP_BUZ_GOT_MAIL 14 /* mail sound */ | ||
285 | // | ||
286 | |||
287 | #defineSHARP_LED_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) | ||
288 | #define SHARP_LED_SETSTATUS (SHARP_LED_IOCTL_START+1) | ||
289 | |||
290 | #define SHARP_IOCTL_GET_ROTATION 0x413c | ||
291 | 245 | ||
292 | typedef struct sharp_led_status { | 246 | typedef struct sharp_led_status { |
293 | int which; /* select which LED status is wanted. */ | 247 | int which; /* select which LED status is wanted. */ |
294 | int status; /* set new led status if you call SHARP_LED_SETSTATUS */ | 248 | int status; /* set new led status if you call SHARP_LED_SETSTATUS */ |
295 | } sharp_led_status; | 249 | } sharp_led_status; |
296 | 250 | ||
297 | #define SHARP_LED_MAIL_EXISTS 9 /* mail status (exists or not) */ | 251 | void Zaurus::buzzer( int sound ) |
298 | |||
299 | #define LED_MAIL_NO_UNREAD_MAIL 0 /* for SHARP_LED_MAIL_EXISTS */ | ||
300 | #define LED_MAIL_NEWMAIL_EXISTS 1 /* for SHARP_LED_MAIL_EXISTS */ | ||
301 | #define LED_MAIL_UNREAD_MAIL_EX 2 /* for SHARP_LED_MAIL_EXISTS */ | ||
302 | |||
303 | // #include <asm/sharp_apm.h> // including kernel headers is evil ... | ||
304 | |||
305 | #define APM_IOCGEVTSRC OD_IOR( 'A', 203, int ) | ||
306 | #define APM_IOCSEVTSRC OD_IORW( 'A', 204, int ) | ||
307 | #define APM_EVT_POWER_BUTTON (1 << 0) | ||
308 | |||
309 | #define FL_IOCTL_STEP_CONTRAST 100 | ||
310 | |||
311 | |||
312 | void Zaurus::buzzer ( int sound ) | ||
313 | { | 252 | { |
314 | #ifndef QT_NO_SOUND | 253 | #ifndef QT_NO_SOUND |
315 | Sound *snd = 0; | 254 | Sound *snd = 0; |
316 | 255 | ||
317 | // Not all devices have real sound | 256 | // Not all devices have real sound |
318 | if ( d->m_model == Model_Zaurus_SLC7x0 | 257 | if ( d->m_model == Model_Zaurus_SLC7x0 |
319 | || d->m_model == Model_Zaurus_SLB600 ){ | 258 | || d->m_model == Model_Zaurus_SLB600 |
259 | || d->m_model == Model_Zaurus_SL6000 ) { | ||
320 | 260 | ||
321 | switch ( sound ){ | 261 | switch ( sound ){ |
322 | case SHARP_BUZ_TOUCHSOUND: { | 262 | case SHARP_BUZ_TOUCHSOUND: { |
323 | static Sound touch_sound("touchsound"); | 263 | static Sound touch_sound("touchsound"); |
324 | snd = &touch_sound; | 264 | snd = &touch_sound; |
325 | } | 265 | } |
326 | break; | 266 | break; |
327 | case SHARP_BUZ_KEYSOUND: { | 267 | case SHARP_BUZ_KEYSOUND: { |
@@ -338,43 +278,43 @@ void Zaurus::buzzer ( int sound ) | |||
338 | } | 278 | } |
339 | } | 279 | } |
340 | 280 | ||
341 | // If a soundname is defined, we expect that this device has | 281 | // If a soundname is defined, we expect that this device has |
342 | // sound capabilities.. Otherwise we expect to have the buzzer | 282 | // sound capabilities.. Otherwise we expect to have the buzzer |
343 | // device.. | 283 | // device.. |
344 | if ( snd && snd->isFinished() ){ | 284 | if ( snd && snd->isFinished() ){ |
345 | changeMixerForAlarm( 0, "/dev/sound/mixer", snd ); | 285 | changeMixerForAlarm( 0, "/dev/sound/mixer", snd ); |
346 | snd-> play(); | 286 | snd->play(); |
347 | } else if( !snd ) { | 287 | } else if( !snd ) { |
348 | int fd = ::open ( "/dev/sharp_buz", O_WRONLY|O_NONBLOCK ); | 288 | int fd = ::open ( "/dev/sharp_buz", O_WRONLY|O_NONBLOCK ); |
349 | 289 | ||
350 | if ( fd >= 0 ) { | 290 | if ( fd >= 0 ) { |
351 | ::ioctl ( fd, SHARP_BUZZER_MAKESOUND, sound ); | 291 | ::ioctl ( fd, SHARP_BUZZER_MAKESOUND, sound ); |
352 | ::close ( fd ); | 292 | ::close ( fd ); |
353 | } | 293 | } |
354 | 294 | ||
355 | } | 295 | } |
356 | #endif | 296 | #endif |
357 | } | 297 | } |
358 | 298 | ||
359 | 299 | ||
360 | void Zaurus::playAlarmSound() | 300 | void Zaurus::playAlarmSound() |
361 | { | 301 | { |
362 | buzzer ( SHARP_BUZ_SCHEDULE_ALARM ); | 302 | buzzer( SHARP_BUZ_SCHEDULE_ALARM ); |
363 | } | 303 | } |
364 | 304 | ||
365 | void Zaurus::playTouchSound() | 305 | void Zaurus::playTouchSound() |
366 | { | 306 | { |
367 | buzzer ( SHARP_BUZ_TOUCHSOUND ); | 307 | buzzer( SHARP_BUZ_TOUCHSOUND ); |
368 | } | 308 | } |
369 | 309 | ||
370 | void Zaurus::playKeySound() | 310 | void Zaurus::playKeySound() |
371 | { | 311 | { |
372 | buzzer ( SHARP_BUZ_KEYSOUND ); | 312 | buzzer( SHARP_BUZ_KEYSOUND ); |
373 | } | 313 | } |
374 | 314 | ||
375 | 315 | ||
376 | QValueList <OLed> Zaurus::ledList() const | 316 | QValueList <OLed> Zaurus::ledList() const |
377 | { | 317 | { |
378 | QValueList <OLed> vl; | 318 | QValueList <OLed> vl; |
379 | vl << Led_Mail; | 319 | vl << Led_Mail; |
380 | return vl; | 320 | return vl; |
@@ -459,18 +399,17 @@ bool Zaurus::setSoftSuspend ( bool soft ) | |||
459 | ::close ( fd ); | 399 | ::close ( fd ); |
460 | } | 400 | } |
461 | else | 401 | else |
462 | perror ( "/dev/apm_bios or /dev/misc/apm_bios" ); | 402 | perror ( "/dev/apm_bios or /dev/misc/apm_bios" ); |
463 | 403 | ||
464 | return res; | 404 | return res; |
465 | } | 405 | } |
466 | 406 | ||
467 | 407 | bool Zaurus::setDisplayBrightness( int bright ) | |
468 | bool Zaurus::setDisplayBrightness ( int bright ) | ||
469 | { | 408 | { |
470 | //qDebug( "Zaurus::setDisplayBrightness( %d )", bright ); | 409 | //qDebug( "Zaurus::setDisplayBrightness( %d )", bright ); |
471 | bool res = false; | 410 | bool res = false; |
472 | int fd; | 411 | int fd; |
473 | 412 | ||
474 | if ( bright > 255 ) bright = 255; | 413 | if ( bright > 255 ) bright = 255; |
475 | if ( bright < 0 ) bright = 0; | 414 | if ( bright < 0 ) bright = 0; |
476 | 415 | ||
@@ -479,23 +418,38 @@ bool Zaurus::setDisplayBrightness ( int bright ) | |||
479 | if ( d->m_model == Model_Zaurus_SLC7x0 ) | 418 | if ( d->m_model == Model_Zaurus_SLC7x0 ) |
480 | { | 419 | { |
481 | //qDebug( "using special treatment for devices with the corgi backlight interface" ); | 420 | //qDebug( "using special treatment for devices with the corgi backlight interface" ); |
482 | // special treatment for devices with the corgi backlight interface | 421 | // special treatment for devices with the corgi backlight interface |
483 | if (( fd = ::open ( "/proc/driver/fl/corgi-bl", O_WRONLY )) >= 0 ) | 422 | if (( fd = ::open ( "/proc/driver/fl/corgi-bl", O_WRONLY )) >= 0 ) |
484 | { | 423 | { |
485 | int value = ( bright == 1 ) ? 1 : static_cast<int>( bright * ( 17.0 / 255.0 ) ); | 424 | int value = ( bright == 1 ) ? 1 : static_cast<int>( bright * ( 17.0 / 255.0 ) ); |
486 | char writeCommand[100]; | 425 | char writeCommand[100]; |
487 | const int count = sprintf( writeCommand, "0x%x\n", value ); | 426 | const int count = sprintf( writeCommand, "%x\n", value ); |
488 | res = ( ::write ( fd, writeCommand, count ) != -1 ); | 427 | res = ( ::write ( fd, writeCommand, count ) != -1 ); |
489 | ::close ( fd ); | 428 | ::close ( fd ); |
490 | } | 429 | } |
491 | return res; | 430 | return res; |
492 | } | 431 | } |
493 | else | 432 | else |
433 | if ( d->m_model == Model_Zaurus_SL6000 ) | ||
434 | { | ||
435 | //qDebug( "using special treatment for devices with the tosa backlight interface" ); | ||
436 | // special treatment for devices with the tosa backlight interface | ||
437 | if (( fd = ::open ( "/proc/driver/fl/tosa-bl", O_WRONLY )) >= 0 ) | ||
438 | { | ||
439 | int value = ( bright == 1 ) ? 1 : static_cast<int>( bright * ( 17.0 / 255.0 ) ); | ||
440 | char writeCommand[100]; | ||
441 | const int count = sprintf( writeCommand, "%x\n", value ); | ||
442 | res = ( ::write ( fd, writeCommand, count ) != -1 ); | ||
443 | ::close ( fd ); | ||
444 | } | ||
445 | return res; | ||
446 | } | ||
447 | else | ||
494 | { | 448 | { |
495 | // standard treatment for devices with the dumb embedix frontlight interface | 449 | // standard treatment for devices with the dumb embedix frontlight interface |
496 | if (( fd = ::open ( "/dev/fl", O_WRONLY )) >= 0 ) { | 450 | if (( fd = ::open ( "/dev/fl", O_WRONLY )) >= 0 ) { |
497 | int bl = ( bright * 4 + 127 ) / 255; // only 4 steps on zaurus | 451 | int bl = ( bright * 4 + 127 ) / 255; // only 4 steps on zaurus |
498 | if ( bright && !bl ) | 452 | if ( bright && !bl ) |
499 | bl = 1; | 453 | bl = 1; |
500 | res = ( ::ioctl ( fd, FL_IOCTL_STEP_CONTRAST, bl ) == 0 ); | 454 | res = ( ::ioctl ( fd, FL_IOCTL_STEP_CONTRAST, bl ) == 0 ); |
501 | ::close ( fd ); | 455 | ::close ( fd ); |
@@ -609,19 +563,25 @@ ODirection Zaurus::direction() const | |||
609 | } | 563 | } |
610 | return dir; | 564 | return dir; |
611 | 565 | ||
612 | } | 566 | } |
613 | 567 | ||
614 | int Zaurus::displayBrightnessResolution() const | 568 | int Zaurus::displayBrightnessResolution() const |
615 | { | 569 | { |
616 | if (m_embedix) | 570 | if (m_embedix) |
617 | return d->m_model == Model_Zaurus_SLC7x0 ? 18 : 5; | 571 | { |
572 | if ( d->m_model == Model_Zaurus_SLC7x0 ) return 18; | ||
573 | if ( d->m_model == Model_Zaurus_SL6000 ) return 18; | ||
574 | return 5; | ||
575 | } | ||
618 | else | 576 | else |
577 | { | ||
619 | return 256; | 578 | return 256; |
579 | } | ||
620 | } | 580 | } |
621 | 581 | ||
622 | bool Zaurus::hasHingeSensor() const | 582 | bool Zaurus::hasHingeSensor() const |
623 | { | 583 | { |
624 | return d->m_model == Model_Zaurus_SLC7x0; | 584 | return d->m_model == Model_Zaurus_SLC7x0; |
625 | } | 585 | } |
626 | 586 | ||
627 | OHingeStatus Zaurus::readHingeSensor() | 587 | OHingeStatus Zaurus::readHingeSensor() |
diff --git a/libopie2/opiecore/device/odevice_zaurus.h b/libopie2/opiecore/device/odevice_zaurus.h index 76a40d6..dc21546 100644 --- a/libopie2/opiecore/device/odevice_zaurus.h +++ b/libopie2/opiecore/device/odevice_zaurus.h | |||
@@ -1,12 +1,12 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the Opie Project | 2 | This file is part of the Opie Project |
3 | Copyright (C) The Opie Team <opie-devel@handhelds.org> | 3 | Copyright (C) The Opie Team <opie-devel@handhelds.org> |
4 | =. | 4 | =. Copyright (C) 2003-2005 Michael 'Mickey' Lauer <mickey@Vanille.de> |
5 | .=l. | 5 | .=l. |
6 | .>+-= | 6 | .>+-= |
7 | _;:, .> :=|. This program is free software; you can | 7 | _;:, .> :=|. This program is free software; you can |
8 | .> <`_, > . <= redistribute it and/or modify it under | 8 | .> <`_, > . <= redistribute it and/or modify it under |
9 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 9 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
10 | .="- .-=="i, .._ License as published by the Free Software | 10 | .="- .-=="i, .._ License as published by the Free Software |
11 | - . .-<_> .<> Foundation; either version 2 of the License, | 11 | - . .-<_> .<> Foundation; either version 2 of the License, |
12 | ._= =} : or (at your option) any later version. | 12 | ._= =} : or (at your option) any later version. |
@@ -32,31 +32,70 @@ | |||
32 | 32 | ||
33 | #include <opie2/odevice.h> | 33 | #include <opie2/odevice.h> |
34 | 34 | ||
35 | #ifndef ARRAY_SIZE | 35 | #ifndef ARRAY_SIZE |
36 | #define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0])) | 36 | #define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0])) |
37 | #endif | 37 | #endif |
38 | 38 | ||
39 | // _IO and friends are only defined in kernel headers ... | 39 | // _IO and friends are only defined in kernel headers ... |
40 | |||
41 | #define OD_IOC(dir,type,number,size) (( dir << 30 ) | ( type << 8 ) | ( number ) | ( size << 16 )) | 40 | #define OD_IOC(dir,type,number,size) (( dir << 30 ) | ( type << 8 ) | ( number ) | ( size << 16 )) |
42 | |||
43 | #define OD_IO(type,number) OD_IOC(0,type,number,0) | 41 | #define OD_IO(type,number) OD_IOC(0,type,number,0) |
44 | #define OD_IOW(type,number,size) OD_IOC(1,type,number,sizeof(size)) | 42 | #define OD_IOW(type,number,size) OD_IOC(1,type,number,sizeof(size)) |
45 | #define OD_IOR(type,number,size) OD_IOC(2,type,number,sizeof(size)) | 43 | #define OD_IOR(type,number,size) OD_IOC(2,type,number,sizeof(size)) |
46 | #define OD_IORW(type,number,size) OD_IOC(3,type,number,sizeof(size)) | 44 | #define OD_IORW(type,number,size) OD_IOC(3,type,number,sizeof(size)) |
47 | 45 | ||
46 | // Audio | ||
47 | #define SHARP_DEV_IOCTL_COMMAND_START 0x5680 | ||
48 | |||
49 | #define SHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) | ||
50 | #define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START) | ||
51 | |||
52 | #define SHARP_BUZ_TOUCHSOUND 1 /* touch panel sound */ | ||
53 | #define SHARP_BUZ_KEYSOUND 2 /* key sound */ | ||
54 | #define SHARP_BUZ_SCHEDULE_ALARM 11 /* schedule alarm */ | ||
55 | |||
56 | #define SHARP_BUZZER_SETVOLUME (SHARP_BUZZER_IOCTL_START+1) | ||
57 | #define SHARP_BUZZER_GETVOLUME (SHARP_BUZZER_IOCTL_START+2) | ||
58 | #define SHARP_BUZZER_ISSUPPORTED (SHARP_BUZZER_IOCTL_START+3) | ||
59 | #define SHARP_BUZZER_SETMUTE (SHARP_BUZZER_IOCTL_START+4) | ||
60 | #define SHARP_BUZZER_STOPSOUND (SHARP_BUZZER_IOCTL_START+5) | ||
61 | |||
62 | // LED | ||
63 | #define SHARP_LED_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) | ||
64 | #define SHARP_LED_SETSTATUS (SHARP_LED_IOCTL_START+1) | ||
65 | #define SHARP_LED_MAIL_EXISTS 9 /* mail status (exists or not) */ | ||
66 | |||
67 | #define LED_MAIL_NO_UNREAD_MAIL 0 /* for SHARP_LED_MAIL_EXISTS */ | ||
68 | #define LED_MAIL_NEWMAIL_EXISTS 1 /* for SHARP_LED_MAIL_EXISTS */ | ||
69 | #define LED_MAIL_UNREAD_MAIL_EX 2 /* for SHARP_LED_MAIL_EXISTS */ | ||
70 | |||
71 | // Rotation and Power Management | ||
72 | #define SHARP_IOCTL_GET_ROTATION 0x413c | ||
73 | |||
74 | #define APM_IOCGEVTSRC OD_IOR( 'A', 203, int ) | ||
75 | #define APM_IOCSEVTSRC OD_IORW( 'A', 204, int ) | ||
76 | #define APM_EVT_POWER_BUTTON (1 << 0) | ||
77 | |||
78 | // Brightness | ||
79 | #define FL_IOCTL_STEP_CONTRAST 100 | ||
80 | |||
81 | #define CORGI_TOSA_BL_IOCTL_ON 1 | ||
82 | #define CORGI_TOSA_BL_IOCTL_OFF 2 | ||
83 | #define CORGI_TOSA_BL_IOCTL_STEP_CONTRAST 100 | ||
84 | #define CORGI_TOSA_BL_IOCTL_GET_STEP_CONTRAST 101 | ||
85 | #define CORGI_TOSA_BL_IOCTL_GET_STEP 102 | ||
86 | #define CORGI_BL_PROC_DEVICE corgi-bl | ||
87 | #define TOSA_BL_PROC_DEVICE tosa-bl | ||
48 | 88 | ||
49 | namespace Opie { | 89 | namespace Opie { |
50 | namespace Core { | 90 | namespace Core { |
51 | namespace Internal { | 91 | namespace Internal { |
52 | class Zaurus : public ODevice | 92 | class Zaurus : public ODevice |
53 | { | 93 | { |
54 | |||
55 | protected: | 94 | protected: |
56 | virtual void init(const QString&); | 95 | virtual void init(const QString&); |
57 | virtual void initButtons(); | 96 | virtual void initButtons(); |
58 | 97 | ||
59 | public: | 98 | public: |
60 | virtual bool setSoftSuspend ( bool soft ); | 99 | virtual bool setSoftSuspend ( bool soft ); |
61 | 100 | ||
62 | virtual bool setDisplayBrightness ( int b ); | 101 | virtual bool setDisplayBrightness ( int b ); |