debug.c revision 1.3 1 /* $NetBSD: debug.c,v 1.3 2010/09/15 01:51:44 manu Exp $ */
2
3 /*-
4 * Copyright (c) 2010 Emmanuel Dreyfus. All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
16 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
17 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
18 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
19 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25 * POSSIBILITY OF SUCH DAMAGE.
26 */
27 #include <stdio.h>
28 #include <errno.h>
29 #include <string.h>
30 #include <syslog.h>
31 #include <ctype.h>
32 #include <sys/socket.h>
33
34 #include "perfused.h"
35
36 #ifdef PERFUSE_DEBUG
37 void
38 perfuse_hexdump(addr, len)
39 char *addr;
40 size_t len;
41 {
42 unsigned int i, j, k;
43
44 for (i = 0; i < len; i += 16) {
45 DPRINTF("%p ", &addr[i]);
46 for (j = 0; j < 16; j += 4) {
47 for (k = 0; k < 4; k++) {
48 if (i + j + k < len) {
49 DPRINTF("%02x ",
50 *(addr + i + j + k) & 0xff);
51 } else {
52 DPRINTF(" ");
53 }
54 }
55 }
56
57 DPRINTF(" ");
58 for (j = 0; j < 16; j++) {
59 char c;
60
61 if (i + j < len) {
62 c = *(addr + i + j);
63 DPRINTF("%c", isprint((int)c) ? c : '.');
64 } else {
65 DPRINTF(" ");
66 }
67 }
68 DPRINTF("\n");
69 }
70
71 return;
72 }
73
74
75
76 #endif /* PERFUSE_DEBUG */
77