summaryrefslogtreecommitdiff
path: root/libopie
authorkergoth <kergoth>2002-12-12 00:28:48 (UTC)
committer kergoth <kergoth>2002-12-12 00:28:48 (UTC)
commitcb783a8ddbeb6c85481c5b1a807f21be83817255 (patch) (unidiff)
treeba7823d58f7cf34d8fffd5818ea5e1ff72432182 /libopie
parent474b8efcacfffb04bf72f486eca7b1455a2b81dd (diff)
downloadopie-cb783a8ddbeb6c85481c5b1a807f21be83817255.zip
opie-cb783a8ddbeb6c85481c5b1a807f21be83817255.tar.gz
opie-cb783a8ddbeb6c85481c5b1a807f21be83817255.tar.bz2
Proper zaurus model checking for ODevice
Diffstat (limited to 'libopie') (more/less context) (ignore whitespace changes)
-rw-r--r--libopie/odevice.cpp19
-rw-r--r--libopie/odevice.h1
2 files changed, 18 insertions, 2 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp
index bc43c52..a33d4ad 100644
--- a/libopie/odevice.cpp
+++ b/libopie/odevice.cpp
@@ -705,49 +705,64 @@ int iPAQ::lightSensorResolution ( ) const
705} 705}
706 706
707/************************************************** 707/**************************************************
708 * 708 *
709 * Zaurus 709 * Zaurus
710 * 710 *
711 **************************************************/ 711 **************************************************/
712 712
713 713
714 714
715void Zaurus::init ( ) 715void Zaurus::init ( )
716{ 716{
717 d-> m_modelstr = "Zaurus SL5000";
718 d-> m_model = Model_Zaurus_SL5000;
719 d-> m_vendorstr = "Sharp"; 717 d-> m_vendorstr = "Sharp";
720 d-> m_vendor = Vendor_Sharp; 718 d-> m_vendor = Vendor_Sharp;
721 719
722 QFile f ( "/proc/filesystems" ); 720 QFile f ( "/proc/filesystems" );
723 721
724 if ( f. open ( IO_ReadOnly ) && ( QTextStream ( &f ). read ( ). find ( "\tjffs2\n" ) >= 0 )) { 722 if ( f. open ( IO_ReadOnly ) && ( QTextStream ( &f ). read ( ). find ( "\tjffs2\n" ) >= 0 )) {
725 d-> m_systemstr = "OpenZaurus"; 723 d-> m_systemstr = "OpenZaurus";
726 d-> m_system = System_OpenZaurus; 724 d-> m_system = System_OpenZaurus;
727 725
728 f. close ( ); 726 f. close ( );
729 727
730 f. setName ( "/etc/oz_version" ); 728 f. setName ( "/etc/oz_version" );
731 if ( f. open ( IO_ReadOnly )) { 729 if ( f. open ( IO_ReadOnly )) {
732 QTextStream ts ( &f ); 730 QTextStream ts ( &f );
733 d-> m_sysverstr = ts. readLine ( );//. mid ( 10 ); 731 d-> m_sysverstr = ts. readLine ( );//. mid ( 10 );
734 f. close ( ); 732 f. close ( );
735 } 733 }
736 } 734 }
737 else { 735 else {
738 d-> m_systemstr = "Zaurus"; 736 d-> m_systemstr = "Zaurus";
739 d-> m_system = System_Zaurus; 737 d-> m_system = System_Zaurus;
740 } 738 }
741 739
740 f. setName ( "/proc/deviceinfo/product" );
741 if ( f. open ( IO_ReadOnly ) ) {
742 QTextStream ts ( &f );
743 QString model = ts. readLine ( );
744 f. close ( );
745 if ( model == "SL-5000D" ) {
746 d-> m_model = Model_Zaurus_SL5000;
747 d-> m_modelstr = "Zaurus SL-5000D";
748 } else if ( model == "SL-5500" ) {
749 d-> m_model = Model_Zaurus_SL5500;
750 d-> m_modelstr = "Zaurus SL-5500";
751 }
752 }
753 else {
754 d-> m_model = Model_Zaurus_SL5000;
755 d-> m_modelstr = "Zaurus SL-5000D (unverified)";
756 }
742 757
743 m_leds [0] = Led_Off; 758 m_leds [0] = Led_Off;
744} 759}
745 760
746#include <unistd.h> 761#include <unistd.h>
747#include <fcntl.h> 762#include <fcntl.h>
748#include <sys/ioctl.h> 763#include <sys/ioctl.h>
749 764
750//#include <asm/sharp_char.h> // including kernel headers is evil ... 765//#include <asm/sharp_char.h> // including kernel headers is evil ...
751 766
752#define SHARP_DEV_IOCTL_COMMAND_START 0x5680 767#define SHARP_DEV_IOCTL_COMMAND_START 0x5680
753 768
diff --git a/libopie/odevice.h b/libopie/odevice.h
index e50009c..86491d4 100644
--- a/libopie/odevice.h
+++ b/libopie/odevice.h
@@ -35,24 +35,25 @@ enum OModel {
35 Model_iPAQ = ( 1 << 24 ), 35 Model_iPAQ = ( 1 << 24 ),
36 36
37 Model_iPAQ_All = ( Model_iPAQ | 0xffffff ), 37 Model_iPAQ_All = ( Model_iPAQ | 0xffffff ),
38 Model_iPAQ_H31xx = ( Model_iPAQ | 0x000001 ), 38 Model_iPAQ_H31xx = ( Model_iPAQ | 0x000001 ),
39 Model_iPAQ_H36xx = ( Model_iPAQ | 0x000002 ), 39 Model_iPAQ_H36xx = ( Model_iPAQ | 0x000002 ),
40 Model_iPAQ_H37xx = ( Model_iPAQ | 0x000004 ), 40 Model_iPAQ_H37xx = ( Model_iPAQ | 0x000004 ),
41 Model_iPAQ_H38xx = ( Model_iPAQ | 0x000008 ), 41 Model_iPAQ_H38xx = ( Model_iPAQ | 0x000008 ),
42 Model_iPAQ_H39xx = ( Model_iPAQ | 0x000010 ), 42 Model_iPAQ_H39xx = ( Model_iPAQ | 0x000010 ),
43 43
44 Model_Zaurus = ( 2 << 24 ), 44 Model_Zaurus = ( 2 << 24 ),
45 45
46 Model_Zaurus_SL5000 = ( Model_Zaurus | 0x000001 ), 46 Model_Zaurus_SL5000 = ( Model_Zaurus | 0x000001 ),
47 Model_Zaurus_SL5500 = ( Model_Zaurus | 0x000002 ),
47}; 48};
48 49
49 enum OVendor { 50 enum OVendor {
50 Vendor_Unknown, 51 Vendor_Unknown,
51 52
52 Vendor_HP, 53 Vendor_HP,
53 Vendor_Sharp 54 Vendor_Sharp
54 }; 55 };
55 56
56enum OSystem { 57enum OSystem {
57 System_Unknown, 58 System_Unknown,
58 59