diff options
Diffstat (limited to 'drivers/isdn')
-rw-r--r-- | drivers/isdn/capi/kcapi.c | 320 | ||||
-rw-r--r-- | drivers/isdn/capi/kcapi.h | 8 | ||||
-rw-r--r-- | drivers/isdn/capi/kcapi_proc.c | 17 |
3 files changed, 177 insertions, 168 deletions
diff --git a/drivers/isdn/capi/kcapi.c b/drivers/isdn/capi/kcapi.c index ef564ee1c06c..f37c13b4ddc7 100644 --- a/drivers/isdn/capi/kcapi.c +++ b/drivers/isdn/capi/kcapi.c | |||
@@ -67,24 +67,24 @@ static DEFINE_RWLOCK(application_lock); | |||
67 | static DEFINE_MUTEX(controller_mutex); | 67 | static DEFINE_MUTEX(controller_mutex); |
68 | 68 | ||
69 | struct capi20_appl *capi_applications[CAPI_MAXAPPL]; | 69 | struct capi20_appl *capi_applications[CAPI_MAXAPPL]; |
70 | struct capi_ctr *capi_cards[CAPI_MAXCONTR]; | 70 | struct capi_ctr *capi_controller[CAPI_MAXCONTR]; |
71 | 71 | ||
72 | static int ncards; | 72 | static int ncontrollers; |
73 | 73 | ||
74 | /* -------- controller ref counting -------------------------------------- */ | 74 | /* -------- controller ref counting -------------------------------------- */ |
75 | 75 | ||
76 | static inline struct capi_ctr * | 76 | static inline struct capi_ctr * |
77 | capi_ctr_get(struct capi_ctr *card) | 77 | capi_ctr_get(struct capi_ctr *ctr) |
78 | { | 78 | { |
79 | if (!try_module_get(card->owner)) | 79 | if (!try_module_get(ctr->owner)) |
80 | return NULL; | 80 | return NULL; |
81 | return card; | 81 | return ctr; |
82 | } | 82 | } |
83 | 83 | ||
84 | static inline void | 84 | static inline void |
85 | capi_ctr_put(struct capi_ctr *card) | 85 | capi_ctr_put(struct capi_ctr *ctr) |
86 | { | 86 | { |
87 | module_put(card->owner); | 87 | module_put(ctr->owner); |
88 | } | 88 | } |
89 | 89 | ||
90 | /* ------------------------------------------------------------- */ | 90 | /* ------------------------------------------------------------- */ |
@@ -94,7 +94,7 @@ static inline struct capi_ctr *get_capi_ctr_by_nr(u16 contr) | |||
94 | if (contr - 1 >= CAPI_MAXCONTR) | 94 | if (contr - 1 >= CAPI_MAXCONTR) |
95 | return NULL; | 95 | return NULL; |
96 | 96 | ||
97 | return capi_cards[contr - 1]; | 97 | return capi_controller[contr - 1]; |
98 | } | 98 | } |
99 | 99 | ||
100 | static inline struct capi20_appl *get_capi_appl_by_nr(u16 applid) | 100 | static inline struct capi20_appl *get_capi_appl_by_nr(u16 applid) |
@@ -144,46 +144,48 @@ static inline int capi_subcmd_valid(u8 subcmd) | |||
144 | 144 | ||
145 | /* ------------------------------------------------------------ */ | 145 | /* ------------------------------------------------------------ */ |
146 | 146 | ||
147 | static void register_appl(struct capi_ctr *card, u16 applid, capi_register_params *rparam) | 147 | static void |
148 | register_appl(struct capi_ctr *ctr, u16 applid, capi_register_params *rparam) | ||
148 | { | 149 | { |
149 | card = capi_ctr_get(card); | 150 | ctr = capi_ctr_get(ctr); |
150 | 151 | ||
151 | if (card) | 152 | if (ctr) |
152 | card->register_appl(card, applid, rparam); | 153 | ctr->register_appl(ctr, applid, rparam); |
153 | else | 154 | else |
154 | printk(KERN_WARNING "%s: cannot get card resources\n", __func__); | 155 | printk(KERN_WARNING "%s: cannot get controller resources\n", |
156 | __func__); | ||
155 | } | 157 | } |
156 | 158 | ||
157 | 159 | ||
158 | static void release_appl(struct capi_ctr *card, u16 applid) | 160 | static void release_appl(struct capi_ctr *ctr, u16 applid) |
159 | { | 161 | { |
160 | DBG("applid %#x", applid); | 162 | DBG("applid %#x", applid); |
161 | 163 | ||
162 | card->release_appl(card, applid); | 164 | ctr->release_appl(ctr, applid); |
163 | capi_ctr_put(card); | 165 | capi_ctr_put(ctr); |
164 | } | 166 | } |
165 | 167 | ||
166 | /* -------- KCI_CONTRUP --------------------------------------- */ | 168 | /* -------- KCI_CONTRUP --------------------------------------- */ |
167 | 169 | ||
168 | static void notify_up(u32 contr) | 170 | static void notify_up(u32 contr) |
169 | { | 171 | { |
170 | struct capi_ctr *card = get_capi_ctr_by_nr(contr); | 172 | struct capi_ctr *ctr = get_capi_ctr_by_nr(contr); |
171 | struct capi20_appl *ap; | 173 | struct capi20_appl *ap; |
172 | u16 applid; | 174 | u16 applid; |
173 | 175 | ||
174 | if (showcapimsgs & 1) { | 176 | if (showcapimsgs & 1) { |
175 | printk(KERN_DEBUG "kcapi: notify up contr %d\n", contr); | 177 | printk(KERN_DEBUG "kcapi: notify up contr %d\n", contr); |
176 | } | 178 | } |
177 | if (!card) { | 179 | if (!ctr) { |
178 | printk(KERN_WARNING "%s: invalid contr %d\n", __func__, contr); | 180 | printk(KERN_WARNING "%s: invalid contr %d\n", __func__, contr); |
179 | return; | 181 | return; |
180 | } | 182 | } |
181 | for (applid = 1; applid <= CAPI_MAXAPPL; applid++) { | 183 | for (applid = 1; applid <= CAPI_MAXAPPL; applid++) { |
182 | ap = get_capi_appl_by_nr(applid); | 184 | ap = get_capi_appl_by_nr(applid); |
183 | if (!ap || ap->release_in_progress) continue; | 185 | if (!ap || ap->release_in_progress) continue; |
184 | register_appl(card, applid, &ap->rparam); | 186 | register_appl(ctr, applid, &ap->rparam); |
185 | if (ap->callback && !ap->release_in_progress) | 187 | if (ap->callback && !ap->release_in_progress) |
186 | ap->callback(KCI_CONTRUP, contr, &card->profile); | 188 | ap->callback(KCI_CONTRUP, contr, &ctr->profile); |
187 | } | 189 | } |
188 | } | 190 | } |
189 | 191 | ||
@@ -269,14 +271,15 @@ static void recv_handler(struct work_struct *work) | |||
269 | 271 | ||
270 | /** | 272 | /** |
271 | * capi_ctr_handle_message() - handle incoming CAPI message | 273 | * capi_ctr_handle_message() - handle incoming CAPI message |
272 | * @card: controller descriptor structure. | 274 | * @ctr: controller descriptor structure. |
273 | * @appl: application ID. | 275 | * @appl: application ID. |
274 | * @skb: message. | 276 | * @skb: message. |
275 | * | 277 | * |
276 | * Called by hardware driver to pass a CAPI message to the application. | 278 | * Called by hardware driver to pass a CAPI message to the application. |
277 | */ | 279 | */ |
278 | 280 | ||
279 | void capi_ctr_handle_message(struct capi_ctr * card, u16 appl, struct sk_buff *skb) | 281 | void capi_ctr_handle_message(struct capi_ctr *ctr, u16 appl, |
282 | struct sk_buff *skb) | ||
280 | { | 283 | { |
281 | struct capi20_appl *ap; | 284 | struct capi20_appl *ap; |
282 | int showctl = 0; | 285 | int showctl = 0; |
@@ -284,43 +287,45 @@ void capi_ctr_handle_message(struct capi_ctr * card, u16 appl, struct sk_buff *s | |||
284 | unsigned long flags; | 287 | unsigned long flags; |
285 | _cdebbuf *cdb; | 288 | _cdebbuf *cdb; |
286 | 289 | ||
287 | if (card->cardstate != CARD_RUNNING) { | 290 | if (ctr->state != CAPI_CTR_RUNNING) { |
288 | cdb = capi_message2str(skb->data); | 291 | cdb = capi_message2str(skb->data); |
289 | if (cdb) { | 292 | if (cdb) { |
290 | printk(KERN_INFO "kcapi: controller [%03d] not active, got: %s", | 293 | printk(KERN_INFO "kcapi: controller [%03d] not active, got: %s", |
291 | card->cnr, cdb->buf); | 294 | ctr->cnr, cdb->buf); |
292 | cdebbuf_free(cdb); | 295 | cdebbuf_free(cdb); |
293 | } else | 296 | } else |
294 | printk(KERN_INFO "kcapi: controller [%03d] not active, cannot trace\n", | 297 | printk(KERN_INFO "kcapi: controller [%03d] not active, cannot trace\n", |
295 | card->cnr); | 298 | ctr->cnr); |
296 | goto error; | 299 | goto error; |
297 | } | 300 | } |
298 | 301 | ||
299 | cmd = CAPIMSG_COMMAND(skb->data); | 302 | cmd = CAPIMSG_COMMAND(skb->data); |
300 | subcmd = CAPIMSG_SUBCOMMAND(skb->data); | 303 | subcmd = CAPIMSG_SUBCOMMAND(skb->data); |
301 | if (cmd == CAPI_DATA_B3 && subcmd == CAPI_IND) { | 304 | if (cmd == CAPI_DATA_B3 && subcmd == CAPI_IND) { |
302 | card->nrecvdatapkt++; | 305 | ctr->nrecvdatapkt++; |
303 | if (card->traceflag > 2) showctl |= 2; | 306 | if (ctr->traceflag > 2) |
307 | showctl |= 2; | ||
304 | } else { | 308 | } else { |
305 | card->nrecvctlpkt++; | 309 | ctr->nrecvctlpkt++; |
306 | if (card->traceflag) showctl |= 2; | 310 | if (ctr->traceflag) |
311 | showctl |= 2; | ||
307 | } | 312 | } |
308 | showctl |= (card->traceflag & 1); | 313 | showctl |= (ctr->traceflag & 1); |
309 | if (showctl & 2) { | 314 | if (showctl & 2) { |
310 | if (showctl & 1) { | 315 | if (showctl & 1) { |
311 | printk(KERN_DEBUG "kcapi: got [%03d] id#%d %s len=%u\n", | 316 | printk(KERN_DEBUG "kcapi: got [%03d] id#%d %s len=%u\n", |
312 | card->cnr, CAPIMSG_APPID(skb->data), | 317 | ctr->cnr, CAPIMSG_APPID(skb->data), |
313 | capi_cmd2str(cmd, subcmd), | 318 | capi_cmd2str(cmd, subcmd), |
314 | CAPIMSG_LEN(skb->data)); | 319 | CAPIMSG_LEN(skb->data)); |
315 | } else { | 320 | } else { |
316 | cdb = capi_message2str(skb->data); | 321 | cdb = capi_message2str(skb->data); |
317 | if (cdb) { | 322 | if (cdb) { |
318 | printk(KERN_DEBUG "kcapi: got [%03d] %s\n", | 323 | printk(KERN_DEBUG "kcapi: got [%03d] %s\n", |
319 | card->cnr, cdb->buf); | 324 | ctr->cnr, cdb->buf); |
320 | cdebbuf_free(cdb); | 325 | cdebbuf_free(cdb); |
321 | } else | 326 | } else |
322 | printk(KERN_DEBUG "kcapi: got [%03d] id#%d %s len=%u, cannot trace\n", | 327 | printk(KERN_DEBUG "kcapi: got [%03d] id#%d %s len=%u, cannot trace\n", |
323 | card->cnr, CAPIMSG_APPID(skb->data), | 328 | ctr->cnr, CAPIMSG_APPID(skb->data), |
324 | capi_cmd2str(cmd, subcmd), | 329 | capi_cmd2str(cmd, subcmd), |
325 | CAPIMSG_LEN(skb->data)); | 330 | CAPIMSG_LEN(skb->data)); |
326 | } | 331 | } |
@@ -356,74 +361,75 @@ EXPORT_SYMBOL(capi_ctr_handle_message); | |||
356 | 361 | ||
357 | /** | 362 | /** |
358 | * capi_ctr_ready() - signal CAPI controller ready | 363 | * capi_ctr_ready() - signal CAPI controller ready |
359 | * @card: controller descriptor structure. | 364 | * @ctr: controller descriptor structure. |
360 | * | 365 | * |
361 | * Called by hardware driver to signal that the controller is up and running. | 366 | * Called by hardware driver to signal that the controller is up and running. |
362 | */ | 367 | */ |
363 | 368 | ||
364 | void capi_ctr_ready(struct capi_ctr * card) | 369 | void capi_ctr_ready(struct capi_ctr *ctr) |
365 | { | 370 | { |
366 | card->cardstate = CARD_RUNNING; | 371 | ctr->state = CAPI_CTR_RUNNING; |
367 | 372 | ||
368 | printk(KERN_NOTICE "kcapi: card [%03d] \"%s\" ready.\n", | 373 | printk(KERN_NOTICE "kcapi: controller [%03d] \"%s\" ready.\n", |
369 | card->cnr, card->name); | 374 | ctr->cnr, ctr->name); |
370 | 375 | ||
371 | notify_push(KCI_CONTRUP, card->cnr, 0, 0); | 376 | notify_push(KCI_CONTRUP, ctr->cnr, 0, 0); |
372 | } | 377 | } |
373 | 378 | ||
374 | EXPORT_SYMBOL(capi_ctr_ready); | 379 | EXPORT_SYMBOL(capi_ctr_ready); |
375 | 380 | ||
376 | /** | 381 | /** |
377 | * capi_ctr_down() - signal CAPI controller not ready | 382 | * capi_ctr_down() - signal CAPI controller not ready |
378 | * @card: controller descriptor structure. | 383 | * @ctr: controller descriptor structure. |
379 | * | 384 | * |
380 | * Called by hardware driver to signal that the controller is down and | 385 | * Called by hardware driver to signal that the controller is down and |
381 | * unavailable for use. | 386 | * unavailable for use. |
382 | */ | 387 | */ |
383 | 388 | ||
384 | void capi_ctr_down(struct capi_ctr * card) | 389 | void capi_ctr_down(struct capi_ctr *ctr) |
385 | { | 390 | { |
386 | u16 appl; | 391 | u16 appl; |
387 | 392 | ||
388 | DBG(""); | 393 | DBG(""); |
389 | 394 | ||
390 | if (card->cardstate == CARD_DETECTED) | 395 | if (ctr->state == CAPI_CTR_DETECTED) |
391 | return; | 396 | return; |
392 | 397 | ||
393 | card->cardstate = CARD_DETECTED; | 398 | ctr->state = CAPI_CTR_DETECTED; |
394 | 399 | ||
395 | memset(card->manu, 0, sizeof(card->manu)); | 400 | memset(ctr->manu, 0, sizeof(ctr->manu)); |
396 | memset(&card->version, 0, sizeof(card->version)); | 401 | memset(&ctr->version, 0, sizeof(ctr->version)); |
397 | memset(&card->profile, 0, sizeof(card->profile)); | 402 | memset(&ctr->profile, 0, sizeof(ctr->profile)); |
398 | memset(card->serial, 0, sizeof(card->serial)); | 403 | memset(ctr->serial, 0, sizeof(ctr->serial)); |
399 | 404 | ||
400 | for (appl = 1; appl <= CAPI_MAXAPPL; appl++) { | 405 | for (appl = 1; appl <= CAPI_MAXAPPL; appl++) { |
401 | struct capi20_appl *ap = get_capi_appl_by_nr(appl); | 406 | struct capi20_appl *ap = get_capi_appl_by_nr(appl); |
402 | if (!ap || ap->release_in_progress) | 407 | if (!ap || ap->release_in_progress) |
403 | continue; | 408 | continue; |
404 | 409 | ||
405 | capi_ctr_put(card); | 410 | capi_ctr_put(ctr); |
406 | } | 411 | } |
407 | 412 | ||
408 | printk(KERN_NOTICE "kcapi: card [%03d] down.\n", card->cnr); | 413 | printk(KERN_NOTICE "kcapi: controller [%03d] down.\n", ctr->cnr); |
409 | 414 | ||
410 | notify_push(KCI_CONTRDOWN, card->cnr, 0, 0); | 415 | notify_push(KCI_CONTRDOWN, ctr->cnr, 0, 0); |
411 | } | 416 | } |
412 | 417 | ||
413 | EXPORT_SYMBOL(capi_ctr_down); | 418 | EXPORT_SYMBOL(capi_ctr_down); |
414 | 419 | ||
415 | /** | 420 | /** |
416 | * capi_ctr_suspend_output() - suspend controller | 421 | * capi_ctr_suspend_output() - suspend controller |
417 | * @card: controller descriptor structure. | 422 | * @ctr: controller descriptor structure. |
418 | * | 423 | * |
419 | * Called by hardware driver to stop data flow. | 424 | * Called by hardware driver to stop data flow. |
420 | */ | 425 | */ |
421 | 426 | ||
422 | void capi_ctr_suspend_output(struct capi_ctr *card) | 427 | void capi_ctr_suspend_output(struct capi_ctr *ctr) |
423 | { | 428 | { |
424 | if (!card->blocked) { | 429 | if (!ctr->blocked) { |
425 | printk(KERN_DEBUG "kcapi: card [%03d] suspend\n", card->cnr); | 430 | printk(KERN_DEBUG "kcapi: controller [%03d] suspend\n", |
426 | card->blocked = 1; | 431 | ctr->cnr); |
432 | ctr->blocked = 1; | ||
427 | } | 433 | } |
428 | } | 434 | } |
429 | 435 | ||
@@ -431,16 +437,17 @@ EXPORT_SYMBOL(capi_ctr_suspend_output); | |||
431 | 437 | ||
432 | /** | 438 | /** |
433 | * capi_ctr_resume_output() - resume controller | 439 | * capi_ctr_resume_output() - resume controller |
434 | * @card: controller descriptor structure. | 440 | * @ctr: controller descriptor structure. |
435 | * | 441 | * |
436 | * Called by hardware driver to resume data flow. | 442 | * Called by hardware driver to resume data flow. |
437 | */ | 443 | */ |
438 | 444 | ||
439 | void capi_ctr_resume_output(struct capi_ctr *card) | 445 | void capi_ctr_resume_output(struct capi_ctr *ctr) |
440 | { | 446 | { |
441 | if (card->blocked) { | 447 | if (ctr->blocked) { |
442 | printk(KERN_DEBUG "kcapi: card [%03d] resume\n", card->cnr); | 448 | printk(KERN_DEBUG "kcapi: controller [%03d] resumed\n", |
443 | card->blocked = 0; | 449 | ctr->cnr); |
450 | ctr->blocked = 0; | ||
444 | } | 451 | } |
445 | } | 452 | } |
446 | 453 | ||
@@ -450,21 +457,20 @@ EXPORT_SYMBOL(capi_ctr_resume_output); | |||
450 | 457 | ||
451 | /** | 458 | /** |
452 | * attach_capi_ctr() - register CAPI controller | 459 | * attach_capi_ctr() - register CAPI controller |
453 | * @card: controller descriptor structure. | 460 | * @ctr: controller descriptor structure. |
454 | * | 461 | * |
455 | * Called by hardware driver to register a controller with the CAPI subsystem. | 462 | * Called by hardware driver to register a controller with the CAPI subsystem. |
456 | * Return value: 0 on success, error code < 0 on error | 463 | * Return value: 0 on success, error code < 0 on error |
457 | */ | 464 | */ |
458 | 465 | ||
459 | int | 466 | int attach_capi_ctr(struct capi_ctr *ctr) |
460 | attach_capi_ctr(struct capi_ctr *card) | ||
461 | { | 467 | { |
462 | int i; | 468 | int i; |
463 | 469 | ||
464 | mutex_lock(&controller_mutex); | 470 | mutex_lock(&controller_mutex); |
465 | 471 | ||
466 | for (i = 0; i < CAPI_MAXCONTR; i++) { | 472 | for (i = 0; i < CAPI_MAXCONTR; i++) { |
467 | if (capi_cards[i] == NULL) | 473 | if (!capi_controller[i]) |
468 | break; | 474 | break; |
469 | } | 475 | } |
470 | if (i == CAPI_MAXCONTR) { | 476 | if (i == CAPI_MAXCONTR) { |
@@ -472,25 +478,25 @@ attach_capi_ctr(struct capi_ctr *card) | |||
472 | printk(KERN_ERR "kcapi: out of controller slots\n"); | 478 | printk(KERN_ERR "kcapi: out of controller slots\n"); |
473 | return -EBUSY; | 479 | return -EBUSY; |
474 | } | 480 | } |
475 | capi_cards[i] = card; | 481 | capi_controller[i] = ctr; |
476 | 482 | ||
477 | mutex_unlock(&controller_mutex); | 483 | mutex_unlock(&controller_mutex); |
478 | 484 | ||
479 | card->nrecvctlpkt = 0; | 485 | ctr->nrecvctlpkt = 0; |
480 | card->nrecvdatapkt = 0; | 486 | ctr->nrecvdatapkt = 0; |
481 | card->nsentctlpkt = 0; | 487 | ctr->nsentctlpkt = 0; |
482 | card->nsentdatapkt = 0; | 488 | ctr->nsentdatapkt = 0; |
483 | card->cnr = i + 1; | 489 | ctr->cnr = i + 1; |
484 | card->cardstate = CARD_DETECTED; | 490 | ctr->state = CAPI_CTR_DETECTED; |
485 | card->blocked = 0; | 491 | ctr->blocked = 0; |
486 | card->traceflag = showcapimsgs; | 492 | ctr->traceflag = showcapimsgs; |
487 | 493 | ||
488 | sprintf(card->procfn, "capi/controllers/%d", card->cnr); | 494 | sprintf(ctr->procfn, "capi/controllers/%d", ctr->cnr); |
489 | card->procent = proc_create_data(card->procfn, 0, NULL, card->proc_fops, card); | 495 | ctr->procent = proc_create_data(ctr->procfn, 0, NULL, ctr->proc_fops, ctr); |
490 | 496 | ||
491 | ncards++; | 497 | ncontrollers++; |
492 | printk(KERN_NOTICE "kcapi: Controller [%03d]: %s attached\n", | 498 | printk(KERN_NOTICE "kcapi: controller [%03d]: %s attached\n", |
493 | card->cnr, card->name); | 499 | ctr->cnr, ctr->name); |
494 | return 0; | 500 | return 0; |
495 | } | 501 | } |
496 | 502 | ||
@@ -498,27 +504,27 @@ EXPORT_SYMBOL(attach_capi_ctr); | |||
498 | 504 | ||
499 | /** | 505 | /** |
500 | * detach_capi_ctr() - unregister CAPI controller | 506 | * detach_capi_ctr() - unregister CAPI controller |
501 | * @card: controller descriptor structure. | 507 | * @ctr: controller descriptor structure. |
502 | * | 508 | * |
503 | * Called by hardware driver to remove the registration of a controller | 509 | * Called by hardware driver to remove the registration of a controller |
504 | * with the CAPI subsystem. | 510 | * with the CAPI subsystem. |
505 | * Return value: 0 on success, error code < 0 on error | 511 | * Return value: 0 on success, error code < 0 on error |
506 | */ | 512 | */ |
507 | 513 | ||
508 | int detach_capi_ctr(struct capi_ctr *card) | 514 | int detach_capi_ctr(struct capi_ctr *ctr) |
509 | { | 515 | { |
510 | if (card->cardstate != CARD_DETECTED) | 516 | if (ctr->state != CAPI_CTR_DETECTED) |
511 | capi_ctr_down(card); | 517 | capi_ctr_down(ctr); |
512 | 518 | ||
513 | ncards--; | 519 | ncontrollers--; |
514 | 520 | ||
515 | if (card->procent) { | 521 | if (ctr->procent) { |
516 | remove_proc_entry(card->procfn, NULL); | 522 | remove_proc_entry(ctr->procfn, NULL); |
517 | card->procent = NULL; | 523 | ctr->procent = NULL; |
518 | } | 524 | } |
519 | capi_cards[card->cnr - 1] = NULL; | 525 | capi_controller[ctr->cnr - 1] = NULL; |
520 | printk(KERN_NOTICE "kcapi: Controller [%03d]: %s unregistered\n", | 526 | printk(KERN_NOTICE "kcapi: controller [%03d]: %s unregistered\n", |
521 | card->cnr, card->name); | 527 | ctr->cnr, ctr->name); |
522 | 528 | ||
523 | return 0; | 529 | return 0; |
524 | } | 530 | } |
@@ -576,7 +582,8 @@ u16 capi20_isinstalled(void) | |||
576 | { | 582 | { |
577 | int i; | 583 | int i; |
578 | for (i = 0; i < CAPI_MAXCONTR; i++) { | 584 | for (i = 0; i < CAPI_MAXCONTR; i++) { |
579 | if (capi_cards[i] && capi_cards[i]->cardstate == CARD_RUNNING) | 585 | if (capi_controller[i] && |
586 | capi_controller[i]->state == CAPI_CTR_RUNNING) | ||
580 | return CAPI_NOERROR; | 587 | return CAPI_NOERROR; |
581 | } | 588 | } |
582 | return CAPI_REGNOTINSTALLED; | 589 | return CAPI_REGNOTINSTALLED; |
@@ -635,9 +642,10 @@ u16 capi20_register(struct capi20_appl *ap) | |||
635 | 642 | ||
636 | mutex_lock(&controller_mutex); | 643 | mutex_lock(&controller_mutex); |
637 | for (i = 0; i < CAPI_MAXCONTR; i++) { | 644 | for (i = 0; i < CAPI_MAXCONTR; i++) { |
638 | if (!capi_cards[i] || capi_cards[i]->cardstate != CARD_RUNNING) | 645 | if (!capi_controller[i] || |
646 | capi_controller[i]->state != CAPI_CTR_RUNNING) | ||
639 | continue; | 647 | continue; |
640 | register_appl(capi_cards[i], applid, &ap->rparam); | 648 | register_appl(capi_controller[i], applid, &ap->rparam); |
641 | } | 649 | } |
642 | mutex_unlock(&controller_mutex); | 650 | mutex_unlock(&controller_mutex); |
643 | 651 | ||
@@ -674,9 +682,10 @@ u16 capi20_release(struct capi20_appl *ap) | |||
674 | 682 | ||
675 | mutex_lock(&controller_mutex); | 683 | mutex_lock(&controller_mutex); |
676 | for (i = 0; i < CAPI_MAXCONTR; i++) { | 684 | for (i = 0; i < CAPI_MAXCONTR; i++) { |
677 | if (!capi_cards[i] || capi_cards[i]->cardstate != CARD_RUNNING) | 685 | if (!capi_controller[i] || |
686 | capi_controller[i]->state != CAPI_CTR_RUNNING) | ||
678 | continue; | 687 | continue; |
679 | release_appl(capi_cards[i], ap->applid); | 688 | release_appl(capi_controller[i], ap->applid); |
680 | } | 689 | } |
681 | mutex_unlock(&controller_mutex); | 690 | mutex_unlock(&controller_mutex); |
682 | 691 | ||
@@ -703,13 +712,13 @@ EXPORT_SYMBOL(capi20_release); | |||
703 | 712 | ||
704 | u16 capi20_put_message(struct capi20_appl *ap, struct sk_buff *skb) | 713 | u16 capi20_put_message(struct capi20_appl *ap, struct sk_buff *skb) |
705 | { | 714 | { |
706 | struct capi_ctr *card; | 715 | struct capi_ctr *ctr; |
707 | int showctl = 0; | 716 | int showctl = 0; |
708 | u8 cmd, subcmd; | 717 | u8 cmd, subcmd; |
709 | 718 | ||
710 | DBG("applid %#x", ap->applid); | 719 | DBG("applid %#x", ap->applid); |
711 | 720 | ||
712 | if (ncards == 0) | 721 | if (ncontrollers == 0) |
713 | return CAPI_REGNOTINSTALLED; | 722 | return CAPI_REGNOTINSTALLED; |
714 | if ((ap->applid == 0) || ap->release_in_progress) | 723 | if ((ap->applid == 0) || ap->release_in_progress) |
715 | return CAPI_ILLAPPNR; | 724 | return CAPI_ILLAPPNR; |
@@ -717,28 +726,30 @@ u16 capi20_put_message(struct capi20_appl *ap, struct sk_buff *skb) | |||
717 | || !capi_cmd_valid(CAPIMSG_COMMAND(skb->data)) | 726 | || !capi_cmd_valid(CAPIMSG_COMMAND(skb->data)) |
718 | || !capi_subcmd_valid(CAPIMSG_SUBCOMMAND(skb->data))) | 727 | || !capi_subcmd_valid(CAPIMSG_SUBCOMMAND(skb->data))) |
719 | return CAPI_ILLCMDORSUBCMDORMSGTOSMALL; | 728 | return CAPI_ILLCMDORSUBCMDORMSGTOSMALL; |
720 | card = get_capi_ctr_by_nr(CAPIMSG_CONTROLLER(skb->data)); | 729 | ctr = get_capi_ctr_by_nr(CAPIMSG_CONTROLLER(skb->data)); |
721 | if (!card || card->cardstate != CARD_RUNNING) { | 730 | if (!ctr || ctr->state != CAPI_CTR_RUNNING) { |
722 | card = get_capi_ctr_by_nr(1); // XXX why? | 731 | ctr = get_capi_ctr_by_nr(1); /* XXX why? */ |
723 | if (!card || card->cardstate != CARD_RUNNING) | 732 | if (!ctr || ctr->state != CAPI_CTR_RUNNING) |
724 | return CAPI_REGNOTINSTALLED; | 733 | return CAPI_REGNOTINSTALLED; |
725 | } | 734 | } |
726 | if (card->blocked) | 735 | if (ctr->blocked) |
727 | return CAPI_SENDQUEUEFULL; | 736 | return CAPI_SENDQUEUEFULL; |
728 | 737 | ||
729 | cmd = CAPIMSG_COMMAND(skb->data); | 738 | cmd = CAPIMSG_COMMAND(skb->data); |
730 | subcmd = CAPIMSG_SUBCOMMAND(skb->data); | 739 | subcmd = CAPIMSG_SUBCOMMAND(skb->data); |
731 | 740 | ||
732 | if (cmd == CAPI_DATA_B3 && subcmd== CAPI_REQ) { | 741 | if (cmd == CAPI_DATA_B3 && subcmd== CAPI_REQ) { |
733 | card->nsentdatapkt++; | 742 | ctr->nsentdatapkt++; |
734 | ap->nsentdatapkt++; | 743 | ap->nsentdatapkt++; |
735 | if (card->traceflag > 2) showctl |= 2; | 744 | if (ctr->traceflag > 2) |
745 | showctl |= 2; | ||
736 | } else { | 746 | } else { |
737 | card->nsentctlpkt++; | 747 | ctr->nsentctlpkt++; |
738 | ap->nsentctlpkt++; | 748 | ap->nsentctlpkt++; |
739 | if (card->traceflag) showctl |= 2; | 749 | if (ctr->traceflag) |
750 | showctl |= 2; | ||
740 | } | 751 | } |
741 | showctl |= (card->traceflag & 1); | 752 | showctl |= (ctr->traceflag & 1); |
742 | if (showctl & 2) { | 753 | if (showctl & 2) { |
743 | if (showctl & 1) { | 754 | if (showctl & 1) { |
744 | printk(KERN_DEBUG "kcapi: put [%03d] id#%d %s len=%u\n", | 755 | printk(KERN_DEBUG "kcapi: put [%03d] id#%d %s len=%u\n", |
@@ -761,7 +772,7 @@ u16 capi20_put_message(struct capi20_appl *ap, struct sk_buff *skb) | |||
761 | CAPIMSG_LEN(skb->data)); | 772 | CAPIMSG_LEN(skb->data)); |
762 | } | 773 | } |
763 | } | 774 | } |
764 | return card->send_message(card, skb); | 775 | return ctr->send_message(ctr, skb); |
765 | } | 776 | } |
766 | 777 | ||
767 | EXPORT_SYMBOL(capi20_put_message); | 778 | EXPORT_SYMBOL(capi20_put_message); |
@@ -778,16 +789,16 @@ EXPORT_SYMBOL(capi20_put_message); | |||
778 | 789 | ||
779 | u16 capi20_get_manufacturer(u32 contr, u8 *buf) | 790 | u16 capi20_get_manufacturer(u32 contr, u8 *buf) |
780 | { | 791 | { |
781 | struct capi_ctr *card; | 792 | struct capi_ctr *ctr; |
782 | 793 | ||
783 | if (contr == 0) { | 794 | if (contr == 0) { |
784 | strlcpy(buf, capi_manufakturer, CAPI_MANUFACTURER_LEN); | 795 | strlcpy(buf, capi_manufakturer, CAPI_MANUFACTURER_LEN); |
785 | return CAPI_NOERROR; | 796 | return CAPI_NOERROR; |
786 | } | 797 | } |
787 | card = get_capi_ctr_by_nr(contr); | 798 | ctr = get_capi_ctr_by_nr(contr); |
788 | if (!card || card->cardstate != CARD_RUNNING) | 799 | if (!ctr || ctr->state != CAPI_CTR_RUNNING) |
789 | return CAPI_REGNOTINSTALLED; | 800 | return CAPI_REGNOTINSTALLED; |
790 | strlcpy(buf, card->manu, CAPI_MANUFACTURER_LEN); | 801 | strlcpy(buf, ctr->manu, CAPI_MANUFACTURER_LEN); |
791 | return CAPI_NOERROR; | 802 | return CAPI_NOERROR; |
792 | } | 803 | } |
793 | 804 | ||
@@ -805,17 +816,17 @@ EXPORT_SYMBOL(capi20_get_manufacturer); | |||
805 | 816 | ||
806 | u16 capi20_get_version(u32 contr, struct capi_version *verp) | 817 | u16 capi20_get_version(u32 contr, struct capi_version *verp) |
807 | { | 818 | { |
808 | struct capi_ctr *card; | 819 | struct capi_ctr *ctr; |
809 | 820 | ||
810 | if (contr == 0) { | 821 | if (contr == 0) { |
811 | *verp = driver_version; | 822 | *verp = driver_version; |
812 | return CAPI_NOERROR; | 823 | return CAPI_NOERROR; |
813 | } | 824 | } |
814 | card = get_capi_ctr_by_nr(contr); | 825 | ctr = get_capi_ctr_by_nr(contr); |
815 | if (!card || card->cardstate != CARD_RUNNING) | 826 | if (!ctr || ctr->state != CAPI_CTR_RUNNING) |
816 | return CAPI_REGNOTINSTALLED; | 827 | return CAPI_REGNOTINSTALLED; |
817 | 828 | ||
818 | memcpy((void *) verp, &card->version, sizeof(capi_version)); | 829 | memcpy(verp, &ctr->version, sizeof(capi_version)); |
819 | return CAPI_NOERROR; | 830 | return CAPI_NOERROR; |
820 | } | 831 | } |
821 | 832 | ||
@@ -833,17 +844,17 @@ EXPORT_SYMBOL(capi20_get_version); | |||
833 | 844 | ||
834 | u16 capi20_get_serial(u32 contr, u8 *serial) | 845 | u16 capi20_get_serial(u32 contr, u8 *serial) |
835 | { | 846 | { |
836 | struct capi_ctr *card; | 847 | struct capi_ctr *ctr; |
837 | 848 | ||
838 | if (contr == 0) { | 849 | if (contr == 0) { |
839 | strlcpy(serial, driver_serial, CAPI_SERIAL_LEN); | 850 | strlcpy(serial, driver_serial, CAPI_SERIAL_LEN); |
840 | return CAPI_NOERROR; | 851 | return CAPI_NOERROR; |
841 | } | 852 | } |
842 | card = get_capi_ctr_by_nr(contr); | 853 | ctr = get_capi_ctr_by_nr(contr); |
843 | if (!card || card->cardstate != CARD_RUNNING) | 854 | if (!ctr || ctr->state != CAPI_CTR_RUNNING) |
844 | return CAPI_REGNOTINSTALLED; | 855 | return CAPI_REGNOTINSTALLED; |
845 | 856 | ||
846 | strlcpy((void *) serial, card->serial, CAPI_SERIAL_LEN); | 857 | strlcpy(serial, ctr->serial, CAPI_SERIAL_LEN); |
847 | return CAPI_NOERROR; | 858 | return CAPI_NOERROR; |
848 | } | 859 | } |
849 | 860 | ||
@@ -861,18 +872,17 @@ EXPORT_SYMBOL(capi20_get_serial); | |||
861 | 872 | ||
862 | u16 capi20_get_profile(u32 contr, struct capi_profile *profp) | 873 | u16 capi20_get_profile(u32 contr, struct capi_profile *profp) |
863 | { | 874 | { |
864 | struct capi_ctr *card; | 875 | struct capi_ctr *ctr; |
865 | 876 | ||
866 | if (contr == 0) { | 877 | if (contr == 0) { |
867 | profp->ncontroller = ncards; | 878 | profp->ncontroller = ncontrollers; |
868 | return CAPI_NOERROR; | 879 | return CAPI_NOERROR; |
869 | } | 880 | } |
870 | card = get_capi_ctr_by_nr(contr); | 881 | ctr = get_capi_ctr_by_nr(contr); |
871 | if (!card || card->cardstate != CARD_RUNNING) | 882 | if (!ctr || ctr->state != CAPI_CTR_RUNNING) |
872 | return CAPI_REGNOTINSTALLED; | 883 | return CAPI_REGNOTINSTALLED; |
873 | 884 | ||
874 | memcpy((void *) profp, &card->profile, | 885 | memcpy(profp, &ctr->profile, sizeof(struct capi_profile)); |
875 | sizeof(struct capi_profile)); | ||
876 | return CAPI_NOERROR; | 886 | return CAPI_NOERROR; |
877 | } | 887 | } |
878 | 888 | ||
@@ -885,7 +895,7 @@ static int old_capi_manufacturer(unsigned int cmd, void __user *data) | |||
885 | avmb1_extcarddef cdef; | 895 | avmb1_extcarddef cdef; |
886 | avmb1_resetdef rdef; | 896 | avmb1_resetdef rdef; |
887 | capicardparams cparams; | 897 | capicardparams cparams; |
888 | struct capi_ctr *card; | 898 | struct capi_ctr *ctr; |
889 | struct capi_driver *driver = NULL; | 899 | struct capi_driver *driver = NULL; |
890 | capiloaddata ldata; | 900 | capiloaddata ldata; |
891 | struct list_head *l; | 901 | struct list_head *l; |
@@ -958,26 +968,26 @@ static int old_capi_manufacturer(unsigned int cmd, void __user *data) | |||
958 | sizeof(avmb1_loadandconfigdef))) | 968 | sizeof(avmb1_loadandconfigdef))) |
959 | return -EFAULT; | 969 | return -EFAULT; |
960 | } | 970 | } |
961 | card = get_capi_ctr_by_nr(ldef.contr); | 971 | ctr = get_capi_ctr_by_nr(ldef.contr); |
962 | if (!card) | 972 | if (!ctr) |
963 | return -EINVAL; | 973 | return -EINVAL; |
964 | card = capi_ctr_get(card); | 974 | ctr = capi_ctr_get(ctr); |
965 | if (!card) | 975 | if (!ctr) |
966 | return -ESRCH; | 976 | return -ESRCH; |
967 | if (card->load_firmware == NULL) { | 977 | if (ctr->load_firmware == NULL) { |
968 | printk(KERN_DEBUG "kcapi: load: no load function\n"); | 978 | printk(KERN_DEBUG "kcapi: load: no load function\n"); |
969 | capi_ctr_put(card); | 979 | capi_ctr_put(ctr); |
970 | return -ESRCH; | 980 | return -ESRCH; |
971 | } | 981 | } |
972 | 982 | ||
973 | if (ldef.t4file.len <= 0) { | 983 | if (ldef.t4file.len <= 0) { |
974 | printk(KERN_DEBUG "kcapi: load: invalid parameter: length of t4file is %d ?\n", ldef.t4file.len); | 984 | printk(KERN_DEBUG "kcapi: load: invalid parameter: length of t4file is %d ?\n", ldef.t4file.len); |
975 | capi_ctr_put(card); | 985 | capi_ctr_put(ctr); |
976 | return -EINVAL; | 986 | return -EINVAL; |
977 | } | 987 | } |
978 | if (ldef.t4file.data == NULL) { | 988 | if (ldef.t4file.data == NULL) { |
979 | printk(KERN_DEBUG "kcapi: load: invalid parameter: dataptr is 0\n"); | 989 | printk(KERN_DEBUG "kcapi: load: invalid parameter: dataptr is 0\n"); |
980 | capi_ctr_put(card); | 990 | capi_ctr_put(ctr); |
981 | return -EINVAL; | 991 | return -EINVAL; |
982 | } | 992 | } |
983 | 993 | ||
@@ -988,46 +998,46 @@ static int old_capi_manufacturer(unsigned int cmd, void __user *data) | |||
988 | ldata.configuration.data = ldef.t4config.data; | 998 | ldata.configuration.data = ldef.t4config.data; |
989 | ldata.configuration.len = ldef.t4config.len; | 999 | ldata.configuration.len = ldef.t4config.len; |
990 | 1000 | ||
991 | if (card->cardstate != CARD_DETECTED) { | 1001 | if (ctr->state != CAPI_CTR_DETECTED) { |
992 | printk(KERN_INFO "kcapi: load: contr=%d not in detect state\n", ldef.contr); | 1002 | printk(KERN_INFO "kcapi: load: contr=%d not in detect state\n", ldef.contr); |
993 | capi_ctr_put(card); | 1003 | capi_ctr_put(ctr); |
994 | return -EBUSY; | 1004 | return -EBUSY; |
995 | } | 1005 | } |
996 | card->cardstate = CARD_LOADING; | 1006 | ctr->state = CAPI_CTR_LOADING; |
997 | 1007 | ||
998 | retval = card->load_firmware(card, &ldata); | 1008 | retval = ctr->load_firmware(ctr, &ldata); |
999 | 1009 | ||
1000 | if (retval) { | 1010 | if (retval) { |
1001 | card->cardstate = CARD_DETECTED; | 1011 | ctr->state = CAPI_CTR_DETECTED; |
1002 | capi_ctr_put(card); | 1012 | capi_ctr_put(ctr); |
1003 | return retval; | 1013 | return retval; |
1004 | } | 1014 | } |
1005 | 1015 | ||
1006 | while (card->cardstate != CARD_RUNNING) { | 1016 | while (ctr->state != CAPI_CTR_RUNNING) { |
1007 | 1017 | ||
1008 | msleep_interruptible(100); /* 0.1 sec */ | 1018 | msleep_interruptible(100); /* 0.1 sec */ |
1009 | 1019 | ||
1010 | if (signal_pending(current)) { | 1020 | if (signal_pending(current)) { |
1011 | capi_ctr_put(card); | 1021 | capi_ctr_put(ctr); |
1012 | return -EINTR; | 1022 | return -EINTR; |
1013 | } | 1023 | } |
1014 | } | 1024 | } |
1015 | capi_ctr_put(card); | 1025 | capi_ctr_put(ctr); |
1016 | return 0; | 1026 | return 0; |
1017 | 1027 | ||
1018 | case AVMB1_RESETCARD: | 1028 | case AVMB1_RESETCARD: |
1019 | if (copy_from_user(&rdef, data, sizeof(avmb1_resetdef))) | 1029 | if (copy_from_user(&rdef, data, sizeof(avmb1_resetdef))) |
1020 | return -EFAULT; | 1030 | return -EFAULT; |
1021 | card = get_capi_ctr_by_nr(rdef.contr); | 1031 | ctr = get_capi_ctr_by_nr(rdef.contr); |
1022 | if (!card) | 1032 | if (!ctr) |
1023 | return -ESRCH; | 1033 | return -ESRCH; |
1024 | 1034 | ||
1025 | if (card->cardstate == CARD_DETECTED) | 1035 | if (ctr->state == CAPI_CTR_DETECTED) |
1026 | return 0; | 1036 | return 0; |
1027 | 1037 | ||
1028 | card->reset_ctr(card); | 1038 | ctr->reset_ctr(ctr); |
1029 | 1039 | ||
1030 | while (card->cardstate > CARD_DETECTED) { | 1040 | while (ctr->state > CAPI_CTR_DETECTED) { |
1031 | 1041 | ||
1032 | msleep_interruptible(100); /* 0.1 sec */ | 1042 | msleep_interruptible(100); /* 0.1 sec */ |
1033 | 1043 | ||
@@ -1052,7 +1062,7 @@ static int old_capi_manufacturer(unsigned int cmd, void __user *data) | |||
1052 | 1062 | ||
1053 | int capi20_manufacturer(unsigned int cmd, void __user *data) | 1063 | int capi20_manufacturer(unsigned int cmd, void __user *data) |
1054 | { | 1064 | { |
1055 | struct capi_ctr *card; | 1065 | struct capi_ctr *ctr; |
1056 | 1066 | ||
1057 | switch (cmd) { | 1067 | switch (cmd) { |
1058 | #ifdef AVMB1_COMPAT | 1068 | #ifdef AVMB1_COMPAT |
@@ -1070,13 +1080,13 @@ int capi20_manufacturer(unsigned int cmd, void __user *data) | |||
1070 | if (copy_from_user(&fdef, data, sizeof(kcapi_flagdef))) | 1080 | if (copy_from_user(&fdef, data, sizeof(kcapi_flagdef))) |
1071 | return -EFAULT; | 1081 | return -EFAULT; |
1072 | 1082 | ||
1073 | card = get_capi_ctr_by_nr(fdef.contr); | 1083 | ctr = get_capi_ctr_by_nr(fdef.contr); |
1074 | if (!card) | 1084 | if (!ctr) |
1075 | return -ESRCH; | 1085 | return -ESRCH; |
1076 | 1086 | ||
1077 | card->traceflag = fdef.flag; | 1087 | ctr->traceflag = fdef.flag; |
1078 | printk(KERN_INFO "kcapi: contr [%03d] set trace=%d\n", | 1088 | printk(KERN_INFO "kcapi: contr [%03d] set trace=%d\n", |
1079 | card->cnr, card->traceflag); | 1089 | ctr->cnr, ctr->traceflag); |
1080 | return 0; | 1090 | return 0; |
1081 | } | 1091 | } |
1082 | case KCAPI_CMD_ADDCARD: | 1092 | case KCAPI_CMD_ADDCARD: |
diff --git a/drivers/isdn/capi/kcapi.h b/drivers/isdn/capi/kcapi.h index 244711f7f838..f62c53bd6a97 100644 --- a/drivers/isdn/capi/kcapi.h +++ b/drivers/isdn/capi/kcapi.h | |||
@@ -24,16 +24,16 @@ printk(KERN_DEBUG "%s: " format "\n" , __func__ , ## arg); \ | |||
24 | #endif | 24 | #endif |
25 | 25 | ||
26 | enum { | 26 | enum { |
27 | CARD_DETECTED = 1, | 27 | CAPI_CTR_DETECTED = 1, |
28 | CARD_LOADING = 2, | 28 | CAPI_CTR_LOADING = 2, |
29 | CARD_RUNNING = 3, | 29 | CAPI_CTR_RUNNING = 3, |
30 | }; | 30 | }; |
31 | 31 | ||
32 | extern struct list_head capi_drivers; | 32 | extern struct list_head capi_drivers; |
33 | extern rwlock_t capi_drivers_list_lock; | 33 | extern rwlock_t capi_drivers_list_lock; |
34 | 34 | ||
35 | extern struct capi20_appl *capi_applications[CAPI_MAXAPPL]; | 35 | extern struct capi20_appl *capi_applications[CAPI_MAXAPPL]; |
36 | extern struct capi_ctr *capi_cards[CAPI_MAXCONTR]; | 36 | extern struct capi_ctr *capi_controller[CAPI_MAXCONTR]; |
37 | 37 | ||
38 | #ifdef CONFIG_PROC_FS | 38 | #ifdef CONFIG_PROC_FS |
39 | 39 | ||
diff --git a/drivers/isdn/capi/kcapi_proc.c b/drivers/isdn/capi/kcapi_proc.c index 09d4db764d22..59fd16a4ad8e 100644 --- a/drivers/isdn/capi/kcapi_proc.c +++ b/drivers/isdn/capi/kcapi_proc.c | |||
@@ -15,13 +15,12 @@ | |||
15 | #include <linux/seq_file.h> | 15 | #include <linux/seq_file.h> |
16 | #include <linux/init.h> | 16 | #include <linux/init.h> |
17 | 17 | ||
18 | static char * | 18 | static char *state2str(unsigned short state) |
19 | cardstate2str(unsigned short cardstate) | ||
20 | { | 19 | { |
21 | switch (cardstate) { | 20 | switch (state) { |
22 | case CARD_DETECTED: return "detected"; | 21 | case CAPI_CTR_DETECTED: return "detected"; |
23 | case CARD_LOADING: return "loading"; | 22 | case CAPI_CTR_LOADING: return "loading"; |
24 | case CARD_RUNNING: return "running"; | 23 | case CAPI_CTR_RUNNING: return "running"; |
25 | default: return "???"; | 24 | default: return "???"; |
26 | } | 25 | } |
27 | } | 26 | } |
@@ -38,7 +37,7 @@ cardstate2str(unsigned short cardstate) | |||
38 | static void *controller_start(struct seq_file *seq, loff_t *pos) | 37 | static void *controller_start(struct seq_file *seq, loff_t *pos) |
39 | { | 38 | { |
40 | if (*pos < CAPI_MAXCONTR) | 39 | if (*pos < CAPI_MAXCONTR) |
41 | return &capi_cards[*pos]; | 40 | return &capi_controller[*pos]; |
42 | 41 | ||
43 | return NULL; | 42 | return NULL; |
44 | } | 43 | } |
@@ -47,7 +46,7 @@ static void *controller_next(struct seq_file *seq, void *v, loff_t *pos) | |||
47 | { | 46 | { |
48 | ++*pos; | 47 | ++*pos; |
49 | if (*pos < CAPI_MAXCONTR) | 48 | if (*pos < CAPI_MAXCONTR) |
50 | return &capi_cards[*pos]; | 49 | return &capi_controller[*pos]; |
51 | 50 | ||
52 | return NULL; | 51 | return NULL; |
53 | } | 52 | } |
@@ -65,7 +64,7 @@ static int controller_show(struct seq_file *seq, void *v) | |||
65 | 64 | ||
66 | seq_printf(seq, "%d %-10s %-8s %-16s %s\n", | 65 | seq_printf(seq, "%d %-10s %-8s %-16s %s\n", |
67 | ctr->cnr, ctr->driver_name, | 66 | ctr->cnr, ctr->driver_name, |
68 | cardstate2str(ctr->cardstate), | 67 | state2str(ctr->state), |
69 | ctr->name, | 68 | ctr->name, |
70 | ctr->procinfo ? ctr->procinfo(ctr) : ""); | 69 | ctr->procinfo ? ctr->procinfo(ctr) : ""); |
71 | 70 | ||