Commit 2ead7b32 authored by Amitoj Kaur Chawla's avatar Amitoj Kaur Chawla Committed by Greg Kroah-Hartman

staging: comedi: drivers: Use DIV_ROUND_CLOSEST

The kernel.h macro DIV_ROUND_CLOSEST performs the computation
`(x +d/2)/d` but is perhaps more readable.

The Coccinelle script used is as follows:
// <smpl>
@@
expression x,__divisor;
@@
- (((x) + ((__divisor) / 2)) / (__divisor))
+ DIV_ROUND_CLOSEST(x,__divisor)
// </smpl>
Signed-off-by: default avatarAmitoj Kaur Chawla <amitoj1606@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent b7c57dd5
...@@ -496,7 +496,7 @@ static int apci3xxx_ai_ns_to_timer(struct comedi_device *dev, ...@@ -496,7 +496,7 @@ static int apci3xxx_ai_ns_to_timer(struct comedi_device *dev,
switch (flags & CMDF_ROUND_MASK) { switch (flags & CMDF_ROUND_MASK) {
case CMDF_ROUND_NEAREST: case CMDF_ROUND_NEAREST:
default: default:
timer = (*ns + base / 2) / base; timer = DIV_ROUND_CLOSEST(*ns, base);
break; break;
case CMDF_ROUND_DOWN: case CMDF_ROUND_DOWN:
timer = *ns / base; timer = *ns / base;
......
...@@ -637,7 +637,7 @@ static unsigned int pci230_divide_ns(uint64_t ns, unsigned int timebase, ...@@ -637,7 +637,7 @@ static unsigned int pci230_divide_ns(uint64_t ns, unsigned int timebase,
switch (flags & CMDF_ROUND_MASK) { switch (flags & CMDF_ROUND_MASK) {
default: default:
case CMDF_ROUND_NEAREST: case CMDF_ROUND_NEAREST:
div += (rem + (timebase / 2)) / timebase; div += DIV_ROUND_CLOSEST(rem, timebase);
break; break;
case CMDF_ROUND_DOWN: case CMDF_ROUND_DOWN:
break; break;
......
...@@ -1376,7 +1376,7 @@ static int set_ai_fifo_segment_length(struct comedi_device *dev, ...@@ -1376,7 +1376,7 @@ static int set_ai_fifo_segment_length(struct comedi_device *dev,
num_entries = fifo->max_segment_length; num_entries = fifo->max_segment_length;
/* 1 == 256 entries, 2 == 512 entries, etc */ /* 1 == 256 entries, 2 == 512 entries, etc */
num_increments = (num_entries + increment_size / 2) / increment_size; num_increments = DIV_ROUND_CLOSEST(num_entries, increment_size);
bits = (~(num_increments - 1)) & fifo->fifo_size_reg_mask; bits = (~(num_increments - 1)) & fifo->fifo_size_reg_mask;
devpriv->fifo_size_bits &= ~fifo->fifo_size_reg_mask; devpriv->fifo_size_bits &= ~fifo->fifo_size_reg_mask;
...@@ -2004,7 +2004,7 @@ static unsigned int get_divisor(unsigned int ns, unsigned int flags) ...@@ -2004,7 +2004,7 @@ static unsigned int get_divisor(unsigned int ns, unsigned int flags)
break; break;
case CMDF_ROUND_NEAREST: case CMDF_ROUND_NEAREST:
default: default:
divisor = (ns + TIMER_BASE / 2) / TIMER_BASE; divisor = DIV_ROUND_CLOSEST(ns, TIMER_BASE);
break; break;
} }
return divisor; return divisor;
......
...@@ -371,7 +371,7 @@ static unsigned int dt282x_ns_to_timer(unsigned int *ns, unsigned int flags) ...@@ -371,7 +371,7 @@ static unsigned int dt282x_ns_to_timer(unsigned int *ns, unsigned int flags)
switch (flags & CMDF_ROUND_MASK) { switch (flags & CMDF_ROUND_MASK) {
case CMDF_ROUND_NEAREST: case CMDF_ROUND_NEAREST:
default: default:
divider = (*ns + base / 2) / base; divider = DIV_ROUND_CLOSEST(*ns, base);
break; break;
case CMDF_ROUND_DOWN: case CMDF_ROUND_DOWN:
divider = (*ns) / base; divider = (*ns) / base;
......
...@@ -361,7 +361,7 @@ static int dt3k_ns_to_timer(unsigned int timer_base, unsigned int *nanosec, ...@@ -361,7 +361,7 @@ static int dt3k_ns_to_timer(unsigned int timer_base, unsigned int *nanosec,
switch (flags & CMDF_ROUND_MASK) { switch (flags & CMDF_ROUND_MASK) {
case CMDF_ROUND_NEAREST: case CMDF_ROUND_NEAREST:
default: default:
divider = (*nanosec + base / 2) / base; divider = DIV_ROUND_CLOSEST(*nanosec, base);
break; break;
case CMDF_ROUND_DOWN: case CMDF_ROUND_DOWN:
divider = (*nanosec) / base; divider = (*nanosec) / base;
......
...@@ -525,7 +525,7 @@ static int ni_pcidio_ns_to_timer(int *nanosec, unsigned int flags) ...@@ -525,7 +525,7 @@ static int ni_pcidio_ns_to_timer(int *nanosec, unsigned int flags)
switch (flags & CMDF_ROUND_MASK) { switch (flags & CMDF_ROUND_MASK) {
case CMDF_ROUND_NEAREST: case CMDF_ROUND_NEAREST:
default: default:
divider = (*nanosec + base / 2) / base; divider = DIV_ROUND_CLOSEST(*nanosec, base);
break; break;
case CMDF_ROUND_DOWN: case CMDF_ROUND_DOWN:
divider = (*nanosec) / base; divider = (*nanosec) / base;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment