2009-04-23 17:19:19

by Simon Arlott

[permalink] [raw]
Subject: [PATCH] cxacru: Fix negative dB output

Values of dB between -0.99 and -0.01 will be output with the wrong
sign. This converts the negative value to positive and outputs it
with a "-" prefix.

Signed-off-by: Simon Arlott <[email protected]>
---
drivers/usb/atm/cxacru.c | 10 ++++++++--
1 files changed, 8 insertions(+), 2 deletions(-)

diff --git a/drivers/usb/atm/cxacru.c b/drivers/usb/atm/cxacru.c
index 6789089..56802d2 100644
--- a/drivers/usb/atm/cxacru.c
+++ b/drivers/usb/atm/cxacru.c
@@ -227,8 +227,14 @@ static ssize_t cxacru_sysfs_showattr_s8(s8 value, char *buf)

static ssize_t cxacru_sysfs_showattr_dB(s16 value, char *buf)
{
- return snprintf(buf, PAGE_SIZE, "%d.%02u\n",
- value / 100, abs(value) % 100);
+ if (likely(value >= 0)) {
+ return snprintf(buf, PAGE_SIZE, "%u.%02u\n",
+ value / 100, value % 100);
+ } else {
+ value = -value;
+ return snprintf(buf, PAGE_SIZE, "-%u.%02u\n",
+ value / 100, value % 100);
+ }
}

static ssize_t cxacru_sysfs_showattr_bool(u32 value, char *buf)
--
1.6.2.2

--
Simon Arlott


2009-04-27 10:22:43

by David Miller

[permalink] [raw]
Subject: Re: [PATCH] cxacru: Fix negative dB output

From: Simon Arlott <[email protected]>
Date: Thu, 23 Apr 2009 18:19:02 +0100

> Values of dB between -0.99 and -0.01 will be output with the wrong
> sign. This converts the negative value to positive and outputs it
> with a "-" prefix.
>
> Signed-off-by: Simon Arlott <[email protected]>

Applied to net-next-2.6, thanks.