summaryrefslogtreecommitdiff
authorschurig <schurig>2004-09-09 09:08:36 (UTC)
committer schurig <schurig>2004-09-09 09:08:36 (UTC)
commit8df28401db620a01144ca45988837583f55e15c3 (patch) (unidiff)
tree7024a45504623a81abbf58c7ab0cae08d7870bd2
parent739d8dc8d4aed25e09d43805c802e9836240655b (diff)
downloadopie-8df28401db620a01144ca45988837583f55e15c3.zip
opie-8df28401db620a01144ca45988837583f55e15c3.tar.gz
opie-8df28401db620a01144ca45988837583f55e15c3.tar.bz2
support for devfs
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/device/odevice.cpp4
1 files changed, 4 insertions, 0 deletions
diff --git a/libopie2/opiecore/device/odevice.cpp b/libopie2/opiecore/device/odevice.cpp
index 280b0c5..2355621 100644
--- a/libopie2/opiecore/device/odevice.cpp
+++ b/libopie2/opiecore/device/odevice.cpp
@@ -194,257 +194,261 @@ ODevice::ODevice()
194 d->m_sysverstr = ts.readLine().replace( QRegExp( "\\\\." ), "" ); 194 d->m_sysverstr = ts.readLine().replace( QRegExp( "\\\\." ), "" );
195 } 195 }
196 break; 196 break;
197 } 197 }
198 } 198 }
199} 199}
200 200
201void ODevice::systemMessage( const QCString &msg, const QByteArray & ) 201void ODevice::systemMessage( const QCString &msg, const QByteArray & )
202{ 202{
203 if ( msg == "deviceButtonMappingChanged()" ) { 203 if ( msg == "deviceButtonMappingChanged()" ) {
204 reloadButtonMapping(); 204 reloadButtonMapping();
205 } 205 }
206} 206}
207 207
208void ODevice::init(const QString&) 208void ODevice::init(const QString&)
209{ 209{
210} 210}
211 211
212/** 212/**
213* This method initialises the button mapping 213* This method initialises the button mapping
214*/ 214*/
215void ODevice::initButtons() 215void ODevice::initButtons()
216{ 216{
217 if ( d->m_buttons ) 217 if ( d->m_buttons )
218 return; 218 return;
219 219
220 qDebug ( "init Buttons" ); 220 qDebug ( "init Buttons" );
221 d->m_buttons = new QValueList <ODeviceButton>; 221 d->m_buttons = new QValueList <ODeviceButton>;
222 for ( uint i = 0; i < ( sizeof( default_buttons ) / sizeof( default_button )); i++ ) { 222 for ( uint i = 0; i < ( sizeof( default_buttons ) / sizeof( default_button )); i++ ) {
223 default_button *db = default_buttons + i; 223 default_button *db = default_buttons + i;
224 ODeviceButton b; 224 ODeviceButton b;
225 b. setKeycode ( db->code ); 225 b. setKeycode ( db->code );
226 b. setUserText ( QObject::tr ( "Button", db->utext )); 226 b. setUserText ( QObject::tr ( "Button", db->utext ));
227 b. setPixmap ( Resource::loadPixmap ( db->pix )); 227 b. setPixmap ( Resource::loadPixmap ( db->pix ));
228 b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( db->fpressedservice ), db->fpressedaction )); 228 b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( db->fpressedservice ), db->fpressedaction ));
229 b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( db->fheldservice ), db->fheldaction )); 229 b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( db->fheldservice ), db->fheldaction ));
230 d->m_buttons->append ( b ); 230 d->m_buttons->append ( b );
231 } 231 }
232 232
233 reloadButtonMapping(); 233 reloadButtonMapping();
234 234
235 QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); 235 QCopChannel *sysch = new QCopChannel ( "QPE/System", this );
236 connect ( sysch, SIGNAL( received(const QCString&,const QByteArray&)), this, SLOT( systemMessage(const QCString&,const QByteArray&))); 236 connect ( sysch, SIGNAL( received(const QCString&,const QByteArray&)), this, SLOT( systemMessage(const QCString&,const QByteArray&)));
237} 237}
238 238
239ODevice::~ODevice() 239ODevice::~ODevice()
240{ 240{
241// we leak m_devicebuttons and m_cpu_frequency 241// we leak m_devicebuttons and m_cpu_frequency
242// but it's a singleton and it is not so importantant 242// but it's a singleton and it is not so importantant
243// -zecke 243// -zecke
244 delete d; 244 delete d;
245} 245}
246 246
247bool ODevice::setSoftSuspend ( bool /*soft*/ ) 247bool ODevice::setSoftSuspend ( bool /*soft*/ )
248{ 248{
249 return false; 249 return false;
250} 250}
251 251
252//#include <linux/apm_bios.h> 252//#include <linux/apm_bios.h>
253 253
254#define APM_IOC_SUSPEND OD_IO( 'A', 2 ) 254#define APM_IOC_SUSPEND OD_IO( 'A', 2 )
255 255
256/** 256/**
257* This method will try to suspend the device 257* This method will try to suspend the device
258* It only works if the user is the QWS Server and the apm application 258* It only works if the user is the QWS Server and the apm application
259* is installed. 259* is installed.
260* It tries to suspend and then waits some time cause some distributions 260* It tries to suspend and then waits some time cause some distributions
261* do have asynchronus apm implementations. 261* do have asynchronus apm implementations.
262* This method will either fail and return false or it'll suspend the 262* This method will either fail and return false or it'll suspend the
263* device and return once the device got woken up 263* device and return once the device got woken up
264* 264*
265* @return if the device got suspended 265* @return if the device got suspended
266*/ 266*/
267bool ODevice::suspend() 267bool ODevice::suspend()
268{ 268{
269 qDebug("ODevice::suspend"); 269 qDebug("ODevice::suspend");
270 if ( !isQWS( ) ) // only qwsserver is allowed to suspend 270 if ( !isQWS( ) ) // only qwsserver is allowed to suspend
271 return false; 271 return false;
272 272
273 if ( d->m_model == Model_Unknown ) // better don't suspend in qvfb / on unkown devices 273 if ( d->m_model == Model_Unknown ) // better don't suspend in qvfb / on unkown devices
274 return false; 274 return false;
275 275
276 bool res = false; 276 bool res = false;
277 ODevice::sendSuspendmsg(); 277 ODevice::sendSuspendmsg();
278 278
279 struct timeval tvs, tvn; 279 struct timeval tvs, tvn;
280 ::gettimeofday ( &tvs, 0 ); 280 ::gettimeofday ( &tvs, 0 );
281 281
282 ::sync(); // flush fs caches 282 ::sync(); // flush fs caches
283 res = ( ::system ( "apm --suspend" ) == 0 ); 283 res = ( ::system ( "apm --suspend" ) == 0 );
284 284
285 // This is needed because the iPAQ apm implementation is asynchronous and we 285 // This is needed because the iPAQ apm implementation is asynchronous and we
286 // can not be sure when exactly the device is really suspended 286 // can not be sure when exactly the device is really suspended
287 // This can be deleted as soon as a stable familiar with a synchronous apm implementation exists. 287 // This can be deleted as soon as a stable familiar with a synchronous apm implementation exists.
288 288
289 if ( res ) { 289 if ( res ) {
290 do { // wait at most 1.5 sec: either suspend didn't work or the device resumed 290 do { // wait at most 1.5 sec: either suspend didn't work or the device resumed
291 ::usleep ( 200 * 1000 ); 291 ::usleep ( 200 * 1000 );
292 ::gettimeofday ( &tvn, 0 ); 292 ::gettimeofday ( &tvn, 0 );
293 } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < 1500 ); 293 } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < 1500 );
294 } 294 }
295 295
296 return res; 296 return res;
297} 297}
298 298
299//#include <linux/fb.h> better not rely on kernel headers in userspace ... 299//#include <linux/fb.h> better not rely on kernel headers in userspace ...
300 300
301#define FBIOBLANK OD_IO( 'F', 0x11 ) // 0x4611 301#define FBIOBLANK OD_IO( 'F', 0x11 ) // 0x4611
302 302
303/* VESA Blanking Levels */ 303/* VESA Blanking Levels */
304#define VESA_NO_BLANKING 0 304#define VESA_NO_BLANKING 0
305#define VESA_VSYNC_SUSPEND 1 305#define VESA_VSYNC_SUSPEND 1
306#define VESA_HSYNC_SUSPEND 2 306#define VESA_HSYNC_SUSPEND 2
307#define VESA_POWERDOWN 3 307#define VESA_POWERDOWN 3
308 308
309/** 309/**
310* This sets the display on or off 310* This sets the display on or off
311*/ 311*/
312bool ODevice::setDisplayStatus ( bool on ) 312bool ODevice::setDisplayStatus ( bool on )
313{ 313{
314 qDebug("ODevice::setDisplayStatus(%d)", on); 314 qDebug("ODevice::setDisplayStatus(%d)", on);
315 315
316 if ( d->m_model == Model_Unknown ) 316 if ( d->m_model == Model_Unknown )
317 return false; 317 return false;
318 318
319 bool res = false; 319 bool res = false;
320 int fd; 320 int fd;
321 321
322#ifdef QT_QWS_DEVFS
323 if (( fd = ::open ( "/dev/fb/0", O_RDWR )) >= 0 ) {
324#else
322 if (( fd = ::open ( "/dev/fb0", O_RDWR )) >= 0 ) { 325 if (( fd = ::open ( "/dev/fb0", O_RDWR )) >= 0 ) {
326#endif
323 res = ( ::ioctl ( fd, FBIOBLANK, on ? VESA_NO_BLANKING : VESA_POWERDOWN ) == 0 ); 327 res = ( ::ioctl ( fd, FBIOBLANK, on ? VESA_NO_BLANKING : VESA_POWERDOWN ) == 0 );
324 ::close ( fd ); 328 ::close ( fd );
325 } 329 }
326 return res; 330 return res;
327} 331}
328 332
329/** 333/**
330* This sets the display brightness 334* This sets the display brightness
331* 335*
332* @param p The brightness to be set on a scale from 0 to 255 336* @param p The brightness to be set on a scale from 0 to 255
333* @return success or failure 337* @return success or failure
334*/ 338*/
335bool ODevice::setDisplayBrightness ( int p) 339bool ODevice::setDisplayBrightness ( int p)
336{ 340{
337 Q_UNUSED( p ) 341 Q_UNUSED( p )
338 return false; 342 return false;
339} 343}
340 344
341/** 345/**
342* @return returns the number of steppings on the brightness slider 346* @return returns the number of steppings on the brightness slider
343* in the Light-'n-Power settings. 347* in the Light-'n-Power settings.
344*/ 348*/
345int ODevice::displayBrightnessResolution() const 349int ODevice::displayBrightnessResolution() const
346{ 350{
347 return 16; 351 return 16;
348} 352}
349 353
350/** 354/**
351* This sets the display contrast 355* This sets the display contrast
352* @param p The contrast to be set on a scale from 0 to 255 356* @param p The contrast to be set on a scale from 0 to 255
353* @return success or failure 357* @return success or failure
354*/ 358*/
355bool ODevice::setDisplayContrast ( int p) 359bool ODevice::setDisplayContrast ( int p)
356{ 360{
357 Q_UNUSED( p ) 361 Q_UNUSED( p )
358 return false; 362 return false;
359} 363}
360 364
361/** 365/**
362* @return return the max value for the brightness settings slider 366* @return return the max value for the brightness settings slider
363* or 0 if the device doesn't support setting of a contrast 367* or 0 if the device doesn't support setting of a contrast
364*/ 368*/
365int ODevice::displayContrastResolution() const 369int ODevice::displayContrastResolution() const
366{ 370{
367 return 0; 371 return 0;
368} 372}
369 373
370/** 374/**
371* This returns the vendor as string 375* This returns the vendor as string
372* @return Vendor as QString 376* @return Vendor as QString
373*/ 377*/
374QString ODevice::vendorString() const 378QString ODevice::vendorString() const
375{ 379{
376 return d->m_vendorstr; 380 return d->m_vendorstr;
377} 381}
378 382
379/** 383/**
380* This returns the vendor as one of the values of OVendor 384* This returns the vendor as one of the values of OVendor
381* @return OVendor 385* @return OVendor
382*/ 386*/
383OVendor ODevice::vendor() const 387OVendor ODevice::vendor() const
384{ 388{
385 return d->m_vendor; 389 return d->m_vendor;
386} 390}
387 391
388/** 392/**
389* This returns the model as a string 393* This returns the model as a string
390* @return A string representing the model 394* @return A string representing the model
391*/ 395*/
392QString ODevice::modelString() const 396QString ODevice::modelString() const
393{ 397{
394 return d->m_modelstr; 398 return d->m_modelstr;
395} 399}
396 400
397/** 401/**
398* This does return the OModel used 402* This does return the OModel used
399*/ 403*/
400OModel ODevice::model() const 404OModel ODevice::model() const
401{ 405{
402 return d->m_model; 406 return d->m_model;
403} 407}
404 408
405/** 409/**
406* This does return the systen name 410* This does return the systen name
407*/ 411*/
408QString ODevice::systemString() const 412QString ODevice::systemString() const
409{ 413{
410 return d->m_systemstr; 414 return d->m_systemstr;
411} 415}
412 416
413/** 417/**
414* Return System as OSystem value 418* Return System as OSystem value
415*/ 419*/
416OSystem ODevice::system() const 420OSystem ODevice::system() const
417{ 421{
418 return d->m_system; 422 return d->m_system;
419} 423}
420 424
421/** 425/**
422* @return the version string of the base system 426* @return the version string of the base system
423*/ 427*/
424QString ODevice::systemVersionString() const 428QString ODevice::systemVersionString() const
425{ 429{
426 return d->m_sysverstr; 430 return d->m_sysverstr;
427} 431}
428 432
429/** 433/**
430* @return the current Transformation 434* @return the current Transformation
431*/ 435*/
432Transformation ODevice::rotation() const 436Transformation ODevice::rotation() const
433{ 437{
434 return d->m_rotation; 438 return d->m_rotation;
435} 439}
436 440
437/** 441/**
438* @return the current rotation direction 442* @return the current rotation direction
439*/ 443*/
440ODirection ODevice::direction() const 444ODirection ODevice::direction() const
441{ 445{
442 return d->m_direction; 446 return d->m_direction;
443} 447}
444 448
445/** 449/**
446* This plays an alarm sound 450* This plays an alarm sound
447*/ 451*/
448void ODevice::playAlarmSound() 452void ODevice::playAlarmSound()
449{ 453{
450#ifndef QT_NO_SOUND 454#ifndef QT_NO_SOUND