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