author | zecke <zecke> | 2005-08-04 19:16:06 (UTC) |
---|---|---|
committer | zecke <zecke> | 2005-08-04 19:16:06 (UTC) |
commit | 3ba74fc183b06760b60f1ad45ca4bfa0e47b3ecc (patch) (unidiff) | |
tree | 1236f7199cdf3133be3882b84400d654cc488d14 | |
parent | 77825e5455872ef0c6def793b38bc767a3838bc0 (diff) | |
download | opie-3ba74fc183b06760b60f1ad45ca4bfa0e47b3ecc.zip opie-3ba74fc183b06760b60f1ad45ca4bfa0e47b3ecc.tar.gz opie-3ba74fc183b06760b60f1ad45ca4bfa0e47b3ecc.tar.bz2 |
ODevice:
Patch by Pawel Kolodziejski (pablo _BEI_ omega.xtr.net.pl) to add
support for the H19xx series of iPAQs
-rw-r--r-- | libopie2/opiecore/device/odevice.h | 1 | ||||
-rw-r--r-- | libopie2/opiecore/device/odevice_ipaq.cpp | 62 | ||||
-rw-r--r-- | libopie2/opiecore/device/odevice_ipaq.h | 1 |
3 files changed, 50 insertions, 14 deletions
diff --git a/libopie2/opiecore/device/odevice.h b/libopie2/opiecore/device/odevice.h index b8478b9..05bb167 100644 --- a/libopie2/opiecore/device/odevice.h +++ b/libopie2/opiecore/device/odevice.h | |||
@@ -69,4 +69,5 @@ enum OModel { | |||
69 | Model_iPAQ_H5xxx = ( Model_iPAQ | 0x000020 ), | 69 | Model_iPAQ_H5xxx = ( Model_iPAQ | 0x000020 ), |
70 | Model_iPAQ_H22xx = ( Model_iPAQ | 0x000040 ), | 70 | Model_iPAQ_H22xx = ( Model_iPAQ | 0x000040 ), |
71 | Model_iPAQ_H191x = ( Model_iPAQ | 0x000080 ), | ||
71 | 72 | ||
72 | Model_Jornada = ( 6 << 24 ), | 73 | Model_Jornada = ( 6 << 24 ), |
diff --git a/libopie2/opiecore/device/odevice_ipaq.cpp b/libopie2/opiecore/device/odevice_ipaq.cpp index 8bc775f..309e1e4 100644 --- a/libopie2/opiecore/device/odevice_ipaq.cpp +++ b/libopie2/opiecore/device/odevice_ipaq.cpp | |||
@@ -86,10 +86,10 @@ typedef struct { | |||
86 | 86 | ||
87 | struct i_button ipaq_buttons [] = { | 87 | struct i_button ipaq_buttons [] = { |
88 | { Model_iPAQ_H31xx | Model_iPAQ_H36xx | Model_iPAQ_H37xx | Model_iPAQ_H38xx | Model_iPAQ_H39xx | Model_iPAQ_H5xxx, | 88 | { Model_iPAQ_H31xx | Model_iPAQ_H36xx | Model_iPAQ_H37xx | Model_iPAQ_H38xx | Model_iPAQ_H39xx | Model_iPAQ_H5xxx | Model_iPAQ_H191x, |
89 | Qt::Key_F9, QT_TRANSLATE_NOOP("Button", "Calendar Button"), | 89 | Qt::Key_F9, QT_TRANSLATE_NOOP("Button", "Calendar Button"), |
90 | "devicebuttons/ipaq_calendar", | 90 | "devicebuttons/ipaq_calendar", |
91 | "datebook", "nextView()", | 91 | "datebook", "nextView()", |
92 | "today", "raise()" }, | 92 | "today", "raise()" }, |
93 | { Model_iPAQ_H31xx | Model_iPAQ_H36xx | Model_iPAQ_H37xx | Model_iPAQ_H38xx | Model_iPAQ_H39xx | Model_iPAQ_H5xxx, | 93 | { Model_iPAQ_H31xx | Model_iPAQ_H36xx | Model_iPAQ_H37xx | Model_iPAQ_H38xx | Model_iPAQ_H39xx | Model_iPAQ_H5xxx | Model_iPAQ_H191x, |
94 | Qt::Key_F10, QT_TRANSLATE_NOOP("Button", "Contacts Button"), | 94 | Qt::Key_F10, QT_TRANSLATE_NOOP("Button", "Contacts Button"), |
95 | "devicebuttons/ipaq_contact", | 95 | "devicebuttons/ipaq_contact", |
@@ -101,15 +101,15 @@ struct i_button ipaq_buttons [] = { | |||
101 | "QPE/TaskBar", "toggleMenu()", | 101 | "QPE/TaskBar", "toggleMenu()", |
102 | "QPE/TaskBar", "toggleStartMenu()" }, | 102 | "QPE/TaskBar", "toggleStartMenu()" }, |
103 | { Model_iPAQ_H38xx | Model_iPAQ_H39xx | Model_iPAQ_H5xxx, | 103 | { Model_iPAQ_H38xx | Model_iPAQ_H39xx | Model_iPAQ_H5xxx | Model_iPAQ_H191x, |
104 | Qt::Key_F13, QT_TRANSLATE_NOOP("Button", "Mail Button"), | 104 | Qt::Key_F13, QT_TRANSLATE_NOOP("Button", "Mail Button"), |
105 | "devicebuttons/ipaq_mail", | 105 | "devicebuttons/ipaq_mail", |
106 | "opiemail", "raise()", | 106 | "opiemail", "raise()", |
107 | "opiemail", "newMail()" }, | 107 | "opiemail", "newMail()" }, |
108 | { Model_iPAQ_H31xx | Model_iPAQ_H36xx | Model_iPAQ_H37xx | Model_iPAQ_H38xx | Model_iPAQ_H39xx | Model_iPAQ_H5xxx, | 108 | { Model_iPAQ_H31xx | Model_iPAQ_H36xx | Model_iPAQ_H37xx | Model_iPAQ_H38xx | Model_iPAQ_H39xx | Model_iPAQ_H5xxx | Model_iPAQ_H191x, |
109 | Qt::Key_F12, QT_TRANSLATE_NOOP("Button", "Home Button"), | 109 | Qt::Key_F12, QT_TRANSLATE_NOOP("Button", "Home Button"), |
110 | "devicebuttons/ipaq_home", | 110 | "devicebuttons/ipaq_home", |
111 | "QPE/Launcher", "home()", | 111 | "QPE/Launcher", "home()", |
112 | "buttonsettings", "raise()" }, | 112 | "buttonsettings", "raise()" }, |
113 | { Model_iPAQ_H31xx | Model_iPAQ_H36xx | Model_iPAQ_H37xx | Model_iPAQ_H38xx | Model_iPAQ_H39xx | Model_iPAQ_H5xxx, | 113 | { Model_iPAQ_H31xx | Model_iPAQ_H36xx | Model_iPAQ_H37xx | Model_iPAQ_H38xx | Model_iPAQ_H39xx | Model_iPAQ_H5xxx | Model_iPAQ_H191x, |
114 | Qt::Key_F24, QT_TRANSLATE_NOOP("Button", "Record Button"), | 114 | Qt::Key_F24, QT_TRANSLATE_NOOP("Button", "Record Button"), |
115 | "devicebuttons/ipaq_record", | 115 | "devicebuttons/ipaq_record", |
@@ -139,4 +139,6 @@ void iPAQ::init(const QString& model) | |||
139 | else if ( d->m_modelstr == "H2200" ) | 139 | else if ( d->m_modelstr == "H2200" ) |
140 | d->m_model = Model_iPAQ_H22xx; | 140 | d->m_model = Model_iPAQ_H22xx; |
141 | else if ( d->m_modelstr == "H1910" ) | ||
142 | d->m_model = Model_iPAQ_H191x; | ||
141 | else | 143 | else |
142 | d->m_model = Model_Unknown; | 144 | d->m_model = Model_Unknown; |
@@ -149,4 +151,5 @@ void iPAQ::init(const QString& model) | |||
149 | case Model_iPAQ_H5xxx: | 151 | case Model_iPAQ_H5xxx: |
150 | case Model_iPAQ_H22xx: | 152 | case Model_iPAQ_H22xx: |
153 | case Model_iPAQ_H191x: | ||
151 | d->m_rotation = Rot0; | 154 | d->m_rotation = Rot0; |
152 | break; | 155 | break; |
@@ -286,5 +289,6 @@ bool iPAQ::filter ( int /*unicode*/, int keycode, int modifiers, bool isPress, b | |||
286 | // add the rotation to it and modolo. No we've the original offset | 289 | // add the rotation to it and modolo. No we've the original offset |
287 | // add the offset to the Key_Left key | 290 | // add the offset to the Key_Left key |
288 | if ( d-> m_model == Model_iPAQ_H5xxx ) | 291 | if (( d->m_model == Model_iPAQ_H5xxx ) || |
292 | ( d->m_model == Model_iPAQ_H191x )) | ||
289 | newkeycode = Key_Left + ( keycode - Key_Left + 3 ) % 4; | 293 | newkeycode = Key_Left + ( keycode - Key_Left + 3 ) % 4; |
290 | break; | 294 | break; |
@@ -349,11 +353,24 @@ bool iPAQ::setDisplayBrightness ( int bright ) | |||
349 | bright = 0; | 353 | bright = 0; |
350 | 354 | ||
351 | if (( fd = ::open ( "/dev/touchscreen/0", O_WRONLY )) >= 0 ) { | 355 | QString cmdline; |
352 | FLITE_IN bl; | 356 | |
353 | bl. mode = 1; | 357 | switch ( model()) { |
354 | bl. pwr = bright ? 1 : 0; | 358 | case Model_iPAQ_H191x: |
355 | bl. brightness = ( bright * ( displayBrightnessResolution() - 1 ) + 127 ) / 255; | 359 | if ( !bright ) |
356 | res = ( ::ioctl ( fd, FLITE_ON, &bl ) == 0 ); | 360 | cmdline = QString::fromLatin1( "echo 4 > /sys/class/backlight/pxafb/power"); |
357 | ::close ( fd ); | 361 | else |
362 | cmdline = QString::fromLatin1( "echo 0 > /sys/class/backlight/pxafb/power; echo %1 > /sys/class/backlight/pxafb/brightness" ).arg( bright ); | ||
363 | // No Global::shellQuote as we gurantee it to be sane | ||
364 | res = ( ::system( QFile::encodeName(cmdline) ) == 0 ); | ||
365 | break; | ||
366 | default: | ||
367 | if (( fd = ::open ( "/dev/touchscreen/0", O_WRONLY )) >= 0 ) { | ||
368 | FLITE_IN bl; | ||
369 | bl. mode = 1; | ||
370 | bl. pwr = bright ? 1 : 0; | ||
371 | bl. brightness = ( bright * ( displayBrightnessResolution() - 1 ) + 127 ) / 255; | ||
372 | res = ( ::ioctl ( fd, FLITE_ON, &bl ) == 0 ); | ||
373 | ::close ( fd ); | ||
374 | } | ||
358 | } | 375 | } |
359 | return res; | 376 | return res; |
@@ -373,5 +390,6 @@ int iPAQ::displayBrightnessResolution() const | |||
373 | case Model_iPAQ_H5xxx: | 390 | case Model_iPAQ_H5xxx: |
374 | return 255; | 391 | return 255; |
375 | 392 | case Model_iPAQ_H191x: | |
393 | return 183; | ||
376 | default: | 394 | default: |
377 | return 2; | 395 | return 2; |
@@ -379,4 +397,20 @@ int iPAQ::displayBrightnessResolution() const | |||
379 | } | 397 | } |
380 | 398 | ||
399 | bool iPAQ::setDisplayStatus ( bool on ) | ||
400 | { | ||
401 | bool res = false; | ||
402 | |||
403 | QString cmdline; | ||
404 | |||
405 | if ( model() == Model_iPAQ_H191x ) { | ||
406 | cmdline = QString::fromLatin1( "echo %1 > /sys/class/lcd/pxafb/power; echo %2 > /sys/class/backlight/pxafb/power").arg( on ? "0" : "4" ).arg( on ? "0" : "4" ); | ||
407 | } else { | ||
408 | res = OAbstractMobileDevice::setDisplayStatus(on); | ||
409 | } | ||
410 | |||
411 | res = ( ::system( QFile::encodeName(cmdline) ) == 0 ); | ||
412 | |||
413 | return res; | ||
414 | } | ||
381 | 415 | ||
382 | bool iPAQ::hasLightSensor() const | 416 | bool iPAQ::hasLightSensor() const |
diff --git a/libopie2/opiecore/device/odevice_ipaq.h b/libopie2/opiecore/device/odevice_ipaq.h index 1889467..3c783bc 100644 --- a/libopie2/opiecore/device/odevice_ipaq.h +++ b/libopie2/opiecore/device/odevice_ipaq.h | |||
@@ -48,4 +48,5 @@ class iPAQ : public OAbstractMobileDevice, public QWSServer::KeyboardFilter | |||
48 | 48 | ||
49 | public: | 49 | public: |
50 | virtual bool setDisplayStatus ( bool on ); | ||
50 | virtual bool setDisplayBrightness( int b ); | 51 | virtual bool setDisplayBrightness( int b ); |
51 | virtual int displayBrightnessResolution() const; | 52 | virtual int displayBrightnessResolution() const; |