summaryrefslogtreecommitdiff
authormickeyl <mickeyl>2005-06-22 09:00:42 (UTC)
committer mickeyl <mickeyl>2005-06-22 09:00:42 (UTC)
commitc7d80acef0bab4babadac288796117987bb4e846 (patch) (unidiff)
treee2fcb8c4f6c7403c4c8a84e4dbe3b97cb88af109
parentb17740434153d8368133b412939cdbe5f4a26c02 (diff)
downloadopie-c7d80acef0bab4babadac288796117987bb4e846.zip
opie-c7d80acef0bab4babadac288796117987bb4e846.tar.gz
opie-c7d80acef0bab4babadac288796117987bb4e846.tar.bz2
Note to self: Don't commit local changes...
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/linux/linux.pro2
-rw-r--r--libopie2/opiecore/linux/opcmciasystem.cpp2
2 files changed, 3 insertions, 1 deletions
diff --git a/libopie2/opiecore/linux/linux.pro b/libopie2/opiecore/linux/linux.pro
index c0c4f7f..d2e36ae 100644
--- a/libopie2/opiecore/linux/linux.pro
+++ b/libopie2/opiecore/linux/linux.pro
@@ -1,11 +1,11 @@
1HEADERS += \ 1HEADERS += \
2 linux/ofilenotify.h \ 2 linux/ofilenotify.h \
3 linux/oinputsystem.h \ 3 linux/oinputsystem.h \
4 linux/opcmciasystem.h 4 linux/opcmciasystem.h
5 5
6SOURCES += \ 6SOURCES += \
7 linux/ofilenotify.cpp \ 7 linux/ofilenotify.cpp \
8 linux/oinputsystem.cpp \ 8 linux/oinputsystem.cpp \
9 linux/opcmciasystem.cpp 9 linux/opcmciasystem.cpp
10 10
11DEFINES += OPCMCIA_DEBUG=1 11# DEFINES += OPCMCIA_DEBUG=1
diff --git a/libopie2/opiecore/linux/opcmciasystem.cpp b/libopie2/opiecore/linux/opcmciasystem.cpp
index 445d903..2b0c01d 100644
--- a/libopie2/opiecore/linux/opcmciasystem.cpp
+++ b/libopie2/opiecore/linux/opcmciasystem.cpp
@@ -1,392 +1,394 @@
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
157OPcmciaSystem* OPcmciaSystem::instance() 157OPcmciaSystem* 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
164OPcmciaSystem::CardIterator OPcmciaSystem::iterator() const 164OPcmciaSystem::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
174OPcmciaSocket::OPcmciaSocket( int major, int socket, QObject* parent, const char* name ) 174OPcmciaSocket::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
182OPcmciaSocket::~OPcmciaSocket() 182OPcmciaSocket::~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 else 210 else
210 { 211 {
211 ::unlink( (const char*) filename ); 212 ::unlink( (const char*) filename );
212 } 213 }
214#endif
213 } 215 }
214 else 216 else
215 { 217 {
216 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 ) );
217 } 219 }
218 } 220 }
219} 221}
220 222
221/* internal */ void OPcmciaSocket::cleanup() 223/* internal */ void OPcmciaSocket::cleanup()
222{ 224{
223 // close control socket 225 // close control socket
224} 226}
225 227
226/* internal */ bool OPcmciaSocket::getTuple( cisdata_t tuple ) const 228/* internal */ bool OPcmciaSocket::getTuple( cisdata_t tuple ) const
227{ 229{
228 _ioctlarg.tuple.DesiredTuple = tuple; 230 _ioctlarg.tuple.DesiredTuple = tuple;
229 _ioctlarg.tuple.Attributes = TUPLE_RETURN_COMMON; 231 _ioctlarg.tuple.Attributes = TUPLE_RETURN_COMMON;
230 _ioctlarg.tuple.TupleOffset = 0; 232 _ioctlarg.tuple.TupleOffset = 0;
231 233
232 int result; 234 int result;
233 result = ::ioctl(_fd, DS_GET_FIRST_TUPLE, &_ioctlarg); 235 result = ::ioctl(_fd, DS_GET_FIRST_TUPLE, &_ioctlarg);
234 if ( result != 0 ) 236 if ( result != 0 )
235 { 237 {
236 qWarning( "OPcmciaSocket::getTuple() - DS_GET_FIRST_TUPLE failed (%s)", strerror( errno ) ); 238 qWarning( "OPcmciaSocket::getTuple() - DS_GET_FIRST_TUPLE failed (%s)", strerror( errno ) );
237 return false; 239 return false;
238 } 240 }
239 241
240 result = ::ioctl(_fd, DS_GET_TUPLE_DATA, &_ioctlarg); 242 result = ::ioctl(_fd, DS_GET_TUPLE_DATA, &_ioctlarg);
241 if ( result != 0 ) 243 if ( result != 0 )
242 { 244 {
243 qWarning( "OPcmciaSocket::getTuple() - DS_GET_TUPLE_DATA failed (%s)", strerror( errno ) ); 245 qWarning( "OPcmciaSocket::getTuple() - DS_GET_TUPLE_DATA failed (%s)", strerror( errno ) );
244 return false; 246 return false;
245 } 247 }
246 248
247 result = ::ioctl( _fd, DS_PARSE_TUPLE, &_ioctlarg ); 249 result = ::ioctl( _fd, DS_PARSE_TUPLE, &_ioctlarg );
248 if ( result != 0 ) 250 if ( result != 0 )
249 { 251 {
250 qWarning( "OPcmciaSocket::getTuple() - DS_PARSE_TUPLE failed (%s)", strerror( errno ) ); 252 qWarning( "OPcmciaSocket::getTuple() - DS_PARSE_TUPLE failed (%s)", strerror( errno ) );
251 return false; 253 return false;
252 } 254 }
253 255
254 return true; 256 return true;
255} 257}
256 258
257 259
258int OPcmciaSocket::number() const 260int OPcmciaSocket::number() const
259{ 261{
260 return _socket; 262 return _socket;
261} 263}
262 264
263 265
264QString OPcmciaSocket::identity() const 266QString OPcmciaSocket::identity() const
265{ 267{
266 return ( strcmp( name(), "empty" ) == 0 ) ? "<Empty Socket>" : name(); 268 return ( strcmp( name(), "empty" ) == 0 ) ? "<Empty Socket>" : name();
267} 269}
268 270
269 271
270const OPcmciaSocket::OPcmciaSocketCardStatus OPcmciaSocket::status() const 272const OPcmciaSocket::OPcmciaSocketCardStatus OPcmciaSocket::status() const
271{ 273{
272 cs_status_t cs_status; 274 cs_status_t cs_status;
273 cs_status.Function = 0; 275 cs_status.Function = 0;
274 int result = ::ioctl( _fd, DS_GET_STATUS, &cs_status ); 276 int result = ::ioctl( _fd, DS_GET_STATUS, &cs_status );
275 if ( result != 0 ) 277 if ( result != 0 )
276 { 278 {
277 qWarning( "OPcmciaSocket::status() - DS_GET_STATUS failed (%s)", strerror( errno ) ); 279 qWarning( "OPcmciaSocket::status() - DS_GET_STATUS failed (%s)", strerror( errno ) );
278 return Unknown; 280 return Unknown;
279 } 281 }
280 else 282 else
281 { 283 {
282 qDebug( " card status = 0x%08x", cs_status.CardState ); 284 qDebug( " card status = 0x%08x", cs_status.CardState );
283 qDebug( " socket status = 0x%08x", cs_status.SocketState ); 285 qDebug( " socket status = 0x%08x", cs_status.SocketState );
284 return (OPcmciaSocket::OPcmciaSocketCardStatus) (cs_status.CardState + cs_status.SocketState); 286 return (OPcmciaSocket::OPcmciaSocketCardStatus) (cs_status.CardState + cs_status.SocketState);
285 } 287 }
286} 288}
287 289
288 290
289bool OPcmciaSocket::isUnsupported() const 291bool OPcmciaSocket::isUnsupported() const
290{ 292{
291 return ( strcmp( name(), "unsupported card" ) == 0 ); 293 return ( strcmp( name(), "unsupported card" ) == 0 );
292} 294}
293 295
294 296
295bool OPcmciaSocket::isEmpty() const 297bool OPcmciaSocket::isEmpty() const
296{ 298{
297 return ! status() && ( Occupied || OccupiedCardBus ); 299 return ! status() && ( Occupied || OccupiedCardBus );
298} 300}
299 301
300 302
301bool OPcmciaSocket::isSuspended() const 303bool OPcmciaSocket::isSuspended() const
302{ 304{
303 return status() && Suspended; 305 return status() && Suspended;
304} 306}
305 307
306 308
307bool OPcmciaSocket::eject() 309bool OPcmciaSocket::eject()
308{ 310{
309 return ::ioctl( _fd, DS_EJECT_CARD ) != -1; 311 return ::ioctl( _fd, DS_EJECT_CARD ) != -1;
310} 312}
311 313
312 314
313bool OPcmciaSocket::insert() 315bool OPcmciaSocket::insert()
314{ 316{
315 return ::ioctl( _fd, DS_INSERT_CARD ) != -1; 317 return ::ioctl( _fd, DS_INSERT_CARD ) != -1;
316} 318}
317 319
318 320
319bool OPcmciaSocket::suspend() 321bool OPcmciaSocket::suspend()
320{ 322{
321 return ::ioctl( _fd, DS_SUSPEND_CARD ) != -1; 323 return ::ioctl( _fd, DS_SUSPEND_CARD ) != -1;
322} 324}
323 325
324 326
325bool OPcmciaSocket::resume() 327bool OPcmciaSocket::resume()
326{ 328{
327 return ::ioctl( _fd, DS_RESUME_CARD ) != -1; 329 return ::ioctl( _fd, DS_RESUME_CARD ) != -1;
328} 330}
329 331
330 332
331bool OPcmciaSocket::reset() 333bool OPcmciaSocket::reset()
332{ 334{
333 return ::ioctl( _fd, DS_RESET_CARD ) != -1; 335 return ::ioctl( _fd, DS_RESET_CARD ) != -1;
334} 336}
335 337
336 338
337QStringList OPcmciaSocket::productIdentity() const 339QStringList OPcmciaSocket::productIdentity() const
338{ 340{
339 QStringList list; 341 QStringList list;
340 cistpl_vers_1_t *vers = &_ioctlarg.tuple_parse.parse.version_1; 342 cistpl_vers_1_t *vers = &_ioctlarg.tuple_parse.parse.version_1;
341 if ( getTuple( CISTPL_VERS_1 ) ) 343 if ( getTuple( CISTPL_VERS_1 ) )
342 { 344 {
343 for ( int i = 0; i < CISTPL_VERS_1_MAX_PROD_STRINGS; ++i ) 345 for ( int i = 0; i < CISTPL_VERS_1_MAX_PROD_STRINGS; ++i )
344 { 346 {
345 qDebug( " PRODID = '%s'", vers->str+vers->ofs[i] ); 347 qDebug( " PRODID = '%s'", vers->str+vers->ofs[i] );
346 list += vers->str+vers->ofs[i]; 348 list += vers->str+vers->ofs[i];
347 } 349 }
348 } 350 }
349 else 351 else
350 { 352 {
351 list += "<unknown>"; 353 list += "<unknown>";
352 } 354 }
353 return list; 355 return list;
354} 356}
355 357
356 358
357QString OPcmciaSocket::manufacturerIdentity() const 359QString OPcmciaSocket::manufacturerIdentity() const
358{ 360{
359 cistpl_manfid_t *manfid = &_ioctlarg.tuple_parse.parse.manfid; 361 cistpl_manfid_t *manfid = &_ioctlarg.tuple_parse.parse.manfid;
360 if ( getTuple( CISTPL_MANFID ) ) 362 if ( getTuple( CISTPL_MANFID ) )
361 { 363 {
362 return QString().sprintf( "0x%04x, 0x%04x", manfid->manf, manfid->card ); 364 return QString().sprintf( "0x%04x, 0x%04x", manfid->manf, manfid->card );
363 } 365 }
364 else 366 else
365 return "<unknown>"; 367 return "<unknown>";
366} 368}
367 369
368 370
369QString OPcmciaSocket::function() const 371QString OPcmciaSocket::function() const
370{ 372{
371 cistpl_funcid_t *funcid = &_ioctlarg.tuple_parse.parse.funcid; 373 cistpl_funcid_t *funcid = &_ioctlarg.tuple_parse.parse.funcid;
372 if ( getTuple( CISTPL_FUNCID ) ) 374 if ( getTuple( CISTPL_FUNCID ) )
373 { 375 {
374 switch ( funcid->func ) 376 switch ( funcid->func )
375 { 377 {
376 case 0: return "Multifunction"; break; 378 case 0: return "Multifunction"; break;
377 case 1: return "Memory"; break; 379 case 1: return "Memory"; break;
378 case 2: return "Serial"; break; 380 case 2: return "Serial"; break;
379 case 3: return "Parallel"; break; 381 case 3: return "Parallel"; break;
380 case 4: return "Fixed Disk"; break; 382 case 4: return "Fixed Disk"; break;
381 case 5: return "Video"; break; 383 case 5: return "Video"; break;
382 case 6: return "Network"; break; 384 case 6: return "Network"; break;
383 case 7: return "AIMS"; break; 385 case 7: return "AIMS"; break;
384 case 8: return "SCSI"; break; 386 case 8: return "SCSI"; break;
385 default: return "<unknown>"; break; 387 default: return "<unknown>"; break;
386 } 388 }
387 } 389 }
388 else 390 else
389 { 391 {
390 return "<unknown>"; 392 return "<unknown>";
391 } 393 }
392} 394}