author | sandman <sandman> | 2002-09-05 19:10:48 (UTC) |
---|---|---|
committer | sandman <sandman> | 2002-09-05 19:10:48 (UTC) |
commit | dd0222d2ec7a8f7363e746b079a46034d80d3466 (patch) (unidiff) | |
tree | cb28ec395f5684a787d6c835c4cfe1ee04221064 | |
parent | b95c5502fb1b7425fe0cc503a17d8dd3658b032b (diff) | |
download | opie-dd0222d2ec7a8f7363e746b079a46034d80d3466.zip opie-dd0222d2ec7a8f7363e746b079a46034d80d3466.tar.gz opie-dd0222d2ec7a8f7363e746b079a46034d80d3466.tar.bz2 |
suspend code now also calls sync() to flush fs caches (just like apm tool)
-rw-r--r-- | libopie/odevice.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp index 1da8862..2f40731 100644 --- a/libopie/odevice.cpp +++ b/libopie/odevice.cpp | |||
@@ -101,110 +101,112 @@ ODevice *ODevice::inst ( ) | |||
101 | dev-> init ( ); | 101 | dev-> init ( ); |
102 | } | 102 | } |
103 | return dev; | 103 | return dev; |
104 | } | 104 | } |
105 | 105 | ||
106 | ODevice::ODevice ( ) | 106 | ODevice::ODevice ( ) |
107 | { | 107 | { |
108 | d = new ODeviceData; | 108 | d = new ODeviceData; |
109 | 109 | ||
110 | d-> m_modelstr = "Unknown"; | 110 | d-> m_modelstr = "Unknown"; |
111 | d-> m_model = OMODEL_Unknown; | 111 | d-> m_model = OMODEL_Unknown; |
112 | d-> m_vendorstr = "Unkown"; | 112 | d-> m_vendorstr = "Unkown"; |
113 | d-> m_vendor = OVENDOR_Unknown; | 113 | d-> m_vendor = OVENDOR_Unknown; |
114 | d-> m_systemstr = "Unkown"; | 114 | d-> m_systemstr = "Unkown"; |
115 | d-> m_system = OSYSTEM_Unknown; | 115 | d-> m_system = OSYSTEM_Unknown; |
116 | d-> m_sysverstr = "0.0"; | 116 | d-> m_sysverstr = "0.0"; |
117 | } | 117 | } |
118 | 118 | ||
119 | void ODevice::init ( ) | 119 | void ODevice::init ( ) |
120 | { | 120 | { |
121 | } | 121 | } |
122 | 122 | ||
123 | ODevice::~ODevice ( ) | 123 | ODevice::~ODevice ( ) |
124 | { | 124 | { |
125 | delete d; | 125 | delete d; |
126 | } | 126 | } |
127 | 127 | ||
128 | //#include <linux/apm_bios.h> | 128 | //#include <linux/apm_bios.h> |
129 | 129 | ||
130 | //#define APM_IOC_SUSPEND _IO('A',2) | 130 | //#define APM_IOC_SUSPEND _IO('A',2) |
131 | 131 | ||
132 | #define APM_IOC_SUSPEND (( 0<<30 ) | ( 'A'<<8 ) | ( 2 ) | ( 0<<16 )) | 132 | #define APM_IOC_SUSPEND (( 0<<30 ) | ( 'A'<<8 ) | ( 2 ) | ( 0<<16 )) |
133 | 133 | ||
134 | bool ODevice::suspend ( ) | 134 | bool ODevice::suspend ( ) |
135 | { | 135 | { |
136 | if ( d-> m_model == OMODEL_Unknown ) // better don't suspend in qvfb / on unkown devices | 136 | if ( d-> m_model == OMODEL_Unknown ) // better don't suspend in qvfb / on unkown devices |
137 | return false; | 137 | return false; |
138 | 138 | ||
139 | int fd; | 139 | int fd; |
140 | bool res = false; | 140 | bool res = false; |
141 | 141 | ||
142 | if ((( fd = ::open ( "/dev/apm_bios", O_RDWR )) >= 0 ) || | 142 | if ((( fd = ::open ( "/dev/apm_bios", O_RDWR )) >= 0 ) || |
143 | (( fd = ::open ( "/dev/misc/apm_bios",O_RDWR )) >= 0 )) { | 143 | (( fd = ::open ( "/dev/misc/apm_bios",O_RDWR )) >= 0 )) { |
144 | struct timeval tvs, tvn; | 144 | struct timeval tvs, tvn; |
145 | 145 | ||
146 | ::signal ( SIGTSTP, SIG_IGN );// we don't want to be stopped | 146 | ::signal ( SIGTSTP, SIG_IGN );// we don't want to be stopped |
147 | ::gettimeofday ( &tvs, 0 ); | 147 | ::gettimeofday ( &tvs, 0 ); |
148 | 148 | ||
149 | ::sync ( ); // flush fs caches | ||
150 | |||
149 | res = ( ::ioctl ( fd, APM_IOC_SUSPEND ) == 0 ); // tell the kernel to "start" suspending | 151 | res = ( ::ioctl ( fd, APM_IOC_SUSPEND ) == 0 ); // tell the kernel to "start" suspending |
150 | ::close ( fd ); | ||
151 | 152 | ||
152 | if ( res ) { | 153 | if ( res ) { |
153 | ::kill ( -::getpid ( ), SIGTSTP ); // stop everthing in out process group | 154 | ::kill ( -::getpid ( ), SIGTSTP ); // stop everthing in our process group |
154 | 155 | ||
155 | do { // wait at most 1.5 sec: either suspend didn't work or the device resumed | 156 | do { // wait at most 1.5 sec: either suspend didn't work or the device resumed |
156 | ::usleep ( 200 * 1000 ); | 157 | ::usleep ( 200 * 1000 ); |
157 | ::gettimeofday ( &tvn, 0 ); | 158 | ::gettimeofday ( &tvn, 0 ); |
158 | } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < 1500 ); | 159 | } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < 1500 ); |
159 | 160 | ||
160 | ::kill ( -::getpid ( ), SIGCONT ); // continue everything in our process group | 161 | ::kill ( -::getpid ( ), SIGCONT ); // continue everything in our process group |
161 | } | 162 | } |
162 | 163 | ||
164 | ::close ( fd ); | ||
163 | ::signal ( SIGTSTP, SIG_DFL ); | 165 | ::signal ( SIGTSTP, SIG_DFL ); |
164 | } | 166 | } |
165 | 167 | ||
166 | return res; | 168 | return res; |
167 | } | 169 | } |
168 | 170 | ||
169 | 171 | ||
170 | QString ODevice::vendorString ( ) | 172 | QString ODevice::vendorString ( ) |
171 | { | 173 | { |
172 | return d-> m_vendorstr; | 174 | return d-> m_vendorstr; |
173 | } | 175 | } |
174 | 176 | ||
175 | OVendor ODevice::vendor ( ) | 177 | OVendor ODevice::vendor ( ) |
176 | { | 178 | { |
177 | return d-> m_vendor; | 179 | return d-> m_vendor; |
178 | } | 180 | } |
179 | 181 | ||
180 | QString ODevice::modelString ( ) | 182 | QString ODevice::modelString ( ) |
181 | { | 183 | { |
182 | return d-> m_modelstr; | 184 | return d-> m_modelstr; |
183 | } | 185 | } |
184 | 186 | ||
185 | OModel ODevice::model ( ) | 187 | OModel ODevice::model ( ) |
186 | { | 188 | { |
187 | return d-> m_model; | 189 | return d-> m_model; |
188 | } | 190 | } |
189 | 191 | ||
190 | QString ODevice::systemString ( ) | 192 | QString ODevice::systemString ( ) |
191 | { | 193 | { |
192 | return d-> m_systemstr; | 194 | return d-> m_systemstr; |
193 | } | 195 | } |
194 | 196 | ||
195 | OSystem ODevice::system ( ) | 197 | OSystem ODevice::system ( ) |
196 | { | 198 | { |
197 | return d-> m_system; | 199 | return d-> m_system; |
198 | } | 200 | } |
199 | 201 | ||
200 | QString ODevice::systemVersionString ( ) | 202 | QString ODevice::systemVersionString ( ) |
201 | { | 203 | { |
202 | return d-> m_sysverstr; | 204 | return d-> m_sysverstr; |
203 | } | 205 | } |
204 | 206 | ||
205 | void ODevice::alarmSound ( ) | 207 | void ODevice::alarmSound ( ) |
206 | { | 208 | { |
207 | #ifndef QT_QWS_EBX | 209 | #ifndef QT_QWS_EBX |
208 | #ifndef QT_NO_SOUND | 210 | #ifndef QT_NO_SOUND |
209 | static Sound snd ( "alarm" ); | 211 | static Sound snd ( "alarm" ); |
210 | 212 | ||