summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/device/odevice_abstractmobiledevice.cpp2
-rw-r--r--libopie2/opiecore/device/odevice_zaurus.cpp2
2 files changed, 4 insertions, 0 deletions
diff --git a/libopie2/opiecore/device/odevice_abstractmobiledevice.cpp b/libopie2/opiecore/device/odevice_abstractmobiledevice.cpp
index dbe9364..b446d05 100644
--- a/libopie2/opiecore/device/odevice_abstractmobiledevice.cpp
+++ b/libopie2/opiecore/device/odevice_abstractmobiledevice.cpp
@@ -61,16 +61,17 @@ bool OAbstractMobileDevice::suspend() {
61 if ( !isQWS( ) ) // only qwsserver is allowed to suspend 61 if ( !isQWS( ) ) // only qwsserver is allowed to suspend
62 return false; 62 return false;
63 63
64 bool res = false; 64 bool res = false;
65 65
66 { 66 {
67 QCopEnvelope( "QPE/System", "aboutToSuspend()" ); 67 QCopEnvelope( "QPE/System", "aboutToSuspend()" );
68 } 68 }
69 qApp->processEvents(); // ensure the qcop call is being processed asap
69 70
70 struct timeval tvs, tvn; 71 struct timeval tvs, tvn;
71 ::gettimeofday ( &tvs, 0 ); 72 ::gettimeofday ( &tvs, 0 );
72 73
73 ::sync(); // flush fs caches 74 ::sync(); // flush fs caches
74 res = ( ::system ( "apm --suspend" ) == 0 ); 75 res = ( ::system ( "apm --suspend" ) == 0 );
75 76
76 // This is needed because some apm implementations are asynchronous and we 77 // This is needed because some apm implementations are asynchronous and we
@@ -82,16 +83,17 @@ bool OAbstractMobileDevice::suspend() {
82 ::usleep ( 200 * 1000 ); 83 ::usleep ( 200 * 1000 );
83 ::gettimeofday ( &tvn, 0 ); 84 ::gettimeofday ( &tvn, 0 );
84 } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < m_timeOut ); 85 } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < m_timeOut );
85 } 86 }
86 87
87 { 88 {
88 QCopEnvelope( "QPE/System", "returnFromSuspend()" ); 89 QCopEnvelope( "QPE/System", "returnFromSuspend()" );
89 } 90 }
91 qApp->processEvents(); // ensure the qcop call is being processed asap
90 92
91 return res; 93 return res;
92} 94}
93 95
94//#include <linux/fb.h> better not rely on kernel headers in userspace ... 96//#include <linux/fb.h> better not rely on kernel headers in userspace ...
95 97
96// _IO and friends are only defined in kernel headers ... 98// _IO and friends are only defined in kernel headers ...
97#define OD_IOC(dir,type,number,size) (( dir << 30 ) | ( type << 8 ) | ( number ) | ( size << 16 )) 99#define OD_IOC(dir,type,number,size) (( dir << 30 ) | ( type << 8 ) | ( number ) | ( size << 16 ))
diff --git a/libopie2/opiecore/device/odevice_zaurus.cpp b/libopie2/opiecore/device/odevice_zaurus.cpp
index 5d48488..2b2467c 100644
--- a/libopie2/opiecore/device/odevice_zaurus.cpp
+++ b/libopie2/opiecore/device/odevice_zaurus.cpp
@@ -710,16 +710,17 @@ bool Zaurus::filter ( int /*unicode*/, int keycode, int modifiers, bool isPress,
710bool Zaurus::suspend() { 710bool Zaurus::suspend() {
711 if ( !isQWS( ) ) // only qwsserver is allowed to suspend 711 if ( !isQWS( ) ) // only qwsserver is allowed to suspend
712 return false; 712 return false;
713 713
714 bool res = false; 714 bool res = false;
715 { 715 {
716 QCopEnvelope( "QPE/System", "aboutToSuspend()" ); 716 QCopEnvelope( "QPE/System", "aboutToSuspend()" );
717 } 717 }
718 qApp->processEvents(); // ensure the qcop call is being processed asap
718 719
719 struct timeval tvs, tvn; 720 struct timeval tvs, tvn;
720 ::gettimeofday ( &tvs, 0 ); 721 ::gettimeofday ( &tvs, 0 );
721 722
722 ::sync(); // flush fs caches 723 ::sync(); // flush fs caches
723 res = ( ::system ( "apm --suspend" ) == 0 ); 724 res = ( ::system ( "apm --suspend" ) == 0 );
724 725
725 // This is needed because some apm implementations are asynchronous and we 726 // This is needed because some apm implementations are asynchronous and we
@@ -732,11 +733,12 @@ bool Zaurus::suspend() {
732 ::usleep ( 200 * 1000 ); 733 ::usleep ( 200 * 1000 );
733 ::gettimeofday ( &tvn, 0 ); 734 ::gettimeofday ( &tvn, 0 );
734 } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < m_timeOut ); 735 } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < m_timeOut );
735 } 736 }
736 737
737 { 738 {
738 QCopEnvelope( "QPE/System", "returnFromSuspend()" ); 739 QCopEnvelope( "QPE/System", "returnFromSuspend()" );
739 } 740 }
741 qApp->processEvents(); // ensure the qcop call is being processed asap
740 742
741 return res; 743 return res;
742} 744}