Diffstat (limited to 'libopie2/opiecore/linux/opcmciasystem.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r-- | libopie2/opiecore/linux/opcmciasystem.cpp | 7 |
1 files changed, 7 insertions, 0 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 | |||
@@ -61,192 +61,199 @@ OPcmciaSystem::OPcmciaSystem() | |||
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 | ||
90 | void OPcmciaSystem::synchronize() | 90 | void 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 | ||
132 | int OPcmciaSystem::count() const | 132 | int OPcmciaSystem::count() const |
133 | { | 133 | { |
134 | return _interfaces.count(); | 134 | return _interfaces.count(); |
135 | } | 135 | } |
136 | 136 | ||
137 | 137 | ||
138 | int OPcmciaSystem::cardCount() const | 138 | int 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 | ||
151 | OPcmciaSocket* OPcmciaSystem::socket( unsigned int number ) | 151 | OPcmciaSocket* OPcmciaSystem::socket( unsigned int number ) |
152 | { | 152 | { |
153 | return _interfaces.at( number ); | 153 | return _interfaces.at( number ); |
154 | } | 154 | } |
155 | 155 | ||
156 | 156 | ||
157 | void OPcmciaSystem::restart() | ||
158 | { | ||
159 | //FIXME Use OProcess or something that allows more control | ||
160 | ::system( "/etc/init.d/pcmcia restart" ); | ||
161 | } | ||
162 | |||
163 | |||
157 | OPcmciaSystem* OPcmciaSystem::instance() | 164 | OPcmciaSystem* 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 | ||
164 | OPcmciaSystem::CardIterator OPcmciaSystem::iterator() const | 171 | OPcmciaSystem::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 | ||
174 | OPcmciaSocket::OPcmciaSocket( int major, int socket, QObject* parent, const char* name ) | 181 | OPcmciaSocket::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 | ||
182 | OPcmciaSocket::~OPcmciaSocket() | 189 | OPcmciaSocket::~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 ) ); |