summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie/odevice.cpp7
1 files changed, 2 insertions, 5 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp
index 80e9a91..58bd663 100644
--- a/libopie/odevice.cpp
+++ b/libopie/odevice.cpp
@@ -535,169 +535,166 @@ bool iPAQ::filter ( int /*unicode*/, int keycode, int modifiers, bool isPress, b
535 // map Power Button short/long press to F34/F35 535 // map Power Button short/long press to F34/F35
536 if ( keycode == Key_SysReq ) { 536 if ( keycode == Key_SysReq ) {
537 if ( isPress ) { 537 if ( isPress ) {
538 if ( m_power_timer ) 538 if ( m_power_timer )
539 killTimer ( m_power_timer ); 539 killTimer ( m_power_timer );
540 m_power_timer = startTimer ( 500 ); 540 m_power_timer = startTimer ( 500 );
541 } 541 }
542 else if ( m_power_timer ) { 542 else if ( m_power_timer ) {
543 killTimer ( m_power_timer ); 543 killTimer ( m_power_timer );
544 m_power_timer = 0; 544 m_power_timer = 0;
545 QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, true, false ); 545 QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, true, false );
546 QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, false, false ); 546 QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, false, false );
547 } 547 }
548 newkeycode = Key_unknown; 548 newkeycode = Key_unknown;
549 } 549 }
550 //nobreak; 550 //nobreak;
551 551
552 default: 552 default:
553 break; 553 break;
554 } 554 }
555 555
556 if ( newkeycode != keycode ) { 556 if ( newkeycode != keycode ) {
557 if ( newkeycode != Key_unknown ) 557 if ( newkeycode != Key_unknown )
558 QWSServer::sendKeyEvent ( -1, newkeycode, modifiers, isPress, autoRepeat ); 558 QWSServer::sendKeyEvent ( -1, newkeycode, modifiers, isPress, autoRepeat );
559 return true; 559 return true;
560 } 560 }
561 else 561 else
562 return false; 562 return false;
563} 563}
564 564
565void iPAQ::timerEvent ( QTimerEvent * ) 565void iPAQ::timerEvent ( QTimerEvent * )
566{ 566{
567 killTimer ( m_power_timer ); 567 killTimer ( m_power_timer );
568 m_power_timer = 0; 568 m_power_timer = 0;
569 QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, true, false ); 569 QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, true, false );
570 QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, false, false ); 570 QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, false, false );
571} 571}
572 572
573 573
574void iPAQ::alarmSound ( ) 574void iPAQ::alarmSound ( )
575{ 575{
576#if defined( QT_QWS_IPAQ ) // IPAQ 576#if defined( QT_QWS_IPAQ ) // IPAQ
577#ifndef QT_NO_SOUND 577#ifndef QT_NO_SOUND
578 static Sound snd ( "alarm" ); 578 static Sound snd ( "alarm" );
579 int fd; 579 int fd;
580 int vol; 580 int vol;
581 bool vol_reset = false; 581 bool vol_reset = false;
582 582
583 if ((( fd = ::open ( "/dev/sound/mixer", O_RDWR )) >= 0 ) || 583 if (( fd = ::open ( "/dev/sound/mixer", O_RDWR )) >= 0 ) {
584 (( fd = ::open ( "/dev/mixer", O_RDWR )) >= 0 )) {
585
586 if ( ::ioctl ( fd, MIXER_READ( 0 ), &vol ) >= 0 ) { 584 if ( ::ioctl ( fd, MIXER_READ( 0 ), &vol ) >= 0 ) {
587 Config cfg ( "qpe" ); 585 Config cfg ( "qpe" );
588 cfg. setGroup ( "Volume" ); 586 cfg. setGroup ( "Volume" );
589 587
590 int volalarm = cfg. readNumEntry ( "AlarmPercent", 50 ); 588 int volalarm = cfg. readNumEntry ( "AlarmPercent", 50 );
591 if ( volalarm < 0 ) 589 if ( volalarm < 0 )
592 volalarm = 0; 590 volalarm = 0;
593 else if ( volalarm > 100 ) 591 else if ( volalarm > 100 )
594 volalarm = 100; 592 volalarm = 100;
595 volalarm |= ( volalarm << 8 ); 593 volalarm |= ( volalarm << 8 );
596 594
597 if (( volalarm & 0xff ) > ( vol & 0xff )) { 595 if (( volalarm & 0xff ) > ( vol & 0xff )) {
598 if ( ::ioctl ( fd, MIXER_WRITE( 0 ), &volalarm ) >= 0 ) 596 if ( ::ioctl ( fd, MIXER_WRITE( 0 ), &volalarm ) >= 0 )
599 vol_reset = true; 597 vol_reset = true;
600 } 598 }
601 } 599 }
602 } 600 }
603 601
604 snd. play ( ); 602 snd. play ( );
605 while ( !snd. isFinished ( )) 603 while ( !snd. isFinished ( ))
606 qApp-> processEvents ( ); 604 qApp-> processEvents ( );
607 605
608 if ( fd >= 0 ) { 606 if ( fd >= 0 ) {
609 if ( vol_reset ) 607 if ( vol_reset )
610 ::ioctl ( fd, MIXER_WRITE( 0 ), &vol ); 608 ::ioctl ( fd, MIXER_WRITE( 0 ), &vol );
611 ::close ( fd ); 609 ::close ( fd );
612 } 610 }
613#endif 611#endif
614#endif 612#endif
615} 613}
616 614
617 615
618bool iPAQ::setSoftSuspend ( bool soft ) 616bool iPAQ::setSoftSuspend ( bool soft )
619{ 617{
620 bool res = false; 618 bool res = false;
621 int fd; 619 int fd;
622 620
623 if (( fd = ::open ( "/proc/sys/ts/suspend_button_mode", O_WRONLY )) >= 0 ) { 621 if (( fd = ::open ( "/proc/sys/ts/suspend_button_mode", O_WRONLY )) >= 0 ) {
624 if ( ::write ( fd, soft ? "1" : "0", 1 ) == 1 ) 622 if ( ::write ( fd, soft ? "1" : "0", 1 ) == 1 )
625 res = true; 623 res = true;
626 else 624 else
627 ::perror ( "write to /proc/sys/ts/suspend_button_mode" ); 625 ::perror ( "write to /proc/sys/ts/suspend_button_mode" );
628 626
629 ::close ( fd ); 627 ::close ( fd );
630 } 628 }
631 else 629 else
632 ::perror ( "/proc/sys/ts/suspend_button_mode" ); 630 ::perror ( "/proc/sys/ts/suspend_button_mode" );
633 631
634 return res; 632 return res;
635} 633}
636 634
637 635
638bool iPAQ::setDisplayBrightness ( int bright ) 636bool iPAQ::setDisplayBrightness ( int bright )
639{ 637{
640 bool res = false; 638 bool res = false;
641 int fd; 639 int fd;
642 640
643 if ( bright > 255 ) 641 if ( bright > 255 )
644 bright = 255; 642 bright = 255;
645 if ( bright < 0 ) 643 if ( bright < 0 )
646 bright = 0; 644 bright = 0;
647 645
648 // 128 is the maximum if you want a decent lifetime for the LCD 646 // 128 is the maximum if you want a decent lifetime for the LCD
649 647
650 if ( bright > 1 ) 648 if ( bright > 1 )
651 bright = (int) ( 0.5 + ( ::pow ( 2, double( bright ) / 255.0 ) - 1 ) * 128.0 ); // logarithmic 649 bright = (int) ( 0.5 + ( ::pow ( 2, double( bright ) / 255.0 ) - 1 ) * 128.0 ); // logarithmic
652 //bright = ( bright + 1 ) / 2; 650 //bright = ( bright + 1 ) / 2;
653 651
654 if ((( fd = ::open ( "/dev/ts", O_WRONLY )) >= 0 ) || 652 if (( fd = ::open ( "/dev/touchscreen/0", O_WRONLY )) >= 0 ) {
655 (( fd = ::open ( "/dev/h3600_ts", O_WRONLY )) >= 0 )) {
656 FLITE_IN bl; 653 FLITE_IN bl;
657 bl. mode = 1; 654 bl. mode = 1;
658 bl. pwr = bright ? 1 : 0; 655 bl. pwr = bright ? 1 : 0;
659 bl. brightness = bright; 656 bl. brightness = bright;
660 res = ( ::ioctl ( fd, FLITE_ON, &bl ) == 0 ); 657 res = ( ::ioctl ( fd, FLITE_ON, &bl ) == 0 );
661 ::close ( fd ); 658 ::close ( fd );
662 } 659 }
663 return res; 660 return res;
664} 661}
665 662
666int iPAQ::displayBrightnessResolution ( ) const 663int iPAQ::displayBrightnessResolution ( ) const
667{ 664{
668 return 255; // really 128, but logarithmic control is smoother this way 665 return 255; // really 128, but logarithmic control is smoother this way
669} 666}
670 667
671 668
672/************************************************** 669/**************************************************
673 * 670 *
674 * Zaurus 671 * Zaurus
675 * 672 *
676 **************************************************/ 673 **************************************************/
677 674
678 675
679 676
680void Zaurus::init ( ) 677void Zaurus::init ( )
681{ 678{
682 d-> m_modelstr = "Zaurus SL5000"; 679 d-> m_modelstr = "Zaurus SL5000";
683 d-> m_model = Model_Zaurus_SL5000; 680 d-> m_model = Model_Zaurus_SL5000;
684 d-> m_vendorstr = "Sharp"; 681 d-> m_vendorstr = "Sharp";
685 d-> m_vendor = Vendor_Sharp; 682 d-> m_vendor = Vendor_Sharp;
686 683
687 QFile f ( "/proc/filesystems" ); 684 QFile f ( "/proc/filesystems" );
688 685
689 if ( f. open ( IO_ReadOnly ) && ( QTextStream ( &f ). read ( ). find ( "\tjffs2\n" ) >= 0 )) { 686 if ( f. open ( IO_ReadOnly ) && ( QTextStream ( &f ). read ( ). find ( "\tjffs2\n" ) >= 0 )) {
690 d-> m_systemstr = "OpenZaurus"; 687 d-> m_systemstr = "OpenZaurus";
691 d-> m_system = System_OpenZaurus; 688 d-> m_system = System_OpenZaurus;
692 689
693 f. close ( ); 690 f. close ( );
694 691
695 f. setName ( "/etc/oz_version" ); 692 f. setName ( "/etc/oz_version" );
696 if ( f. open ( IO_ReadOnly )) { 693 if ( f. open ( IO_ReadOnly )) {
697 QTextStream ts ( &f ); 694 QTextStream ts ( &f );
698 d-> m_sysverstr = ts. readLine ( ). mid ( 10 ); 695 d-> m_sysverstr = ts. readLine ( ). mid ( 10 );
699 f. close ( ); 696 f. close ( );
700 } 697 }
701 } 698 }
702 else { 699 else {
703 d-> m_systemstr = "Zaurus"; 700 d-> m_systemstr = "Zaurus";