Remove historical file.
[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
29 static int isprint(int c)
30 {
31         return (c >= 32 && c <= 126);
32 }
33
34 void hexdump(void *v, int length)
35 {
36         int i;
37         uint8_t *m = v;
38         uintptr_t memory = (uintptr_t) v;
39         int all_zero = 0;
40
41         for (i = 0; i < length; i += 16) {
42                 int j;
43
44                 all_zero++;
45                 for (j = 0; (j < 16) && (i + j < length); j++) {
46                         if (m[i + j] != 0) {
47                                 all_zero = 0;
48                                 break;
49                         }
50                 }
51
52                 if (all_zero < 2) {
53                         printk("%08lx:", memory + i);
54                         for (j = 0; j < 16; j++)
55                                 printk(" %02x", m[i + j]);
56                         printk("  ");
57                         for (j = 0; j < 16; j++)
58                                 printk("%c", isprint(m[i + j]) ? m[i + j] : '.');
59                         printk("\n");
60                 } else if (all_zero == 2) {
61                         printk("...\n");
62                 }
63         }
64 }
65
66 /* easier in monitor */
67 void pahexdump(uintptr_t pa, int len)
68 {
69         void *v = KADDR(pa);
70         hexdump(v, len);
71 }
72
73 /* Print a string, with printables preserved, and \xxx where not possible. */
74 int printdump(char *buf, int buflen, uint8_t *data)
75 {
76         int ret = 0;
77         int ix = 0;
78         while (ret < buflen) {
79                 if (isprint(data[ix])) {
80                         buf[ret++] = data[ix];
81                 } else if (ret < buflen - 4) {
82                         /* guarantee there is room for a \xxx sequence */
83                         ret += snprintf(&buf[ret], buflen-ret, "\\%03o", data[ix]);
84                 } else {
85                         break;
86                 }
87                 ix++;
88         }
89         return ret;
90 }