summaryrefslogtreecommitdiff
authormickeyl <mickeyl>2005-06-14 13:14:38 (UTC)
committer mickeyl <mickeyl>2005-06-14 13:14:38 (UTC)
commitc1194d42d8456417452b125bd6c2c5048d7bbe02 (patch) (unidiff)
treedbc31e47615d840745eafd0635f724548ece6281
parent9e210f138184f9cc93e28dd894243fc7bfea1b0f (diff)
downloadopie-c1194d42d8456417452b125bd6c2c5048d7bbe02.zip
opie-c1194d42d8456417452b125bd6c2c5048d7bbe02.tar.gz
opie-c1194d42d8456417452b125bd6c2c5048d7bbe02.tar.bz2
enable OPcmciaSocket::manufacturer()
Did I mention Qt2 sucks? We don't even have a QPair :/
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/linux/opcmciasystem.cpp24
-rw-r--r--libopie2/opiecore/linux/opcmciasystem.h6
2 files changed, 20 insertions, 10 deletions
diff --git a/libopie2/opiecore/linux/opcmciasystem.cpp b/libopie2/opiecore/linux/opcmciasystem.cpp
index 929e289..2eece6b 100644
--- a/libopie2/opiecore/linux/opcmciasystem.cpp
+++ b/libopie2/opiecore/linux/opcmciasystem.cpp
@@ -36,32 +36,34 @@ using namespace Opie::Core;
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#define OPCMCIA_DEBUG 1
53
52/*====================================================================================== 54/*======================================================================================
53 * OPcmciaSystem 55 * OPcmciaSystem
54 *======================================================================================*/ 56 *======================================================================================*/
55 57
56OPcmciaSystem* OPcmciaSystem::_instance = 0; 58OPcmciaSystem* OPcmciaSystem::_instance = 0;
57 59
58OPcmciaSystem::OPcmciaSystem() 60OPcmciaSystem::OPcmciaSystem()
59 :_major( 0 ) 61 :_major( 0 )
60{ 62{
61 qDebug( "OPcmciaSystem::OPcmciaSystem()" ); 63 qDebug( "OPcmciaSystem::OPcmciaSystem()" );
62 64
63 // get major node number out of /proc/devices 65 // get major node number out of /proc/devices
64 QFile procfile( PROC_DEVICES ); 66 QFile procfile( PROC_DEVICES );
65 if ( procfile.exists() && procfile.open( IO_ReadOnly ) ) 67 if ( procfile.exists() && procfile.open( IO_ReadOnly ) )
66 { 68 {
67 QTextStream devstream( &procfile ); 69 QTextStream devstream( &procfile );
@@ -176,48 +178,54 @@ OPcmciaSocket::OPcmciaSocket( int major, int socket, QObject* parent, const char
176} 178}
177 179
178 180
179OPcmciaSocket::~OPcmciaSocket() 181OPcmciaSocket::~OPcmciaSocket()
180{ 182{
181 qDebug( "OPcmciaSocket::~OPcmciaSocket()" ); 183 qDebug( "OPcmciaSocket::~OPcmciaSocket()" );
182 cleanup(); 184 cleanup();
183} 185}
184 186
185 187
186/* internal */ void OPcmciaSocket::init() 188/* internal */ void OPcmciaSocket::init()
187{ 189{
188 // open control socket and gather file descriptor 190 // open control socket and gather file descriptor
189 if ( _major ) 191 if ( _major )
190 { 192 {
191 dev_t dev = makedev( _major, _socket ); 193 dev_t dev = makedev( _major, _socket );
194
195#ifdef OPCMCIA_DEBUG
196 QString filename = "/tmp/opcmciasystem-debug";
197 if ( QFile::exists( filename ) )
198#else
192 QString filename = QString().sprintf( "/tmp/opcmciasystem-%d", ::getpid() ); 199 QString filename = QString().sprintf( "/tmp/opcmciasystem-%d", ::getpid() );
193 if ( ::mknod( (const char*) filename, ( S_IFCHR|S_IREAD|S_IWRITE ), dev ) == 0 ) 200 if ( ::mknod( (const char*) filename, ( S_IFCHR|S_IREAD|S_IWRITE ), dev ) == 0 )
201#endif
194 { 202 {
195 _fd = ::open( (const char*) filename, O_RDONLY); 203 _fd = ::open( (const char*) filename, O_RDONLY);
196 if ( !_fd ) 204 if ( !_fd )
197 { 205 {
198 qWarning( "OPcmciaSocket::init() - can't open control socket (%s)", strerror( errno ) ); 206 qWarning( "OPcmciaSocket::init() - can't open control socket (%s)", strerror( errno ) );
199 } 207 }
200 else 208 else
201 { 209 {
202 ::unlink( (const char*) filename ); 210 ::unlink( (const char*) filename );
203 } 211 }
204 } 212 }
205 else 213 else
206 { 214 {
207 qWarning( "OPcmciaSocket::init() - can't create device node (%s)", strerror( errno ) ); 215 qWarning( "OPcmciaSocket::init() - can't create device node '%s' (%s)", (const char*) filename, strerror( errno ) );
208 } 216 }
209 } 217 }
210} 218}
211 219
212/* internal */ void OPcmciaSocket::cleanup() 220/* internal */ void OPcmciaSocket::cleanup()
213{ 221{
214 // close control socket 222 // close control socket
215} 223}
216 224
217/* internal */ bool OPcmciaSocket::getTuple( cisdata_t tuple ) const 225/* internal */ bool OPcmciaSocket::getTuple( cisdata_t tuple ) const
218{ 226{
219 _ioctlarg.tuple.DesiredTuple = tuple; 227 _ioctlarg.tuple.DesiredTuple = tuple;
220 _ioctlarg.tuple.Attributes = TUPLE_RETURN_COMMON; 228 _ioctlarg.tuple.Attributes = TUPLE_RETURN_COMMON;
221 _ioctlarg.tuple.TupleOffset = 0; 229 _ioctlarg.tuple.TupleOffset = 0;
222 230
223 int result; 231 int result;
@@ -278,33 +286,33 @@ const OPcmciaSocket::OPcmciaSocketCardStatus OPcmciaSocket::status() const
278 286
279 287
280bool OPcmciaSocket::isUnsupported() const 288bool OPcmciaSocket::isUnsupported() const
281{ 289{
282 return ( strcmp( name(), "unsupported card" ) == 0 ); 290 return ( strcmp( name(), "unsupported card" ) == 0 );
283} 291}
284 292
285 293
286bool OPcmciaSocket::isEmpty() const 294bool OPcmciaSocket::isEmpty() const
287{ 295{
288 return ! status() && ( Occupied || OccupiedCardBus ); 296 return ! status() && ( Occupied || OccupiedCardBus );
289} 297}
290 298
291 299
292bool OPcmciaSocket::isSuspended() const 300bool OPcmciaSocket::isSuspended() const
293{ 301{
294 return status() && Suspended; 302 return status() && Suspended;
295} 303}
296 304
297 305
298bool OPcmciaSocket::eject() 306bool OPcmciaSocket::eject()
299{ 307{
300 return ::ioctl( _fd, DS_EJECT_CARD ); 308 return ::ioctl( _fd, DS_EJECT_CARD );
301} 309}
302 310
303 311
304bool OPcmciaSocket::insert() 312bool OPcmciaSocket::insert()
305{ 313{
306 return ::ioctl( _fd, DS_INSERT_CARD ); 314 return ::ioctl( _fd, DS_INSERT_CARD );
307} 315}
308 316
309 317
310bool OPcmciaSocket::suspend() 318bool OPcmciaSocket::suspend()
@@ -332,38 +340,42 @@ QStringList OPcmciaSocket::productIdentity() const
332 if ( getTuple( CISTPL_VERS_1 ) ) 340 if ( getTuple( CISTPL_VERS_1 ) )
333 { 341 {
334 for ( int i = 0; i < CISTPL_VERS_1_MAX_PROD_STRINGS; ++i ) 342 for ( int i = 0; i < CISTPL_VERS_1_MAX_PROD_STRINGS; ++i )
335 { 343 {
336 qDebug( " PRODID = '%s'", vers->str+vers->ofs[i] ); 344 qDebug( " PRODID = '%s'", vers->str+vers->ofs[i] );
337 list += vers->str+vers->ofs[i]; 345 list += vers->str+vers->ofs[i];
338 } 346 }
339 } 347 }
340 else 348 else
341 { 349 {
342 list += "<unknown>"; 350 list += "<unknown>";
343 } 351 }
344 return list; 352 return list;
345} 353}
346 354
347 355
348#if 0 356QString OPcmciaSocket::manufacturerIdentity() const
349const QPair& OPcmciaSocket::manufacturerIdentity() const
350{ 357{
351 return _manufId; 358 cistpl_manfid_t *manfid = &_ioctlarg.tuple_parse.parse.manfid;
359 if ( getTuple( CISTPL_MANFID ) )
360 {
361 return QString().sprintf( "0x%04x, 0x%04x", manfid->manf, manfid->card );
362 }
363 else
364 return "<unknown>";
352} 365}
353#endif
354 366
355 367
356QString OPcmciaSocket::function() const 368QString OPcmciaSocket::function() const
357{ 369{
358 cistpl_funcid_t *funcid = &_ioctlarg.tuple_parse.parse.funcid; 370 cistpl_funcid_t *funcid = &_ioctlarg.tuple_parse.parse.funcid;
359 if ( getTuple( CISTPL_FUNCID ) ) 371 if ( getTuple( CISTPL_FUNCID ) )
360 { 372 {
361 switch ( funcid->func ) 373 switch ( funcid->func )
362 { 374 {
363 case 0: return "Multifunction"; break; 375 case 0: return "Multifunction"; break;
364 case 1: return "Memory"; break; 376 case 1: return "Memory"; break;
365 case 2: return "Serial"; break; 377 case 2: return "Serial"; break;
366 case 3: return "Parallel"; break; 378 case 3: return "Parallel"; break;
367 case 4: return "Fixed Disk"; break; 379 case 4: return "Fixed Disk"; break;
368 case 5: return "Video"; break; 380 case 5: return "Video"; break;
369 case 6: return "Network"; break; 381 case 6: return "Network"; break;
diff --git a/libopie2/opiecore/linux/opcmciasystem.h b/libopie2/opiecore/linux/opcmciasystem.h
index ac6c1de..0fd43cf 100644
--- a/libopie2/opiecore/linux/opcmciasystem.h
+++ b/libopie2/opiecore/linux/opcmciasystem.h
@@ -179,37 +179,35 @@ class OPcmciaSocket : public QObject
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 a list of product IDs
192 */ 192 */
193 QStringList productIdentity() const; 193 QStringList productIdentity() const;
194 /** 194 /**
195 * @returns the manufacturer ID pair 195 * @returns the manufacturer ID string
196 */ 196 */
197#if 0 197 QString manufacturerIdentity() const;
198 const QPair& manufacturerIdentity() const;
199#endif
200 /** 198 /**
201 * @returns the function string 199 * @returns the function string
202 */ 200 */
203 QString function() const; 201 QString function() const;
204 202
205 private: 203 private:
206 void init(); 204 void init();
207 void cleanup(); 205 void cleanup();
208 bool getTuple( cisdata_t tuple ) const; 206 bool getTuple( cisdata_t tuple ) const;
209 int _major; 207 int _major;
210 int _socket; 208 int _socket;
211 int _fd; 209 int _fd;
212 mutable ds_ioctl_arg_t _ioctlarg; 210 mutable ds_ioctl_arg_t _ioctlarg;
213 211
214 private: 212 private:
215 class Private; 213 class Private;