-rw-r--r-- | libopie/odevice.cpp | 142 |
1 files changed, 112 insertions, 30 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp index a134810..3ff029e 100644 --- a/libopie/odevice.cpp +++ b/libopie/odevice.cpp | |||
@@ -124,16 +124,19 @@ public: | |||
124 | 124 | ||
125 | virtual QValueList <OLed> ledList ( ) const; | 125 | virtual QValueList <OLed> ledList ( ) const; |
126 | virtual QValueList <OLedState> ledStateList ( OLed led ) const; | 126 | virtual QValueList <OLedState> ledStateList ( OLed led ) const; |
127 | virtual OLedState ledState ( OLed led ) const; | 127 | virtual OLedState ledState ( OLed led ) const; |
128 | virtual bool setLedState ( OLed led, OLedState st ); | 128 | virtual bool setLedState ( OLed led, OLedState st ); |
129 | 129 | ||
130 | static bool isZaurus(); | ||
131 | |||
130 | protected: | 132 | protected: |
131 | virtual void buzzer ( int snd ); | 133 | virtual void buzzer ( int snd ); |
132 | 134 | ||
133 | OLedState m_leds [1]; | 135 | OLedState m_leds [1]; |
136 | bool m_embedix; | ||
134 | }; | 137 | }; |
135 | 138 | ||
136 | class SIMpad : public ODevice, public QWSServer::KeyboardFilter { | 139 | class SIMpad : public ODevice, public QWSServer::KeyboardFilter { |
137 | protected: | 140 | protected: |
138 | virtual void init ( ); | 141 | virtual void init ( ); |
139 | virtual void initButtons ( ); | 142 | virtual void initButtons ( ); |
@@ -380,16 +383,16 @@ static inline bool isQWS() | |||
380 | } | 383 | } |
381 | 384 | ||
382 | ODevice *ODevice::inst ( ) | 385 | ODevice *ODevice::inst ( ) |
383 | { | 386 | { |
384 | static ODevice *dev = 0; | 387 | static ODevice *dev = 0; |
385 | 388 | ||
386 | if ( !dev ) { | 389 | if ( !dev ) { |
387 | if ( QFile::exists ( "/proc/hal/model" )) | 390 | if ( QFile::exists ( "/proc/hal/model" )) |
388 | dev = new iPAQ ( ); | 391 | dev = new iPAQ ( ); |
389 | else if ( QFile::exists ( "/dev/sharp_buz" ) || QFile::exists ( "/dev/sharp_led" )) | 392 | else if ( Zaurus::isZaurus() ) |
390 | dev = new Zaurus ( ); | 393 | dev = new Zaurus ( ); |
391 | else if ( QFile::exists ( "/proc/ucb1x00" ) && QFile::exists ( "/proc/cs3" )) | 394 | else if ( QFile::exists ( "/proc/ucb1x00" ) && QFile::exists ( "/proc/cs3" )) |
392 | dev = new SIMpad ( ); | 395 | dev = new SIMpad ( ); |
393 | else if ( QFile::exists ( "/proc/sys/board/name" )) | 396 | else if ( QFile::exists ( "/proc/sys/board/name" )) |
394 | dev = new Ramses ( ); | 397 | dev = new Ramses ( ); |
395 | else | 398 | else |
@@ -1317,18 +1320,56 @@ int iPAQ::lightSensorResolution ( ) const | |||
1317 | /************************************************** | 1320 | /************************************************** |
1318 | * | 1321 | * |
1319 | * Zaurus | 1322 | * Zaurus |
1320 | * | 1323 | * |
1321 | **************************************************/ | 1324 | **************************************************/ |
1322 | 1325 | ||
1326 | // Check whether this device is the sharp zaurus.. | ||
1327 | bool Zaurus::isZaurus() | ||
1328 | { | ||
1329 | |||
1330 | // If the special devices by embedix exist, it is quite simple: it is a Zaurus ! | ||
1331 | if ( QFile::exists ( "/dev/sharp_buz" ) || QFile::exists ( "/dev/sharp_led" ) ){ | ||
1332 | return true; | ||
1333 | } | ||
1334 | |||
1335 | // On non-embedix kenrnels, we have too look closer. | ||
1336 | bool is_zaurus = false; | ||
1337 | QFile f ( "/proc/cpuinfo" ); | ||
1338 | if ( f. open ( IO_ReadOnly ) ) { | ||
1339 | QString model; | ||
1340 | QFile f ( "/proc/cpuinfo" ); | ||
1341 | |||
1342 | QTextStream ts ( &f ); | ||
1343 | QString line; | ||
1344 | while( line = ts. readLine ( ) ) { | ||
1345 | if ( line. left ( 8 ) == "Hardware" ) | ||
1346 | break; | ||
1347 | } | ||
1348 | int loc = line. find ( ":" ); | ||
1349 | if ( loc != -1 ) | ||
1350 | model = line. mid ( loc + 2 ). simplifyWhiteSpace( ); | ||
1351 | |||
1352 | if ( model == "Sharp-Collie" | ||
1353 | || model == "Collie" | ||
1354 | || model == "SHARP Corgi" | ||
1355 | || model == "SHARP Shepherd" | ||
1356 | || model == "SHARP Poodle" | ||
1357 | ) | ||
1358 | is_zaurus = true; | ||
1359 | |||
1360 | } | ||
1361 | return is_zaurus; | ||
1362 | } | ||
1323 | 1363 | ||
1324 | 1364 | ||
1325 | void Zaurus::init ( ) | 1365 | void Zaurus::init ( ) |
1326 | { | 1366 | { |
1327 | d-> m_vendorstr = "Sharp"; | 1367 | d-> m_vendorstr = "Sharp"; |
1328 | d-> m_vendor = Vendor_Sharp; | 1368 | d-> m_vendor = Vendor_Sharp; |
1369 | m_embedix = true; // Not openzaurus means: It has an embedix kernel ! | ||
1329 | 1370 | ||
1330 | // QFile f ( "/proc/filesystems" ); | 1371 | // QFile f ( "/proc/filesystems" ); |
1331 | QString model; | 1372 | QString model; |
1332 | 1373 | ||
1333 | // It isn't a good idea to check the system configuration to | 1374 | // It isn't a good idea to check the system configuration to |
1334 | // detect the distribution ! | 1375 | // detect the distribution ! |
@@ -1339,20 +1380,33 @@ void Zaurus::init ( ) | |||
1339 | QFile f ("/etc/oz_version"); | 1380 | QFile f ("/etc/oz_version"); |
1340 | if ( f.exists() ){ | 1381 | if ( f.exists() ){ |
1341 | d-> m_vendorstr = "OpenZaurus Team"; | 1382 | d-> m_vendorstr = "OpenZaurus Team"; |
1342 | d-> m_systemstr = "OpenZaurus"; | 1383 | d-> m_systemstr = "OpenZaurus"; |
1343 | d-> m_system = System_OpenZaurus; | 1384 | d-> m_system = System_OpenZaurus; |
1344 | 1385 | ||
1345 | // f. close ( ); | ||
1346 | |||
1347 | // f. setName ( "/etc/oz_version" ); | ||
1348 | if ( f. open ( IO_ReadOnly )) { | 1386 | if ( f. open ( IO_ReadOnly )) { |
1349 | QTextStream ts ( &f ); | 1387 | QTextStream ts ( &f ); |
1350 | d-> m_sysverstr = ts. readLine ( );//. mid ( 10 ); | 1388 | d-> m_sysverstr = ts. readLine ( );//. mid ( 10 ); |
1351 | f. close ( ); | 1389 | f. close ( ); |
1352 | } | 1390 | } |
1391 | |||
1392 | // Openzaurus sometimes uses the embedix kernel! | ||
1393 | // => Check whether this is an embedix kernel | ||
1394 | FILE *uname = popen("uname -r", "r"); | ||
1395 | QString line; | ||
1396 | if ( f.open(IO_ReadOnly, uname) ) { | ||
1397 | QTextStream ts ( &f ); | ||
1398 | line = ts. readLine ( ); | ||
1399 | int loc = line. find ( "embedix" ); | ||
1400 | if ( loc != -1 ) | ||
1401 | m_embedix = true; | ||
1402 | else | ||
1403 | m_embedix = false; | ||
1404 | f. close ( ); | ||
1405 | } | ||
1406 | pclose(uname); | ||
1353 | } | 1407 | } |
1354 | else { | 1408 | else { |
1355 | d-> m_systemstr = "Zaurus"; | 1409 | d-> m_systemstr = "Zaurus"; |
1356 | d-> m_system = System_Zaurus; | 1410 | d-> m_system = System_Zaurus; |
1357 | } | 1411 | } |
1358 | 1412 | ||
@@ -1372,16 +1426,16 @@ void Zaurus::init ( ) | |||
1372 | if ( model == "SHARP Corgi" ) { | 1426 | if ( model == "SHARP Corgi" ) { |
1373 | d-> m_model = Model_Zaurus_SLC700; | 1427 | d-> m_model = Model_Zaurus_SLC700; |
1374 | d-> m_modelstr = "Zaurus SL-C700"; | 1428 | d-> m_modelstr = "Zaurus SL-C700"; |
1375 | } else if ( model == "SHARP Shepherd" ) { | 1429 | } else if ( model == "SHARP Shepherd" ) { |
1376 | d-> m_model = Model_Zaurus_SLC700; // Do we need a special type for the C750 ? (eilers) | 1430 | d-> m_model = Model_Zaurus_SLC700; // Do we need a special type for the C750 ? (eilers) |
1377 | d-> m_modelstr = "Zaurus SL-C750"; | 1431 | d-> m_modelstr = "Zaurus SL-C750"; |
1378 | }else if ( model == "SHARP Poodle" ) { | 1432 | } else if ( model == "SHARP Poodle" ) { |
1379 | d-> m_model = Model_Zaurus_SLB600; | 1433 | d-> m_model = Model_Zaurus_SLB600; |
1380 | d-> m_modelstr = "Zaurus SL-B500 or SL-5600"; | 1434 | d-> m_modelstr = "Zaurus SL-B500 or SL-5600"; |
1381 | } else if ( model = "Sharp-Collie" ) { | 1435 | } else if ( model == "Sharp-Collie" || model == "Collie" ) { |
1382 | d-> m_model = Model_Zaurus_SL5500; | 1436 | d-> m_model = Model_Zaurus_SL5500; |
1383 | d-> m_modelstr = "Zaurus SL-5500 or SL-5000d"; | 1437 | d-> m_modelstr = "Zaurus SL-5500 or SL-5000d"; |
1384 | } else { | 1438 | } else { |
1385 | d-> m_model = Model_Zaurus_SL5500; | 1439 | d-> m_model = Model_Zaurus_SL5500; |
1386 | d-> m_modelstr = "Zaurus (Model unknown)"; | 1440 | d-> m_modelstr = "Zaurus (Model unknown)"; |
1387 | } | 1441 | } |
@@ -1440,22 +1494,25 @@ void Zaurus::initButtons ( ) | |||
1440 | struct z_button *zb = pz_buttons + i; | 1494 | struct z_button *zb = pz_buttons + i; |
1441 | ODeviceButton b; | 1495 | ODeviceButton b; |
1442 | 1496 | ||
1443 | b. setKeycode ( zb-> code ); | 1497 | b. setKeycode ( zb-> code ); |
1444 | b. setUserText ( QObject::tr ( "Button", zb-> utext )); | 1498 | b. setUserText ( QObject::tr ( "Button", zb-> utext )); |
1445 | b. setPixmap ( Resource::loadPixmap ( zb-> pix )); | 1499 | b. setPixmap ( Resource::loadPixmap ( zb-> pix )); |
1446 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( zb-> fpressedservice ), zb-> fpressedaction )); | 1500 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( zb-> fpressedservice ), |
1447 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( zb-> fheldservice ), zb-> fheldaction )); | 1501 | zb-> fpressedaction )); |
1502 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( zb-> fheldservice ), | ||
1503 | zb-> fheldaction )); | ||
1448 | 1504 | ||
1449 | d-> m_buttons-> append ( b ); | 1505 | d-> m_buttons-> append ( b ); |
1450 | } | 1506 | } |
1451 | 1507 | ||
1452 | reloadButtonMapping ( ); | 1508 | reloadButtonMapping ( ); |
1453 | 1509 | ||
1454 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); | 1510 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); |
1455 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); | 1511 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), |
1512 | this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); | ||
1456 | } | 1513 | } |
1457 | 1514 | ||
1458 | #include <unistd.h> | 1515 | #include <unistd.h> |
1459 | #include <fcntl.h> | 1516 | #include <fcntl.h> |
1460 | #include <sys/ioctl.h> | 1517 | #include <sys/ioctl.h> |
1461 | 1518 | ||
@@ -1521,22 +1578,21 @@ typedef struct sharp_led_status { | |||
1521 | 1578 | ||
1522 | #define FL_IOCTL_STEP_CONTRAST 100 | 1579 | #define FL_IOCTL_STEP_CONTRAST 100 |
1523 | 1580 | ||
1524 | 1581 | ||
1525 | void Zaurus::buzzer ( int sound ) | 1582 | void Zaurus::buzzer ( int sound ) |
1526 | { | 1583 | { |
1527 | // Not all devices have real sound. | ||
1528 | #ifndef QT_NO_SOUND | 1584 | #ifndef QT_NO_SOUND |
1529 | switch ( d-> m_model ) { | 1585 | QString soundname; |
1530 | case Model_Zaurus_SLC700:{ | 1586 | |
1531 | int fd; | 1587 | // Not all devices have real sound. But I expect |
1532 | int vol; | 1588 | // that Openzaurus now has a sound driver which |
1533 | bool vol_reset = false; | 1589 | // I will use instead the buzzer... |
1590 | if ( ( d->m_model == Model_Zaurus_SLC700 ) | ||
1591 | || d->m_system == System_OpenZaurus ){ | ||
1534 | 1592 | ||
1535 | QString soundname; | ||
1536 | |||
1537 | switch ( sound ){ | 1593 | switch ( sound ){ |
1538 | case SHARP_BUZ_SCHEDULE_ALARM: | 1594 | case SHARP_BUZ_SCHEDULE_ALARM: |
1539 | soundname = "alarm"; | 1595 | soundname = "alarm"; |
1540 | break; | 1596 | break; |
1541 | case SHARP_BUZ_TOUCHSOUND: | 1597 | case SHARP_BUZ_TOUCHSOUND: |
1542 | soundname = "touchsound"; | 1598 | soundname = "touchsound"; |
@@ -1545,12 +1601,21 @@ void Zaurus::buzzer ( int sound ) | |||
1545 | soundname = "keysound"; | 1601 | soundname = "keysound"; |
1546 | break; | 1602 | break; |
1547 | default: | 1603 | default: |
1548 | soundname = "alarm"; | 1604 | soundname = "alarm"; |
1549 | 1605 | ||
1550 | } | 1606 | } |
1607 | } | ||
1608 | |||
1609 | // If a soundname is defined, we expect that this device has | ||
1610 | // sound capabilities.. Otherwise we expect to have the buzzer | ||
1611 | // device.. | ||
1612 | if ( !soundname.isEmpty() ){ | ||
1613 | int fd; | ||
1614 | int vol; | ||
1615 | bool vol_reset = false; | ||
1551 | 1616 | ||
1552 | Sound snd ( soundname ); | 1617 | Sound snd ( soundname ); |
1553 | 1618 | ||
1554 | if (( fd = ::open ( "/dev/sound/mixer", O_RDWR )) >= 0 ) { | 1619 | if (( fd = ::open ( "/dev/sound/mixer", O_RDWR )) >= 0 ) { |
1555 | if ( ::ioctl ( fd, MIXER_READ( 0 ), &vol ) >= 0 ) { | 1620 | if ( ::ioctl ( fd, MIXER_READ( 0 ), &vol ) >= 0 ) { |
1556 | Config cfg ( "qpe" ); | 1621 | Config cfg ( "qpe" ); |
@@ -1574,23 +1639,21 @@ void Zaurus::buzzer ( int sound ) | |||
1574 | 1639 | ||
1575 | if ( fd >= 0 ) { | 1640 | if ( fd >= 0 ) { |
1576 | if ( vol_reset ) | 1641 | if ( vol_reset ) |
1577 | ::ioctl ( fd, MIXER_WRITE( 0 ), &vol ); | 1642 | ::ioctl ( fd, MIXER_WRITE( 0 ), &vol ); |
1578 | ::close ( fd ); | 1643 | ::close ( fd ); |
1579 | } | 1644 | } |
1580 | break; | 1645 | } else { |
1581 | } | ||
1582 | default:{ // Devices with buzzer | ||
1583 | int fd = ::open ( "/dev/sharp_buz", O_WRONLY|O_NONBLOCK ); | 1646 | int fd = ::open ( "/dev/sharp_buz", O_WRONLY|O_NONBLOCK ); |
1584 | 1647 | ||
1585 | if ( fd >= 0 ) { | 1648 | if ( fd >= 0 ) { |
1586 | ::ioctl ( fd, SHARP_BUZZER_MAKESOUND, sound ); | 1649 | ::ioctl ( fd, SHARP_BUZZER_MAKESOUND, sound ); |
1587 | ::close ( fd ); | 1650 | ::close ( fd ); |
1588 | } | 1651 | } |
1589 | } | 1652 | |
1590 | } | 1653 | } |
1591 | #endif | 1654 | #endif |
1592 | } | 1655 | } |
1593 | 1656 | ||
1594 | 1657 | ||
1595 | void Zaurus::alarmSound ( ) | 1658 | void Zaurus::alarmSound ( ) |
1596 | { | 1659 | { |
@@ -1631,12 +1694,15 @@ OLedState Zaurus::ledState ( OLed which ) const | |||
1631 | else | 1694 | else |
1632 | return Led_Off; | 1695 | return Led_Off; |
1633 | } | 1696 | } |
1634 | 1697 | ||
1635 | bool Zaurus::setLedState ( OLed which, OLedState st ) | 1698 | bool Zaurus::setLedState ( OLed which, OLedState st ) |
1636 | { | 1699 | { |
1700 | if (!m_embedix) // Currently not supported on non_embedix kernels | ||
1701 | return false; | ||
1702 | |||
1637 | static int fd = ::open ( "/dev/sharp_led", O_RDWR|O_NONBLOCK ); | 1703 | static int fd = ::open ( "/dev/sharp_led", O_RDWR|O_NONBLOCK ); |
1638 | 1704 | ||
1639 | if ( which == Led_Mail ) { | 1705 | if ( which == Led_Mail ) { |
1640 | if ( fd >= 0 ) { | 1706 | if ( fd >= 0 ) { |
1641 | struct sharp_led_status leds; | 1707 | struct sharp_led_status leds; |
1642 | ::memset ( &leds, 0, sizeof( leds )); | 1708 | ::memset ( &leds, 0, sizeof( leds )); |
@@ -1658,12 +1724,17 @@ bool Zaurus::setLedState ( OLed which, OLedState st ) | |||
1658 | } | 1724 | } |
1659 | return false; | 1725 | return false; |
1660 | } | 1726 | } |
1661 | 1727 | ||
1662 | bool Zaurus::setSoftSuspend ( bool soft ) | 1728 | bool Zaurus::setSoftSuspend ( bool soft ) |
1663 | { | 1729 | { |
1730 | if (!m_embedix) { | ||
1731 | /* non-Embedix kernels dont have kernel autosuspend */ | ||
1732 | return ODevice::setSoftSuspend( soft ); | ||
1733 | } | ||
1734 | |||
1664 | bool res = false; | 1735 | bool res = false; |
1665 | int fd; | 1736 | int fd; |
1666 | 1737 | ||
1667 | if ((( fd = ::open ( "/dev/apm_bios", O_RDWR )) >= 0 ) || | 1738 | if ((( fd = ::open ( "/dev/apm_bios", O_RDWR )) >= 0 ) || |
1668 | (( fd = ::open ( "/dev/misc/apm_bios",O_RDWR )) >= 0 )) { | 1739 | (( fd = ::open ( "/dev/misc/apm_bios",O_RDWR )) >= 0 )) { |
1669 | 1740 | ||
@@ -1699,26 +1770,37 @@ bool Zaurus::setDisplayBrightness ( int bright ) | |||
1699 | 1770 | ||
1700 | if ( bright > 255 ) | 1771 | if ( bright > 255 ) |
1701 | bright = 255; | 1772 | bright = 255; |
1702 | if ( bright < 0 ) | 1773 | if ( bright < 0 ) |
1703 | bright = 0; | 1774 | bright = 0; |
1704 | 1775 | ||
1705 | if (( fd = ::open ( "/dev/fl", O_WRONLY )) >= 0 ) { | 1776 | if (m_embedix) { |
1706 | int bl = ( bright * 4 + 127 ) / 255; // only 4 steps on zaurus | 1777 | if (( fd = ::open ( "/dev/fl", O_WRONLY )) >= 0 ) { |
1707 | if ( bright && !bl ) | 1778 | int bl = ( bright * 4 + 127 ) / 255; // only 4 steps on zaurus |
1708 | bl = 1; | 1779 | if ( bright && !bl ) |
1709 | res = ( ::ioctl ( fd, FL_IOCTL_STEP_CONTRAST, bl ) == 0 ); | 1780 | bl = 1; |
1710 | ::close ( fd ); | 1781 | res = ( ::ioctl ( fd, FL_IOCTL_STEP_CONTRAST, bl ) == 0 ); |
1782 | ::close ( fd ); | ||
1783 | } | ||
1784 | } else { | ||
1785 | #define FB_BACKLIGHT_SET_BRIGHTNESS _IOW('F', 1, u_int) /* set brightness */ | ||
1786 | if (( fd = ::open ( "/dev/fb0", O_WRONLY )) >= 0 ) { | ||
1787 | res = ( ::ioctl ( fd , FB_BACKLIGHT_SET_BRIGHTNESS, bright ) == 0 ); | ||
1788 | ::close ( fd ); | ||
1789 | } | ||
1711 | } | 1790 | } |
1712 | return res; | 1791 | return res; |
1713 | } | 1792 | } |
1714 | 1793 | ||
1715 | 1794 | ||
1716 | int Zaurus::displayBrightnessResolution ( ) const | 1795 | int Zaurus::displayBrightnessResolution ( ) const |
1717 | { | 1796 | { |
1718 | return 5; | 1797 | if (m_embedix) |
1798 | return 5; | ||
1799 | else | ||
1800 | return 256; | ||
1719 | } | 1801 | } |
1720 | 1802 | ||
1721 | /************************************************** | 1803 | /************************************************** |
1722 | * | 1804 | * |
1723 | * SIMpad | 1805 | * SIMpad |
1724 | * | 1806 | * |