author | mickeyl <mickeyl> | 2005-06-25 15:29:59 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2005-06-25 15:29:59 (UTC) |
commit | 790aeb8898d635468c2b9e24fd16a70aab64b1dd (patch) (unidiff) | |
tree | 72139f02106b88325efbb39fc11f5ccd79ce29fb | |
parent | 3d434ac35915afe7f7035468ca18656264a91c52 (diff) | |
download | opie-790aeb8898d635468c2b9e24fd16a70aab64b1dd.zip opie-790aeb8898d635468c2b9e24fd16a70aab64b1dd.tar.gz opie-790aeb8898d635468c2b9e24fd16a70aab64b1dd.tar.bz2 |
- fix logic in isEmpty() and isSuspended()
- add convenience API productIdentityVendor()
-rw-r--r-- | libopie2/opiecore/linux/opcmciasystem.cpp | 13 | ||||
-rw-r--r-- | libopie2/opiecore/linux/opcmciasystem.h | 8 |
2 files changed, 16 insertions, 5 deletions
diff --git a/libopie2/opiecore/linux/opcmciasystem.cpp b/libopie2/opiecore/linux/opcmciasystem.cpp index a5725f1..21c5a84 100644 --- a/libopie2/opiecore/linux/opcmciasystem.cpp +++ b/libopie2/opiecore/linux/opcmciasystem.cpp | |||
@@ -1,396 +1,403 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the Opie Project | 2 | This file is part of the Opie Project |
3 | =. (C) 2005 Michael 'Mickey' Lauer <mickey@Vanille.de> | 3 | =. (C) 2005 Michael 'Mickey' Lauer <mickey@Vanille.de> |
4 | .=l. | 4 | .=l. |
5 | .>+-= | 5 | .>+-= |
6 | _;:, .> :=|. This program is free software; you can | 6 | _;:, .> :=|. This program is free software; you can |
7 | .> <`_, > . <= redistribute it and/or modify it under | 7 | .> <`_, > . <= redistribute it and/or modify it under |
8 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 8 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
9 | .="- .-=="i, .._ License as published by the Free Software | 9 | .="- .-=="i, .._ License as published by the Free Software |
10 | - . .-<_> .<> Foundation; version 2 of the License. | 10 | - . .-<_> .<> Foundation; version 2 of the License. |
11 | ._= =} : | 11 | ._= =} : |
12 | .%`+i> _;_. | 12 | .%`+i> _;_. |
13 | .i_,=:_. -<s. This program is distributed in the hope that | 13 | .i_,=:_. -<s. This program is distributed in the hope that |
14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
15 | : .. .:, . . . without even the implied warranty of | 15 | : .. .:, . . . without even the implied warranty of |
16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU | 17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU |
18 | ..}^=.= = ; Library General Public License for more | 18 | ..}^=.= = ; Library General Public License for more |
19 | ++= -. .` .: details. | 19 | ++= -. .` .: details. |
20 | : = ...= . :.=- | 20 | : = ...= . :.=- |
21 | -. .:....=;==+<; You should have received a copy of the GNU | 21 | -. .:....=;==+<; You should have received a copy of the GNU |
22 | -_. . . )=. = Library General Public License along with | 22 | -_. . . )=. = Library General Public License along with |
23 | -- :-=` this library; see the file COPYING.LIB. | 23 | -- :-=` this library; see the file COPYING.LIB. |
24 | If not, write to the Free Software Foundation, | 24 | If not, write to the Free Software Foundation, |
25 | Inc., 59 Temple Place - Suite 330, | 25 | Inc., 59 Temple Place - Suite 330, |
26 | Boston, MA 02111-1307, USA. | 26 | Boston, MA 02111-1307, USA. |
27 | 27 | ||
28 | */ | 28 | */ |
29 | 29 | ||
30 | #include "opcmciasystem.h" | 30 | #include "opcmciasystem.h" |
31 | using namespace Opie::Core; | 31 | using namespace Opie::Core; |
32 | 32 | ||
33 | /* OPIE */ | 33 | /* OPIE */ |
34 | #include <opie2/odebug.h> | 34 | #include <opie2/odebug.h> |
35 | 35 | ||
36 | /* QT */ | 36 | /* QT */ |
37 | #include <qfile.h> | 37 | #include <qfile.h> |
38 | #include <qtextstream.h> | 38 | #include <qtextstream.h> |
39 | 39 | ||
40 | /* STD */ | 40 | /* STD */ |
41 | #include <errno.h> | 41 | #include <errno.h> |
42 | #include <fcntl.h> | 42 | #include <fcntl.h> |
43 | #include <string.h> | 43 | #include <string.h> |
44 | #include <stdlib.h> | 44 | #include <stdlib.h> |
45 | #include <sys/ioctl.h> | 45 | #include <sys/ioctl.h> |
46 | #include <sys/types.h> | 46 | #include <sys/types.h> |
47 | #include <sys/stat.h> | 47 | #include <sys/stat.h> |
48 | #include <unistd.h> | 48 | #include <unistd.h> |
49 | 49 | ||
50 | #define PROC_DEVICES "/proc/devices" | 50 | #define PROC_DEVICES "/proc/devices" |
51 | 51 | ||
52 | /*====================================================================================== | 52 | /*====================================================================================== |
53 | * OPcmciaSystem | 53 | * OPcmciaSystem |
54 | *======================================================================================*/ | 54 | *======================================================================================*/ |
55 | 55 | ||
56 | OPcmciaSystem* OPcmciaSystem::_instance = 0; | 56 | OPcmciaSystem* OPcmciaSystem::_instance = 0; |
57 | 57 | ||
58 | OPcmciaSystem::OPcmciaSystem() | 58 | OPcmciaSystem::OPcmciaSystem() |
59 | :_major( 0 ) | 59 | :_major( 0 ) |
60 | { | 60 | { |
61 | qDebug( "OPcmciaSystem::OPcmciaSystem()" ); | 61 | qDebug( "OPcmciaSystem::OPcmciaSystem()" ); |
62 | 62 | ||
63 | // get major node number out of /proc/devices | 63 | // get major node number out of /proc/devices |
64 | QFile procfile( PROC_DEVICES ); | 64 | QFile procfile( PROC_DEVICES ); |
65 | if ( procfile.exists() && procfile.open( IO_ReadOnly ) ) | 65 | if ( procfile.exists() && procfile.open( IO_ReadOnly ) ) |
66 | { | 66 | { |
67 | QTextStream devstream( &procfile ); | 67 | QTextStream devstream( &procfile ); |
68 | devstream.readLine(); // skip header | 68 | devstream.readLine(); // skip header |
69 | while ( !devstream.atEnd() && !_major ) | 69 | while ( !devstream.atEnd() && !_major ) |
70 | { | 70 | { |
71 | int nodenumber; | 71 | int nodenumber; |
72 | QString driver; | 72 | QString driver; |
73 | devstream >> nodenumber >> driver; | 73 | devstream >> nodenumber >> driver; |
74 | if ( driver == "pcmcia" ) | 74 | if ( driver == "pcmcia" ) |
75 | { | 75 | { |
76 | qDebug( "OPcmciaSystem::OPcmciaSystem(): gotcha! pcmcia node number = %d", nodenumber ); | 76 | qDebug( "OPcmciaSystem::OPcmciaSystem(): gotcha! pcmcia node number = %d", nodenumber ); |
77 | _major = nodenumber; | 77 | _major = nodenumber; |
78 | break; | 78 | break; |
79 | } | 79 | } |
80 | } | 80 | } |
81 | } | 81 | } |
82 | else | 82 | else |
83 | { | 83 | { |
84 | qWarning( "OPcmciaSystem::OPcmciaSystem() - can't open /proc/devices - continuing with limited functionality." ); | 84 | qWarning( "OPcmciaSystem::OPcmciaSystem() - can't open /proc/devices - continuing with limited functionality." ); |
85 | } | 85 | } |
86 | 86 | ||
87 | synchronize(); | 87 | synchronize(); |
88 | } | 88 | } |
89 | 89 | ||
90 | void OPcmciaSystem::synchronize() | 90 | void OPcmciaSystem::synchronize() |
91 | { | 91 | { |
92 | qDebug( "OPcmciaSystem::synchronize()" ); | 92 | qDebug( "OPcmciaSystem::synchronize()" ); |
93 | _interfaces.clear(); | 93 | _interfaces.clear(); |
94 | 94 | ||
95 | //NOTE: We _could_ use ioctl's here as well, however we want to know if | 95 | //NOTE: We _could_ use ioctl's here as well, however we want to know if |
96 | // the card is recognized by the cardmgr (hence has a valid binding) | 96 | // the card is recognized by the cardmgr (hence has a valid binding) |
97 | // If it is not recognized yet, userland may want to provide a configuration dialog | 97 | // If it is not recognized yet, userland may want to provide a configuration dialog |
98 | //TODO: Revise for pcmciautils | 98 | //TODO: Revise for pcmciautils |
99 | 99 | ||
100 | QString fileName; | 100 | QString fileName; |
101 | if ( QFile::exists( "/var/run/stab" ) ) { fileName = "/var/run/stab"; } | 101 | if ( QFile::exists( "/var/run/stab" ) ) { fileName = "/var/run/stab"; } |
102 | else if ( QFile::exists( "/var/state/pcmcia/stab" ) ) { fileName = "/var/state/pcmcia/stab"; } | 102 | else if ( QFile::exists( "/var/state/pcmcia/stab" ) ) { fileName = "/var/state/pcmcia/stab"; } |
103 | else { fileName = "/var/lib/pcmcia/stab"; } | 103 | else { fileName = "/var/lib/pcmcia/stab"; } |
104 | QFile cardinfofile( fileName ); | 104 | QFile cardinfofile( fileName ); |
105 | if ( !cardinfofile.exists() || !cardinfofile.open( IO_ReadOnly ) ) | 105 | if ( !cardinfofile.exists() || !cardinfofile.open( IO_ReadOnly ) ) |
106 | { | 106 | { |
107 | qWarning( "pcmcia info file not found or unaccessible" ); | 107 | qWarning( "pcmcia info file not found or unaccessible" ); |
108 | return; | 108 | return; |
109 | } | 109 | } |
110 | QTextStream cardinfo( &cardinfofile ); | 110 | QTextStream cardinfo( &cardinfofile ); |
111 | while ( !cardinfo.atEnd() ) | 111 | while ( !cardinfo.atEnd() ) |
112 | { | 112 | { |
113 | QString strSocket; | 113 | QString strSocket; |
114 | int numSocket; | 114 | int numSocket; |
115 | char colon; | 115 | char colon; |
116 | QString cardName; | 116 | QString cardName; |
117 | cardinfo >> strSocket >> numSocket >> colon; | 117 | cardinfo >> strSocket >> numSocket >> colon; |
118 | cardName = cardinfo.readLine().stripWhiteSpace(); | 118 | cardName = cardinfo.readLine().stripWhiteSpace(); |
119 | qDebug( "strSocket = '%s', numSocket = '%d', colon = '%c', cardName = '%s'", (const char*) strSocket, numSocket, colon, ( const char*) cardName ); | 119 | qDebug( "strSocket = '%s', numSocket = '%d', colon = '%c', cardName = '%s'", (const char*) strSocket, numSocket, colon, ( const char*) cardName ); |
120 | if ( strSocket == "Socket" && colon == ':' ) | 120 | if ( strSocket == "Socket" && colon == ':' ) |
121 | { | 121 | { |
122 | _interfaces.append( new OPcmciaSocket( _major, numSocket, this, (const char*) cardName ) ); | 122 | _interfaces.append( new OPcmciaSocket( _major, numSocket, this, (const char*) cardName ) ); |
123 | } | 123 | } |
124 | else | 124 | else |
125 | { | 125 | { |
126 | continue; | 126 | continue; |
127 | } | 127 | } |
128 | } | 128 | } |
129 | } | 129 | } |
130 | 130 | ||
131 | 131 | ||
132 | int OPcmciaSystem::count() const | 132 | int OPcmciaSystem::count() const |
133 | { | 133 | { |
134 | return _interfaces.count(); | 134 | return _interfaces.count(); |
135 | } | 135 | } |
136 | 136 | ||
137 | 137 | ||
138 | int OPcmciaSystem::cardCount() const | 138 | int OPcmciaSystem::cardCount() const |
139 | { | 139 | { |
140 | int nonEmpty = 0; | 140 | int nonEmpty = 0; |
141 | OPcmciaSystem::CardIterator it = iterator(); | 141 | OPcmciaSystem::CardIterator it = iterator(); |
142 | while ( it.current() ) | 142 | while ( it.current() ) |
143 | { | 143 | { |
144 | if ( !it.current()->isEmpty() ) nonEmpty++; | 144 | if ( !it.current()->isEmpty() ) nonEmpty++; |
145 | ++it; | 145 | ++it; |
146 | } | 146 | } |
147 | return nonEmpty; | 147 | return nonEmpty; |
148 | } | 148 | } |
149 | 149 | ||
150 | 150 | ||
151 | OPcmciaSocket* OPcmciaSystem::socket( unsigned int number ) | 151 | OPcmciaSocket* OPcmciaSystem::socket( unsigned int number ) |
152 | { | 152 | { |
153 | return _interfaces.at( number ); | 153 | return _interfaces.at( number ); |
154 | } | 154 | } |
155 | 155 | ||
156 | 156 | ||
157 | OPcmciaSystem* OPcmciaSystem::instance() | 157 | OPcmciaSystem* OPcmciaSystem::instance() |
158 | { | 158 | { |
159 | if ( !_instance ) _instance = new OPcmciaSystem(); | 159 | if ( !_instance ) _instance = new OPcmciaSystem(); |
160 | return _instance; | 160 | return _instance; |
161 | } | 161 | } |
162 | 162 | ||
163 | 163 | ||
164 | OPcmciaSystem::CardIterator OPcmciaSystem::iterator() const | 164 | OPcmciaSystem::CardIterator OPcmciaSystem::iterator() const |
165 | { | 165 | { |
166 | return OPcmciaSystem::CardIterator( _interfaces ); | 166 | return OPcmciaSystem::CardIterator( _interfaces ); |
167 | } | 167 | } |
168 | 168 | ||
169 | 169 | ||
170 | /*====================================================================================== | 170 | /*====================================================================================== |
171 | * OPcmciaSocket | 171 | * OPcmciaSocket |
172 | *======================================================================================*/ | 172 | *======================================================================================*/ |
173 | 173 | ||
174 | OPcmciaSocket::OPcmciaSocket( int major, int socket, QObject* parent, const char* name ) | 174 | OPcmciaSocket::OPcmciaSocket( int major, int socket, QObject* parent, const char* name ) |
175 | :QObject( parent, name ), _major( major ), _socket( socket ) | 175 | :QObject( parent, name ), _major( major ), _socket( socket ) |
176 | { | 176 | { |
177 | qDebug( "OPcmciaSocket::OPcmciaSocket()" ); | 177 | qDebug( "OPcmciaSocket::OPcmciaSocket()" ); |
178 | init(); | 178 | init(); |
179 | } | 179 | } |
180 | 180 | ||
181 | 181 | ||
182 | OPcmciaSocket::~OPcmciaSocket() | 182 | OPcmciaSocket::~OPcmciaSocket() |
183 | { | 183 | { |
184 | qDebug( "OPcmciaSocket::~OPcmciaSocket()" ); | 184 | qDebug( "OPcmciaSocket::~OPcmciaSocket()" ); |
185 | cleanup(); | 185 | cleanup(); |
186 | } | 186 | } |
187 | 187 | ||
188 | 188 | ||
189 | /* internal */ void OPcmciaSocket::init() | 189 | /* internal */ void OPcmciaSocket::init() |
190 | { | 190 | { |
191 | // open control socket and gather file descriptor | 191 | // open control socket and gather file descriptor |
192 | if ( _major ) | 192 | if ( _major ) |
193 | { | 193 | { |
194 | dev_t dev = makedev( _major, _socket ); | 194 | dev_t dev = makedev( _major, _socket ); |
195 | 195 | ||
196 | #ifdef OPCMCIA_DEBUG | 196 | #ifdef OPCMCIA_DEBUG |
197 | QString filename = "/tmp/opcmciasystem-debug"; | 197 | QString filename = "/tmp/opcmciasystem-debug"; |
198 | if ( QFile::exists( filename ) ) | 198 | if ( QFile::exists( filename ) ) |
199 | #else | 199 | #else |
200 | QString filename = QString().sprintf( "/tmp/opcmciasystem-%d", ::getpid() ); | 200 | QString filename = QString().sprintf( "/tmp/opcmciasystem-%d", ::getpid() ); |
201 | if ( ::mknod( (const char*) filename, ( S_IFCHR|S_IREAD|S_IWRITE ), dev ) == 0 ) | 201 | if ( ::mknod( (const char*) filename, ( S_IFCHR|S_IREAD|S_IWRITE ), dev ) == 0 ) |
202 | #endif | 202 | #endif |
203 | { | 203 | { |
204 | _fd = ::open( (const char*) filename, O_RDONLY); | 204 | _fd = ::open( (const char*) filename, O_RDONLY); |
205 | if ( !_fd ) | 205 | if ( !_fd ) |
206 | { | 206 | { |
207 | qWarning( "OPcmciaSocket::init() - can't open control socket (%s)", strerror( errno ) ); | 207 | qWarning( "OPcmciaSocket::init() - can't open control socket (%s)", strerror( errno ) ); |
208 | } | 208 | } |
209 | #ifndef OPCMCIA_DEBUG | 209 | #ifndef OPCMCIA_DEBUG |
210 | else | 210 | else |
211 | { | 211 | { |
212 | ::unlink( (const char*) filename ); | 212 | ::unlink( (const char*) filename ); |
213 | } | 213 | } |
214 | #endif | 214 | #endif |
215 | } | 215 | } |
216 | else | 216 | else |
217 | { | 217 | { |
218 | qWarning( "OPcmciaSocket::init() - can't create device node '%s' (%s)", (const char*) filename, strerror( errno ) ); | 218 | qWarning( "OPcmciaSocket::init() - can't create device node '%s' (%s)", (const char*) filename, strerror( errno ) ); |
219 | } | 219 | } |
220 | } | 220 | } |
221 | } | 221 | } |
222 | 222 | ||
223 | /* internal */ void OPcmciaSocket::cleanup() | 223 | /* internal */ void OPcmciaSocket::cleanup() |
224 | { | 224 | { |
225 | // close control socket | 225 | // close control socket |
226 | } | 226 | } |
227 | 227 | ||
228 | /* internal */ bool OPcmciaSocket::getTuple( cisdata_t tuple ) const | 228 | /* internal */ bool OPcmciaSocket::getTuple( cisdata_t tuple ) const |
229 | { | 229 | { |
230 | _ioctlarg.tuple.DesiredTuple = tuple; | 230 | _ioctlarg.tuple.DesiredTuple = tuple; |
231 | _ioctlarg.tuple.Attributes = TUPLE_RETURN_COMMON; | 231 | _ioctlarg.tuple.Attributes = TUPLE_RETURN_COMMON; |
232 | _ioctlarg.tuple.TupleOffset = 0; | 232 | _ioctlarg.tuple.TupleOffset = 0; |
233 | 233 | ||
234 | int result; | 234 | int result; |
235 | result = ::ioctl(_fd, DS_GET_FIRST_TUPLE, &_ioctlarg); | 235 | result = ::ioctl(_fd, DS_GET_FIRST_TUPLE, &_ioctlarg); |
236 | if ( result != 0 ) | 236 | if ( result != 0 ) |
237 | { | 237 | { |
238 | qWarning( "OPcmciaSocket::getTuple() - DS_GET_FIRST_TUPLE failed (%s)", strerror( errno ) ); | 238 | qWarning( "OPcmciaSocket::getTuple() - DS_GET_FIRST_TUPLE failed (%s)", strerror( errno ) ); |
239 | return false; | 239 | return false; |
240 | } | 240 | } |
241 | 241 | ||
242 | result = ::ioctl(_fd, DS_GET_TUPLE_DATA, &_ioctlarg); | 242 | result = ::ioctl(_fd, DS_GET_TUPLE_DATA, &_ioctlarg); |
243 | if ( result != 0 ) | 243 | if ( result != 0 ) |
244 | { | 244 | { |
245 | qWarning( "OPcmciaSocket::getTuple() - DS_GET_TUPLE_DATA failed (%s)", strerror( errno ) ); | 245 | qWarning( "OPcmciaSocket::getTuple() - DS_GET_TUPLE_DATA failed (%s)", strerror( errno ) ); |
246 | return false; | 246 | return false; |
247 | } | 247 | } |
248 | 248 | ||
249 | result = ::ioctl( _fd, DS_PARSE_TUPLE, &_ioctlarg ); | 249 | result = ::ioctl( _fd, DS_PARSE_TUPLE, &_ioctlarg ); |
250 | if ( result != 0 ) | 250 | if ( result != 0 ) |
251 | { | 251 | { |
252 | qWarning( "OPcmciaSocket::getTuple() - DS_PARSE_TUPLE failed (%s)", strerror( errno ) ); | 252 | qWarning( "OPcmciaSocket::getTuple() - DS_PARSE_TUPLE failed (%s)", strerror( errno ) ); |
253 | return false; | 253 | return false; |
254 | } | 254 | } |
255 | 255 | ||
256 | return true; | 256 | return true; |
257 | } | 257 | } |
258 | 258 | ||
259 | 259 | ||
260 | int OPcmciaSocket::number() const | 260 | int OPcmciaSocket::number() const |
261 | { | 261 | { |
262 | return _socket; | 262 | return _socket; |
263 | } | 263 | } |
264 | 264 | ||
265 | 265 | ||
266 | QString OPcmciaSocket::identity() const | 266 | QString OPcmciaSocket::identity() const |
267 | { | 267 | { |
268 | return ( strcmp( name(), "empty" ) == 0 ) ? "<Empty Socket>" : name(); | 268 | return ( strcmp( name(), "empty" ) == 0 ) ? "<Empty Socket>" : name(); |
269 | } | 269 | } |
270 | 270 | ||
271 | 271 | ||
272 | const OPcmciaSocket::OPcmciaSocketCardStatus OPcmciaSocket::status() const | 272 | const OPcmciaSocket::OPcmciaSocketCardStatus OPcmciaSocket::status() const |
273 | { | 273 | { |
274 | cs_status_t cs_status; | 274 | cs_status_t cs_status; |
275 | cs_status.Function = 0; | 275 | cs_status.Function = 0; |
276 | int result = ::ioctl( _fd, DS_GET_STATUS, &cs_status ); | 276 | int result = ::ioctl( _fd, DS_GET_STATUS, &cs_status ); |
277 | if ( result != 0 ) | 277 | if ( result != 0 ) |
278 | { | 278 | { |
279 | qWarning( "OPcmciaSocket::status() - DS_GET_STATUS failed (%s)", strerror( errno ) ); | 279 | qWarning( "OPcmciaSocket::status() - DS_GET_STATUS failed (%s)", strerror( errno ) ); |
280 | // return ( errno == -ENODEV ) ? Empty : Unknown; | ||
280 | return Unknown; | 281 | return Unknown; |
281 | } | 282 | } |
282 | else | 283 | else |
283 | { | 284 | { |
284 | qDebug( " card status = 0x%08x", cs_status.CardState ); | 285 | qDebug( " card status = 0x%08x", cs_status.CardState ); |
285 | qDebug( " socket status = 0x%08x", cs_status.SocketState ); | 286 | qDebug( " socket status = 0x%08x", cs_status.SocketState ); |
286 | return (OPcmciaSocket::OPcmciaSocketCardStatus) (cs_status.CardState + cs_status.SocketState); | 287 | return (OPcmciaSocket::OPcmciaSocketCardStatus) (cs_status.CardState + cs_status.SocketState); |
287 | } | 288 | } |
288 | } | 289 | } |
289 | 290 | ||
290 | 291 | ||
291 | bool OPcmciaSocket::isUnsupported() const | 292 | bool OPcmciaSocket::isUnsupported() const |
292 | { | 293 | { |
293 | return ( strcmp( name(), "unsupported card" ) == 0 ); | 294 | return ( strcmp( name(), "unsupported card" ) == 0 ); |
294 | } | 295 | } |
295 | 296 | ||
296 | 297 | ||
297 | bool OPcmciaSocket::isEmpty() const | 298 | bool OPcmciaSocket::isEmpty() const |
298 | { | 299 | { |
299 | return ! status() && ( Occupied || OccupiedCardBus ); | 300 | return !(status() & ( Occupied | OccupiedCardBus )); |
300 | } | 301 | } |
301 | 302 | ||
302 | 303 | ||
303 | bool OPcmciaSocket::isSuspended() const | 304 | bool OPcmciaSocket::isSuspended() const |
304 | { | 305 | { |
305 | return status() && Suspended; | 306 | return status() & Suspended; |
306 | } | 307 | } |
307 | 308 | ||
308 | 309 | ||
309 | bool OPcmciaSocket::eject() | 310 | bool OPcmciaSocket::eject() |
310 | { | 311 | { |
311 | return ::ioctl( _fd, DS_EJECT_CARD ) != -1; | 312 | return ::ioctl( _fd, DS_EJECT_CARD ) != -1; |
312 | } | 313 | } |
313 | 314 | ||
314 | 315 | ||
315 | bool OPcmciaSocket::insert() | 316 | bool OPcmciaSocket::insert() |
316 | { | 317 | { |
317 | return ::ioctl( _fd, DS_INSERT_CARD ) != -1; | 318 | return ::ioctl( _fd, DS_INSERT_CARD ) != -1; |
318 | } | 319 | } |
319 | 320 | ||
320 | 321 | ||
321 | bool OPcmciaSocket::suspend() | 322 | bool OPcmciaSocket::suspend() |
322 | { | 323 | { |
323 | return ::ioctl( _fd, DS_SUSPEND_CARD ) != -1; | 324 | return ::ioctl( _fd, DS_SUSPEND_CARD ) != -1; |
324 | } | 325 | } |
325 | 326 | ||
326 | 327 | ||
327 | bool OPcmciaSocket::resume() | 328 | bool OPcmciaSocket::resume() |
328 | { | 329 | { |
329 | return ::ioctl( _fd, DS_RESUME_CARD ) != -1; | 330 | return ::ioctl( _fd, DS_RESUME_CARD ) != -1; |
330 | } | 331 | } |
331 | 332 | ||
332 | 333 | ||
333 | bool OPcmciaSocket::reset() | 334 | bool OPcmciaSocket::reset() |
334 | { | 335 | { |
335 | return ::ioctl( _fd, DS_RESET_CARD ) != -1; | 336 | return ::ioctl( _fd, DS_RESET_CARD ) != -1; |
336 | } | 337 | } |
337 | 338 | ||
338 | 339 | ||
339 | QStringList OPcmciaSocket::productIdentity() const | 340 | QStringList OPcmciaSocket::productIdentityVector() const |
340 | { | 341 | { |
341 | QStringList list; | 342 | QStringList list; |
342 | cistpl_vers_1_t *vers = &_ioctlarg.tuple_parse.parse.version_1; | 343 | cistpl_vers_1_t *vers = &_ioctlarg.tuple_parse.parse.version_1; |
343 | vers->ns = 0; // number of strings | 344 | vers->ns = 0; // number of strings |
344 | if ( getTuple( CISTPL_VERS_1 ) ) | 345 | if ( getTuple( CISTPL_VERS_1 ) ) |
345 | { | 346 | { |
346 | qDebug( " NUMBER_OF_PRODIDs = %d", vers->ns ); | 347 | qDebug( " NUMBER_OF_PRODIDs = %d", vers->ns ); |
347 | for ( int i = 0; i < QMIN( CISTPL_VERS_1_MAX_PROD_STRINGS, vers->ns ); ++i ) | 348 | for ( int i = 0; i < QMIN( CISTPL_VERS_1_MAX_PROD_STRINGS, vers->ns ); ++i ) |
348 | { | 349 | { |
349 | qDebug( " PRODID = '%s'", vers->str+vers->ofs[i] ); | 350 | qDebug( " PRODID = '%s'", vers->str+vers->ofs[i] ); |
350 | list += vers->str+vers->ofs[i]; | 351 | list += vers->str+vers->ofs[i]; |
351 | } | 352 | } |
352 | } | 353 | } |
353 | else | 354 | else |
354 | { | 355 | { |
355 | list += "<unknown>"; | 356 | list += "<unknown>"; |
356 | } | 357 | } |
357 | return list; | 358 | return list; |
358 | } | 359 | } |
359 | 360 | ||
360 | 361 | ||
362 | QString OPcmciaSocket::productIdentity() const | ||
363 | { | ||
364 | return productIdentityVector().join( " " ).stripWhiteSpace(); | ||
365 | } | ||
366 | |||
367 | |||
361 | QString OPcmciaSocket::manufacturerIdentity() const | 368 | QString OPcmciaSocket::manufacturerIdentity() const |
362 | { | 369 | { |
363 | cistpl_manfid_t *manfid = &_ioctlarg.tuple_parse.parse.manfid; | 370 | cistpl_manfid_t *manfid = &_ioctlarg.tuple_parse.parse.manfid; |
364 | if ( getTuple( CISTPL_MANFID ) ) | 371 | if ( getTuple( CISTPL_MANFID ) ) |
365 | { | 372 | { |
366 | return QString().sprintf( "0x%04x, 0x%04x", manfid->manf, manfid->card ); | 373 | return QString().sprintf( "0x%04x, 0x%04x", manfid->manf, manfid->card ); |
367 | } | 374 | } |
368 | else | 375 | else |
369 | return "<unknown>"; | 376 | return "<unknown>"; |
370 | } | 377 | } |
371 | 378 | ||
372 | 379 | ||
373 | QString OPcmciaSocket::function() const | 380 | QString OPcmciaSocket::function() const |
374 | { | 381 | { |
375 | cistpl_funcid_t *funcid = &_ioctlarg.tuple_parse.parse.funcid; | 382 | cistpl_funcid_t *funcid = &_ioctlarg.tuple_parse.parse.funcid; |
376 | if ( getTuple( CISTPL_FUNCID ) ) | 383 | if ( getTuple( CISTPL_FUNCID ) ) |
377 | { | 384 | { |
378 | switch ( funcid->func ) | 385 | switch ( funcid->func ) |
379 | { | 386 | { |
380 | case 0: return "Multifunction"; break; | 387 | case 0: return "Multifunction"; break; |
381 | case 1: return "Memory"; break; | 388 | case 1: return "Memory"; break; |
382 | case 2: return "Serial"; break; | 389 | case 2: return "Serial"; break; |
383 | case 3: return "Parallel"; break; | 390 | case 3: return "Parallel"; break; |
384 | case 4: return "Fixed Disk"; break; | 391 | case 4: return "Fixed Disk"; break; |
385 | case 5: return "Video"; break; | 392 | case 5: return "Video"; break; |
386 | case 6: return "Network"; break; | 393 | case 6: return "Network"; break; |
387 | case 7: return "AIMS"; break; | 394 | case 7: return "AIMS"; break; |
388 | case 8: return "SCSI"; break; | 395 | case 8: return "SCSI"; break; |
389 | default: return "<unknown>"; break; | 396 | default: return "<unknown>"; break; |
390 | } | 397 | } |
391 | } | 398 | } |
392 | else | 399 | else |
393 | { | 400 | { |
394 | return "<unknown>"; | 401 | return "<unknown>"; |
395 | } | 402 | } |
396 | } | 403 | } |
diff --git a/libopie2/opiecore/linux/opcmciasystem.h b/libopie2/opiecore/linux/opcmciasystem.h index 0fd43cf..23d8c41 100644 --- a/libopie2/opiecore/linux/opcmciasystem.h +++ b/libopie2/opiecore/linux/opcmciasystem.h | |||
@@ -1,221 +1,225 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the Opie Project | 2 | This file is part of the Opie Project |
3 | =. (C) 2005 Michael 'Mickey' Lauer <mickey@Vanille.de> | 3 | =. (C) 2005 Michael 'Mickey' Lauer <mickey@Vanille.de> |
4 | .=l. | 4 | .=l. |
5 | .>+-= | 5 | .>+-= |
6 | _;:, .> :=|. This program is free software; you can | 6 | _;:, .> :=|. This program is free software; you can |
7 | .> <`_, > . <= redistribute it and/or modify it under | 7 | .> <`_, > . <= redistribute it and/or modify it under |
8 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 8 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
9 | .="- .-=="i, .._ License as published by the Free Software | 9 | .="- .-=="i, .._ License as published by the Free Software |
10 | - . .-<_> .<> Foundation; version 2 of the License. | 10 | - . .-<_> .<> Foundation; version 2 of the License. |
11 | ._= =} : | 11 | ._= =} : |
12 | .%`+i> _;_. | 12 | .%`+i> _;_. |
13 | .i_,=:_. -<s. This program is distributed in the hope that | 13 | .i_,=:_. -<s. This program is distributed in the hope that |
14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
15 | : .. .:, . . . without even the implied warranty of | 15 | : .. .:, . . . without even the implied warranty of |
16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU | 17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU |
18 | ..}^=.= = ; Library General Public License for more | 18 | ..}^=.= = ; Library General Public License for more |
19 | ++= -. .` .: details. | 19 | ++= -. .` .: details. |
20 | : = ...= . :.=- | 20 | : = ...= . :.=- |
21 | -. .:....=;==+<; You should have received a copy of the GNU | 21 | -. .:....=;==+<; You should have received a copy of the GNU |
22 | -_. . . )=. = Library General Public License along with | 22 | -_. . . )=. = Library General Public License along with |
23 | -- :-=` this library; see the file COPYING.LIB. | 23 | -- :-=` this library; see the file COPYING.LIB. |
24 | If not, write to the Free Software Foundation, | 24 | If not, write to the Free Software Foundation, |
25 | Inc., 59 Temple Place - Suite 330, | 25 | Inc., 59 Temple Place - Suite 330, |
26 | Boston, MA 02111-1307, USA. | 26 | Boston, MA 02111-1307, USA. |
27 | 27 | ||
28 | */ | 28 | */ |
29 | 29 | ||
30 | #ifndef OPCMCIASYSTEM_H | 30 | #ifndef OPCMCIASYSTEM_H |
31 | #define OPCMCIASYSTEM_H | 31 | #define OPCMCIASYSTEM_H |
32 | 32 | ||
33 | #include "linux_pcmcia.h" | 33 | #include "linux_pcmcia.h" |
34 | 34 | ||
35 | #include <qobject.h> | 35 | #include <qobject.h> |
36 | #include <qlist.h> | 36 | #include <qlist.h> |
37 | 37 | ||
38 | namespace Opie { | 38 | namespace Opie { |
39 | namespace Core { | 39 | namespace Core { |
40 | 40 | ||
41 | class OPcmciaSocket; | 41 | class OPcmciaSocket; |
42 | 42 | ||
43 | /*====================================================================================== | 43 | /*====================================================================================== |
44 | * OPcmciaSystem | 44 | * OPcmciaSystem |
45 | *======================================================================================*/ | 45 | *======================================================================================*/ |
46 | 46 | ||
47 | /** | 47 | /** |
48 | * @brief A container class for the linux pcmcia subsystem | 48 | * @brief A container class for the linux pcmcia subsystem |
49 | * | 49 | * |
50 | * This class provides access to all available pcmcia/cf cards on your device. | 50 | * This class provides access to all available pcmcia/cf cards on your device. |
51 | * | 51 | * |
52 | * @author Michael 'Mickey' Lauer <mickey@Vanille.de> | 52 | * @author Michael 'Mickey' Lauer <mickey@Vanille.de> |
53 | */ | 53 | */ |
54 | class OPcmciaSystem : public QObject | 54 | class OPcmciaSystem : public QObject |
55 | { | 55 | { |
56 | Q_OBJECT | 56 | Q_OBJECT |
57 | 57 | ||
58 | public: | 58 | public: |
59 | typedef QList<OPcmciaSocket> CardList; | 59 | typedef QList<OPcmciaSocket> CardList; |
60 | typedef QListIterator<OPcmciaSocket> CardIterator; | 60 | typedef QListIterator<OPcmciaSocket> CardIterator; |
61 | 61 | ||
62 | public: | 62 | public: |
63 | /** | 63 | /** |
64 | * @returns the number of available sockets | 64 | * @returns the number of available sockets |
65 | */ | 65 | */ |
66 | int count() const; | 66 | int count() const; |
67 | /** | 67 | /** |
68 | * @returns the number of populated sockets | 68 | * @returns the number of populated sockets |
69 | */ | 69 | */ |
70 | int cardCount() const; | 70 | int cardCount() const; |
71 | /** | 71 | /** |
72 | * @returns a pointer to the (one and only) @ref OSystem instance. | 72 | * @returns a pointer to the (one and only) @ref OSystem instance. |
73 | */ | 73 | */ |
74 | static OPcmciaSystem* instance(); | 74 | static OPcmciaSystem* instance(); |
75 | /** | 75 | /** |
76 | * @returns an iterator usable for iterating through all sound cards. | 76 | * @returns an iterator usable for iterating through all sound cards. |
77 | */ | 77 | */ |
78 | CardIterator iterator() const; | 78 | CardIterator iterator() const; |
79 | /** | 79 | /** |
80 | * @returns a pointer to the @ref OPcmciaSocket object correspinding to socket number n, or 0, if not found | 80 | * @returns a pointer to the @ref OPcmciaSocket object correspinding to socket number n, or 0, if not found |
81 | * @see OPcmciaSocket | 81 | * @see OPcmciaSocket |
82 | */ | 82 | */ |
83 | OPcmciaSocket* socket( unsigned int number ); | 83 | OPcmciaSocket* socket( unsigned int number ); |
84 | /** | 84 | /** |
85 | * @internal Rebuild the internal database | 85 | * @internal Rebuild the internal database |
86 | * @note Sometimes it might be useful to call this from client code, | 86 | * @note Sometimes it might be useful to call this from client code, |
87 | * e.g. after issuing a cardctl insert | 87 | * e.g. after issuing a cardctl insert |
88 | */ | 88 | */ |
89 | void synchronize(); | 89 | void synchronize(); |
90 | 90 | ||
91 | protected: | 91 | protected: |
92 | OPcmciaSystem(); | 92 | OPcmciaSystem(); |
93 | 93 | ||
94 | private: | 94 | private: |
95 | static OPcmciaSystem* _instance; | 95 | static OPcmciaSystem* _instance; |
96 | CardList _interfaces; | 96 | CardList _interfaces; |
97 | int _major; | 97 | int _major; |
98 | 98 | ||
99 | private: | 99 | private: |
100 | class Private; | 100 | class Private; |
101 | Private *d; | 101 | Private *d; |
102 | }; | 102 | }; |
103 | 103 | ||
104 | 104 | ||
105 | /*====================================================================================== | 105 | /*====================================================================================== |
106 | * OPcmciaSocket | 106 | * OPcmciaSocket |
107 | *======================================================================================*/ | 107 | *======================================================================================*/ |
108 | 108 | ||
109 | class OPcmciaSocket : public QObject | 109 | class OPcmciaSocket : public QObject |
110 | { | 110 | { |
111 | Q_OBJECT | 111 | Q_OBJECT |
112 | public: | 112 | public: |
113 | 113 | ||
114 | enum OPcmciaSocketCardStatus | 114 | enum OPcmciaSocketCardStatus |
115 | { | 115 | { |
116 | Unknown = 0, | 116 | Unknown = 0, |
117 | Occupied = CS_EVENT_CARD_DETECT, | 117 | Occupied = CS_EVENT_CARD_DETECT, |
118 | OccupiedCardBus = CS_EVENT_CB_DETECT, | 118 | OccupiedCardBus = CS_EVENT_CB_DETECT, |
119 | WriteProtected = CS_EVENT_WRITE_PROTECT, | 119 | WriteProtected = CS_EVENT_WRITE_PROTECT, |
120 | BatteryLow = CS_EVENT_BATTERY_LOW, | 120 | BatteryLow = CS_EVENT_BATTERY_LOW, |
121 | BatteryDead = CS_EVENT_BATTERY_DEAD, | 121 | BatteryDead = CS_EVENT_BATTERY_DEAD, |
122 | Ready = CS_EVENT_READY_CHANGE, | 122 | Ready = CS_EVENT_READY_CHANGE, |
123 | Suspended = CS_EVENT_PM_SUSPEND, | 123 | Suspended = CS_EVENT_PM_SUSPEND, |
124 | Attention = CS_EVENT_REQUEST_ATTENTION, | 124 | Attention = CS_EVENT_REQUEST_ATTENTION, |
125 | InsertionInProgress = CS_EVENT_CARD_INSERTION, | 125 | InsertionInProgress = CS_EVENT_CARD_INSERTION, |
126 | RemovalInProgress = CS_EVENT_CARD_REMOVAL, | 126 | RemovalInProgress = CS_EVENT_CARD_REMOVAL, |
127 | ThreeVolts = CS_EVENT_3VCARD, | 127 | ThreeVolts = CS_EVENT_3VCARD, |
128 | SupportsVoltage = CS_EVENT_XVCARD, | 128 | SupportsVoltage = CS_EVENT_XVCARD, |
129 | }; | 129 | }; |
130 | 130 | ||
131 | public: | 131 | public: |
132 | /** | 132 | /** |
133 | * Constructor. Normally you don't create @ref OPcmciaSocket objects yourself, | 133 | * Constructor. Normally you don't create @ref OPcmciaSocket objects yourself, |
134 | * but access them via @ref OPcmciaSystem::socket(). | 134 | * but access them via @ref OPcmciaSystem::socket(). |
135 | */ | 135 | */ |
136 | OPcmciaSocket( int major, int socket, QObject* parent, const char* name ); | 136 | OPcmciaSocket( int major, int socket, QObject* parent, const char* name ); |
137 | /** | 137 | /** |
138 | * Destructor. | 138 | * Destructor. |
139 | */ | 139 | */ |
140 | virtual ~OPcmciaSocket(); | 140 | virtual ~OPcmciaSocket(); |
141 | /** | 141 | /** |
142 | * @returns the corresponding socket number | 142 | * @returns the corresponding socket number |
143 | */ | 143 | */ |
144 | int number() const; | 144 | int number() const; |
145 | /** | 145 | /** |
146 | * @returns the card managers idea of the cards' identy, or "<Empty Socket>" | 146 | * @returns the card managers idea of the cards' identy, or "<Empty Socket>" |
147 | */ | 147 | */ |
148 | QString identity() const; | 148 | QString identity() const; |
149 | /** | 149 | /** |
150 | * @returns the socket status | 150 | * @returns the socket status |
151 | */ | 151 | */ |
152 | const OPcmciaSocketCardStatus status() const; | 152 | const OPcmciaSocketCardStatus status() const; |
153 | /** | 153 | /** |
154 | * @returns true, if the card is unsupported by the cardmgr | 154 | * @returns true, if the card is unsupported by the cardmgr |
155 | */ | 155 | */ |
156 | bool isUnsupported() const; | 156 | bool isUnsupported() const; |
157 | /** | 157 | /** |
158 | * @returns true, if the socket is empty | 158 | * @returns true, if the socket is empty |
159 | */ | 159 | */ |
160 | bool isEmpty() const; | 160 | bool isEmpty() const; |
161 | /** | 161 | /** |
162 | * @returns true, if the socket is suspended | 162 | * @returns true, if the socket is suspended |
163 | */ | 163 | */ |
164 | bool isSuspended() const; | 164 | bool isSuspended() const; |
165 | /** | 165 | /** |
166 | * Eject card. @returns true, if operation succeeded | 166 | * Eject card. @returns true, if operation succeeded |
167 | * @note: This operation needs root privileges | 167 | * @note: This operation needs root privileges |
168 | */ | 168 | */ |
169 | bool eject(); | 169 | bool eject(); |
170 | /** | 170 | /** |
171 | * Insert card. @returns true, if operation succeeded | 171 | * Insert card. @returns true, if operation succeeded |
172 | * @note: This operation needs root privileges | 172 | * @note: This operation needs root privileges |
173 | */ | 173 | */ |
174 | bool insert(); | 174 | bool insert(); |
175 | /** | 175 | /** |
176 | * Suspend card. @returns true, if operation succeeded | 176 | * Suspend card. @returns true, if operation succeeded |
177 | * @note: This operation needs root privileges | 177 | * @note: This operation needs root privileges |
178 | */ | 178 | */ |
179 | bool suspend(); | 179 | bool suspend(); |
180 | /** | 180 | /** |
181 | * Resume card. @returns true, if operation succeeded | 181 | * Resume card. @returns true, if operation succeeded |
182 | * @note: This operation needs root privileges | 182 | * @note: This operation needs root privileges |
183 | */ | 183 | */ |
184 | bool resume(); | 184 | bool resume(); |
185 | /** | 185 | /** |
186 | * Reset card. @returns true, if operation succeeded | 186 | * Reset card. @returns true, if operation succeeded |
187 | * @note: This operation needs root privileges | 187 | * @note: This operation needs root privileges |
188 | */ | 188 | */ |
189 | bool reset(); | 189 | bool reset(); |
190 | /** | 190 | /** |
191 | * @returns a list of product IDs | 191 | * @returns the product ID vector |
192 | */ | ||
193 | QStringList productIdentityVector() const; | ||
194 | /** | ||
195 | * @returns the product ID string | ||
192 | */ | 196 | */ |
193 | QStringList productIdentity() const; | 197 | QString productIdentity() const; |
194 | /** | 198 | /** |
195 | * @returns the manufacturer ID string | 199 | * @returns the manufacturer ID string |
196 | */ | 200 | */ |
197 | QString manufacturerIdentity() const; | 201 | QString manufacturerIdentity() const; |
198 | /** | 202 | /** |
199 | * @returns the function string | 203 | * @returns the function string |
200 | */ | 204 | */ |
201 | QString function() const; | 205 | QString function() const; |
202 | 206 | ||
203 | private: | 207 | private: |
204 | void init(); | 208 | void init(); |
205 | void cleanup(); | 209 | void cleanup(); |
206 | bool getTuple( cisdata_t tuple ) const; | 210 | bool getTuple( cisdata_t tuple ) const; |
207 | int _major; | 211 | int _major; |
208 | int _socket; | 212 | int _socket; |
209 | int _fd; | 213 | int _fd; |
210 | mutable ds_ioctl_arg_t _ioctlarg; | 214 | mutable ds_ioctl_arg_t _ioctlarg; |
211 | 215 | ||
212 | private: | 216 | private: |
213 | class Private; | 217 | class Private; |
214 | Private *d; | 218 | Private *d; |
215 | }; | 219 | }; |
216 | 220 | ||
217 | 221 | ||
218 | } | 222 | } |
219 | } | 223 | } |
220 | 224 | ||
221 | #endif // OPCMCIASYSTEM_H | 225 | #endif // OPCMCIASYSTEM_H |