author | mickeyl <mickeyl> | 2005-06-19 22:01:20 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2005-06-19 22:01:20 (UTC) |
commit | 83fec70860e56af97d66e9505b913602505423d7 (patch) (unidiff) | |
tree | 1d883e98c9d6897a7305ed2b87ba8fe9aaf9e99d | |
parent | ff5063b7d4f67b77c8bb87bd9c80649f59f3f12d (diff) | |
download | opie-83fec70860e56af97d66e9505b913602505423d7.zip opie-83fec70860e56af97d66e9505b913602505423d7.tar.gz opie-83fec70860e56af97d66e9505b913602505423d7.tar.bz2 |
add note about why we don't use ioctls for gathering the cards initially
-rw-r--r-- | libopie2/opiecore/linux/opcmciasystem.cpp | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/libopie2/opiecore/linux/opcmciasystem.cpp b/libopie2/opiecore/linux/opcmciasystem.cpp index 054d261..eae356e 100644 --- a/libopie2/opiecore/linux/opcmciasystem.cpp +++ b/libopie2/opiecore/linux/opcmciasystem.cpp | |||
@@ -73,49 +73,52 @@ OPcmciaSystem::OPcmciaSystem() | |||
73 | int nodenumber; | 73 | int nodenumber; |
74 | QString driver; | 74 | QString driver; |
75 | devstream >> nodenumber >> driver; | 75 | devstream >> nodenumber >> driver; |
76 | if ( driver == "pcmcia" ) | 76 | if ( driver == "pcmcia" ) |
77 | { | 77 | { |
78 | qDebug( "OPcmciaSystem::OPcmciaSystem(): gotcha! pcmcia node number = %d", nodenumber ); | 78 | qDebug( "OPcmciaSystem::OPcmciaSystem(): gotcha! pcmcia node number = %d", nodenumber ); |
79 | _major = nodenumber; | 79 | _major = nodenumber; |
80 | break; | 80 | break; |
81 | } | 81 | } |
82 | } | 82 | } |
83 | } | 83 | } |
84 | else | 84 | else |
85 | { | 85 | { |
86 | qWarning( "OPcmciaSystem::OPcmciaSystem() - can't open /proc/devices - continuing with limited functionality." ); | 86 | qWarning( "OPcmciaSystem::OPcmciaSystem() - can't open /proc/devices - continuing with limited functionality." ); |
87 | } | 87 | } |
88 | 88 | ||
89 | synchronize(); | 89 | synchronize(); |
90 | } | 90 | } |
91 | 91 | ||
92 | void OPcmciaSystem::synchronize() | 92 | void OPcmciaSystem::synchronize() |
93 | { | 93 | { |
94 | qDebug( "OPcmciaSystem::synchronize()" ); | 94 | qDebug( "OPcmciaSystem::synchronize()" ); |
95 | _interfaces.clear(); | 95 | _interfaces.clear(); |
96 | 96 | ||
97 | //FIXME: Use cardmgr subsystem ioctls | 97 | //NOTE: We _could_ use ioctl's here as well, however we want to know if |
98 | // the card is recognized by the cardmgr (hence has a valid binding) | ||
99 | // If it is not recognized yet, userland may want to provide a configuration dialog | ||
100 | //TODO: Revise for pcmciautils | ||
98 | 101 | ||
99 | QString fileName; | 102 | QString fileName; |
100 | if ( QFile::exists( "/var/run/stab" ) ) { fileName = "/var/run/stab"; } | 103 | if ( QFile::exists( "/var/run/stab" ) ) { fileName = "/var/run/stab"; } |
101 | else if ( QFile::exists( "/var/state/pcmcia/stab" ) ) { fileName = "/var/state/pcmcia/stab"; } | 104 | else if ( QFile::exists( "/var/state/pcmcia/stab" ) ) { fileName = "/var/state/pcmcia/stab"; } |
102 | else { fileName = "/var/lib/pcmcia/stab"; } | 105 | else { fileName = "/var/lib/pcmcia/stab"; } |
103 | QFile cardinfofile( fileName ); | 106 | QFile cardinfofile( fileName ); |
104 | if ( !cardinfofile.exists() || !cardinfofile.open( IO_ReadOnly ) ) | 107 | if ( !cardinfofile.exists() || !cardinfofile.open( IO_ReadOnly ) ) |
105 | { | 108 | { |
106 | qWarning( "pcmcia info file not found or unaccessible" ); | 109 | qWarning( "pcmcia info file not found or unaccessible" ); |
107 | return; | 110 | return; |
108 | } | 111 | } |
109 | QTextStream cardinfo( &cardinfofile ); | 112 | QTextStream cardinfo( &cardinfofile ); |
110 | while ( !cardinfo.atEnd() ) | 113 | while ( !cardinfo.atEnd() ) |
111 | { | 114 | { |
112 | QString strSocket; | 115 | QString strSocket; |
113 | int numSocket; | 116 | int numSocket; |
114 | char colon; | 117 | char colon; |
115 | QString cardName; | 118 | QString cardName; |
116 | cardinfo >> strSocket >> numSocket >> colon; | 119 | cardinfo >> strSocket >> numSocket >> colon; |
117 | cardName = cardinfo.readLine().stripWhiteSpace(); | 120 | cardName = cardinfo.readLine().stripWhiteSpace(); |
118 | qDebug( "strSocket = '%s', numSocket = '%d', colon = '%c', cardName = '%s'", (const char*) strSocket, numSocket, colon, ( const char*) cardName ); | 121 | qDebug( "strSocket = '%s', numSocket = '%d', colon = '%c', cardName = '%s'", (const char*) strSocket, numSocket, colon, ( const char*) cardName ); |
119 | if ( strSocket == "Socket" && colon == ':' ) | 122 | if ( strSocket == "Socket" && colon == ':' ) |
120 | { | 123 | { |
121 | _interfaces.append( new OPcmciaSocket( _major, numSocket, this, (const char*) cardName ) ); | 124 | _interfaces.append( new OPcmciaSocket( _major, numSocket, this, (const char*) cardName ) ); |