-rw-r--r-- | libopie2/opiecore/device/odevice_beagle.h | 1 | ||||
-rw-r--r-- | libopie2/opiecore/device/odevice_simpad.cpp | 3 |
2 files changed, 0 insertions, 4 deletions
diff --git a/libopie2/opiecore/device/odevice_beagle.h b/libopie2/opiecore/device/odevice_beagle.h index 1626330..17b040c 100644 --- a/libopie2/opiecore/device/odevice_beagle.h +++ b/libopie2/opiecore/device/odevice_beagle.h | |||
@@ -1,62 +1,61 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the Opie Project | 2 | This file is part of the Opie Project |
3 | Copyright (C) 2004 The Opie Team <opie-devel@handhelds.org> | 3 | Copyright (C) 2004 The Opie Team <opie-devel@handhelds.org> |
4 | =. | 4 | =. |
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. |
13 | .%`+i> _;_. | 13 | .%`+i> _;_. |
14 | .i_,=:_. -<s. This program is distributed in the hope that | 14 | .i_,=:_. -<s. This program is distributed in the hope that |
15 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 15 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
16 | : .. .:, . . . without even the implied warranty of | 16 | : .. .:, . . . without even the implied warranty of |
17 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 17 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
18 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU | 18 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU |
19 | ..}^=.= = ; Library General Public License for more | 19 | ..}^=.= = ; Library General Public License for more |
20 | ++= -. .` .: details. | 20 | ++= -. .` .: details. |
21 | : = ...= . :.=- | 21 | : = ...= . :.=- |
22 | -. .:....=;==+<; You should have received a copy of the GNU | 22 | -. .:....=;==+<; You should have received a copy of the GNU |
23 | -_. . . )=. = Library General Public License along with | 23 | -_. . . )=. = Library General Public License along with |
24 | -- :-=` this library; see the file COPYING.LIB. | 24 | -- :-=` this library; see the file COPYING.LIB. |
25 | If not, write to the Free Software Foundation, | 25 | If not, write to the Free Software Foundation, |
26 | Inc., 59 Temple Place - Suite 330, | 26 | Inc., 59 Temple Place - Suite 330, |
27 | Boston, MA 02111-1307, USA. | 27 | Boston, MA 02111-1307, USA. |
28 | */ | 28 | */ |
29 | 29 | ||
30 | #ifndef OPIE_CORE_DEVICE_BEAGLE_H | 30 | #ifndef OPIE_CORE_DEVICE_BEAGLE_H |
31 | #define OPIE_CORE_DEVICE_BEAGLE_H | 31 | #define OPIE_CORE_DEVICE_BEAGLE_H |
32 | 32 | ||
33 | #include "odevice.h" | 33 | #include "odevice.h" |
34 | 34 | ||
35 | namespace Opie { | 35 | namespace Opie { |
36 | namespace Core { | 36 | namespace Core { |
37 | namespace Internal { | 37 | namespace Internal { |
38 | class Beagle : public ODevice { | 38 | class Beagle : public ODevice { |
39 | Q_OBJECT | ||
40 | public: | 39 | public: |
41 | Beagle(); | 40 | Beagle(); |
42 | ~Beagle(); | 41 | ~Beagle(); |
43 | 42 | ||
44 | //@{ | 43 | //@{ |
45 | void init( const QString& init ); | 44 | void init( const QString& init ); |
46 | void initButtons(); | 45 | void initButtons(); |
47 | //@} | 46 | //@} |
48 | 47 | ||
49 | 48 | ||
50 | //@{ | 49 | //@{ |
51 | bool setDisplayStatus( bool on ); | 50 | bool setDisplayStatus( bool on ); |
52 | int displayBrightnessResolution()const; | 51 | int displayBrightnessResolution()const; |
53 | bool setDisplayBrightness( int brightness ); | 52 | bool setDisplayBrightness( int brightness ); |
54 | //@} | 53 | //@} |
55 | 54 | ||
56 | }; | 55 | }; |
57 | } | 56 | } |
58 | } | 57 | } |
59 | } | 58 | } |
60 | 59 | ||
61 | 60 | ||
62 | #endif | 61 | #endif |
diff --git a/libopie2/opiecore/device/odevice_simpad.cpp b/libopie2/opiecore/device/odevice_simpad.cpp index 335e0db..4ae3c4f 100644 --- a/libopie2/opiecore/device/odevice_simpad.cpp +++ b/libopie2/opiecore/device/odevice_simpad.cpp | |||
@@ -102,131 +102,128 @@ struct s_button simpad_buttons [] = { | |||
102 | /* | 102 | /* |
103 | { Model_SIMpad_CL4 | Model_SIMpad_SL4 | Model_SIMpad_SLC | Model_SIMpad_TSinus, | 103 | { Model_SIMpad_CL4 | Model_SIMpad_SL4 | Model_SIMpad_SLC | Model_SIMpad_TSinus, |
104 | Qt::Key_F12, QT_TRANSLATE_NOOP("Button", "Lower+Upper"), | 104 | Qt::Key_F12, QT_TRANSLATE_NOOP("Button", "Lower+Upper"), |
105 | "devicebuttons/simpad_lower_upper", | 105 | "devicebuttons/simpad_lower_upper", |
106 | "QPE/Launcher", "home()", | 106 | "QPE/Launcher", "home()", |
107 | "buttonsettings", "raise()" }, | 107 | "buttonsettings", "raise()" }, |
108 | { Model_SIMpad_CL4 | Model_SIMpad_SL4 | Model_SIMpad_SLC | Model_SIMpad_TSinus, | 108 | { Model_SIMpad_CL4 | Model_SIMpad_SL4 | Model_SIMpad_SLC | Model_SIMpad_TSinus, |
109 | Qt::Key_F12, QT_TRANSLATE_NOOP("Button", "Lower+Upper"), | 109 | Qt::Key_F12, QT_TRANSLATE_NOOP("Button", "Lower+Upper"), |
110 | "devicebuttons/simpad_upper_lower", | 110 | "devicebuttons/simpad_upper_lower", |
111 | "QPE/Launcher", "home()", | 111 | "QPE/Launcher", "home()", |
112 | "buttonsettings", "raise()" }, | 112 | "buttonsettings", "raise()" }, |
113 | */ | 113 | */ |
114 | }; | 114 | }; |
115 | 115 | ||
116 | void SIMpad::init(const QString&) | 116 | void SIMpad::init(const QString&) |
117 | { | 117 | { |
118 | d->m_vendorstr = "SIEMENS"; | 118 | d->m_vendorstr = "SIEMENS"; |
119 | d->m_vendor = Vendor_SIEMENS; | 119 | d->m_vendor = Vendor_SIEMENS; |
120 | 120 | ||
121 | 121 | ||
122 | //TODO Implement model checking | 122 | //TODO Implement model checking |
123 | //FIXME For now we assume an SL4 | 123 | //FIXME For now we assume an SL4 |
124 | 124 | ||
125 | d->m_modelstr = "SL4"; | 125 | d->m_modelstr = "SL4"; |
126 | d->m_model = Model_SIMpad_SL4; | 126 | d->m_model = Model_SIMpad_SL4; |
127 | 127 | ||
128 | switch ( d->m_model ) { | 128 | switch ( d->m_model ) { |
129 | default: | 129 | default: |
130 | d->m_rotation = Rot0; | 130 | d->m_rotation = Rot0; |
131 | d->m_direction = CCW; | 131 | d->m_direction = CCW; |
132 | d->m_holdtime = 1000; // 1000ms | 132 | d->m_holdtime = 1000; // 1000ms |
133 | 133 | ||
134 | break; | 134 | break; |
135 | } | 135 | } |
136 | 136 | ||
137 | //Distribution detecting code is now in base class | 137 | //Distribution detecting code is now in base class |
138 | m_leds [0] = m_leds [1] = Led_Off; | 138 | m_leds [0] = m_leds [1] = Led_Off; |
139 | 139 | ||
140 | m_power_timer = 0; | 140 | m_power_timer = 0; |
141 | 141 | ||
142 | } | 142 | } |
143 | 143 | ||
144 | void SIMpad::initButtons() | 144 | void SIMpad::initButtons() |
145 | { | 145 | { |
146 | if ( d->m_buttons ) | 146 | if ( d->m_buttons ) |
147 | return; | 147 | return; |
148 | 148 | ||
149 | d->m_buttons = new QValueList <ODeviceButton>; | 149 | d->m_buttons = new QValueList <ODeviceButton>; |
150 | 150 | ||
151 | for ( uint i = 0; i < ( sizeof( simpad_buttons ) / sizeof( s_button )); i++ ) { | 151 | for ( uint i = 0; i < ( sizeof( simpad_buttons ) / sizeof( s_button )); i++ ) { |
152 | s_button *sb = simpad_buttons + i; | 152 | s_button *sb = simpad_buttons + i; |
153 | ODeviceButton b; | 153 | ODeviceButton b; |
154 | 154 | ||
155 | if (( sb->model & d->m_model ) == d->m_model ) { | 155 | if (( sb->model & d->m_model ) == d->m_model ) { |
156 | b. setKeycode ( sb->code ); | 156 | b. setKeycode ( sb->code ); |
157 | b. setUserText ( QObject::tr ( "Button", sb->utext )); | 157 | b. setUserText ( QObject::tr ( "Button", sb->utext )); |
158 | b. setPixmap ( Resource::loadPixmap ( sb->pix )); | 158 | b. setPixmap ( Resource::loadPixmap ( sb->pix )); |
159 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( sb->fpressedservice ), sb->fpressedaction )); | 159 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( sb->fpressedservice ), sb->fpressedaction )); |
160 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( sb->fheldservice ), sb->fheldaction )); | 160 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( sb->fheldservice ), sb->fheldaction )); |
161 | 161 | ||
162 | d->m_buttons->append ( b ); | 162 | d->m_buttons->append ( b ); |
163 | } | 163 | } |
164 | } | 164 | } |
165 | reloadButtonMapping(); | 165 | reloadButtonMapping(); |
166 | |||
167 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); | ||
168 | connect ( sysch, SIGNAL( received(const QCString&,const QByteArray&)), this, SLOT( systemMessage(const QCString&,const QByteArray&))); | ||
169 | } | 166 | } |
170 | 167 | ||
171 | // SIMpad boardcontrol register CS3 | 168 | // SIMpad boardcontrol register CS3 |
172 | #define SIMPAD_BOARDCONTROL "/proc/cs3" | 169 | #define SIMPAD_BOARDCONTROL "/proc/cs3" |
173 | #define SIMPAD_VCC_5V_EN 0x0001 // For 5V PCMCIA | 170 | #define SIMPAD_VCC_5V_EN 0x0001 // For 5V PCMCIA |
174 | #define SIMPAD_VCC_3V_EN 0x0002 // FOR 3.3V PCMCIA | 171 | #define SIMPAD_VCC_3V_EN 0x0002 // FOR 3.3V PCMCIA |
175 | #define SIMPAD_EN1 0x0004 // This is only for EPROM's | 172 | #define SIMPAD_EN1 0x0004 // This is only for EPROM's |
176 | #define SIMPAD_EN0 0x0008 // Both should be enable for 3.3V or 5V | 173 | #define SIMPAD_EN0 0x0008 // Both should be enable for 3.3V or 5V |
177 | #define SIMPAD_DISPLAY_ON 0x0010 | 174 | #define SIMPAD_DISPLAY_ON 0x0010 |
178 | #define SIMPAD_PCMCIA_BUFF_DIS 0x0020 | 175 | #define SIMPAD_PCMCIA_BUFF_DIS 0x0020 |
179 | #define SIMPAD_MQ_RESET 0x0040 | 176 | #define SIMPAD_MQ_RESET 0x0040 |
180 | #define SIMPAD_PCMCIA_RESET 0x0080 | 177 | #define SIMPAD_PCMCIA_RESET 0x0080 |
181 | #define SIMPAD_DECT_POWER_ON 0x0100 | 178 | #define SIMPAD_DECT_POWER_ON 0x0100 |
182 | #define SIMPAD_IRDA_SD 0x0200 // Shutdown for powersave | 179 | #define SIMPAD_IRDA_SD 0x0200 // Shutdown for powersave |
183 | #define SIMPAD_RS232_ON 0x0400 | 180 | #define SIMPAD_RS232_ON 0x0400 |
184 | #define SIMPAD_SD_MEDIAQ 0x0800 // Shutdown for powersave | 181 | #define SIMPAD_SD_MEDIAQ 0x0800 // Shutdown for powersave |
185 | #define SIMPAD_LED2_ON 0x1000 | 182 | #define SIMPAD_LED2_ON 0x1000 |
186 | #define SIMPAD_IRDA_MODE 0x2000 // Fast/Slow IrDA mode | 183 | #define SIMPAD_IRDA_MODE 0x2000 // Fast/Slow IrDA mode |
187 | #define SIMPAD_ENABLE_5V 0x4000 // Enable 5V circuit | 184 | #define SIMPAD_ENABLE_5V 0x4000 // Enable 5V circuit |
188 | #define SIMPAD_RESET_SIMCARD 0x8000 | 185 | #define SIMPAD_RESET_SIMCARD 0x8000 |
189 | 186 | ||
190 | //SIMpad touchscreen backlight strength control | 187 | //SIMpad touchscreen backlight strength control |
191 | #define SIMPAD_BACKLIGHT_CONTROL "/proc/driver/mq200/backlight" | 188 | #define SIMPAD_BACKLIGHT_CONTROL "/proc/driver/mq200/backlight" |
192 | 189 | ||
193 | 190 | ||
194 | /* | 191 | /* |
195 | * The SIMpad exposes ChipSelect3 to userspace | 192 | * The SIMpad exposes ChipSelect3 to userspace |
196 | * via a proc filesystem file. Using this register | 193 | * via a proc filesystem file. Using this register |
197 | * one can toggle power of serial, irda, dect circuits | 194 | * one can toggle power of serial, irda, dect circuits |
198 | * change the video driver and display status and | 195 | * change the video driver and display status and |
199 | * many more things. | 196 | * many more things. |
200 | * To not lose the current setting we read the current | 197 | * To not lose the current setting we read the current |
201 | * cs3 setting and toggle the necessary bits and then | 198 | * cs3 setting and toggle the necessary bits and then |
202 | * write it. | 199 | * write it. |
203 | */ | 200 | */ |
204 | static bool setCS3Bit( bool bitset, int bit ) { | 201 | static bool setCS3Bit( bool bitset, int bit ) { |
205 | int cs3_fd = ::open( SIMPAD_BOARDCONTROL, O_RDONLY ); | 202 | int cs3_fd = ::open( SIMPAD_BOARDCONTROL, O_RDONLY ); |
206 | 203 | ||
207 | if ( cs3_fd < 0 ) | 204 | if ( cs3_fd < 0 ) |
208 | return false; | 205 | return false; |
209 | 206 | ||
210 | static char line[32]; | 207 | static char line[32]; |
211 | int val = 0; | 208 | int val = 0; |
212 | bool ok = false; | 209 | bool ok = false; |
213 | 210 | ||
214 | /* | 211 | /* |
215 | * try to read and parse the Chipselect3 status | 212 | * try to read and parse the Chipselect3 status |
216 | * be paranoid and make sure line[31] is null | 213 | * be paranoid and make sure line[31] is null |
217 | * terminated | 214 | * terminated |
218 | */ | 215 | */ |
219 | while( !ok && ::read(cs3_fd, &line, sizeof(line)) > 0 ) { | 216 | while( !ok && ::read(cs3_fd, &line, sizeof(line)) > 0 ) { |
220 | line[31] = '\0'; | 217 | line[31] = '\0'; |
221 | if (::sscanf(line, "Chipselect3 : %x", &val )) | 218 | if (::sscanf(line, "Chipselect3 : %x", &val )) |
222 | ok = true; | 219 | ok = true; |
223 | } | 220 | } |
224 | 221 | ||
225 | ::close(cs3_fd); | 222 | ::close(cs3_fd); |
226 | 223 | ||
227 | /* | 224 | /* |
228 | * we were not able to find the current value | 225 | * we were not able to find the current value |
229 | * and as a result we won't set it | 226 | * and as a result we won't set it |
230 | */ | 227 | */ |
231 | if ( !ok ) | 228 | if ( !ok ) |
232 | return false; | 229 | return false; |