summaryrefslogtreecommitdiff
authormickeyl <mickeyl>2005-06-29 13:04:06 (UTC)
committer mickeyl <mickeyl>2005-06-29 13:04:06 (UTC)
commit094e14624d99d521af6cfc875abafcdc550a7378 (patch) (unidiff)
treee305bb28c71fdb9483f03dd536b7f13929a73f0a
parentb82756d94b91516a7c36903648382a224a36f0e2 (diff)
downloadopie-094e14624d99d521af6cfc875abafcdc550a7378.zip
opie-094e14624d99d521af6cfc875abafcdc550a7378.tar.gz
opie-094e14624d99d521af6cfc875abafcdc550a7378.tar.bz2
add restart() method (FIXME included ;)
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/linux/opcmciasystem.cpp7
-rw-r--r--libopie2/opiecore/linux/opcmciasystem.h8
2 files changed, 13 insertions, 2 deletions
diff --git a/libopie2/opiecore/linux/opcmciasystem.cpp b/libopie2/opiecore/linux/opcmciasystem.cpp
index 21c5a84..9f151ce 100644
--- a/libopie2/opiecore/linux/opcmciasystem.cpp
+++ b/libopie2/opiecore/linux/opcmciasystem.cpp
@@ -1,403 +1,410 @@
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"
31using namespace Opie::Core; 31using 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
56OPcmciaSystem* OPcmciaSystem::_instance = 0; 56OPcmciaSystem* OPcmciaSystem::_instance = 0;
57 57
58OPcmciaSystem::OPcmciaSystem() 58OPcmciaSystem::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
90void OPcmciaSystem::synchronize() 90void 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
132int OPcmciaSystem::count() const 132int OPcmciaSystem::count() const
133{ 133{
134 return _interfaces.count(); 134 return _interfaces.count();
135} 135}
136 136
137 137
138int OPcmciaSystem::cardCount() const 138int 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
151OPcmciaSocket* OPcmciaSystem::socket( unsigned int number ) 151OPcmciaSocket* OPcmciaSystem::socket( unsigned int number )
152{ 152{
153 return _interfaces.at( number ); 153 return _interfaces.at( number );
154} 154}
155 155
156 156
157void OPcmciaSystem::restart()
158{
159 //FIXME Use OProcess or something that allows more control
160 ::system( "/etc/init.d/pcmcia restart" );
161}
162
163
157OPcmciaSystem* OPcmciaSystem::instance() 164OPcmciaSystem* OPcmciaSystem::instance()
158{ 165{
159 if ( !_instance ) _instance = new OPcmciaSystem(); 166 if ( !_instance ) _instance = new OPcmciaSystem();
160 return _instance; 167 return _instance;
161} 168}
162 169
163 170
164OPcmciaSystem::CardIterator OPcmciaSystem::iterator() const 171OPcmciaSystem::CardIterator OPcmciaSystem::iterator() const
165{ 172{
166 return OPcmciaSystem::CardIterator( _interfaces ); 173 return OPcmciaSystem::CardIterator( _interfaces );
167} 174}
168 175
169 176
170/*====================================================================================== 177/*======================================================================================
171 * OPcmciaSocket 178 * OPcmciaSocket
172 *======================================================================================*/ 179 *======================================================================================*/
173 180
174OPcmciaSocket::OPcmciaSocket( int major, int socket, QObject* parent, const char* name ) 181OPcmciaSocket::OPcmciaSocket( int major, int socket, QObject* parent, const char* name )
175 :QObject( parent, name ), _major( major ), _socket( socket ) 182 :QObject( parent, name ), _major( major ), _socket( socket )
176{ 183{
177 qDebug( "OPcmciaSocket::OPcmciaSocket()" ); 184 qDebug( "OPcmciaSocket::OPcmciaSocket()" );
178 init(); 185 init();
179} 186}
180 187
181 188
182OPcmciaSocket::~OPcmciaSocket() 189OPcmciaSocket::~OPcmciaSocket()
183{ 190{
184 qDebug( "OPcmciaSocket::~OPcmciaSocket()" ); 191 qDebug( "OPcmciaSocket::~OPcmciaSocket()" );
185 cleanup(); 192 cleanup();
186} 193}
187 194
188 195
189/* internal */ void OPcmciaSocket::init() 196/* internal */ void OPcmciaSocket::init()
190{ 197{
191 // open control socket and gather file descriptor 198 // open control socket and gather file descriptor
192 if ( _major ) 199 if ( _major )
193 { 200 {
194 dev_t dev = makedev( _major, _socket ); 201 dev_t dev = makedev( _major, _socket );
195 202
196#ifdef OPCMCIA_DEBUG 203#ifdef OPCMCIA_DEBUG
197 QString filename = "/tmp/opcmciasystem-debug"; 204 QString filename = "/tmp/opcmciasystem-debug";
198 if ( QFile::exists( filename ) ) 205 if ( QFile::exists( filename ) )
199#else 206#else
200 QString filename = QString().sprintf( "/tmp/opcmciasystem-%d", ::getpid() ); 207 QString filename = QString().sprintf( "/tmp/opcmciasystem-%d", ::getpid() );
201 if ( ::mknod( (const char*) filename, ( S_IFCHR|S_IREAD|S_IWRITE ), dev ) == 0 ) 208 if ( ::mknod( (const char*) filename, ( S_IFCHR|S_IREAD|S_IWRITE ), dev ) == 0 )
202#endif 209#endif
203 { 210 {
204 _fd = ::open( (const char*) filename, O_RDONLY); 211 _fd = ::open( (const char*) filename, O_RDONLY);
205 if ( !_fd ) 212 if ( !_fd )
206 { 213 {
207 qWarning( "OPcmciaSocket::init() - can't open control socket (%s)", strerror( errno ) ); 214 qWarning( "OPcmciaSocket::init() - can't open control socket (%s)", strerror( errno ) );
208 } 215 }
209#ifndef OPCMCIA_DEBUG 216#ifndef OPCMCIA_DEBUG
210 else 217 else
211 { 218 {
212 ::unlink( (const char*) filename ); 219 ::unlink( (const char*) filename );
213 } 220 }
214#endif 221#endif
215 } 222 }
216 else 223 else
217 { 224 {
218 qWarning( "OPcmciaSocket::init() - can't create device node '%s' (%s)", (const char*) filename, strerror( errno ) ); 225 qWarning( "OPcmciaSocket::init() - can't create device node '%s' (%s)", (const char*) filename, strerror( errno ) );
219 } 226 }
220 } 227 }
221} 228}
222 229
223/* internal */ void OPcmciaSocket::cleanup() 230/* internal */ void OPcmciaSocket::cleanup()
224{ 231{
225 // close control socket 232 // close control socket
226} 233}
227 234
228/* internal */ bool OPcmciaSocket::getTuple( cisdata_t tuple ) const 235/* internal */ bool OPcmciaSocket::getTuple( cisdata_t tuple ) const
229{ 236{
230 _ioctlarg.tuple.DesiredTuple = tuple; 237 _ioctlarg.tuple.DesiredTuple = tuple;
231 _ioctlarg.tuple.Attributes = TUPLE_RETURN_COMMON; 238 _ioctlarg.tuple.Attributes = TUPLE_RETURN_COMMON;
232 _ioctlarg.tuple.TupleOffset = 0; 239 _ioctlarg.tuple.TupleOffset = 0;
233 240
234 int result; 241 int result;
235 result = ::ioctl(_fd, DS_GET_FIRST_TUPLE, &_ioctlarg); 242 result = ::ioctl(_fd, DS_GET_FIRST_TUPLE, &_ioctlarg);
236 if ( result != 0 ) 243 if ( result != 0 )
237 { 244 {
238 qWarning( "OPcmciaSocket::getTuple() - DS_GET_FIRST_TUPLE failed (%s)", strerror( errno ) ); 245 qWarning( "OPcmciaSocket::getTuple() - DS_GET_FIRST_TUPLE failed (%s)", strerror( errno ) );
239 return false; 246 return false;
240 } 247 }
241 248
242 result = ::ioctl(_fd, DS_GET_TUPLE_DATA, &_ioctlarg); 249 result = ::ioctl(_fd, DS_GET_TUPLE_DATA, &_ioctlarg);
243 if ( result != 0 ) 250 if ( result != 0 )
244 { 251 {
245 qWarning( "OPcmciaSocket::getTuple() - DS_GET_TUPLE_DATA failed (%s)", strerror( errno ) ); 252 qWarning( "OPcmciaSocket::getTuple() - DS_GET_TUPLE_DATA failed (%s)", strerror( errno ) );
246 return false; 253 return false;
247 } 254 }
248 255
249 result = ::ioctl( _fd, DS_PARSE_TUPLE, &_ioctlarg ); 256 result = ::ioctl( _fd, DS_PARSE_TUPLE, &_ioctlarg );
250 if ( result != 0 ) 257 if ( result != 0 )
251 { 258 {
252 qWarning( "OPcmciaSocket::getTuple() - DS_PARSE_TUPLE failed (%s)", strerror( errno ) ); 259 qWarning( "OPcmciaSocket::getTuple() - DS_PARSE_TUPLE failed (%s)", strerror( errno ) );
253 return false; 260 return false;
254 } 261 }
255 262
256 return true; 263 return true;
257} 264}
258 265
259 266
260int OPcmciaSocket::number() const 267int OPcmciaSocket::number() const
261{ 268{
262 return _socket; 269 return _socket;
263} 270}
264 271
265 272
266QString OPcmciaSocket::identity() const 273QString OPcmciaSocket::identity() const
267{ 274{
268 return ( strcmp( name(), "empty" ) == 0 ) ? "<Empty Socket>" : name(); 275 return ( strcmp( name(), "empty" ) == 0 ) ? "<Empty Socket>" : name();
269} 276}
270 277
271 278
272const OPcmciaSocket::OPcmciaSocketCardStatus OPcmciaSocket::status() const 279const OPcmciaSocket::OPcmciaSocketCardStatus OPcmciaSocket::status() const
273{ 280{
274 cs_status_t cs_status; 281 cs_status_t cs_status;
275 cs_status.Function = 0; 282 cs_status.Function = 0;
276 int result = ::ioctl( _fd, DS_GET_STATUS, &cs_status ); 283 int result = ::ioctl( _fd, DS_GET_STATUS, &cs_status );
277 if ( result != 0 ) 284 if ( result != 0 )
278 { 285 {
279 qWarning( "OPcmciaSocket::status() - DS_GET_STATUS failed (%s)", strerror( errno ) ); 286 qWarning( "OPcmciaSocket::status() - DS_GET_STATUS failed (%s)", strerror( errno ) );
280 // return ( errno == -ENODEV ) ? Empty : Unknown; 287 // return ( errno == -ENODEV ) ? Empty : Unknown;
281 return Unknown; 288 return Unknown;
282 } 289 }
283 else 290 else
284 { 291 {
285 qDebug( " card status = 0x%08x", cs_status.CardState ); 292 qDebug( " card status = 0x%08x", cs_status.CardState );
286 qDebug( " socket status = 0x%08x", cs_status.SocketState ); 293 qDebug( " socket status = 0x%08x", cs_status.SocketState );
287 return (OPcmciaSocket::OPcmciaSocketCardStatus) (cs_status.CardState + cs_status.SocketState); 294 return (OPcmciaSocket::OPcmciaSocketCardStatus) (cs_status.CardState + cs_status.SocketState);
288 } 295 }
289} 296}
290 297
291 298
292bool OPcmciaSocket::isUnsupported() const 299bool OPcmciaSocket::isUnsupported() const
293{ 300{
294 return ( strcmp( name(), "unsupported card" ) == 0 ); 301 return ( strcmp( name(), "unsupported card" ) == 0 );
295} 302}
296 303
297 304
298bool OPcmciaSocket::isEmpty() const 305bool OPcmciaSocket::isEmpty() const
299{ 306{
300 return !(status() & ( Occupied | OccupiedCardBus )); 307 return !(status() & ( Occupied | OccupiedCardBus ));
301} 308}
302 309
303 310
304bool OPcmciaSocket::isSuspended() const 311bool OPcmciaSocket::isSuspended() const
305{ 312{
306 return status() & Suspended; 313 return status() & Suspended;
307} 314}
308 315
309 316
310bool OPcmciaSocket::eject() 317bool OPcmciaSocket::eject()
311{ 318{
312 return ::ioctl( _fd, DS_EJECT_CARD ) != -1; 319 return ::ioctl( _fd, DS_EJECT_CARD ) != -1;
313} 320}
314 321
315 322
316bool OPcmciaSocket::insert() 323bool OPcmciaSocket::insert()
317{ 324{
318 return ::ioctl( _fd, DS_INSERT_CARD ) != -1; 325 return ::ioctl( _fd, DS_INSERT_CARD ) != -1;
319} 326}
320 327
321 328
322bool OPcmciaSocket::suspend() 329bool OPcmciaSocket::suspend()
323{ 330{
324 return ::ioctl( _fd, DS_SUSPEND_CARD ) != -1; 331 return ::ioctl( _fd, DS_SUSPEND_CARD ) != -1;
325} 332}
326 333
327 334
328bool OPcmciaSocket::resume() 335bool OPcmciaSocket::resume()
329{ 336{
330 return ::ioctl( _fd, DS_RESUME_CARD ) != -1; 337 return ::ioctl( _fd, DS_RESUME_CARD ) != -1;
331} 338}
332 339
333 340
334bool OPcmciaSocket::reset() 341bool OPcmciaSocket::reset()
335{ 342{
336 return ::ioctl( _fd, DS_RESET_CARD ) != -1; 343 return ::ioctl( _fd, DS_RESET_CARD ) != -1;
337} 344}
338 345
339 346
340QStringList OPcmciaSocket::productIdentityVector() const 347QStringList OPcmciaSocket::productIdentityVector() const
341{ 348{
342 QStringList list; 349 QStringList list;
343 cistpl_vers_1_t *vers = &_ioctlarg.tuple_parse.parse.version_1; 350 cistpl_vers_1_t *vers = &_ioctlarg.tuple_parse.parse.version_1;
344 vers->ns = 0; // number of strings 351 vers->ns = 0; // number of strings
345 if ( getTuple( CISTPL_VERS_1 ) ) 352 if ( getTuple( CISTPL_VERS_1 ) )
346 { 353 {
347 qDebug( " NUMBER_OF_PRODIDs = %d", vers->ns ); 354 qDebug( " NUMBER_OF_PRODIDs = %d", vers->ns );
348 for ( int i = 0; i < QMIN( CISTPL_VERS_1_MAX_PROD_STRINGS, vers->ns ); ++i ) 355 for ( int i = 0; i < QMIN( CISTPL_VERS_1_MAX_PROD_STRINGS, vers->ns ); ++i )
349 { 356 {
350 qDebug( " PRODID = '%s'", vers->str+vers->ofs[i] ); 357 qDebug( " PRODID = '%s'", vers->str+vers->ofs[i] );
351 list += vers->str+vers->ofs[i]; 358 list += vers->str+vers->ofs[i];
352 } 359 }
353 } 360 }
354 else 361 else
355 { 362 {
356 list += "<unknown>"; 363 list += "<unknown>";
357 } 364 }
358 return list; 365 return list;
359} 366}
360 367
361 368
362QString OPcmciaSocket::productIdentity() const 369QString OPcmciaSocket::productIdentity() const
363{ 370{
364 return productIdentityVector().join( " " ).stripWhiteSpace(); 371 return productIdentityVector().join( " " ).stripWhiteSpace();
365} 372}
366 373
367 374
368QString OPcmciaSocket::manufacturerIdentity() const 375QString OPcmciaSocket::manufacturerIdentity() const
369{ 376{
370 cistpl_manfid_t *manfid = &_ioctlarg.tuple_parse.parse.manfid; 377 cistpl_manfid_t *manfid = &_ioctlarg.tuple_parse.parse.manfid;
371 if ( getTuple( CISTPL_MANFID ) ) 378 if ( getTuple( CISTPL_MANFID ) )
372 { 379 {
373 return QString().sprintf( "0x%04x, 0x%04x", manfid->manf, manfid->card ); 380 return QString().sprintf( "0x%04x, 0x%04x", manfid->manf, manfid->card );
374 } 381 }
375 else 382 else
376 return "<unknown>"; 383 return "<unknown>";
377} 384}
378 385
379 386
380QString OPcmciaSocket::function() const 387QString OPcmciaSocket::function() const
381{ 388{
382 cistpl_funcid_t *funcid = &_ioctlarg.tuple_parse.parse.funcid; 389 cistpl_funcid_t *funcid = &_ioctlarg.tuple_parse.parse.funcid;
383 if ( getTuple( CISTPL_FUNCID ) ) 390 if ( getTuple( CISTPL_FUNCID ) )
384 { 391 {
385 switch ( funcid->func ) 392 switch ( funcid->func )
386 { 393 {
387 case 0: return "Multifunction"; break; 394 case 0: return "Multifunction"; break;
388 case 1: return "Memory"; break; 395 case 1: return "Memory"; break;
389 case 2: return "Serial"; break; 396 case 2: return "Serial"; break;
390 case 3: return "Parallel"; break; 397 case 3: return "Parallel"; break;
391 case 4: return "Fixed Disk"; break; 398 case 4: return "Fixed Disk"; break;
392 case 5: return "Video"; break; 399 case 5: return "Video"; break;
393 case 6: return "Network"; break; 400 case 6: return "Network"; break;
394 case 7: return "AIMS"; break; 401 case 7: return "AIMS"; break;
395 case 8: return "SCSI"; break; 402 case 8: return "SCSI"; break;
396 default: return "<unknown>"; break; 403 default: return "<unknown>"; break;
397 } 404 }
398 } 405 }
399 else 406 else
400 { 407 {
401 return "<unknown>"; 408 return "<unknown>";
402 } 409 }
403} 410}
diff --git a/libopie2/opiecore/linux/opcmciasystem.h b/libopie2/opiecore/linux/opcmciasystem.h
index 23d8c41..fecbb21 100644
--- a/libopie2/opiecore/linux/opcmciasystem.h
+++ b/libopie2/opiecore/linux/opcmciasystem.h
@@ -1,225 +1,229 @@
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
38namespace Opie { 38namespace Opie {
39namespace Core { 39namespace Core {
40 40
41class OPcmciaSocket; 41class 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 */
54class OPcmciaSystem : public QObject 54class 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 * Restarts the subsystem
86 */
87 void restart();
88 /**
85 * @internal Rebuild the internal database 89 * @internal Rebuild the internal database
86 * @note Sometimes it might be useful to call this from client code, 90 * @note Sometimes it might be useful to call this from client code,
87 * e.g. after issuing a cardctl insert 91 * e.g. after issuing a cardctl insert
88 */ 92 */
89 void synchronize(); 93 void synchronize();
90 94
91 protected: 95 protected:
92 OPcmciaSystem(); 96 OPcmciaSystem();
93 97
94 private: 98 private:
95 static OPcmciaSystem* _instance; 99 static OPcmciaSystem* _instance;
96 CardList _interfaces; 100 CardList _interfaces;
97 int _major; 101 int _major;
98 102
99 private: 103 private:
100 class Private; 104 class Private;
101 Private *d; 105 Private *d;
102}; 106};
103 107
104 108
105/*====================================================================================== 109/*======================================================================================
106 * OPcmciaSocket 110 * OPcmciaSocket
107 *======================================================================================*/ 111 *======================================================================================*/
108 112
109class OPcmciaSocket : public QObject 113class OPcmciaSocket : public QObject
110{ 114{
111 Q_OBJECT 115 Q_OBJECT
112 public: 116 public:
113 117
114 enum OPcmciaSocketCardStatus 118 enum OPcmciaSocketCardStatus
115 { 119 {
116 Unknown = 0, 120 Unknown = 0,
117 Occupied = CS_EVENT_CARD_DETECT, 121 Occupied = CS_EVENT_CARD_DETECT,
118 OccupiedCardBus = CS_EVENT_CB_DETECT, 122 OccupiedCardBus = CS_EVENT_CB_DETECT,
119 WriteProtected = CS_EVENT_WRITE_PROTECT, 123 WriteProtected = CS_EVENT_WRITE_PROTECT,
120 BatteryLow = CS_EVENT_BATTERY_LOW, 124 BatteryLow = CS_EVENT_BATTERY_LOW,
121 BatteryDead = CS_EVENT_BATTERY_DEAD, 125 BatteryDead = CS_EVENT_BATTERY_DEAD,
122 Ready = CS_EVENT_READY_CHANGE, 126 Ready = CS_EVENT_READY_CHANGE,
123 Suspended = CS_EVENT_PM_SUSPEND, 127 Suspended = CS_EVENT_PM_SUSPEND,
124 Attention = CS_EVENT_REQUEST_ATTENTION, 128 Attention = CS_EVENT_REQUEST_ATTENTION,
125 InsertionInProgress = CS_EVENT_CARD_INSERTION, 129 InsertionInProgress = CS_EVENT_CARD_INSERTION,
126 RemovalInProgress = CS_EVENT_CARD_REMOVAL, 130 RemovalInProgress = CS_EVENT_CARD_REMOVAL,
127 ThreeVolts = CS_EVENT_3VCARD, 131 ThreeVolts = CS_EVENT_3VCARD,
128 SupportsVoltage = CS_EVENT_XVCARD, 132 SupportsVoltage = CS_EVENT_XVCARD,
129 }; 133 };
130 134
131 public: 135 public:
132 /** 136 /**
133 * Constructor. Normally you don't create @ref OPcmciaSocket objects yourself, 137 * Constructor. Normally you don't create @ref OPcmciaSocket objects yourself,
134 * but access them via @ref OPcmciaSystem::socket(). 138 * but access them via @ref OPcmciaSystem::socket().
135 */ 139 */
136 OPcmciaSocket( int major, int socket, QObject* parent, const char* name ); 140 OPcmciaSocket( int major, int socket, QObject* parent, const char* name );
137 /** 141 /**
138 * Destructor. 142 * Destructor.
139 */ 143 */
140 virtual ~OPcmciaSocket(); 144 virtual ~OPcmciaSocket();
141 /** 145 /**
142 * @returns the corresponding socket number 146 * @returns the corresponding socket number
143 */ 147 */
144 int number() const; 148 int number() const;
145 /** 149 /**
146 * @returns the card managers idea of the cards' identy, or "<Empty Socket>" 150 * @returns the card managers idea of the cards' identy, or "<Empty Socket>"
147 */ 151 */
148 QString identity() const; 152 QString identity() const;
149 /** 153 /**
150 * @returns the socket status 154 * @returns the socket status
151 */ 155 */
152 const OPcmciaSocketCardStatus status() const; 156 const OPcmciaSocketCardStatus status() const;
153 /** 157 /**
154 * @returns true, if the card is unsupported by the cardmgr 158 * @returns true, if the card is unsupported by the cardmgr
155 */ 159 */
156 bool isUnsupported() const; 160 bool isUnsupported() const;
157 /** 161 /**
158 * @returns true, if the socket is empty 162 * @returns true, if the socket is empty
159 */ 163 */
160 bool isEmpty() const; 164 bool isEmpty() const;
161 /** 165 /**
162 * @returns true, if the socket is suspended 166 * @returns true, if the socket is suspended
163 */ 167 */
164 bool isSuspended() const; 168 bool isSuspended() const;
165 /** 169 /**
166 * Eject card. @returns true, if operation succeeded 170 * Eject card. @returns true, if operation succeeded
167 * @note: This operation needs root privileges 171 * @note: This operation needs root privileges
168 */ 172 */
169 bool eject(); 173 bool eject();
170 /** 174 /**
171 * Insert card. @returns true, if operation succeeded 175 * Insert card. @returns true, if operation succeeded
172 * @note: This operation needs root privileges 176 * @note: This operation needs root privileges
173 */ 177 */
174 bool insert(); 178 bool insert();
175 /** 179 /**
176 * Suspend card. @returns true, if operation succeeded 180 * Suspend card. @returns true, if operation succeeded
177 * @note: This operation needs root privileges 181 * @note: This operation needs root privileges
178 */ 182 */
179 bool suspend(); 183 bool suspend();
180 /** 184 /**
181 * Resume card. @returns true, if operation succeeded 185 * Resume card. @returns true, if operation succeeded
182 * @note: This operation needs root privileges 186 * @note: This operation needs root privileges
183 */ 187 */
184 bool resume(); 188 bool resume();
185 /** 189 /**
186 * Reset card. @returns true, if operation succeeded 190 * Reset card. @returns true, if operation succeeded
187 * @note: This operation needs root privileges 191 * @note: This operation needs root privileges
188 */ 192 */
189 bool reset(); 193 bool reset();
190 /** 194 /**
191 * @returns the product ID vector 195 * @returns the product ID vector
192 */ 196 */
193 QStringList productIdentityVector() const; 197 QStringList productIdentityVector() const;
194 /** 198 /**
195 * @returns the product ID string 199 * @returns the product ID string
196 */ 200 */
197 QString productIdentity() const; 201 QString productIdentity() const;
198 /** 202 /**
199 * @returns the manufacturer ID string 203 * @returns the manufacturer ID string
200 */ 204 */
201 QString manufacturerIdentity() const; 205 QString manufacturerIdentity() const;
202 /** 206 /**
203 * @returns the function string 207 * @returns the function string
204 */ 208 */
205 QString function() const; 209 QString function() const;
206 210
207 private: 211 private:
208 void init(); 212 void init();
209 void cleanup(); 213 void cleanup();
210 bool getTuple( cisdata_t tuple ) const; 214 bool getTuple( cisdata_t tuple ) const;
211 int _major; 215 int _major;
212 int _socket; 216 int _socket;
213 int _fd; 217 int _fd;
214 mutable ds_ioctl_arg_t _ioctlarg; 218 mutable ds_ioctl_arg_t _ioctlarg;
215 219
216 private: 220 private:
217 class Private; 221 class Private;
218 Private *d; 222 Private *d;
219}; 223};
220 224
221 225
222} 226}
223} 227}
224 228
225#endif // OPCMCIASYSTEM_H 229#endif // OPCMCIASYSTEM_H