
Hi Simon,
On Tue, Apr 28, 2015 at 6:48 AM, Simon Glass sjg@chromium.org wrote:
Add a function similar to print_size() that works for frequencies. It can handle from Hz to GHz.
Signed-off-by: Simon Glass sjg@chromium.org
include/display_options.h | 11 +++++++++++ lib/display_options.c | 41 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 52 insertions(+)
diff --git a/include/display_options.h b/include/display_options.h index c222ea2..10b4641 100644 --- a/include/display_options.h +++ b/include/display_options.h @@ -23,6 +23,17 @@ void print_size(uint64_t size, const char *suffix);
/**
- print_freq() - Print a frequency with a suffix
- print frequencies as "x.xx GHz", "xxx KHz", etc as needed; allow for
print->Print
- optional trailing string (like "\n")
- @freq: Frequency to print in Hz
- @suffix String to print after the frequency
- */
+void print_freq(uint64_t freq, const char *suffix);
+/**
- print_buffer() - Print data buffer in hex and ascii form
- Data reads are buffered so that each memory address is only read once.
diff --git a/lib/display_options.c b/lib/display_options.c index 3f32bcd..cf6f50b 100644 --- a/lib/display_options.c +++ b/lib/display_options.c @@ -7,6 +7,7 @@
#include <config.h> #include <common.h> +#include <div64.h> #include <inttypes.h> #include <version.h> #include <linux/ctype.h> @@ -22,6 +23,46 @@ int display_options (void) return 0; }
+#ifndef CONFIG_SH +/* SH gcc 4.6 toolchain produces "undefined reference to '__umoddi3' here */ +void print_freq(uint64_t freq, const char *s) +{
unsigned long m = 0, n;
uint32_t f;
static const char names[] = {'G', 'M', 'K'};
unsigned long d = 1e9;
char c = 0;
unsigned int i;
for (i = 0; i < ARRAY_SIZE(names); i++, d /= 10) {
I think this is broken. Should be d /= 1000;
if (freq >= d) {
c = names[i];
break;
}
}
if (!c) {
printf("%" PRIu64 " Hz%s", freq, s);
return;
}
f = do_div(freq, d);
n = freq;
/* If there's a remainder, show the first few digits */
if (f) {
m = f % 1000;
This is broken too. Should be m = f % d;
while (!(m % 10))
And I think you need add a variable to control how many first few digits you want to show in this loop.
m /= 10;
}
printf("%lu", n);
if (m)
printf(".%ld", m);
printf(" %cHz%s", c, s);
+} +#endif
void print_size(uint64_t size, const char *s) { unsigned long m = 0, n; --
Regards, Bin