Skip to content
Snippets Groups Projects
Commit efd7c114 authored by Andreas Bießmann's avatar Andreas Bießmann Committed by Tom Rini
Browse files

display_options:print_buffer: align ASCII print


This patch adds whitespace to the printed hex numbers to have an aligned ASCII
printout at the end of the line.

This changes for example the md output from:

---8<---
OMAP3 Tricorder # md.l $loadaddr 5
82000000: 30200109 20a4028c 90010000 08a00000    .. 0... ........
82000010: 01010000    ....
--->8---

to

---8<---
OMAP3 Tricorder # md.l $loadaddr 5
82000000: 30200109 20a4028c 90010000 08a00000    .. 0... ........
82000010: 01010000                               ....
--->8---

The cost of this is about 72 byte .text increase (tested with at91 build).

Signed-off-by: default avatarAndreas Bießmann <andreas.devel@googlemail.com>
parent a2681707
No related branches found
No related tags found
No related merge requests found
...@@ -115,14 +115,15 @@ int print_buffer(ulong addr, const void *data, uint width, uint count, ...@@ -115,14 +115,15 @@ int print_buffer(ulong addr, const void *data, uint width, uint count,
linelen = DEFAULT_LINE_LENGTH_BYTES / width; linelen = DEFAULT_LINE_LENGTH_BYTES / width;
while (count) { while (count) {
uint thislinelen = linelen;
printf("%08lx:", addr); printf("%08lx:", addr);
/* check for overflow condition */ /* check for overflow condition */
if (count < linelen) if (count < thislinelen)
linelen = count; thislinelen = count;
/* Copy from memory into linebuf and print hex values */ /* Copy from memory into linebuf and print hex values */
for (i = 0; i < linelen; i++) { for (i = 0; i < thislinelen; i++) {
uint32_t x; uint32_t x;
if (width == 4) if (width == 4)
x = lb.ui[i] = *(volatile uint32_t *)data; x = lb.ui[i] = *(volatile uint32_t *)data;
...@@ -134,8 +135,15 @@ int print_buffer(ulong addr, const void *data, uint width, uint count, ...@@ -134,8 +135,15 @@ int print_buffer(ulong addr, const void *data, uint width, uint count,
data += width; data += width;
} }
while (thislinelen < linelen) {
/* fill line with whitespace for nice ASCII print */
for (i=0; i<width*2+1; i++)
puts(" ");
linelen--;
}
/* Print data in ASCII characters */ /* Print data in ASCII characters */
for (i = 0; i < linelen * width; i++) { for (i = 0; i < thislinelen * width; i++) {
if (!isprint(lb.uc[i]) || lb.uc[i] >= 0x80) if (!isprint(lb.uc[i]) || lb.uc[i] >= 0x80)
lb.uc[i] = '.'; lb.uc[i] = '.';
} }
...@@ -143,8 +151,8 @@ int print_buffer(ulong addr, const void *data, uint width, uint count, ...@@ -143,8 +151,8 @@ int print_buffer(ulong addr, const void *data, uint width, uint count,
printf(" %s\n", lb.uc); printf(" %s\n", lb.uc);
/* update references */ /* update references */
addr += linelen * width; addr += thislinelen * width;
count -= linelen; count -= thislinelen;
if (ctrlc()) if (ctrlc())
return -1; return -1;
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment