Alias "e" to monitor's "exit"
[akaros.git] / kern / src / hexdump.c
1 /*
2  * Copyright 2013 Google Inc.
3  *
4  * See file CREDITS for list of people who contributed to this
5  * project.
6  *
7  * This program is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU General Public License as
9  * published by the Free Software Foundation; either version 2 of
10  * the License, or (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but without any warranty; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software
19  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
20  * MA 02111-1307 USA
21  */
22
23 #include <kdebug.h>
24 #include <kmalloc.h>
25 #include <string.h>
26 #include <assert.h>
27 #include <smp.h>
28 #include <pmap.h>
29
30 static int isprint(int c)
31 {
32         return (c >= 32 && c <= 126);
33 }
34
35 void hexdump(void *v, int length)
36 {
37         int i;
38         uint8_t *m = v;
39         uintptr_t memory = (uintptr_t) v;
40         int all_zero = 0;
41
42         for (i = 0; i < length; i += 16) {
43                 int j;
44
45                 all_zero++;
46                 for (j = 0; (j < 16) && (i + j < length); j++) {
47                         if (m[i + j] != 0) {
48                                 all_zero = 0;
49                                 break;
50                         }
51                 }
52
53                 if (all_zero < 2) {
54                         printk("%08lx:", memory + i);
55                         for (j = 0; j < 16; j++)
56                                 printk(" %02x", m[i + j]);
57                         printk("  ");
58                         for (j = 0; j < 16; j++)
59                                 printk("%c", isprint(m[i + j]) ? m[i + j] : '.');
60                         printk("\n");
61                 } else if (all_zero == 2) {
62                         printk("...\n");
63                 }
64         }
65 }
66
67 /* easier in monitor */
68 void pahexdump(uintptr_t pa, int len)
69 {
70         void *v = KADDR(pa);
71         hexdump(v, len);
72 }
73
74 /* Print a string, with printables preserved, and \xxx where not possible. */
75 int printdump(char *buf, int buflen, uint8_t *data)
76 {
77         int ret = 0;
78         int ix = 0;
79         while (ret < buflen) {
80                 if (isprint(data[ix])) {
81                         buf[ret++] = data[ix];
82                 } else if (ret < buflen - 4) {
83                         /* guarantee there is room for a \xxx sequence */
84                         ret += snprintf(&buf[ret], buflen-ret, "\\%03o", data[ix]);
85                 } else {
86                         break;
87                 }
88                 ix++;
89         }
90         return ret;
91 }