aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/isdn/gigaset/i4l.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/isdn/gigaset/i4l.c')
-rw-r--r--drivers/isdn/gigaset/i4l.c29
1 files changed, 12 insertions, 17 deletions
diff --git a/drivers/isdn/gigaset/i4l.c b/drivers/isdn/gigaset/i4l.c
index 828824f905c4..c129ee47a8fb 100644
--- a/drivers/isdn/gigaset/i4l.c
+++ b/drivers/isdn/gigaset/i4l.c
@@ -39,12 +39,12 @@
39static int writebuf_from_LL(int driverID, int channel, int ack, 39static int writebuf_from_LL(int driverID, int channel, int ack,
40 struct sk_buff *skb) 40 struct sk_buff *skb)
41{ 41{
42 struct cardstate *cs; 42 struct cardstate *cs = gigaset_get_cs_by_id(driverID);
43 struct bc_state *bcs; 43 struct bc_state *bcs;
44 unsigned char *ack_header; 44 unsigned char *ack_header;
45 unsigned len; 45 unsigned len;
46 46
47 if (!(cs = gigaset_get_cs_by_id(driverID))) { 47 if (!cs) {
48 pr_err("%s: invalid driver ID (%d)\n", __func__, driverID); 48 pr_err("%s: invalid driver ID (%d)\n", __func__, driverID);
49 return -ENODEV; 49 return -ENODEV;
50 } 50 }
@@ -391,22 +391,19 @@ static int command_from_LL(isdn_ctrl *cntrl)
391 391
392 break; 392 break;
393 case ISDN_CMD_PROCEED: 393 case ISDN_CMD_PROCEED:
394 gig_dbg(DEBUG_ANY, "ISDN_CMD_PROCEED"); //FIXME 394 gig_dbg(DEBUG_ANY, "ISDN_CMD_PROCEED");
395 break; 395 break;
396 case ISDN_CMD_ALERT: 396 case ISDN_CMD_ALERT:
397 gig_dbg(DEBUG_ANY, "ISDN_CMD_ALERT"); //FIXME 397 gig_dbg(DEBUG_ANY, "ISDN_CMD_ALERT");
398 if (cntrl->arg >= cs->channels) { 398 if (cntrl->arg >= cs->channels) {
399 dev_err(cs->dev, 399 dev_err(cs->dev,
400 "ISDN_CMD_ALERT: invalid channel (%d)\n", 400 "ISDN_CMD_ALERT: invalid channel (%d)\n",
401 (int) cntrl->arg); 401 (int) cntrl->arg);
402 return -EINVAL; 402 return -EINVAL;
403 } 403 }
404 //bcs = cs->bcs + cntrl->arg;
405 //bcs->proto2 = -1;
406 // FIXME
407 break; 404 break;
408 case ISDN_CMD_REDIR: 405 case ISDN_CMD_REDIR:
409 gig_dbg(DEBUG_ANY, "ISDN_CMD_REDIR"); //FIXME 406 gig_dbg(DEBUG_ANY, "ISDN_CMD_REDIR");
410 break; 407 break;
411 case ISDN_CMD_PROT_IO: 408 case ISDN_CMD_PROT_IO:
412 gig_dbg(DEBUG_ANY, "ISDN_CMD_PROT_IO"); 409 gig_dbg(DEBUG_ANY, "ISDN_CMD_PROT_IO");
@@ -486,7 +483,7 @@ int gigaset_isdn_icall(struct at_state_t *at_state)
486 /* fill ICALL structure */ 483 /* fill ICALL structure */
487 response.parm.setup.si1 = 0; /* default: unknown */ 484 response.parm.setup.si1 = 0; /* default: unknown */
488 response.parm.setup.si2 = 0; 485 response.parm.setup.si2 = 0;
489 response.parm.setup.screen = 0; //FIXME how to set these? 486 response.parm.setup.screen = 0;
490 response.parm.setup.plan = 0; 487 response.parm.setup.plan = 0;
491 if (!at_state->str_var[STR_ZBC]) { 488 if (!at_state->str_var[STR_ZBC]) {
492 /* no BC (internal call): assume speech, A-law */ 489 /* no BC (internal call): assume speech, A-law */
@@ -507,26 +504,24 @@ int gigaset_isdn_icall(struct at_state_t *at_state)
507 return ICALL_IGNORE; 504 return ICALL_IGNORE;
508 } 505 }
509 if (at_state->str_var[STR_NMBR]) { 506 if (at_state->str_var[STR_NMBR]) {
510 strncpy(response.parm.setup.phone, at_state->str_var[STR_NMBR], 507 strlcpy(response.parm.setup.phone, at_state->str_var[STR_NMBR],
511 sizeof response.parm.setup.phone - 1); 508 sizeof response.parm.setup.phone);
512 response.parm.setup.phone[sizeof response.parm.setup.phone - 1] = 0;
513 } else 509 } else
514 response.parm.setup.phone[0] = 0; 510 response.parm.setup.phone[0] = 0;
515 if (at_state->str_var[STR_ZCPN]) { 511 if (at_state->str_var[STR_ZCPN]) {
516 strncpy(response.parm.setup.eazmsn, at_state->str_var[STR_ZCPN], 512 strlcpy(response.parm.setup.eazmsn, at_state->str_var[STR_ZCPN],
517 sizeof response.parm.setup.eazmsn - 1); 513 sizeof response.parm.setup.eazmsn);
518 response.parm.setup.eazmsn[sizeof response.parm.setup.eazmsn - 1] = 0;
519 } else 514 } else
520 response.parm.setup.eazmsn[0] = 0; 515 response.parm.setup.eazmsn[0] = 0;
521 516
522 if (!bcs) { 517 if (!bcs) {
523 dev_notice(cs->dev, "no channel for incoming call\n"); 518 dev_notice(cs->dev, "no channel for incoming call\n");
524 response.command = ISDN_STAT_ICALLW; 519 response.command = ISDN_STAT_ICALLW;
525 response.arg = 0; //FIXME 520 response.arg = 0;
526 } else { 521 } else {
527 gig_dbg(DEBUG_CMD, "Sending ICALL"); 522 gig_dbg(DEBUG_CMD, "Sending ICALL");
528 response.command = ISDN_STAT_ICALL; 523 response.command = ISDN_STAT_ICALL;
529 response.arg = bcs->channel; //FIXME 524 response.arg = bcs->channel;
530 } 525 }
531 response.driver = cs->myid; 526 response.driver = cs->myid;
532 retval = iif->statcallb(&response); 527 retval = iif->statcallb(&response);