diff options
Diffstat (limited to 'net/can/bcm.c')
| -rw-r--r-- | net/can/bcm.c | 53 | 
1 files changed, 24 insertions, 29 deletions
diff --git a/net/can/bcm.c b/net/can/bcm.c index d6c8ae5b2e6..c84963d2dee 100644 --- a/net/can/bcm.c +++ b/net/can/bcm.c @@ -344,6 +344,18 @@ static void bcm_send_to_user(struct bcm_op *op, struct bcm_msg_head *head,  	}  } +static void bcm_tx_start_timer(struct bcm_op *op) +{ +	if (op->kt_ival1.tv64 && op->count) +		hrtimer_start(&op->timer, +			      ktime_add(ktime_get(), op->kt_ival1), +			      HRTIMER_MODE_ABS); +	else if (op->kt_ival2.tv64) +		hrtimer_start(&op->timer, +			      ktime_add(ktime_get(), op->kt_ival2), +			      HRTIMER_MODE_ABS); +} +  static void bcm_tx_timeout_tsklet(unsigned long data)  {  	struct bcm_op *op = (struct bcm_op *)data; @@ -365,26 +377,12 @@ static void bcm_tx_timeout_tsklet(unsigned long data)  			bcm_send_to_user(op, &msg_head, NULL, 0);  		} -	} - -	if (op->kt_ival1.tv64 && (op->count > 0)) { - -		/* send (next) frame */  		bcm_can_tx(op); -		hrtimer_start(&op->timer, -			      ktime_add(ktime_get(), op->kt_ival1), -			      HRTIMER_MODE_ABS); -	} else { -		if (op->kt_ival2.tv64) { +	} else if (op->kt_ival2.tv64) +		bcm_can_tx(op); -			/* send (next) frame */ -			bcm_can_tx(op); -			hrtimer_start(&op->timer, -				      ktime_add(ktime_get(), op->kt_ival2), -				      HRTIMER_MODE_ABS); -		} -	} +	bcm_tx_start_timer(op);  }  /* @@ -964,23 +962,20 @@ static int bcm_tx_setup(struct bcm_msg_head *msg_head, struct msghdr *msg,  			hrtimer_cancel(&op->timer);  	} -	if ((op->flags & STARTTIMER) && -	    ((op->kt_ival1.tv64 && op->count) || op->kt_ival2.tv64)) { - +	if (op->flags & STARTTIMER) { +		hrtimer_cancel(&op->timer);  		/* spec: send can_frame when starting timer */  		op->flags |= TX_ANNOUNCE; - -		if (op->kt_ival1.tv64 && (op->count > 0)) { -			/* op->count-- is done in bcm_tx_timeout_handler */ -			hrtimer_start(&op->timer, op->kt_ival1, -				      HRTIMER_MODE_REL); -		} else -			hrtimer_start(&op->timer, op->kt_ival2, -				      HRTIMER_MODE_REL);  	} -	if (op->flags & TX_ANNOUNCE) +	if (op->flags & TX_ANNOUNCE) {  		bcm_can_tx(op); +		if (op->count) +			op->count--; +	} + +	if (op->flags & STARTTIMER) +		bcm_tx_start_timer(op);  	return msg_head->nframes * CFSIZ + MHSIZ;  }  |