summaryrefslogtreecommitdiff
authormickeyl <mickeyl>2005-06-25 15:29:59 (UTC)
committer mickeyl <mickeyl>2005-06-25 15:29:59 (UTC)
commit790aeb8898d635468c2b9e24fd16a70aab64b1dd (patch) (unidiff)
tree72139f02106b88325efbb39fc11f5ccd79ce29fb
parent3d434ac35915afe7f7035468ca18656264a91c52 (diff)
downloadopie-790aeb8898d635468c2b9e24fd16a70aab64b1dd.zip
opie-790aeb8898d635468c2b9e24fd16a70aab64b1dd.tar.gz
opie-790aeb8898d635468c2b9e24fd16a70aab64b1dd.tar.bz2
- fix logic in isEmpty() and isSuspended()
- add convenience API productIdentityVendor()
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/linux/opcmciasystem.cpp13
-rw-r--r--libopie2/opiecore/linux/opcmciasystem.h8
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
@@ -152,245 +152,252 @@ OPcmciaSocket* 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#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
260int OPcmciaSocket::number() const 260int OPcmciaSocket::number() const
261{ 261{
262 return _socket; 262 return _socket;
263} 263}
264 264
265 265
266QString OPcmciaSocket::identity() const 266QString 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
272const OPcmciaSocket::OPcmciaSocketCardStatus OPcmciaSocket::status() const 272const 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
291bool OPcmciaSocket::isUnsupported() const 292bool 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
297bool OPcmciaSocket::isEmpty() const 298bool OPcmciaSocket::isEmpty() const
298{ 299{
299 return ! status() && ( Occupied || OccupiedCardBus ); 300 return !(status() & ( Occupied | OccupiedCardBus ));
300} 301}
301 302
302 303
303bool OPcmciaSocket::isSuspended() const 304bool OPcmciaSocket::isSuspended() const
304{ 305{
305 return status() && Suspended; 306 return status() & Suspended;
306} 307}
307 308
308 309
309bool OPcmciaSocket::eject() 310bool 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
315bool OPcmciaSocket::insert() 316bool 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
321bool OPcmciaSocket::suspend() 322bool 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
327bool OPcmciaSocket::resume() 328bool 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
333bool OPcmciaSocket::reset() 334bool 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
339QStringList OPcmciaSocket::productIdentity() const 340QStringList 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
362QString OPcmciaSocket::productIdentity() const
363{
364 return productIdentityVector().join( " " ).stripWhiteSpace();
365}
366
367
361QString OPcmciaSocket::manufacturerIdentity() const 368QString 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
373QString OPcmciaSocket::function() const 380QString 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
@@ -63,159 +63,163 @@ class OPcmciaSystem : public QObject
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
109class OPcmciaSocket : public QObject 109class 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