-rw-r--r-- | libopie/odevice.cpp | 90 |
1 files changed, 78 insertions, 12 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp index e24e043..bc09e92 100644 --- a/libopie/odevice.cpp +++ b/libopie/odevice.cpp | |||
@@ -119,48 +119,51 @@ public: | |||
119 | static bool isJornada(); | 119 | static bool isJornada(); |
120 | 120 | ||
121 | }; | 121 | }; |
122 | 122 | ||
123 | class Zaurus : public ODevice { | 123 | class Zaurus : public ODevice { |
124 | protected: | 124 | protected: |
125 | virtual void init ( ); | 125 | virtual void init ( ); |
126 | virtual void initButtons ( ); | 126 | virtual void initButtons ( ); |
127 | 127 | ||
128 | public: | 128 | public: |
129 | virtual bool setSoftSuspend ( bool soft ); | 129 | virtual bool setSoftSuspend ( bool soft ); |
130 | 130 | ||
131 | virtual bool setDisplayBrightness ( int b ); | 131 | virtual bool setDisplayBrightness ( int b ); |
132 | virtual int displayBrightnessResolution ( ) const; | 132 | virtual int displayBrightnessResolution ( ) const; |
133 | 133 | ||
134 | virtual void alarmSound ( ); | 134 | virtual void alarmSound ( ); |
135 | virtual void keySound ( ); | 135 | virtual void keySound ( ); |
136 | virtual void touchSound ( ); | 136 | virtual void touchSound ( ); |
137 | 137 | ||
138 | virtual QValueList <OLed> ledList ( ) const; | 138 | virtual QValueList <OLed> ledList ( ) const; |
139 | virtual QValueList <OLedState> ledStateList ( OLed led ) const; | 139 | virtual QValueList <OLedState> ledStateList ( OLed led ) const; |
140 | virtual OLedState ledState ( OLed led ) const; | 140 | virtual OLedState ledState ( OLed led ) const; |
141 | virtual bool setLedState ( OLed led, OLedState st ); | 141 | virtual bool setLedState ( OLed led, OLedState st ); |
142 | 142 | ||
143 | virtual bool hasHingeSensor() const; | ||
144 | virtual OHingeStatus readHingeSensor(); | ||
145 | |||
143 | static bool isZaurus(); | 146 | static bool isZaurus(); |
144 | 147 | ||
145 | // Does this break BC? | 148 | // Does this break BC? |
146 | virtual bool suspend ( ); | 149 | virtual bool suspend ( ); |
147 | virtual Transformation rotation ( ) const; | 150 | virtual Transformation rotation ( ) const; |
148 | virtual ODirection direction ( ) const; | 151 | virtual ODirection direction ( ) const; |
149 | 152 | ||
150 | protected: | 153 | protected: |
151 | virtual void buzzer ( int snd ); | 154 | virtual void buzzer ( int snd ); |
152 | 155 | ||
153 | OLedState m_leds [1]; | 156 | OLedState m_leds [1]; |
154 | bool m_embedix; | 157 | bool m_embedix; |
155 | }; | 158 | }; |
156 | 159 | ||
157 | class SIMpad : public ODevice, public QWSServer::KeyboardFilter { | 160 | class SIMpad : public ODevice, public QWSServer::KeyboardFilter { |
158 | protected: | 161 | protected: |
159 | virtual void init ( ); | 162 | virtual void init ( ); |
160 | virtual void initButtons ( ); | 163 | virtual void initButtons ( ); |
161 | 164 | ||
162 | public: | 165 | public: |
163 | virtual bool setSoftSuspend ( bool soft ); | 166 | virtual bool setSoftSuspend ( bool soft ); |
164 | virtual bool suspend(); | 167 | virtual bool suspend(); |
165 | 168 | ||
166 | virtual bool setDisplayStatus( bool on ); | 169 | virtual bool setDisplayStatus( bool on ); |
@@ -802,64 +805,80 @@ OLedState ODevice::ledState ( OLed /*which*/ ) const | |||
802 | } | 805 | } |
803 | 806 | ||
804 | /** | 807 | /** |
805 | * Set the state for a LED | 808 | * Set the state for a LED |
806 | * @param which Which OLed to use | 809 | * @param which Which OLed to use |
807 | * @param st The state to set | 810 | * @param st The state to set |
808 | * @return success or failure | 811 | * @return success or failure |
809 | */ | 812 | */ |
810 | bool ODevice::setLedState ( OLed which, OLedState st ) | 813 | bool ODevice::setLedState ( OLed which, OLedState st ) |
811 | { | 814 | { |
812 | Q_UNUSED( which ) | 815 | Q_UNUSED( which ) |
813 | Q_UNUSED( st ) | 816 | Q_UNUSED( st ) |
814 | return false; | 817 | return false; |
815 | } | 818 | } |
816 | 819 | ||
817 | /** | 820 | /** |
818 | * @return if the device has a light sensor | 821 | * @return if the device has a light sensor |
819 | */ | 822 | */ |
820 | bool ODevice::hasLightSensor ( ) const | 823 | bool ODevice::hasLightSensor ( ) const |
821 | { | 824 | { |
822 | return false; | 825 | return false; |
823 | } | 826 | } |
824 | 827 | ||
825 | /** | 828 | /** |
826 | * @return a value from the light senso | 829 | * @return a value from the light sensor |
827 | */ | 830 | */ |
828 | int ODevice::readLightSensor ( ) | 831 | int ODevice::readLightSensor ( ) |
829 | { | 832 | { |
830 | return -1; | 833 | return -1; |
831 | } | 834 | } |
832 | 835 | ||
833 | /** | 836 | /** |
834 | * @return the light sensor resolution whatever that is ;) | 837 | * @return the light sensor resolution |
835 | */ | 838 | */ |
836 | int ODevice::lightSensorResolution ( ) const | 839 | int ODevice::lightSensorResolution ( ) const |
837 | { | 840 | { |
838 | return 0; | 841 | return 0; |
839 | } | 842 | } |
840 | 843 | ||
841 | /** | 844 | /** |
845 | * @return if the device has a hinge sensor | ||
846 | */ | ||
847 | bool ODevice::hasHingeSensor ( ) const | ||
848 | { | ||
849 | return false; | ||
850 | } | ||
851 | |||
852 | /** | ||
853 | * @return a value from the hinge sensor | ||
854 | */ | ||
855 | OHingeStatus ODevice::readHingeSensor ( ) | ||
856 | { | ||
857 | return CASE_UNKNOWN; | ||
858 | } | ||
859 | |||
860 | /** | ||
842 | * @return a list with CPU frequencies supported by the hardware | 861 | * @return a list with CPU frequencies supported by the hardware |
843 | */ | 862 | */ |
844 | const QStrList &ODevice::allowedCpuFrequencies ( ) const | 863 | const QStrList &ODevice::allowedCpuFrequencies ( ) const |
845 | { | 864 | { |
846 | return *d->m_cpu_frequencies; | 865 | return *d->m_cpu_frequencies; |
847 | } | 866 | } |
848 | 867 | ||
849 | 868 | ||
850 | /** | 869 | /** |
851 | * Set desired CPU frequency | 870 | * Set desired CPU frequency |
852 | * | 871 | * |
853 | * @param index index into d->m_cpu_frequencies of the frequency to be set | 872 | * @param index index into d->m_cpu_frequencies of the frequency to be set |
854 | */ | 873 | */ |
855 | bool ODevice::setCurrentCpuFrequency(uint index) | 874 | bool ODevice::setCurrentCpuFrequency(uint index) |
856 | { | 875 | { |
857 | if (index >= d->m_cpu_frequencies->count()) | 876 | if (index >= d->m_cpu_frequencies->count()) |
858 | return false; | 877 | return false; |
859 | 878 | ||
860 | char *freq = d->m_cpu_frequencies->at(index); | 879 | char *freq = d->m_cpu_frequencies->at(index); |
861 | qWarning("set freq to %s", freq); | 880 | qWarning("set freq to %s", freq); |
862 | 881 | ||
863 | int fd; | 882 | int fd; |
864 | 883 | ||
865 | if ((fd = ::open("/proc/sys/cpu/0/speed", O_WRONLY)) >= 0) { | 884 | if ((fd = ::open("/proc/sys/cpu/0/speed", O_WRONLY)) >= 0) { |
@@ -1924,68 +1943,84 @@ bool Zaurus::setSoftSuspend ( bool soft ) | |||
1924 | if ( soft ) | 1943 | if ( soft ) |
1925 | sources &= ~APM_EVT_POWER_BUTTON; | 1944 | sources &= ~APM_EVT_POWER_BUTTON; |
1926 | else | 1945 | else |
1927 | sources |= APM_EVT_POWER_BUTTON; | 1946 | sources |= APM_EVT_POWER_BUTTON; |
1928 | 1947 | ||
1929 | if ( ::ioctl ( fd, APM_IOCSEVTSRC, sources ) >= 0 ) // set new event sources | 1948 | if ( ::ioctl ( fd, APM_IOCSEVTSRC, sources ) >= 0 ) // set new event sources |
1930 | res = true; | 1949 | res = true; |
1931 | else | 1950 | else |
1932 | perror ( "APM_IOCGEVTSRC" ); | 1951 | perror ( "APM_IOCGEVTSRC" ); |
1933 | } | 1952 | } |
1934 | else | 1953 | else |
1935 | perror ( "APM_IOCGEVTSRC" ); | 1954 | perror ( "APM_IOCGEVTSRC" ); |
1936 | 1955 | ||
1937 | ::close ( fd ); | 1956 | ::close ( fd ); |
1938 | } | 1957 | } |
1939 | else | 1958 | else |
1940 | perror ( "/dev/apm_bios or /dev/misc/apm_bios" ); | 1959 | perror ( "/dev/apm_bios or /dev/misc/apm_bios" ); |
1941 | 1960 | ||
1942 | return res; | 1961 | return res; |
1943 | } | 1962 | } |
1944 | 1963 | ||
1945 | 1964 | ||
1946 | bool Zaurus::setDisplayBrightness ( int bright ) | 1965 | bool Zaurus::setDisplayBrightness ( int bright ) |
1947 | { | 1966 | { |
1948 | // FIXME The C7x0 have a proc-interface (/proc/drivers/corgi-bl) which | ||
1949 | // is nice to use. Currently it exposes 16+1 levels. Implement this! | ||
1950 | // (or wait for kergoth unifying the interfaces in the OpenZaurus kernel.) | ||
1951 | bool res = false; | 1967 | bool res = false; |
1952 | int fd; | 1968 | int fd; |
1953 | 1969 | ||
1954 | if ( bright > 255 ) | 1970 | if ( bright > 255 ) bright = 255; |
1955 | bright = 255; | 1971 | if ( bright < 0 ) bright = 0; |
1956 | if ( bright < 0 ) | ||
1957 | bright = 0; | ||
1958 | 1972 | ||
1959 | if (m_embedix) { | 1973 | if ( m_embedix ) |
1974 | { | ||
1975 | if ( d->m_model == Model_Zaurus_SLC7x0 ) | ||
1976 | { | ||
1977 | // special treatment for devices with the corgi backlight interface | ||
1978 | if (( fd = ::open ( "/proc/driver/fl/corgi-bl", O_WRONLY )) >= 0 ) | ||
1979 | { | ||
1980 | if ( bright > 0x11 ) bright = 0x11; | ||
1981 | char writeCommand[100]; | ||
1982 | const int count = sprintf( writeCommand, "0x%x\n", bright ); | ||
1983 | res = ( ::write ( fd, writeCommand, count ) != -1 ); | ||
1984 | ::close ( fd ); | ||
1985 | } | ||
1986 | return res; | ||
1987 | } | ||
1988 | else | ||
1989 | { | ||
1990 | // standard treatment for devices with the dumb embedix frontlight interface | ||
1960 | if (( fd = ::open ( "/dev/fl", O_WRONLY )) >= 0 ) { | 1991 | if (( fd = ::open ( "/dev/fl", O_WRONLY )) >= 0 ) { |
1961 | int bl = ( bright * 4 + 127 ) / 255; // only 4 steps on zaurus | 1992 | int bl = ( bright * 4 + 127 ) / 255; // only 4 steps on zaurus |
1962 | if ( bright && !bl ) | 1993 | if ( bright && !bl ) |
1963 | bl = 1; | 1994 | bl = 1; |
1964 | res = ( ::ioctl ( fd, FL_IOCTL_STEP_CONTRAST, bl ) == 0 ); | 1995 | res = ( ::ioctl ( fd, FL_IOCTL_STEP_CONTRAST, bl ) == 0 ); |
1965 | ::close ( fd ); | 1996 | ::close ( fd ); |
1966 | } | 1997 | } |
1967 | } else { | 1998 | } |
1999 | } | ||
2000 | else | ||
2001 | { | ||
2002 | // special treatment for the OpenZaurus unified interface | ||
1968 | #define FB_BACKLIGHT_SET_BRIGHTNESS _IOW('F', 1, u_int) /* set brightness */ | 2003 | #define FB_BACKLIGHT_SET_BRIGHTNESS _IOW('F', 1, u_int) /* set brightness */ |
1969 | if (( fd = ::open ( "/dev/fb0", O_WRONLY )) >= 0 ) { | 2004 | if (( fd = ::open ( "/dev/fb0", O_WRONLY )) >= 0 ) { |
1970 | res = ( ::ioctl ( fd , FB_BACKLIGHT_SET_BRIGHTNESS, bright ) == 0 ); | 2005 | res = ( ::ioctl ( fd , FB_BACKLIGHT_SET_BRIGHTNESS, bright ) == 0 ); |
1971 | ::close ( fd ); | 2006 | ::close ( fd ); |
1972 | } | 2007 | } |
1973 | } | 2008 | } |
1974 | return res; | 2009 | return res; |
1975 | } | 2010 | } |
1976 | 2011 | ||
1977 | bool Zaurus::suspend ( ) | 2012 | bool Zaurus::suspend ( ) |
1978 | { | 2013 | { |
1979 | qDebug("ODevice::suspend"); | 2014 | qDebug("ODevice::suspend"); |
1980 | if ( !isQWS( ) ) // only qwsserver is allowed to suspend | 2015 | if ( !isQWS( ) ) // only qwsserver is allowed to suspend |
1981 | return false; | 2016 | return false; |
1982 | 2017 | ||
1983 | if ( d-> m_model == Model_Unknown ) // better don't suspend in qvfb / on unkown devices | 2018 | if ( d-> m_model == Model_Unknown ) // better don't suspend in qvfb / on unkown devices |
1984 | return false; | 2019 | return false; |
1985 | 2020 | ||
1986 | bool res = false; | 2021 | bool res = false; |
1987 | 2022 | ||
1988 | struct timeval tvs, tvn; | 2023 | struct timeval tvs, tvn; |
1989 | ::gettimeofday ( &tvs, 0 ); | 2024 | ::gettimeofday ( &tvs, 0 ); |
1990 | 2025 | ||
1991 | ::sync ( ); // flush fs caches | 2026 | ::sync ( ); // flush fs caches |
@@ -2052,53 +2087,84 @@ ODirection Zaurus::direction ( ) const | |||
2052 | } else { | 2087 | } else { |
2053 | retval = ::ioctl(handle, SHARP_IOCTL_GET_ROTATION); | 2088 | retval = ::ioctl(handle, SHARP_IOCTL_GET_ROTATION); |
2054 | ::close (handle); | 2089 | ::close (handle); |
2055 | if (retval == 2 ) | 2090 | if (retval == 2 ) |
2056 | dir = CCW; | 2091 | dir = CCW; |
2057 | else | 2092 | else |
2058 | dir = CW; | 2093 | dir = CW; |
2059 | } | 2094 | } |
2060 | break; | 2095 | break; |
2061 | case Model_Zaurus_SLA300: | 2096 | case Model_Zaurus_SLA300: |
2062 | case Model_Zaurus_SLB600: | 2097 | case Model_Zaurus_SLB600: |
2063 | case Model_Zaurus_SL5500: | 2098 | case Model_Zaurus_SL5500: |
2064 | case Model_Zaurus_SL5000: | 2099 | case Model_Zaurus_SL5000: |
2065 | default: | 2100 | default: |
2066 | dir = d-> m_direction; | 2101 | dir = d-> m_direction; |
2067 | break; | 2102 | break; |
2068 | } | 2103 | } |
2069 | return dir; | 2104 | return dir; |
2070 | 2105 | ||
2071 | } | 2106 | } |
2072 | 2107 | ||
2073 | int Zaurus::displayBrightnessResolution ( ) const | 2108 | int Zaurus::displayBrightnessResolution ( ) const |
2074 | { | 2109 | { |
2075 | if (m_embedix) | 2110 | if (m_embedix) |
2076 | return 5; | 2111 | return d->m_model == Model_Zaurus_SLC7x0 ? 18 : 5; |
2077 | else | 2112 | else |
2078 | return 256; | 2113 | return 256; |
2079 | } | 2114 | } |
2080 | 2115 | ||
2116 | bool Zaurus::hasHingeSensor() const | ||
2117 | { | ||
2118 | return d->m_model == Model_Zaurus_SLC7x0; | ||
2119 | } | ||
2120 | |||
2121 | OHingeStatus Zaurus::readHingeSensor() | ||
2122 | { | ||
2123 | int handle = ::open("/dev/apm_bios", O_RDWR|O_NONBLOCK); | ||
2124 | if (handle == -1) | ||
2125 | { | ||
2126 | qWarning("Zaurus::readHingeSensor() - failed (%s)", "unknown reason" ); //FIXME: use strerror | ||
2127 | return CASE_UNKNOWN; | ||
2128 | } | ||
2129 | else | ||
2130 | { | ||
2131 | int retval = ::ioctl(handle, SHARP_IOCTL_GET_ROTATION); | ||
2132 | ::close (handle); | ||
2133 | if ( retval == CASE_CLOSED || retval == CASE_PORTRAIT || retval == CASE_LANDSCAPE ) | ||
2134 | { | ||
2135 | qDebug( "Zaurus::readHingeSensor() - result = %d", retval ); | ||
2136 | return static_cast<OHingeStatus>( retval ); | ||
2137 | } | ||
2138 | else | ||
2139 | { | ||
2140 | qWarning("Zaurus::readHingeSensor() - couldn't compute hinge status!" ); | ||
2141 | return CASE_UNKNOWN; | ||
2142 | } | ||
2143 | } | ||
2144 | } | ||
2145 | |||
2146 | |||
2081 | /************************************************** | 2147 | /************************************************** |
2082 | * | 2148 | * |
2083 | * SIMpad | 2149 | * SIMpad |
2084 | * | 2150 | * |
2085 | **************************************************/ | 2151 | **************************************************/ |
2086 | 2152 | ||
2087 | void SIMpad::init ( ) | 2153 | void SIMpad::init ( ) |
2088 | { | 2154 | { |
2089 | d-> m_vendorstr = "SIEMENS"; | 2155 | d-> m_vendorstr = "SIEMENS"; |
2090 | d-> m_vendor = Vendor_SIEMENS; | 2156 | d-> m_vendor = Vendor_SIEMENS; |
2091 | 2157 | ||
2092 | QFile f ( "/proc/hal/model" ); | 2158 | QFile f ( "/proc/hal/model" ); |
2093 | 2159 | ||
2094 | //TODO Implement model checking | 2160 | //TODO Implement model checking |
2095 | //FIXME For now we assume an SL4 | 2161 | //FIXME For now we assume an SL4 |
2096 | 2162 | ||
2097 | d-> m_modelstr = "SL4"; | 2163 | d-> m_modelstr = "SL4"; |
2098 | d-> m_model = Model_SIMpad_SL4; | 2164 | d-> m_model = Model_SIMpad_SL4; |
2099 | 2165 | ||
2100 | switch ( d-> m_model ) { | 2166 | switch ( d-> m_model ) { |
2101 | default: | 2167 | default: |
2102 | d-> m_rotation = Rot0; | 2168 | d-> m_rotation = Rot0; |
2103 | d-> m_direction = CCW; | 2169 | d-> m_direction = CCW; |
2104 | d-> m_holdtime = 1000; // 1000ms | 2170 | d-> m_holdtime = 1000; // 1000ms |