summaryrefslogtreecommitdiff
path: root/libopie/odevice.cpp
Unidiff
Diffstat (limited to 'libopie/odevice.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--libopie/odevice.cpp34
1 files changed, 19 insertions, 15 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp
index 4c49c4f..8f4e296 100644
--- a/libopie/odevice.cpp
+++ b/libopie/odevice.cpp
@@ -219,748 +219,752 @@ bool ODevice::suspend ( )
219 219
220 do { // wait at most 1.5 sec: either suspend didn't work or the device resumed 220 do { // wait at most 1.5 sec: either suspend didn't work or the device resumed
221 ::usleep ( 200 * 1000 ); 221 ::usleep ( 200 * 1000 );
222 ::gettimeofday ( &tvn, 0 ); 222 ::gettimeofday ( &tvn, 0 );
223 } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < 1500 ); 223 } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < 1500 );
224 224
225 // ::kill ( -::getpid ( ), SIGCONT ); // continue everything in our process group 225 // ::kill ( -::getpid ( ), SIGCONT ); // continue everything in our process group
226 } 226 }
227 227
228 // ::signal ( SIGTSTP, SIG_DFL ); 228 // ::signal ( SIGTSTP, SIG_DFL );
229 } 229 }
230 230
231 return res; 231 return res;
232} 232}
233 233
234//#include <linux/fb.h> better not rely on kernel headers in userspace ... 234//#include <linux/fb.h> better not rely on kernel headers in userspace ...
235 235
236#define FBIOBLANK OD_IO( 'F', 0x11 ) // 0x4611 236#define FBIOBLANK OD_IO( 'F', 0x11 ) // 0x4611
237 237
238/* VESA Blanking Levels */ 238/* VESA Blanking Levels */
239#define VESA_NO_BLANKING 0 239#define VESA_NO_BLANKING 0
240#define VESA_VSYNC_SUSPEND 1 240#define VESA_VSYNC_SUSPEND 1
241#define VESA_HSYNC_SUSPEND 2 241#define VESA_HSYNC_SUSPEND 2
242#define VESA_POWERDOWN 3 242#define VESA_POWERDOWN 3
243 243
244 244
245bool ODevice::setDisplayStatus ( bool on ) 245bool ODevice::setDisplayStatus ( bool on )
246{ 246{
247 if ( d-> m_model == Model_Unknown ) 247 if ( d-> m_model == Model_Unknown )
248 return false; 248 return false;
249 249
250 bool res = false; 250 bool res = false;
251 int fd; 251 int fd;
252 252
253 if (( fd = ::open ( "/dev/fb0", O_RDWR )) >= 0 ) { 253 if (( fd = ::open ( "/dev/fb0", O_RDWR )) >= 0 ) {
254 res = ( ::ioctl ( fd, FBIOBLANK, on ? VESA_NO_BLANKING : VESA_POWERDOWN ) == 0 ); 254 res = ( ::ioctl ( fd, FBIOBLANK, on ? VESA_NO_BLANKING : VESA_POWERDOWN ) == 0 );
255 ::close ( fd ); 255 ::close ( fd );
256 } 256 }
257 return res; 257 return res;
258} 258}
259 259
260bool ODevice::setDisplayBrightness ( int ) 260bool ODevice::setDisplayBrightness ( int )
261{ 261{
262 return false; 262 return false;
263} 263}
264 264
265int ODevice::displayBrightnessResolution ( ) const 265int ODevice::displayBrightnessResolution ( ) const
266{ 266{
267 return 16; 267 return 16;
268} 268}
269 269
270QString ODevice::vendorString ( ) const 270QString ODevice::vendorString ( ) const
271{ 271{
272 return d-> m_vendorstr; 272 return d-> m_vendorstr;
273} 273}
274 274
275OVendor ODevice::vendor ( ) const 275OVendor ODevice::vendor ( ) const
276{ 276{
277 return d-> m_vendor; 277 return d-> m_vendor;
278} 278}
279 279
280QString ODevice::modelString ( ) const 280QString ODevice::modelString ( ) const
281{ 281{
282 return d-> m_modelstr; 282 return d-> m_modelstr;
283} 283}
284 284
285OModel ODevice::model ( ) const 285OModel ODevice::model ( ) const
286{ 286{
287 return d-> m_model; 287 return d-> m_model;
288} 288}
289 289
290QString ODevice::systemString ( ) const 290QString ODevice::systemString ( ) const
291{ 291{
292 return d-> m_systemstr; 292 return d-> m_systemstr;
293} 293}
294 294
295OSystem ODevice::system ( ) const 295OSystem ODevice::system ( ) const
296{ 296{
297 return d-> m_system; 297 return d-> m_system;
298} 298}
299 299
300QString ODevice::systemVersionString ( ) const 300QString ODevice::systemVersionString ( ) const
301{ 301{
302 return d-> m_sysverstr; 302 return d-> m_sysverstr;
303} 303}
304 304
305void ODevice::alarmSound ( ) 305void ODevice::alarmSound ( )
306{ 306{
307#ifndef QT_QWS_EBX 307#ifndef QT_QWS_EBX
308#ifndef QT_NO_SOUND 308#ifndef QT_NO_SOUND
309 static Sound snd ( "alarm" ); 309 static Sound snd ( "alarm" );
310 310
311 if ( snd. isFinished ( )) 311 if ( snd. isFinished ( ))
312 snd. play ( ); 312 snd. play ( );
313#endif 313#endif
314#endif 314#endif
315} 315}
316 316
317void ODevice::keySound ( ) 317void ODevice::keySound ( )
318{ 318{
319#ifndef QT_QWS_EBX 319#ifndef QT_QWS_EBX
320#ifndef QT_NO_SOUND 320#ifndef QT_NO_SOUND
321 static Sound snd ( "keysound" ); 321 static Sound snd ( "keysound" );
322 322
323 if ( snd. isFinished ( )) 323 if ( snd. isFinished ( ))
324 snd. play ( ); 324 snd. play ( );
325#endif 325#endif
326#endif 326#endif
327} 327}
328 328
329void ODevice::touchSound ( ) 329void ODevice::touchSound ( )
330{ 330{
331 331
332#ifndef QT_QWS_EBX 332#ifndef QT_QWS_EBX
333#ifndef QT_NO_SOUND 333#ifndef QT_NO_SOUND
334 static Sound snd ( "touchsound" ); 334 static Sound snd ( "touchsound" );
335 335
336 if ( snd. isFinished ( )) 336 if ( snd. isFinished ( ))
337 snd. play ( ); 337 snd. play ( );
338#endif 338#endif
339#endif 339#endif
340} 340}
341 341
342 342
343QValueList <OLed> ODevice::ledList ( ) const 343QValueList <OLed> ODevice::ledList ( ) const
344{ 344{
345 return QValueList <OLed> ( ); 345 return QValueList <OLed> ( );
346} 346}
347 347
348QValueList <OLedState> ODevice::ledStateList ( OLed /*which*/ ) const 348QValueList <OLedState> ODevice::ledStateList ( OLed /*which*/ ) const
349{ 349{
350 return QValueList <OLedState> ( ); 350 return QValueList <OLedState> ( );
351} 351}
352 352
353OLedState ODevice::ledState ( OLed /*which*/ ) const 353OLedState ODevice::ledState ( OLed /*which*/ ) const
354{ 354{
355 return Led_Off; 355 return Led_Off;
356} 356}
357 357
358bool ODevice::setLedState ( OLed /*which*/, OLedState /*st*/ ) 358bool ODevice::setLedState ( OLed /*which*/, OLedState /*st*/ )
359{ 359{
360 return false; 360 return false;
361} 361}
362 362
363bool ODevice::hasLightSensor ( ) const 363bool ODevice::hasLightSensor ( ) const
364{ 364{
365 return false; 365 return false;
366} 366}
367 367
368int ODevice::readLightSensor ( ) 368int ODevice::readLightSensor ( )
369{ 369{
370 return -1; 370 return -1;
371} 371}
372 372
373int ODevice::lightSensorResolution ( ) const 373int ODevice::lightSensorResolution ( ) const
374{ 374{
375 return 0; 375 return 0;
376} 376}
377 377
378//QValueList <int> ODevice::keyList ( ) const 378//QValueList <int> ODevice::keyList ( ) const
379//{ 379//{
380 //return QValueList <int> ( ); 380 //return QValueList <int> ( );
381//} 381//}
382 382
383 383
384 384
385/************************************************** 385/**************************************************
386 * 386 *
387 * iPAQ 387 * iPAQ
388 * 388 *
389 **************************************************/ 389 **************************************************/
390 390
391void iPAQ::init ( ) 391void iPAQ::init ( )
392{ 392{
393 d-> m_vendorstr = "HP"; 393 d-> m_vendorstr = "HP";
394 d-> m_vendor = Vendor_HP; 394 d-> m_vendor = Vendor_HP;
395 395
396 QFile f ( "/proc/hal/model" ); 396 QFile f ( "/proc/hal/model" );
397 397
398 if ( f. open ( IO_ReadOnly )) { 398 if ( f. open ( IO_ReadOnly )) {
399 QTextStream ts ( &f ); 399 QTextStream ts ( &f );
400 400
401 d-> m_modelstr = "H" + ts. readLine ( ); 401 d-> m_modelstr = "H" + ts. readLine ( );
402 402
403 if ( d-> m_modelstr == "H3100" ) 403 if ( d-> m_modelstr == "H3100" )
404 d-> m_model = Model_iPAQ_H31xx; 404 d-> m_model = Model_iPAQ_H31xx;
405 else if ( d-> m_modelstr == "H3600" ) 405 else if ( d-> m_modelstr == "H3600" )
406 d-> m_model = Model_iPAQ_H36xx; 406 d-> m_model = Model_iPAQ_H36xx;
407 else if ( d-> m_modelstr == "H3700" ) 407 else if ( d-> m_modelstr == "H3700" )
408 d-> m_model = Model_iPAQ_H37xx; 408 d-> m_model = Model_iPAQ_H37xx;
409 else if ( d-> m_modelstr == "H3800" ) 409 else if ( d-> m_modelstr == "H3800" )
410 d-> m_model = Model_iPAQ_H38xx; 410 d-> m_model = Model_iPAQ_H38xx;
411 else if ( d-> m_modelstr == "H3900" )
412 d-> m_model = Model_iPAQ_H39xx;
411 else 413 else
412 d-> m_model = Model_Unknown; 414 d-> m_model = Model_Unknown;
413 415
414 f. close ( ); 416 f. close ( );
415 } 417 }
416 418
417 f. setName ( "/etc/familiar-version" ); 419 f. setName ( "/etc/familiar-version" );
418 if ( f. open ( IO_ReadOnly )) { 420 if ( f. open ( IO_ReadOnly )) {
419 d-> m_systemstr = "Familiar"; 421 d-> m_systemstr = "Familiar";
420 d-> m_system = System_Familiar; 422 d-> m_system = System_Familiar;
421 423
422 QTextStream ts ( &f ); 424 QTextStream ts ( &f );
423 d-> m_sysverstr = ts. readLine ( ). mid ( 10 ); 425 d-> m_sysverstr = ts. readLine ( ). mid ( 10 );
424 426
425 f. close ( ); 427 f. close ( );
426 } 428 }
427 429
428 m_leds [0] = m_leds [1] = Led_Off; 430 m_leds [0] = m_leds [1] = Led_Off;
429 431
430 m_power_timer = 0; 432 m_power_timer = 0;
431 433
432 if ( d-> m_qwsserver ) 434 if ( d-> m_qwsserver )
433 QWSServer::setKeyboardFilter ( this ); 435 QWSServer::setKeyboardFilter ( this );
434} 436}
435 437
436//#include <linux/h3600_ts.h> // including kernel headers is evil ... 438//#include <linux/h3600_ts.h> // including kernel headers is evil ...
437 439
438typedef struct { 440typedef struct {
439 unsigned char OffOnBlink; /* 0=off 1=on 2=Blink */ 441 unsigned char OffOnBlink; /* 0=off 1=on 2=Blink */
440 unsigned char TotalTime; /* Units of 5 seconds */ 442 unsigned char TotalTime; /* Units of 5 seconds */
441 unsigned char OnTime; /* units of 100m/s */ 443 unsigned char OnTime; /* units of 100m/s */
442 unsigned char OffTime; /* units of 100m/s */ 444 unsigned char OffTime; /* units of 100m/s */
443} LED_IN; 445} LED_IN;
444 446
445typedef struct { 447typedef struct {
446 unsigned char mode; 448 unsigned char mode;
447 unsigned char pwr; 449 unsigned char pwr;
448 unsigned char brightness; 450 unsigned char brightness;
449} FLITE_IN; 451} FLITE_IN;
450 452
451#define LED_ON OD_IOW( 'f', 5, LED_IN ) 453#define LED_ON OD_IOW( 'f', 5, LED_IN )
452#define FLITE_ON OD_IOW( 'f', 7, FLITE_IN ) 454#define FLITE_ON OD_IOW( 'f', 7, FLITE_IN )
453 455
454 456
455 457
456QValueList <OLed> iPAQ::ledList ( ) const 458QValueList <OLed> iPAQ::ledList ( ) const
457{ 459{
458 QValueList <OLed> vl; 460 QValueList <OLed> vl;
459 vl << Led_Power; 461 vl << Led_Power;
460 462
461 if ( d-> m_model == Model_iPAQ_H38xx ) 463 if ( d-> m_model == Model_iPAQ_H38xx )
462 vl << Led_BlueTooth; 464 vl << Led_BlueTooth;
463 return vl; 465 return vl;
464} 466}
465 467
466QValueList <OLedState> iPAQ::ledStateList ( OLed l ) const 468QValueList <OLedState> iPAQ::ledStateList ( OLed l ) const
467{ 469{
468 QValueList <OLedState> vl; 470 QValueList <OLedState> vl;
469 471
470 if ( l == Led_Power ) 472 if ( l == Led_Power )
471 vl << Led_Off << Led_On << Led_BlinkSlow << Led_BlinkFast; 473 vl << Led_Off << Led_On << Led_BlinkSlow << Led_BlinkFast;
472 else if ( l == Led_BlueTooth && d-> m_model == Model_iPAQ_H38xx ) 474 else if ( l == Led_BlueTooth && d-> m_model == Model_iPAQ_H38xx )
473 vl << Led_Off; // << Led_On << ??? 475 vl << Led_Off; // << Led_On << ???
474 476
475 return vl; 477 return vl;
476} 478}
477 479
478OLedState iPAQ::ledState ( OLed l ) const 480OLedState iPAQ::ledState ( OLed l ) const
479 { 481 {
480 switch ( l ) { 482 switch ( l ) {
481 case Led_Power: 483 case Led_Power:
482 return m_leds [0]; 484 return m_leds [0];
483 case Led_BlueTooth: 485 case Led_BlueTooth:
484 return m_leds [1]; 486 return m_leds [1];
485 default: 487 default:
486 return Led_Off; 488 return Led_Off;
487 } 489 }
488} 490}
489 491
490bool iPAQ::setLedState ( OLed l, OLedState st ) 492bool iPAQ::setLedState ( OLed l, OLedState st )
491{ 493{
492 static int fd = ::open ( "/dev/touchscreen/0", O_RDWR | O_NONBLOCK ); 494 static int fd = ::open ( "/dev/touchscreen/0", O_RDWR | O_NONBLOCK );
493 495
494 if ( l == Led_Power ) { 496 if ( l == Led_Power ) {
495 if ( fd >= 0 ) { 497 if ( fd >= 0 ) {
496 LED_IN leds; 498 LED_IN leds;
497 ::memset ( &leds, 0, sizeof( leds )); 499 ::memset ( &leds, 0, sizeof( leds ));
498 leds. TotalTime = 0; 500 leds. TotalTime = 0;
499 leds. OnTime = 0; 501 leds. OnTime = 0;
500 leds. OffTime = 1; 502 leds. OffTime = 1;
501 leds. OffOnBlink = 2; 503 leds. OffOnBlink = 2;
502 504
503 switch ( st ) { 505 switch ( st ) {
504 case Led_Off : leds. OffOnBlink = 0; break; 506 case Led_Off : leds. OffOnBlink = 0; break;
505 case Led_On : leds. OffOnBlink = 1; break; 507 case Led_On : leds. OffOnBlink = 1; break;
506 case Led_BlinkSlow: leds. OnTime = 10; leds. OffTime = 10; break; 508 case Led_BlinkSlow: leds. OnTime = 10; leds. OffTime = 10; break;
507 case Led_BlinkFast: leds. OnTime = 5; leds. OffTime = 5; break; 509 case Led_BlinkFast: leds. OnTime = 5; leds. OffTime = 5; break;
508 } 510 }
509 511
510 if ( ::ioctl ( fd, LED_ON, &leds ) >= 0 ) { 512 if ( ::ioctl ( fd, LED_ON, &leds ) >= 0 ) {
511 m_leds [0] = st; 513 m_leds [0] = st;
512 return true; 514 return true;
513 } 515 }
514 } 516 }
515 } 517 }
516 return false; 518 return false;
517} 519}
518 520
519 521
520//QValueList <int> iPAQ::keyList ( ) const 522//QValueList <int> iPAQ::keyList ( ) const
521//{ 523//{
522 //QValueList <int> vl; 524 //QValueList <int> vl;
523 //vl << HardKey_Datebook << HardKey_Contacts << ( model ( ) == Model_iPAQ_H38xx ? HardKey_Mail : HardKey_Menu ) << HardKey_Home << HardKey_Record << HardKey_Suspend << HardKey_Backlight; 525 //vl << HardKey_Datebook << HardKey_Contacts << ( model ( ) == Model_iPAQ_H38xx ? HardKey_Mail : HardKey_Menu ) << HardKey_Home << HardKey_Record << HardKey_Suspend << HardKey_Backlight;
524 //return vl; 526 //return vl;
525//} 527//}
526 528
527bool iPAQ::filter ( int /*unicode*/, int keycode, int modifiers, bool isPress, bool autoRepeat ) 529bool iPAQ::filter ( int /*unicode*/, int keycode, int modifiers, bool isPress, bool autoRepeat )
528{ 530{
529 int newkeycode = keycode; 531 int newkeycode = keycode;
530 532
531 533
532 // simple susbstitutions 534 // simple susbstitutions
533 switch ( d-> m_model ) { 535 switch ( d-> m_model ) {
534 case Model_iPAQ_H38xx: 536 case Model_iPAQ_H38xx:
535 // H38xx has no "Q" key anymore - this is now the Mail key 537 // H38xx has no "Q" key anymore - this is now the Mail key
536 if ( keycode == HardKey_Menu ) 538 if ( keycode == HardKey_Menu )
537 newkeycode = HardKey_Mail; 539 newkeycode = HardKey_Mail;
538 //nobreak 540 //nobreak
539 541
540 case Model_iPAQ_H31xx: 542 case Model_iPAQ_H31xx:
541 // Rotate cursor keys 180° 543 // Rotate cursor keys 180°
542 switch ( keycode ) { 544 switch ( keycode ) {
543 case Key_Left : newkeycode = Key_Right; break; 545 case Key_Left : newkeycode = Key_Right; break;
544 case Key_Right: newkeycode = Key_Left; break; 546 case Key_Right: newkeycode = Key_Left; break;
545 case Key_Up : newkeycode = Key_Down; break; 547 case Key_Up : newkeycode = Key_Down; break;
546 case Key_Down : newkeycode = Key_Up; break; 548 case Key_Down : newkeycode = Key_Up; break;
547 } 549 }
548 //nobreak; 550 //nobreak;
549 551
550 case Model_iPAQ_H36xx: 552 case Model_iPAQ_H36xx:
551 case Model_iPAQ_H37xx: 553 case Model_iPAQ_H37xx:
552 // map Power Button short/long press to F34/F35 554 // map Power Button short/long press to F34/F35
553 if ( keycode == Key_SysReq ) { 555 if ( keycode == Key_SysReq ) {
554 if ( isPress ) { 556 if ( isPress ) {
555 if ( m_power_timer ) 557 if ( m_power_timer )
556 killTimer ( m_power_timer ); 558 killTimer ( m_power_timer );
557 m_power_timer = startTimer ( 500 ); 559 m_power_timer = startTimer ( 500 );
558 } 560 }
559 else if ( m_power_timer ) { 561 else if ( m_power_timer ) {
560 killTimer ( m_power_timer ); 562 killTimer ( m_power_timer );
561 m_power_timer = 0; 563 m_power_timer = 0;
562 QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, true, false ); 564 QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, true, false );
563 QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, false, false ); 565 QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, false, false );
564 } 566 }
565 newkeycode = Key_unknown; 567 newkeycode = Key_unknown;
566 } 568 }
567 //nobreak; 569 //nobreak;
568 570
569 default: 571 default:
570 break; 572 break;
571 } 573 }
572 574
573 if ( newkeycode != keycode ) { 575 if ( newkeycode != keycode ) {
574 if ( newkeycode != Key_unknown ) 576 if ( newkeycode != Key_unknown )
575 QWSServer::sendKeyEvent ( -1, newkeycode, modifiers, isPress, autoRepeat ); 577 QWSServer::sendKeyEvent ( -1, newkeycode, modifiers, isPress, autoRepeat );
576 return true; 578 return true;
577 } 579 }
578 else 580 else
579 return false; 581 return false;
580} 582}
581 583
582void iPAQ::timerEvent ( QTimerEvent * ) 584void iPAQ::timerEvent ( QTimerEvent * )
583{ 585{
584 killTimer ( m_power_timer ); 586 killTimer ( m_power_timer );
585 m_power_timer = 0; 587 m_power_timer = 0;
586 QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, true, false ); 588 QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, true, false );
587 QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, false, false ); 589 QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, false, false );
588} 590}
589 591
590 592
591void iPAQ::alarmSound ( ) 593void iPAQ::alarmSound ( )
592{ 594{
593#if defined( QT_QWS_IPAQ ) // IPAQ 595#if defined( QT_QWS_IPAQ ) // IPAQ
594#ifndef QT_NO_SOUND 596#ifndef QT_NO_SOUND
595 static Sound snd ( "alarm" ); 597 static Sound snd ( "alarm" );
596 int fd; 598 int fd;
597 int vol; 599 int vol;
598 bool vol_reset = false; 600 bool vol_reset = false;
599 601
600 if (( fd = ::open ( "/dev/sound/mixer", O_RDWR )) >= 0 ) { 602 if (( fd = ::open ( "/dev/sound/mixer", O_RDWR )) >= 0 ) {
601 if ( ::ioctl ( fd, MIXER_READ( 0 ), &vol ) >= 0 ) { 603 if ( ::ioctl ( fd, MIXER_READ( 0 ), &vol ) >= 0 ) {
602 Config cfg ( "qpe" ); 604 Config cfg ( "qpe" );
603 cfg. setGroup ( "Volume" ); 605 cfg. setGroup ( "Volume" );
604 606
605 int volalarm = cfg. readNumEntry ( "AlarmPercent", 50 ); 607 int volalarm = cfg. readNumEntry ( "AlarmPercent", 50 );
606 if ( volalarm < 0 ) 608 if ( volalarm < 0 )
607 volalarm = 0; 609 volalarm = 0;
608 else if ( volalarm > 100 ) 610 else if ( volalarm > 100 )
609 volalarm = 100; 611 volalarm = 100;
610 volalarm |= ( volalarm << 8 ); 612 volalarm |= ( volalarm << 8 );
611 613
612 if (( volalarm & 0xff ) > ( vol & 0xff )) { 614 if (( volalarm & 0xff ) > ( vol & 0xff )) {
613 if ( ::ioctl ( fd, MIXER_WRITE( 0 ), &volalarm ) >= 0 ) 615 if ( ::ioctl ( fd, MIXER_WRITE( 0 ), &volalarm ) >= 0 )
614 vol_reset = true; 616 vol_reset = true;
615 } 617 }
616 } 618 }
617 } 619 }
618 620
619 snd. play ( ); 621 snd. play ( );
620 while ( !snd. isFinished ( )) 622 while ( !snd. isFinished ( ))
621 qApp-> processEvents ( ); 623 qApp-> processEvents ( );
622 624
623 if ( fd >= 0 ) { 625 if ( fd >= 0 ) {
624 if ( vol_reset ) 626 if ( vol_reset )
625 ::ioctl ( fd, MIXER_WRITE( 0 ), &vol ); 627 ::ioctl ( fd, MIXER_WRITE( 0 ), &vol );
626 ::close ( fd ); 628 ::close ( fd );
627 } 629 }
628#endif 630#endif
629#endif 631#endif
630} 632}
631 633
632 634
633bool iPAQ::setSoftSuspend ( bool soft ) 635bool iPAQ::setSoftSuspend ( bool soft )
634{ 636{
635 bool res = false; 637 bool res = false;
636 int fd; 638 int fd;
637 639
638 if (( fd = ::open ( "/proc/sys/ts/suspend_button_mode", O_WRONLY )) >= 0 ) { 640 if (( fd = ::open ( "/proc/sys/ts/suspend_button_mode", O_WRONLY )) >= 0 ) {
639 if ( ::write ( fd, soft ? "1" : "0", 1 ) == 1 ) 641 if ( ::write ( fd, soft ? "1" : "0", 1 ) == 1 )
640 res = true; 642 res = true;
641 else 643 else
642 ::perror ( "write to /proc/sys/ts/suspend_button_mode" ); 644 ::perror ( "write to /proc/sys/ts/suspend_button_mode" );
643 645
644 ::close ( fd ); 646 ::close ( fd );
645 } 647 }
646 else 648 else
647 ::perror ( "/proc/sys/ts/suspend_button_mode" ); 649 ::perror ( "/proc/sys/ts/suspend_button_mode" );
648 650
649 return res; 651 return res;
650} 652}
651 653
652 654
653bool iPAQ::setDisplayBrightness ( int bright ) 655bool iPAQ::setDisplayBrightness ( int bright )
654{ 656{
655 bool res = false; 657 bool res = false;
656 int fd; 658 int fd;
657 659
658 if ( bright > 255 ) 660 int maxbright = displayBrightnessResolution ( );
659 bright = 255; 661
662 if ( bright > maxbright )
663 bright = maxbright;
660 if ( bright < 0 ) 664 if ( bright < 0 )
661 bright = 0; 665 bright = 0;
662 666
663 // 128 is the maximum if you want a decent lifetime for the LCD
664
665 if ( bright > 1 )
666 bright = (int) ( 0.5 + ( ::pow ( 2, double( bright ) / 255.0 ) - 1 ) * 128.0 ); // logarithmic
667 //bright = ( bright + 1 ) / 2;
668
669 if (( fd = ::open ( "/dev/touchscreen/0", O_WRONLY )) >= 0 ) { 667 if (( fd = ::open ( "/dev/touchscreen/0", O_WRONLY )) >= 0 ) {
670 FLITE_IN bl; 668 FLITE_IN bl;
671 bl. mode = 1; 669 bl. mode = 1;
672 bl. pwr = bright ? 1 : 0; 670 bl. pwr = bright ? 1 : 0;
673 bl. brightness = bright; 671 bl. brightness = bright;
674 res = ( ::ioctl ( fd, FLITE_ON, &bl ) == 0 ); 672 res = ( ::ioctl ( fd, FLITE_ON, &bl ) == 0 );
675 ::close ( fd ); 673 ::close ( fd );
676 } 674 }
677 return res; 675 return res;
678} 676}
679 677
680int iPAQ::displayBrightnessResolution ( ) const 678int iPAQ::displayBrightnessResolution ( ) const
681{ 679{
682 return 256; // really 128, but logarithmic control is smoother this way 680 switch ( model ( )) {
681 case Model_iPAQ_H31xx:
682 case Model_iPAQ_H36xx:
683 case Model_iPAQ_H37xx:
684 return 128; // really 256, but >128 could damage the LCD
685
686 case Model_iPAQ_H38xx:
687 case Model_iPAQ_H39xx:
688 return 64;
689
690 default:
691 return 2;
692 }
683} 693}
684 694
685 695
686bool iPAQ::hasLightSensor ( ) const 696bool iPAQ::hasLightSensor ( ) const
687{ 697{
688 return true; 698 return true;
689} 699}
690 700
691int iPAQ::readLightSensor ( ) 701int iPAQ::readLightSensor ( )
692{ 702{
693 int fd; 703 int fd;
694 int val = -1; 704 int val = -1;
695 705
696 if (( fd = ::open ( "/proc/hal/light_sensor", O_RDONLY )) >= 0 ) { 706 if (( fd = ::open ( "/proc/hal/light_sensor", O_RDONLY )) >= 0 ) {
697 char buffer [8]; 707 char buffer [8];
698 708
699 if ( ::read ( fd, buffer, 5 ) == 5 ) { 709 if ( ::read ( fd, buffer, 5 ) == 5 ) {
700 char *endptr; 710 char *endptr;
701 711
702 buffer [4] = 0; 712 buffer [4] = 0;
703 val = ::strtol ( buffer + 2, &endptr, 16 ); 713 val = ::strtol ( buffer + 2, &endptr, 16 );
704 714
705 if ( *endptr != 0 ) 715 if ( *endptr != 0 )
706 val = -1; 716 val = -1;
707 } 717 }
708 ::close ( fd ); 718 ::close ( fd );
709 } 719 }
710 720
711 return val; 721 return val;
712} 722}
713 723
714int iPAQ::lightSensorResolution ( ) const 724int iPAQ::lightSensorResolution ( ) const
715{ 725{
716 return 256; 726 return 256;
717} 727}
718 728
719/************************************************** 729/**************************************************
720 * 730 *
721 * Zaurus 731 * Zaurus
722 * 732 *
723 **************************************************/ 733 **************************************************/
724 734
725 735
726 736
727void Zaurus::init ( ) 737void Zaurus::init ( )
728{ 738{
729 d-> m_modelstr = "Zaurus SL5000"; 739 d-> m_modelstr = "Zaurus SL5000";
730 d-> m_model = Model_Zaurus_SL5000; 740 d-> m_model = Model_Zaurus_SL5000;
731 d-> m_vendorstr = "Sharp"; 741 d-> m_vendorstr = "Sharp";
732 d-> m_vendor = Vendor_Sharp; 742 d-> m_vendor = Vendor_Sharp;
733 743
734 QFile f ( "/proc/filesystems" ); 744 QFile f ( "/proc/filesystems" );
735 745
736 if ( f. open ( IO_ReadOnly ) && ( QTextStream ( &f ). read ( ). find ( "\tjffs2\n" ) >= 0 )) { 746 if ( f. open ( IO_ReadOnly ) && ( QTextStream ( &f ). read ( ). find ( "\tjffs2\n" ) >= 0 )) {
737 d-> m_systemstr = "OpenZaurus"; 747 d-> m_systemstr = "OpenZaurus";
738 d-> m_system = System_OpenZaurus; 748 d-> m_system = System_OpenZaurus;
739 749
740 f. close ( ); 750 f. close ( );
741 751
742 f. setName ( "/etc/oz_version" ); 752 f. setName ( "/etc/oz_version" );
743 if ( f. open ( IO_ReadOnly )) { 753 if ( f. open ( IO_ReadOnly )) {
744 QTextStream ts ( &f ); 754 QTextStream ts ( &f );
745 d-> m_sysverstr = ts. readLine ( ). mid ( 10 ); 755 d-> m_sysverstr = ts. readLine ( ). mid ( 10 );
746 f. close ( ); 756 f. close ( );
747 } 757 }
748 } 758 }
749 else { 759 else {
750 d-> m_systemstr = "Zaurus"; 760 d-> m_systemstr = "Zaurus";
751 d-> m_system = System_Zaurus; 761 d-> m_system = System_Zaurus;
752 } 762 }
753 763
754 764
755 m_leds [0] = Led_Off; 765 m_leds [0] = Led_Off;
756} 766}
757 767
758#include <unistd.h> 768#include <unistd.h>
759#include <fcntl.h> 769#include <fcntl.h>
760#include <sys/ioctl.h> 770#include <sys/ioctl.h>
761 771
762//#include <asm/sharp_char.h> // including kernel headers is evil ... 772//#include <asm/sharp_char.h> // including kernel headers is evil ...
763 773
764#define SHARP_DEV_IOCTL_COMMAND_START 0x5680 774#define SHARP_DEV_IOCTL_COMMAND_START 0x5680
765 775
766 #defineSHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) 776 #defineSHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START)
767#define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START) 777#define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START)
768 778
769#define SHARP_BUZ_TOUCHSOUND 1 /* touch panel sound */ 779#define SHARP_BUZ_TOUCHSOUND 1 /* touch panel sound */
770#define SHARP_BUZ_KEYSOUND 2 /* key sound */ 780#define SHARP_BUZ_KEYSOUND 2 /* key sound */
771#define SHARP_BUZ_SCHEDULE_ALARM 11 /* schedule alarm */ 781#define SHARP_BUZ_SCHEDULE_ALARM 11 /* schedule alarm */
772 782
773/* --- for SHARP_BUZZER device --- */ 783/* --- for SHARP_BUZZER device --- */
774 784
775 //#defineSHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) 785 //#defineSHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START)
776//#define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START) 786//#define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START)
777 787
778#define SHARP_BUZZER_SETVOLUME (SHARP_BUZZER_IOCTL_START+1) 788#define SHARP_BUZZER_SETVOLUME (SHARP_BUZZER_IOCTL_START+1)
779#define SHARP_BUZZER_GETVOLUME (SHARP_BUZZER_IOCTL_START+2) 789#define SHARP_BUZZER_GETVOLUME (SHARP_BUZZER_IOCTL_START+2)
780#define SHARP_BUZZER_ISSUPPORTED (SHARP_BUZZER_IOCTL_START+3) 790#define SHARP_BUZZER_ISSUPPORTED (SHARP_BUZZER_IOCTL_START+3)
781#define SHARP_BUZZER_SETMUTE (SHARP_BUZZER_IOCTL_START+4) 791#define SHARP_BUZZER_SETMUTE (SHARP_BUZZER_IOCTL_START+4)
782#define SHARP_BUZZER_STOPSOUND (SHARP_BUZZER_IOCTL_START+5) 792#define SHARP_BUZZER_STOPSOUND (SHARP_BUZZER_IOCTL_START+5)
783 793
784//#define SHARP_BUZ_TOUCHSOUND 1 /* touch panel sound */ 794//#define SHARP_BUZ_TOUCHSOUND 1 /* touch panel sound */
785//#define SHARP_BUZ_KEYSOUND 2 /* key sound */ 795//#define SHARP_BUZ_KEYSOUND 2 /* key sound */
786 796
787//#define SHARP_PDA_ILLCLICKSOUND 3 /* illegal click */ 797//#define SHARP_PDA_ILLCLICKSOUND 3 /* illegal click */
788//#define SHARP_PDA_WARNSOUND 4 /* warning occurred */ 798//#define SHARP_PDA_WARNSOUND 4 /* warning occurred */
789//#define SHARP_PDA_ERRORSOUND 5 /* error occurred */ 799//#define SHARP_PDA_ERRORSOUND 5 /* error occurred */
790//#define SHARP_PDA_CRITICALSOUND 6 /* critical error occurred */ 800//#define SHARP_PDA_CRITICALSOUND 6 /* critical error occurred */
791//#define SHARP_PDA_SYSSTARTSOUND 7 /* system start */ 801//#define SHARP_PDA_SYSSTARTSOUND 7 /* system start */
792//#define SHARP_PDA_SYSTEMENDSOUND 8 /* system shutdown */ 802//#define SHARP_PDA_SYSTEMENDSOUND 8 /* system shutdown */
793//#define SHARP_PDA_APPSTART 9 /* application start */ 803//#define SHARP_PDA_APPSTART 9 /* application start */
794//#define SHARP_PDA_APPQUIT 10 /* application ends */ 804//#define SHARP_PDA_APPQUIT 10 /* application ends */
795 805
796//#define SHARP_BUZ_SCHEDULE_ALARM 11 /* schedule alarm */ 806//#define SHARP_BUZ_SCHEDULE_ALARM 11 /* schedule alarm */
797//#define SHARP_BUZ_DAILY_ALARM 12 /* daily alarm */ 807//#define SHARP_BUZ_DAILY_ALARM 12 /* daily alarm */
798//#define SHARP_BUZ_GOT_PHONE_CALL 13 /* phone call sound */ 808//#define SHARP_BUZ_GOT_PHONE_CALL 13 /* phone call sound */
799//#define SHARP_BUZ_GOT_MAIL 14 /* mail sound */ 809//#define SHARP_BUZ_GOT_MAIL 14 /* mail sound */
800// 810//
801 811
802 #defineSHARP_LED_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) 812 #defineSHARP_LED_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START)
803#define SHARP_LED_SETSTATUS (SHARP_LED_IOCTL_START+1) 813#define SHARP_LED_SETSTATUS (SHARP_LED_IOCTL_START+1)
804 814
805typedef struct sharp_led_status { 815typedef struct sharp_led_status {
806 int which; /* select which LED status is wanted. */ 816 int which; /* select which LED status is wanted. */
807 int status; /* set new led status if you call SHARP_LED_SETSTATUS */ 817 int status; /* set new led status if you call SHARP_LED_SETSTATUS */
808} sharp_led_status; 818} sharp_led_status;
809 819
810#define SHARP_LED_MAIL_EXISTS 9 /* mail status (exists or not) */ 820#define SHARP_LED_MAIL_EXISTS 9 /* mail status (exists or not) */
811 821
812#define LED_MAIL_NO_UNREAD_MAIL 0 /* for SHARP_LED_MAIL_EXISTS */ 822#define LED_MAIL_NO_UNREAD_MAIL 0 /* for SHARP_LED_MAIL_EXISTS */
813#define LED_MAIL_NEWMAIL_EXISTS 1 /* for SHARP_LED_MAIL_EXISTS */ 823#define LED_MAIL_NEWMAIL_EXISTS 1 /* for SHARP_LED_MAIL_EXISTS */
814#define LED_MAIL_UNREAD_MAIL_EX 2 /* for SHARP_LED_MAIL_EXISTS */ 824#define LED_MAIL_UNREAD_MAIL_EX 2 /* for SHARP_LED_MAIL_EXISTS */
815 825
816// #include <asm/sharp_apm.h> // including kernel headers is evil ... 826// #include <asm/sharp_apm.h> // including kernel headers is evil ...
817 827
818#define APM_IOCGEVTSRC OD_IOR( 'A', 203, int ) 828#define APM_IOCGEVTSRC OD_IOR( 'A', 203, int )
819#define APM_IOCSEVTSRC OD_IORW( 'A', 204, int ) 829#define APM_IOCSEVTSRC OD_IORW( 'A', 204, int )
820#define APM_EVT_POWER_BUTTON (1 << 0) 830#define APM_EVT_POWER_BUTTON (1 << 0)
821 831
822#define FL_IOCTL_STEP_CONTRAST 100 832#define FL_IOCTL_STEP_CONTRAST 100
823 833
824 834
825void Zaurus::buzzer ( int sound ) 835void Zaurus::buzzer ( int sound )
826{ 836{
827 static int fd = ::open ( "/dev/sharp_buz", O_RDWR|O_NONBLOCK ); 837 static int fd = ::open ( "/dev/sharp_buz", O_RDWR|O_NONBLOCK );
828 838
829 if ( fd >= 0 ) 839 if ( fd >= 0 )
830 ::ioctl ( fd, SHARP_BUZZER_MAKESOUND, sound ); 840 ::ioctl ( fd, SHARP_BUZZER_MAKESOUND, sound );
831} 841}
832 842
833 843
834void Zaurus::alarmSound ( ) 844void Zaurus::alarmSound ( )
835{ 845{
836 buzzer ( SHARP_BUZ_SCHEDULE_ALARM ); 846 buzzer ( SHARP_BUZ_SCHEDULE_ALARM );
837} 847}
838 848
839void Zaurus::touchSound ( ) 849void Zaurus::touchSound ( )
840{ 850{
841 buzzer ( SHARP_BUZ_TOUCHSOUND ); 851 buzzer ( SHARP_BUZ_TOUCHSOUND );
842} 852}
843 853
844void Zaurus::keySound ( ) 854void Zaurus::keySound ( )
845{ 855{
846 buzzer ( SHARP_BUZ_KEYSOUND ); 856 buzzer ( SHARP_BUZ_KEYSOUND );
847} 857}
848 858
849 859
850QValueList <OLed> Zaurus::ledList ( ) const 860QValueList <OLed> Zaurus::ledList ( ) const
851{ 861{
852 QValueList <OLed> vl; 862 QValueList <OLed> vl;
853 vl << Led_Mail; 863 vl << Led_Mail;
854 return vl; 864 return vl;
855} 865}
856 866
857QValueList <OLedState> Zaurus::ledStateList ( OLed l ) const 867QValueList <OLedState> Zaurus::ledStateList ( OLed l ) const
858{ 868{
859 QValueList <OLedState> vl; 869 QValueList <OLedState> vl;
860 870
861 if ( l == Led_Mail ) 871 if ( l == Led_Mail )
862 vl << Led_Off << Led_On << Led_BlinkSlow; 872 vl << Led_Off << Led_On << Led_BlinkSlow;
863 return vl; 873 return vl;
864} 874}
865 875
866OLedState Zaurus::ledState ( OLed which ) const 876OLedState Zaurus::ledState ( OLed which ) const
867{ 877{
868 if ( which == Led_Mail ) 878 if ( which == Led_Mail )
869 return m_leds [0]; 879 return m_leds [0];
870 else 880 else
871 return Led_Off; 881 return Led_Off;
872} 882}
873 883
874bool Zaurus::setLedState ( OLed which, OLedState st ) 884bool Zaurus::setLedState ( OLed which, OLedState st )
875{ 885{
876 static int fd = ::open ( "/dev/sharp_led", O_RDWR|O_NONBLOCK ); 886 static int fd = ::open ( "/dev/sharp_led", O_RDWR|O_NONBLOCK );
877 887
878 if ( which == Led_Mail ) { 888 if ( which == Led_Mail ) {
879 if ( fd >= 0 ) { 889 if ( fd >= 0 ) {
880 struct sharp_led_status leds; 890 struct sharp_led_status leds;
881 ::memset ( &leds, 0, sizeof( leds )); 891 ::memset ( &leds, 0, sizeof( leds ));
882 leds. which = SHARP_LED_MAIL_EXISTS; 892 leds. which = SHARP_LED_MAIL_EXISTS;
883 bool ok = true; 893 bool ok = true;
884 894
885 switch ( st ) { 895 switch ( st ) {
886 case Led_Off : leds. status = LED_MAIL_NO_UNREAD_MAIL; break; 896 case Led_Off : leds. status = LED_MAIL_NO_UNREAD_MAIL; break;
887 case Led_On : leds. status = LED_MAIL_NEWMAIL_EXISTS; break; 897 case Led_On : leds. status = LED_MAIL_NEWMAIL_EXISTS; break;
888 case Led_BlinkSlow: leds. status = LED_MAIL_UNREAD_MAIL_EX; break; 898 case Led_BlinkSlow: leds. status = LED_MAIL_UNREAD_MAIL_EX; break;
889 default : ok = false; 899 default : ok = false;
890 } 900 }
891 901
892 if ( ok && ( ::ioctl ( fd, SHARP_LED_SETSTATUS, &leds ) >= 0 )) { 902 if ( ok && ( ::ioctl ( fd, SHARP_LED_SETSTATUS, &leds ) >= 0 )) {
893 m_leds [0] = st; 903 m_leds [0] = st;
894 return true; 904 return true;
895 } 905 }
896 } 906 }
897 } 907 }
898 return false; 908 return false;
899} 909}
900 910
901bool Zaurus::setSoftSuspend ( bool soft ) 911bool Zaurus::setSoftSuspend ( bool soft )
902{ 912{
903 bool res = false; 913 bool res = false;
904 int fd; 914 int fd;
905 915
906 if ((( fd = ::open ( "/dev/apm_bios", O_RDWR )) >= 0 ) || 916 if ((( fd = ::open ( "/dev/apm_bios", O_RDWR )) >= 0 ) ||
907 (( fd = ::open ( "/dev/misc/apm_bios",O_RDWR )) >= 0 )) { 917 (( fd = ::open ( "/dev/misc/apm_bios",O_RDWR )) >= 0 )) {
908 918
909 int sources = ::ioctl ( fd, APM_IOCGEVTSRC, 0 ); // get current event sources 919 int sources = ::ioctl ( fd, APM_IOCGEVTSRC, 0 ); // get current event sources
910 920
911 if ( sources >= 0 ) { 921 if ( sources >= 0 ) {
912 if ( soft ) 922 if ( soft )
913 sources &= ~APM_EVT_POWER_BUTTON; 923 sources &= ~APM_EVT_POWER_BUTTON;
914 else 924 else
915 sources |= APM_EVT_POWER_BUTTON; 925 sources |= APM_EVT_POWER_BUTTON;
916 926
917 if ( ::ioctl ( fd, APM_IOCSEVTSRC, sources ) >= 0 ) // set new event sources 927 if ( ::ioctl ( fd, APM_IOCSEVTSRC, sources ) >= 0 ) // set new event sources
918 res = true; 928 res = true;
919 else 929 else
920 perror ( "APM_IOCGEVTSRC" ); 930 perror ( "APM_IOCGEVTSRC" );
921 } 931 }
922 else 932 else
923 perror ( "APM_IOCGEVTSRC" ); 933 perror ( "APM_IOCGEVTSRC" );
924 934
925 ::close ( fd ); 935 ::close ( fd );
926 } 936 }
927 else 937 else
928 perror ( "/dev/apm_bios or /dev/misc/apm_bios" ); 938 perror ( "/dev/apm_bios or /dev/misc/apm_bios" );
929 939
930 return res; 940 return res;
931} 941}
932 942
933 943
934bool Zaurus::setDisplayBrightness ( int bright ) 944bool Zaurus::setDisplayBrightness ( int bright )
935{ 945{
936 bool res = false; 946 bool res = false;
937 int fd; 947 int fd;
938 948
939 if ( bright > 255 ) 949 if ( bright > 255 )
940 bright = 255; 950 bright = 255;
941 if ( bright < 0 ) 951 if ( bright < 0 )
942 bright = 0; 952 bright = 0;
943 953
944 if (( fd = ::open ( "/dev/fl", O_WRONLY )) >= 0 ) { 954 if (( fd = ::open ( "/dev/fl", O_WRONLY )) >= 0 ) {
945 int bl = ( bright * 4 + 127 ) / 255; // only 4 steps on zaurus 955 int bl = ( bright * 4 + 127 ) / 255; // only 4 steps on zaurus
946 if ( bright && !bl ) 956 if ( bright && !bl )
947 bl = 1; 957 bl = 1;
948 res = ( ::ioctl ( fd, FL_IOCTL_STEP_CONTRAST, bl ) == 0 ); 958 res = ( ::ioctl ( fd, FL_IOCTL_STEP_CONTRAST, bl ) == 0 );
949 ::close ( fd ); 959 ::close ( fd );
950 } 960 }
951 return res; 961 return res;
952} 962}
953 963
954 964
955int Zaurus::displayBrightnessResolution ( ) const 965int Zaurus::displayBrightnessResolution ( ) const
956{ 966{
957 return 5; 967 return 5;
958} 968}
959 969
960//QValueList <int> Zaurus::keyList ( ) const
961//{
962 //QValueList <int> vl;
963 //vl << HardKey_Datebook << HardKey_Contacts << HardKey_Mail << HardKey_Menu << HardKey_Home << HardKey_Suspend << HardKey_Backlight;
964 //return vl;
965//}
966 970