author | sandman <sandman> | 2002-09-06 19:24:57 (UTC) |
---|---|---|
committer | sandman <sandman> | 2002-09-06 19:24:57 (UTC) |
commit | 98c0d3f0eca58993cb18e740f2a3d07d67c5c64d (patch) (unidiff) | |
tree | 4215a42f10fb9afa11ddfefcf21c6808e2c1ffae /libopie | |
parent | 4acfa3f53762b6c786e421444d23c49c279e556f (diff) | |
download | opie-98c0d3f0eca58993cb18e740f2a3d07d67c5c64d.zip opie-98c0d3f0eca58993cb18e740f2a3d07d67c5c64d.tar.gz opie-98c0d3f0eca58993cb18e740f2a3d07d67c5c64d.tar.bz2 |
Added new functionality to libopie / ODevice, regarding LCD control (on/off
brightness)
-rw-r--r-- | libopie/odevice.cpp | 164 | ||||
-rw-r--r-- | libopie/odevice.h | 4 |
2 files changed, 148 insertions, 20 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp index 95fd6bd..6e3f114 100644 --- a/libopie/odevice.cpp +++ b/libopie/odevice.cpp | |||
@@ -26,2 +26,3 @@ | |||
26 | #include <linux/soundcard.h> | 26 | #include <linux/soundcard.h> |
27 | #include <math.h> | ||
27 | 28 | ||
@@ -35,5 +36,10 @@ | |||
35 | 36 | ||
37 | #include "odevice.h" | ||
36 | 38 | ||
39 | // _IO and friends are only defined in kernel headers ... | ||
37 | 40 | ||
38 | #include "odevice.h" | 41 | #define OD_IO(type,area,number,args) (( type << 30 ) | ( area << 8 ) | ( number ) | ( sizeof( args ) << 16 )) |
42 | #define OD_IOW(area,number,args) OD_IO(1,area,number,args) | ||
43 | #define OD_IOR(area,number,args) OD_IO(2,area,number,args) | ||
44 | #define OD_IORW(area,number,args) OD_IO(3,area,number,args) | ||
39 | 45 | ||
@@ -63,2 +69,5 @@ public: | |||
63 | 69 | ||
70 | virtual bool setDisplayBrightness ( int b ); | ||
71 | virtual int displayBrightnessResolution ( ) const; | ||
72 | |||
64 | virtual void alarmSound ( ); | 73 | virtual void alarmSound ( ); |
@@ -77,2 +86,5 @@ public: | |||
77 | 86 | ||
87 | virtual bool setDisplayBrightness ( int b ); | ||
88 | virtual int displayBrightnessResolution ( ) const; | ||
89 | |||
78 | virtual void alarmSound ( ); | 90 | virtual void alarmSound ( ); |
@@ -109,2 +121,10 @@ ODevice *ODevice::inst ( ) | |||
109 | 121 | ||
122 | |||
123 | /************************************************** | ||
124 | * | ||
125 | * common | ||
126 | * | ||
127 | **************************************************/ | ||
128 | |||
129 | |||
110 | ODevice::ODevice ( ) | 130 | ODevice::ODevice ( ) |
@@ -131,8 +151,2 @@ ODevice::~ODevice ( ) | |||
131 | 151 | ||
132 | //#include <linux/apm_bios.h> | ||
133 | |||
134 | //#define APM_IOC_SUSPEND _IO('A',2) | ||
135 | |||
136 | #define APM_IOC_SUSPEND (( 0<<30 ) | ( 'A'<<8 ) | ( 2 ) | ( 0<<16 )) | ||
137 | |||
138 | bool ODevice::setPowerButtonHandler ( ODevice::PowerButtonHandler ) | 152 | bool ODevice::setPowerButtonHandler ( ODevice::PowerButtonHandler ) |
@@ -142,2 +156,7 @@ bool ODevice::setPowerButtonHandler ( ODevice::PowerButtonHandler ) | |||
142 | 156 | ||
157 | //#include <linux/apm_bios.h> | ||
158 | |||
159 | #define APM_IOC_SUSPEND OD_IO( 0, 'A', 2, 0 ) | ||
160 | |||
161 | |||
143 | bool ODevice::suspend ( ) | 162 | bool ODevice::suspend ( ) |
@@ -179,2 +198,37 @@ bool ODevice::suspend ( ) | |||
179 | 198 | ||
199 | //#include <linux/fb.h> better not rely on kernel headers in userspace ... | ||
200 | |||
201 | #define FBIOBLANK OD_IO( 0, 'F', 0x11, 0 ) // 0x4611 | ||
202 | |||
203 | /* VESA Blanking Levels */ | ||
204 | #define VESA_NO_BLANKING 0 | ||
205 | #define VESA_VSYNC_SUSPEND 1 | ||
206 | #define VESA_HSYNC_SUSPEND 2 | ||
207 | #define VESA_POWERDOWN 3 | ||
208 | |||
209 | |||
210 | bool ODevice::setDisplayStatus ( bool on ) | ||
211 | { | ||
212 | if ( d-> m_model == OMODEL_Unknown ) | ||
213 | return false; | ||
214 | |||
215 | bool res = false; | ||
216 | int fd; | ||
217 | |||
218 | if (( fd = ::open ( "/dev/fb0", O_RDWR )) >= 0 ) { | ||
219 | res = ( ::ioctl ( fd, FBIOBLANK, on ? VESA_NO_BLANKING : VESA_POWERDOWN ) == 0 ); | ||
220 | ::close ( fd ); | ||
221 | } | ||
222 | return res; | ||
223 | } | ||
224 | |||
225 | bool ODevice::setDisplayBrightness ( int ) | ||
226 | { | ||
227 | return false; | ||
228 | } | ||
229 | |||
230 | int ODevice::displayBrightnessResolution ( ) const | ||
231 | { | ||
232 | return 16; | ||
233 | } | ||
180 | 234 | ||
@@ -245,7 +299,5 @@ void ODevice::touchSound ( ) | |||
245 | static Sound snd ( "touchsound" ); | 299 | static Sound snd ( "touchsound" ); |
246 | //qDebug("touchSound"); | 300 | |
247 | if ( snd. isFinished ( )) { | 301 | if ( snd. isFinished ( )) |
248 | snd. play ( ); | 302 | snd. play ( ); |
249 | // qDebug("sound should play"); | ||
250 | } | ||
251 | #endif | 303 | #endif |
@@ -272,4 +324,7 @@ bool ODevice::setLed ( uint /*which*/, OLedState /*st*/ ) | |||
272 | 324 | ||
273 | //#if defined( QT_QWS_IPAQ ) // IPAQ | 325 | /************************************************** |
274 | 326 | * | |
327 | * iPAQ | ||
328 | * | ||
329 | **************************************************/ | ||
275 | 330 | ||
@@ -317,3 +372,3 @@ void ODeviceIPAQ::init ( ) | |||
317 | 372 | ||
318 | typedef struct h3600_ts_led { | 373 | typedef struct { |
319 | unsigned char OffOnBlink; /* 0=off 1=on 2=Blink */ | 374 | unsigned char OffOnBlink; /* 0=off 1=on 2=Blink */ |
@@ -324,6 +379,10 @@ typedef struct h3600_ts_led { | |||
324 | 379 | ||
380 | typedef struct { | ||
381 | unsigned char mode; | ||
382 | unsigned char pwr; | ||
383 | unsigned char brightness; | ||
384 | } FLITE_IN; | ||
325 | 385 | ||
326 | // #define IOC_H3600_TS_MAGIC 'f' | 386 | #define LED_ON OD_IOW( 'f', 5, LED_IN ) |
327 | // #define LED_ON _IOW(IOC_H3600_TS_MAGIC, 5, struct h3600_ts_led) | 387 | #define FLITE_ON OD_IOW( 'f', 7, FLITE_IN ) |
328 | #define LED_ON (( 1<<30 ) | ( 'f'<<8 ) | ( 5 ) | ( sizeof(struct h3600_ts_led)<<16 )) // _IOW only defined in kernel headers :( | ||
329 | 388 | ||
@@ -392,3 +451,3 @@ bool ODeviceIPAQ::setLed ( uint which, OLedState st ) | |||
392 | if ( fd >= 0 ) { | 451 | if ( fd >= 0 ) { |
393 | struct h3600_ts_led leds; | 452 | LED_IN leds; |
394 | ::memset ( &leds, 0, sizeof( leds )); | 453 | ::memset ( &leds, 0, sizeof( leds )); |
@@ -435,3 +494,40 @@ bool ODeviceIPAQ::setPowerButtonHandler ( ODevice::PowerButtonHandler p ) | |||
435 | 494 | ||
495 | bool ODeviceIPAQ::setDisplayBrightness ( int bright ) | ||
496 | { | ||
497 | bool res = false; | ||
498 | int fd; | ||
499 | |||
500 | if ( bright > 255 ) | ||
501 | bright = 255; | ||
502 | if ( bright < 0 ) | ||
503 | bright = 0; | ||
504 | |||
505 | // 128 is the maximum if you want a decent lifetime for the LCD | ||
506 | |||
507 | bright = (int) (( ::pow ( 2, double( bright ) / 255.0 ) - 1 ) * 128.0 ); // logarithmic | ||
508 | //bright = ( bright + 1 ) / 2; | ||
509 | |||
510 | if ((( fd = ::open ( "/dev/ts", O_WRONLY )) >= 0 ) || | ||
511 | (( fd = ::open ( "/dev/h3600_ts", O_WRONLY )) >= 0 )) { | ||
512 | FLITE_IN bl; | ||
513 | bl. mode = 1; | ||
514 | bl. pwr = bright ? 1 : 0; | ||
515 | bl. brightness = bright; | ||
516 | res = ( ::ioctl ( fd, FLITE_ON, &bl ) == 0 ); | ||
517 | ::close ( fd ); | ||
518 | } | ||
519 | return res; | ||
520 | } | ||
521 | |||
522 | int ODeviceIPAQ::displayBrightnessResolution ( ) const | ||
523 | { | ||
524 | return 255; // really 128, but logarithmic control is smoother this way | ||
525 | } | ||
526 | |||
436 | 527 | ||
528 | /************************************************** | ||
529 | * | ||
530 | * Zaurus | ||
531 | * | ||
532 | **************************************************/ | ||
437 | 533 | ||
@@ -522,6 +618,7 @@ typedef struct sharp_led_status { | |||
522 | 618 | ||
523 | #define APM_IOCGEVTSRC (( 2 ) | ( 'A'<<8 ) | ( 203 ) | ( sizeof(int) )) | 619 | #define APM_IOCGEVTSRC OD_IOR( 'A', 203, int ) |
524 | #define APM_IOCSEVTSRC (( 3 ) | ( 'A'<<8 ) | ( 204 ) | ( sizeof(int) )) | 620 | #define APM_IOCSEVTSRC OD_IORW( 'A', 204, int ) |
525 | #define APM_EVT_POWER_BUTTON (1 << 0) | 621 | #define APM_EVT_POWER_BUTTON (1 << 0) |
526 | 622 | ||
623 | #define FL_IOCTL_STEP_CONTRAST 100 | ||
527 | 624 | ||
@@ -623 +720,28 @@ bool ODeviceZaurus::setPowerButtonHandler ( ODevice::PowerButtonHandler p ) | |||
623 | } | 720 | } |
721 | |||
722 | |||
723 | bool ODeviceZaurus::setDisplayBrightness ( int bright ) | ||
724 | { | ||
725 | bool res = false; | ||
726 | int fd; | ||
727 | |||
728 | if ( bright > 255 ) | ||
729 | bright = 255; | ||
730 | if ( bright < 0 ) | ||
731 | bright = 0; | ||
732 | |||
733 | if (( fd = ::open ( "/dev/fl", O_WRONLY )) >= 0 ) { | ||
734 | int bl = ( bright * 4 + 127 ) / 255; // only 4 steps on zaurus | ||
735 | if ( bright && !bl ) | ||
736 | bl = 1; | ||
737 | res = ( ::ioctl ( fd, FL_IOCTL_STEP_CONTRAST, bl ) == 0 ); | ||
738 | ::close ( fd ); | ||
739 | } | ||
740 | return res; | ||
741 | } | ||
742 | |||
743 | |||
744 | int ODeviceZaurus::displayBrightnessResolution ( ) const | ||
745 | { | ||
746 | return 4; | ||
747 | } | ||
diff --git a/libopie/odevice.h b/libopie/odevice.h index ee01f0f..9dda68e 100644 --- a/libopie/odevice.h +++ b/libopie/odevice.h | |||
@@ -77,2 +77,6 @@ public: | |||
77 | 77 | ||
78 | virtual bool setDisplayStatus ( bool on ); | ||
79 | virtual bool setDisplayBrightness ( int brightness ); | ||
80 | virtual int displayBrightnessResolution ( ) const; | ||
81 | |||
78 | // information | 82 | // information |