-rw-r--r-- | libopie/odevice.cpp | 8 |
1 files changed, 3 insertions, 5 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp index 8f4e296..7d8cdbf 100644 --- a/libopie/odevice.cpp +++ b/libopie/odevice.cpp | |||
@@ -468,396 +468,394 @@ QValueList <OLed> iPAQ::ledList ( ) const | |||
468 | QValueList <OLedState> iPAQ::ledStateList ( OLed l ) const | 468 | QValueList <OLedState> iPAQ::ledStateList ( OLed l ) const |
469 | { | 469 | { |
470 | QValueList <OLedState> vl; | 470 | QValueList <OLedState> vl; |
471 | 471 | ||
472 | if ( l == Led_Power ) | 472 | if ( l == Led_Power ) |
473 | vl << Led_Off << Led_On << Led_BlinkSlow << Led_BlinkFast; | 473 | vl << Led_Off << Led_On << Led_BlinkSlow << Led_BlinkFast; |
474 | else if ( l == Led_BlueTooth && d-> m_model == Model_iPAQ_H38xx ) | 474 | else if ( l == Led_BlueTooth && d-> m_model == Model_iPAQ_H38xx ) |
475 | vl << Led_Off; // << Led_On << ??? | 475 | vl << Led_Off; // << Led_On << ??? |
476 | 476 | ||
477 | return vl; | 477 | return vl; |
478 | } | 478 | } |
479 | 479 | ||
480 | OLedState iPAQ::ledState ( OLed l ) const | 480 | OLedState iPAQ::ledState ( OLed l ) const |
481 | { | 481 | { |
482 | switch ( l ) { | 482 | switch ( l ) { |
483 | case Led_Power: | 483 | case Led_Power: |
484 | return m_leds [0]; | 484 | return m_leds [0]; |
485 | case Led_BlueTooth: | 485 | case Led_BlueTooth: |
486 | return m_leds [1]; | 486 | return m_leds [1]; |
487 | default: | 487 | default: |
488 | return Led_Off; | 488 | return Led_Off; |
489 | } | 489 | } |
490 | } | 490 | } |
491 | 491 | ||
492 | bool iPAQ::setLedState ( OLed l, OLedState st ) | 492 | bool iPAQ::setLedState ( OLed l, OLedState st ) |
493 | { | 493 | { |
494 | static int fd = ::open ( "/dev/touchscreen/0", O_RDWR | O_NONBLOCK ); | 494 | static int fd = ::open ( "/dev/touchscreen/0", O_RDWR | O_NONBLOCK ); |
495 | 495 | ||
496 | if ( l == Led_Power ) { | 496 | if ( l == Led_Power ) { |
497 | if ( fd >= 0 ) { | 497 | if ( fd >= 0 ) { |
498 | LED_IN leds; | 498 | LED_IN leds; |
499 | ::memset ( &leds, 0, sizeof( leds )); | 499 | ::memset ( &leds, 0, sizeof( leds )); |
500 | leds. TotalTime = 0; | 500 | leds. TotalTime = 0; |
501 | leds. OnTime = 0; | 501 | leds. OnTime = 0; |
502 | leds. OffTime = 1; | 502 | leds. OffTime = 1; |
503 | leds. OffOnBlink = 2; | 503 | leds. OffOnBlink = 2; |
504 | 504 | ||
505 | switch ( st ) { | 505 | switch ( st ) { |
506 | case Led_Off : leds. OffOnBlink = 0; break; | 506 | case Led_Off : leds. OffOnBlink = 0; break; |
507 | case Led_On : leds. OffOnBlink = 1; break; | 507 | case Led_On : leds. OffOnBlink = 1; break; |
508 | case Led_BlinkSlow: leds. OnTime = 10; leds. OffTime = 10; break; | 508 | case Led_BlinkSlow: leds. OnTime = 10; leds. OffTime = 10; break; |
509 | case Led_BlinkFast: leds. OnTime = 5; leds. OffTime = 5; break; | 509 | case Led_BlinkFast: leds. OnTime = 5; leds. OffTime = 5; break; |
510 | } | 510 | } |
511 | 511 | ||
512 | if ( ::ioctl ( fd, LED_ON, &leds ) >= 0 ) { | 512 | if ( ::ioctl ( fd, LED_ON, &leds ) >= 0 ) { |
513 | m_leds [0] = st; | 513 | m_leds [0] = st; |
514 | return true; | 514 | return true; |
515 | } | 515 | } |
516 | } | 516 | } |
517 | } | 517 | } |
518 | return false; | 518 | return false; |
519 | } | 519 | } |
520 | 520 | ||
521 | 521 | ||
522 | //QValueList <int> iPAQ::keyList ( ) const | 522 | //QValueList <int> iPAQ::keyList ( ) const |
523 | //{ | 523 | //{ |
524 | //QValueList <int> vl; | 524 | //QValueList <int> vl; |
525 | //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; |
526 | //return vl; | 526 | //return vl; |
527 | //} | 527 | //} |
528 | 528 | ||
529 | bool iPAQ::filter ( int /*unicode*/, int keycode, int modifiers, bool isPress, bool autoRepeat ) | 529 | bool iPAQ::filter ( int /*unicode*/, int keycode, int modifiers, bool isPress, bool autoRepeat ) |
530 | { | 530 | { |
531 | int newkeycode = keycode; | 531 | int newkeycode = keycode; |
532 | 532 | ||
533 | 533 | ||
534 | // simple susbstitutions | 534 | // simple susbstitutions |
535 | switch ( d-> m_model ) { | 535 | switch ( d-> m_model ) { |
536 | case Model_iPAQ_H38xx: | 536 | case Model_iPAQ_H38xx: |
537 | // 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 |
538 | if ( keycode == HardKey_Menu ) | 538 | if ( keycode == HardKey_Menu ) |
539 | newkeycode = HardKey_Mail; | 539 | newkeycode = HardKey_Mail; |
540 | //nobreak | 540 | //nobreak |
541 | 541 | ||
542 | case Model_iPAQ_H31xx: | 542 | case Model_iPAQ_H31xx: |
543 | // Rotate cursor keys 180° | 543 | // Rotate cursor keys 180° |
544 | switch ( keycode ) { | 544 | switch ( keycode ) { |
545 | case Key_Left : newkeycode = Key_Right; break; | 545 | case Key_Left : newkeycode = Key_Right; break; |
546 | case Key_Right: newkeycode = Key_Left; break; | 546 | case Key_Right: newkeycode = Key_Left; break; |
547 | case Key_Up : newkeycode = Key_Down; break; | 547 | case Key_Up : newkeycode = Key_Down; break; |
548 | case Key_Down : newkeycode = Key_Up; break; | 548 | case Key_Down : newkeycode = Key_Up; break; |
549 | } | 549 | } |
550 | //nobreak; | 550 | //nobreak; |
551 | 551 | ||
552 | case Model_iPAQ_H36xx: | 552 | case Model_iPAQ_H36xx: |
553 | case Model_iPAQ_H37xx: | 553 | case Model_iPAQ_H37xx: |
554 | // map Power Button short/long press to F34/F35 | 554 | // map Power Button short/long press to F34/F35 |
555 | if ( keycode == Key_SysReq ) { | 555 | if ( keycode == Key_SysReq ) { |
556 | if ( isPress ) { | 556 | if ( isPress ) { |
557 | if ( m_power_timer ) | 557 | if ( m_power_timer ) |
558 | killTimer ( m_power_timer ); | 558 | killTimer ( m_power_timer ); |
559 | m_power_timer = startTimer ( 500 ); | 559 | m_power_timer = startTimer ( 500 ); |
560 | } | 560 | } |
561 | else if ( m_power_timer ) { | 561 | else if ( m_power_timer ) { |
562 | killTimer ( m_power_timer ); | 562 | killTimer ( m_power_timer ); |
563 | m_power_timer = 0; | 563 | m_power_timer = 0; |
564 | QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, true, false ); | 564 | QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, true, false ); |
565 | QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, false, false ); | 565 | QWSServer::sendKeyEvent ( -1, HardKey_Suspend, 0, false, false ); |
566 | } | 566 | } |
567 | newkeycode = Key_unknown; | 567 | newkeycode = Key_unknown; |
568 | } | 568 | } |
569 | //nobreak; | 569 | //nobreak; |
570 | 570 | ||
571 | default: | 571 | default: |
572 | break; | 572 | break; |
573 | } | 573 | } |
574 | 574 | ||
575 | if ( newkeycode != keycode ) { | 575 | if ( newkeycode != keycode ) { |
576 | if ( newkeycode != Key_unknown ) | 576 | if ( newkeycode != Key_unknown ) |
577 | QWSServer::sendKeyEvent ( -1, newkeycode, modifiers, isPress, autoRepeat ); | 577 | QWSServer::sendKeyEvent ( -1, newkeycode, modifiers, isPress, autoRepeat ); |
578 | return true; | 578 | return true; |
579 | } | 579 | } |
580 | else | 580 | else |
581 | return false; | 581 | return false; |
582 | } | 582 | } |
583 | 583 | ||
584 | void iPAQ::timerEvent ( QTimerEvent * ) | 584 | void iPAQ::timerEvent ( QTimerEvent * ) |
585 | { | 585 | { |
586 | killTimer ( m_power_timer ); | 586 | killTimer ( m_power_timer ); |
587 | m_power_timer = 0; | 587 | m_power_timer = 0; |
588 | QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, true, false ); | 588 | QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, true, false ); |
589 | QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, false, false ); | 589 | QWSServer::sendKeyEvent ( -1, HardKey_Backlight, 0, false, false ); |
590 | } | 590 | } |
591 | 591 | ||
592 | 592 | ||
593 | void iPAQ::alarmSound ( ) | 593 | void iPAQ::alarmSound ( ) |
594 | { | 594 | { |
595 | #if defined( QT_QWS_IPAQ ) // IPAQ | 595 | #if defined( QT_QWS_IPAQ ) // IPAQ |
596 | #ifndef QT_NO_SOUND | 596 | #ifndef QT_NO_SOUND |
597 | static Sound snd ( "alarm" ); | 597 | static Sound snd ( "alarm" ); |
598 | int fd; | 598 | int fd; |
599 | int vol; | 599 | int vol; |
600 | bool vol_reset = false; | 600 | bool vol_reset = false; |
601 | 601 | ||
602 | if (( fd = ::open ( "/dev/sound/mixer", O_RDWR )) >= 0 ) { | 602 | if (( fd = ::open ( "/dev/sound/mixer", O_RDWR )) >= 0 ) { |
603 | if ( ::ioctl ( fd, MIXER_READ( 0 ), &vol ) >= 0 ) { | 603 | if ( ::ioctl ( fd, MIXER_READ( 0 ), &vol ) >= 0 ) { |
604 | Config cfg ( "qpe" ); | 604 | Config cfg ( "qpe" ); |
605 | cfg. setGroup ( "Volume" ); | 605 | cfg. setGroup ( "Volume" ); |
606 | 606 | ||
607 | int volalarm = cfg. readNumEntry ( "AlarmPercent", 50 ); | 607 | int volalarm = cfg. readNumEntry ( "AlarmPercent", 50 ); |
608 | if ( volalarm < 0 ) | 608 | if ( volalarm < 0 ) |
609 | volalarm = 0; | 609 | volalarm = 0; |
610 | else if ( volalarm > 100 ) | 610 | else if ( volalarm > 100 ) |
611 | volalarm = 100; | 611 | volalarm = 100; |
612 | volalarm |= ( volalarm << 8 ); | 612 | volalarm |= ( volalarm << 8 ); |
613 | 613 | ||
614 | if (( volalarm & 0xff ) > ( vol & 0xff )) { | 614 | if (( volalarm & 0xff ) > ( vol & 0xff )) { |
615 | if ( ::ioctl ( fd, MIXER_WRITE( 0 ), &volalarm ) >= 0 ) | 615 | if ( ::ioctl ( fd, MIXER_WRITE( 0 ), &volalarm ) >= 0 ) |
616 | vol_reset = true; | 616 | vol_reset = true; |
617 | } | 617 | } |
618 | } | 618 | } |
619 | } | 619 | } |
620 | 620 | ||
621 | snd. play ( ); | 621 | snd. play ( ); |
622 | while ( !snd. isFinished ( )) | 622 | while ( !snd. isFinished ( )) |
623 | qApp-> processEvents ( ); | 623 | qApp-> processEvents ( ); |
624 | 624 | ||
625 | if ( fd >= 0 ) { | 625 | if ( fd >= 0 ) { |
626 | if ( vol_reset ) | 626 | if ( vol_reset ) |
627 | ::ioctl ( fd, MIXER_WRITE( 0 ), &vol ); | 627 | ::ioctl ( fd, MIXER_WRITE( 0 ), &vol ); |
628 | ::close ( fd ); | 628 | ::close ( fd ); |
629 | } | 629 | } |
630 | #endif | 630 | #endif |
631 | #endif | 631 | #endif |
632 | } | 632 | } |
633 | 633 | ||
634 | 634 | ||
635 | bool iPAQ::setSoftSuspend ( bool soft ) | 635 | bool iPAQ::setSoftSuspend ( bool soft ) |
636 | { | 636 | { |
637 | bool res = false; | 637 | bool res = false; |
638 | int fd; | 638 | int fd; |
639 | 639 | ||
640 | 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 ) { |
641 | if ( ::write ( fd, soft ? "1" : "0", 1 ) == 1 ) | 641 | if ( ::write ( fd, soft ? "1" : "0", 1 ) == 1 ) |
642 | res = true; | 642 | res = true; |
643 | else | 643 | else |
644 | ::perror ( "write to /proc/sys/ts/suspend_button_mode" ); | 644 | ::perror ( "write to /proc/sys/ts/suspend_button_mode" ); |
645 | 645 | ||
646 | ::close ( fd ); | 646 | ::close ( fd ); |
647 | } | 647 | } |
648 | else | 648 | else |
649 | ::perror ( "/proc/sys/ts/suspend_button_mode" ); | 649 | ::perror ( "/proc/sys/ts/suspend_button_mode" ); |
650 | 650 | ||
651 | return res; | 651 | return res; |
652 | } | 652 | } |
653 | 653 | ||
654 | 654 | ||
655 | bool iPAQ::setDisplayBrightness ( int bright ) | 655 | bool iPAQ::setDisplayBrightness ( int bright ) |
656 | { | 656 | { |
657 | bool res = false; | 657 | bool res = false; |
658 | int fd; | 658 | int fd; |
659 | 659 | ||
660 | int maxbright = displayBrightnessResolution ( ); | 660 | if ( bright > 255 ) |
661 | 661 | bright = 255; | |
662 | if ( bright > maxbright ) | ||
663 | bright = maxbright; | ||
664 | if ( bright < 0 ) | 662 | if ( bright < 0 ) |
665 | bright = 0; | 663 | bright = 0; |
666 | 664 | ||
667 | if (( fd = ::open ( "/dev/touchscreen/0", O_WRONLY )) >= 0 ) { | 665 | if (( fd = ::open ( "/dev/touchscreen/0", O_WRONLY )) >= 0 ) { |
668 | FLITE_IN bl; | 666 | FLITE_IN bl; |
669 | bl. mode = 1; | 667 | bl. mode = 1; |
670 | bl. pwr = bright ? 1 : 0; | 668 | bl. pwr = bright ? 1 : 0; |
671 | bl. brightness = bright; | 669 | bl. brightness = ( bright * ( displayBrightnessResolution ( ) - 1 ) + 127 ) / 255; |
672 | res = ( ::ioctl ( fd, FLITE_ON, &bl ) == 0 ); | 670 | res = ( ::ioctl ( fd, FLITE_ON, &bl ) == 0 ); |
673 | ::close ( fd ); | 671 | ::close ( fd ); |
674 | } | 672 | } |
675 | return res; | 673 | return res; |
676 | } | 674 | } |
677 | 675 | ||
678 | int iPAQ::displayBrightnessResolution ( ) const | 676 | int iPAQ::displayBrightnessResolution ( ) const |
679 | { | 677 | { |
680 | switch ( model ( )) { | 678 | switch ( model ( )) { |
681 | case Model_iPAQ_H31xx: | 679 | case Model_iPAQ_H31xx: |
682 | case Model_iPAQ_H36xx: | 680 | case Model_iPAQ_H36xx: |
683 | case Model_iPAQ_H37xx: | 681 | case Model_iPAQ_H37xx: |
684 | return 128; // really 256, but >128 could damage the LCD | 682 | return 128; // really 256, but >128 could damage the LCD |
685 | 683 | ||
686 | case Model_iPAQ_H38xx: | 684 | case Model_iPAQ_H38xx: |
687 | case Model_iPAQ_H39xx: | 685 | case Model_iPAQ_H39xx: |
688 | return 64; | 686 | return 64; |
689 | 687 | ||
690 | default: | 688 | default: |
691 | return 2; | 689 | return 2; |
692 | } | 690 | } |
693 | } | 691 | } |
694 | 692 | ||
695 | 693 | ||
696 | bool iPAQ::hasLightSensor ( ) const | 694 | bool iPAQ::hasLightSensor ( ) const |
697 | { | 695 | { |
698 | return true; | 696 | return true; |
699 | } | 697 | } |
700 | 698 | ||
701 | int iPAQ::readLightSensor ( ) | 699 | int iPAQ::readLightSensor ( ) |
702 | { | 700 | { |
703 | int fd; | 701 | int fd; |
704 | int val = -1; | 702 | int val = -1; |
705 | 703 | ||
706 | if (( fd = ::open ( "/proc/hal/light_sensor", O_RDONLY )) >= 0 ) { | 704 | if (( fd = ::open ( "/proc/hal/light_sensor", O_RDONLY )) >= 0 ) { |
707 | char buffer [8]; | 705 | char buffer [8]; |
708 | 706 | ||
709 | if ( ::read ( fd, buffer, 5 ) == 5 ) { | 707 | if ( ::read ( fd, buffer, 5 ) == 5 ) { |
710 | char *endptr; | 708 | char *endptr; |
711 | 709 | ||
712 | buffer [4] = 0; | 710 | buffer [4] = 0; |
713 | val = ::strtol ( buffer + 2, &endptr, 16 ); | 711 | val = ::strtol ( buffer + 2, &endptr, 16 ); |
714 | 712 | ||
715 | if ( *endptr != 0 ) | 713 | if ( *endptr != 0 ) |
716 | val = -1; | 714 | val = -1; |
717 | } | 715 | } |
718 | ::close ( fd ); | 716 | ::close ( fd ); |
719 | } | 717 | } |
720 | 718 | ||
721 | return val; | 719 | return val; |
722 | } | 720 | } |
723 | 721 | ||
724 | int iPAQ::lightSensorResolution ( ) const | 722 | int iPAQ::lightSensorResolution ( ) const |
725 | { | 723 | { |
726 | return 256; | 724 | return 256; |
727 | } | 725 | } |
728 | 726 | ||
729 | /************************************************** | 727 | /************************************************** |
730 | * | 728 | * |
731 | * Zaurus | 729 | * Zaurus |
732 | * | 730 | * |
733 | **************************************************/ | 731 | **************************************************/ |
734 | 732 | ||
735 | 733 | ||
736 | 734 | ||
737 | void Zaurus::init ( ) | 735 | void Zaurus::init ( ) |
738 | { | 736 | { |
739 | d-> m_modelstr = "Zaurus SL5000"; | 737 | d-> m_modelstr = "Zaurus SL5000"; |
740 | d-> m_model = Model_Zaurus_SL5000; | 738 | d-> m_model = Model_Zaurus_SL5000; |
741 | d-> m_vendorstr = "Sharp"; | 739 | d-> m_vendorstr = "Sharp"; |
742 | d-> m_vendor = Vendor_Sharp; | 740 | d-> m_vendor = Vendor_Sharp; |
743 | 741 | ||
744 | QFile f ( "/proc/filesystems" ); | 742 | QFile f ( "/proc/filesystems" ); |
745 | 743 | ||
746 | if ( f. open ( IO_ReadOnly ) && ( QTextStream ( &f ). read ( ). find ( "\tjffs2\n" ) >= 0 )) { | 744 | if ( f. open ( IO_ReadOnly ) && ( QTextStream ( &f ). read ( ). find ( "\tjffs2\n" ) >= 0 )) { |
747 | d-> m_systemstr = "OpenZaurus"; | 745 | d-> m_systemstr = "OpenZaurus"; |
748 | d-> m_system = System_OpenZaurus; | 746 | d-> m_system = System_OpenZaurus; |
749 | 747 | ||
750 | f. close ( ); | 748 | f. close ( ); |
751 | 749 | ||
752 | f. setName ( "/etc/oz_version" ); | 750 | f. setName ( "/etc/oz_version" ); |
753 | if ( f. open ( IO_ReadOnly )) { | 751 | if ( f. open ( IO_ReadOnly )) { |
754 | QTextStream ts ( &f ); | 752 | QTextStream ts ( &f ); |
755 | d-> m_sysverstr = ts. readLine ( ). mid ( 10 ); | 753 | d-> m_sysverstr = ts. readLine ( ). mid ( 10 ); |
756 | f. close ( ); | 754 | f. close ( ); |
757 | } | 755 | } |
758 | } | 756 | } |
759 | else { | 757 | else { |
760 | d-> m_systemstr = "Zaurus"; | 758 | d-> m_systemstr = "Zaurus"; |
761 | d-> m_system = System_Zaurus; | 759 | d-> m_system = System_Zaurus; |
762 | } | 760 | } |
763 | 761 | ||
764 | 762 | ||
765 | m_leds [0] = Led_Off; | 763 | m_leds [0] = Led_Off; |
766 | } | 764 | } |
767 | 765 | ||
768 | #include <unistd.h> | 766 | #include <unistd.h> |
769 | #include <fcntl.h> | 767 | #include <fcntl.h> |
770 | #include <sys/ioctl.h> | 768 | #include <sys/ioctl.h> |
771 | 769 | ||
772 | //#include <asm/sharp_char.h> // including kernel headers is evil ... | 770 | //#include <asm/sharp_char.h> // including kernel headers is evil ... |
773 | 771 | ||
774 | #define SHARP_DEV_IOCTL_COMMAND_START 0x5680 | 772 | #define SHARP_DEV_IOCTL_COMMAND_START 0x5680 |
775 | 773 | ||
776 | #defineSHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) | 774 | #defineSHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) |
777 | #define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START) | 775 | #define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START) |
778 | 776 | ||
779 | #define SHARP_BUZ_TOUCHSOUND 1 /* touch panel sound */ | 777 | #define SHARP_BUZ_TOUCHSOUND 1 /* touch panel sound */ |
780 | #define SHARP_BUZ_KEYSOUND 2 /* key sound */ | 778 | #define SHARP_BUZ_KEYSOUND 2 /* key sound */ |
781 | #define SHARP_BUZ_SCHEDULE_ALARM 11 /* schedule alarm */ | 779 | #define SHARP_BUZ_SCHEDULE_ALARM 11 /* schedule alarm */ |
782 | 780 | ||
783 | /* --- for SHARP_BUZZER device --- */ | 781 | /* --- for SHARP_BUZZER device --- */ |
784 | 782 | ||
785 | //#defineSHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) | 783 | //#defineSHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) |
786 | //#define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START) | 784 | //#define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START) |
787 | 785 | ||
788 | #define SHARP_BUZZER_SETVOLUME (SHARP_BUZZER_IOCTL_START+1) | 786 | #define SHARP_BUZZER_SETVOLUME (SHARP_BUZZER_IOCTL_START+1) |
789 | #define SHARP_BUZZER_GETVOLUME (SHARP_BUZZER_IOCTL_START+2) | 787 | #define SHARP_BUZZER_GETVOLUME (SHARP_BUZZER_IOCTL_START+2) |
790 | #define SHARP_BUZZER_ISSUPPORTED (SHARP_BUZZER_IOCTL_START+3) | 788 | #define SHARP_BUZZER_ISSUPPORTED (SHARP_BUZZER_IOCTL_START+3) |
791 | #define SHARP_BUZZER_SETMUTE (SHARP_BUZZER_IOCTL_START+4) | 789 | #define SHARP_BUZZER_SETMUTE (SHARP_BUZZER_IOCTL_START+4) |
792 | #define SHARP_BUZZER_STOPSOUND (SHARP_BUZZER_IOCTL_START+5) | 790 | #define SHARP_BUZZER_STOPSOUND (SHARP_BUZZER_IOCTL_START+5) |
793 | 791 | ||
794 | //#define SHARP_BUZ_TOUCHSOUND 1 /* touch panel sound */ | 792 | //#define SHARP_BUZ_TOUCHSOUND 1 /* touch panel sound */ |
795 | //#define SHARP_BUZ_KEYSOUND 2 /* key sound */ | 793 | //#define SHARP_BUZ_KEYSOUND 2 /* key sound */ |
796 | 794 | ||
797 | //#define SHARP_PDA_ILLCLICKSOUND 3 /* illegal click */ | 795 | //#define SHARP_PDA_ILLCLICKSOUND 3 /* illegal click */ |
798 | //#define SHARP_PDA_WARNSOUND 4 /* warning occurred */ | 796 | //#define SHARP_PDA_WARNSOUND 4 /* warning occurred */ |
799 | //#define SHARP_PDA_ERRORSOUND 5 /* error occurred */ | 797 | //#define SHARP_PDA_ERRORSOUND 5 /* error occurred */ |
800 | //#define SHARP_PDA_CRITICALSOUND 6 /* critical error occurred */ | 798 | //#define SHARP_PDA_CRITICALSOUND 6 /* critical error occurred */ |
801 | //#define SHARP_PDA_SYSSTARTSOUND 7 /* system start */ | 799 | //#define SHARP_PDA_SYSSTARTSOUND 7 /* system start */ |
802 | //#define SHARP_PDA_SYSTEMENDSOUND 8 /* system shutdown */ | 800 | //#define SHARP_PDA_SYSTEMENDSOUND 8 /* system shutdown */ |
803 | //#define SHARP_PDA_APPSTART 9 /* application start */ | 801 | //#define SHARP_PDA_APPSTART 9 /* application start */ |
804 | //#define SHARP_PDA_APPQUIT 10 /* application ends */ | 802 | //#define SHARP_PDA_APPQUIT 10 /* application ends */ |
805 | 803 | ||
806 | //#define SHARP_BUZ_SCHEDULE_ALARM 11 /* schedule alarm */ | 804 | //#define SHARP_BUZ_SCHEDULE_ALARM 11 /* schedule alarm */ |
807 | //#define SHARP_BUZ_DAILY_ALARM 12 /* daily alarm */ | 805 | //#define SHARP_BUZ_DAILY_ALARM 12 /* daily alarm */ |
808 | //#define SHARP_BUZ_GOT_PHONE_CALL 13 /* phone call sound */ | 806 | //#define SHARP_BUZ_GOT_PHONE_CALL 13 /* phone call sound */ |
809 | //#define SHARP_BUZ_GOT_MAIL 14 /* mail sound */ | 807 | //#define SHARP_BUZ_GOT_MAIL 14 /* mail sound */ |
810 | // | 808 | // |
811 | 809 | ||
812 | #defineSHARP_LED_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) | 810 | #defineSHARP_LED_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START) |
813 | #define SHARP_LED_SETSTATUS (SHARP_LED_IOCTL_START+1) | 811 | #define SHARP_LED_SETSTATUS (SHARP_LED_IOCTL_START+1) |
814 | 812 | ||
815 | typedef struct sharp_led_status { | 813 | typedef struct sharp_led_status { |
816 | int which; /* select which LED status is wanted. */ | 814 | int which; /* select which LED status is wanted. */ |
817 | int status; /* set new led status if you call SHARP_LED_SETSTATUS */ | 815 | int status; /* set new led status if you call SHARP_LED_SETSTATUS */ |
818 | } sharp_led_status; | 816 | } sharp_led_status; |
819 | 817 | ||
820 | #define SHARP_LED_MAIL_EXISTS 9 /* mail status (exists or not) */ | 818 | #define SHARP_LED_MAIL_EXISTS 9 /* mail status (exists or not) */ |
821 | 819 | ||
822 | #define LED_MAIL_NO_UNREAD_MAIL 0 /* for SHARP_LED_MAIL_EXISTS */ | 820 | #define LED_MAIL_NO_UNREAD_MAIL 0 /* for SHARP_LED_MAIL_EXISTS */ |
823 | #define LED_MAIL_NEWMAIL_EXISTS 1 /* for SHARP_LED_MAIL_EXISTS */ | 821 | #define LED_MAIL_NEWMAIL_EXISTS 1 /* for SHARP_LED_MAIL_EXISTS */ |
824 | #define LED_MAIL_UNREAD_MAIL_EX 2 /* for SHARP_LED_MAIL_EXISTS */ | 822 | #define LED_MAIL_UNREAD_MAIL_EX 2 /* for SHARP_LED_MAIL_EXISTS */ |
825 | 823 | ||
826 | // #include <asm/sharp_apm.h> // including kernel headers is evil ... | 824 | // #include <asm/sharp_apm.h> // including kernel headers is evil ... |
827 | 825 | ||
828 | #define APM_IOCGEVTSRC OD_IOR( 'A', 203, int ) | 826 | #define APM_IOCGEVTSRC OD_IOR( 'A', 203, int ) |
829 | #define APM_IOCSEVTSRC OD_IORW( 'A', 204, int ) | 827 | #define APM_IOCSEVTSRC OD_IORW( 'A', 204, int ) |
830 | #define APM_EVT_POWER_BUTTON (1 << 0) | 828 | #define APM_EVT_POWER_BUTTON (1 << 0) |
831 | 829 | ||
832 | #define FL_IOCTL_STEP_CONTRAST 100 | 830 | #define FL_IOCTL_STEP_CONTRAST 100 |
833 | 831 | ||
834 | 832 | ||
835 | void Zaurus::buzzer ( int sound ) | 833 | void Zaurus::buzzer ( int sound ) |
836 | { | 834 | { |
837 | static int fd = ::open ( "/dev/sharp_buz", O_RDWR|O_NONBLOCK ); | 835 | static int fd = ::open ( "/dev/sharp_buz", O_RDWR|O_NONBLOCK ); |
838 | 836 | ||
839 | if ( fd >= 0 ) | 837 | if ( fd >= 0 ) |
840 | ::ioctl ( fd, SHARP_BUZZER_MAKESOUND, sound ); | 838 | ::ioctl ( fd, SHARP_BUZZER_MAKESOUND, sound ); |
841 | } | 839 | } |
842 | 840 | ||
843 | 841 | ||
844 | void Zaurus::alarmSound ( ) | 842 | void Zaurus::alarmSound ( ) |
845 | { | 843 | { |
846 | buzzer ( SHARP_BUZ_SCHEDULE_ALARM ); | 844 | buzzer ( SHARP_BUZ_SCHEDULE_ALARM ); |
847 | } | 845 | } |
848 | 846 | ||
849 | void Zaurus::touchSound ( ) | 847 | void Zaurus::touchSound ( ) |
850 | { | 848 | { |
851 | buzzer ( SHARP_BUZ_TOUCHSOUND ); | 849 | buzzer ( SHARP_BUZ_TOUCHSOUND ); |
852 | } | 850 | } |
853 | 851 | ||
854 | void Zaurus::keySound ( ) | 852 | void Zaurus::keySound ( ) |
855 | { | 853 | { |
856 | buzzer ( SHARP_BUZ_KEYSOUND ); | 854 | buzzer ( SHARP_BUZ_KEYSOUND ); |
857 | } | 855 | } |
858 | 856 | ||
859 | 857 | ||
860 | QValueList <OLed> Zaurus::ledList ( ) const | 858 | QValueList <OLed> Zaurus::ledList ( ) const |
861 | { | 859 | { |
862 | QValueList <OLed> vl; | 860 | QValueList <OLed> vl; |
863 | vl << Led_Mail; | 861 | vl << Led_Mail; |