X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fvmm_util.c;h=5d51666f28976dd43bc190717aa5c14be2136b36;hb=0ab69a6bdddef0ae09d8beb82b9c6c051e1a564d;hp=79933e4d9cc51e769321f2459336b934eea4f356;hpb=3a5aea3d9ef41bf3e7b8df4d29f309e2f4304d9d;p=palacios.git diff --git a/palacios/src/palacios/vmm_util.c b/palacios/src/palacios/vmm_util.c index 79933e4..5d51666 100644 --- a/palacios/src/palacios/vmm_util.c +++ b/palacios/src/palacios/vmm_util.c @@ -1,48 +1,67 @@ +/* + * This file is part of the Palacios Virtual Machine Monitor developed + * by the V3VEE Project with funding from the United States National + * Science Foundation and the Department of Energy. + * + * The V3VEE Project is a joint project between Northwestern University + * and the University of New Mexico. You can find out more at + * http://www.v3vee.org + * + * Copyright (c) 2008, Jack Lange + * Copyright (c) 2008, The V3VEE Project + * All rights reserved. + * + * Author: Jack Lange + * + * This is free software. You are permitted to use, + * redistribute, and modify it as specified in the file "V3VEE_LICENSE". + */ + + #include #include -extern struct vmm_os_hooks * os_hooks; +extern struct v3_os_hooks * os_hooks; void PrintTraceHex(unsigned char x) { - unsigned char z; + unsigned char z; - z = (x >> 4) & 0xf; - PrintTrace("%x", z); - z = x & 0xf; - PrintTrace("%x", z); + z = (x >> 4) & 0xf; + PrintTrace("%x", z); + z = x & 0xf; + PrintTrace("%x", z); } void PrintTraceLL(ullong_t num) { - unsigned char * z = (unsigned char *)# - int i; + unsigned char * z = (unsigned char *)# + int i; - for (i = 7; i >= 0; i--) { - PrintTraceHex(*(z + i)); - } + for (i = 7; i >= 0; i--) { + PrintTraceHex(*(z + i)); + } } -void PrintTraceMemDump(unsigned char *start, int n) -{ - int i, j; +void PrintTraceMemDump(uchar_t * start, int n) { + int i, j; - for (i = 0; i < n; i += 16) { - PrintTrace("%8x", (unsigned)(start + i)); - for (j = i; (j < (i + 16)) && (j < n); j += 2) { - PrintTrace(" "); - PrintTraceHex(*((unsigned char *)(start + j))); - if ((j + 1) < n) { - PrintTraceHex(*((unsigned char *)(start + j + 1))); - } - } - PrintTrace(" "); - for (j = i; (j < (i + 16)) && (j < n); j++) { - PrintTrace("%c", ((start[j] >= 32) && (start[j] <= 126)) ? start[j] : '.'); + for (i = 0; i < n; i += 16) { + PrintTrace("%p", (void *)(start + i)); + for (j = i; (j < (i + 16)) && (j < n); j += 2) { + PrintTrace(" "); + PrintTraceHex(*(uchar_t *)(start + j)); + if ((j + 1) < n) { + PrintTraceHex(*((uchar_t *)(start + j + 1))); + } + } + PrintTrace(" "); + for (j = i; (j < (i + 16)) && (j < n); j++) { + PrintTrace("%c", ((start[j] >= 32) && (start[j] <= 126)) ? start[j] : '.'); + } + PrintTrace("\n"); } - PrintTrace("\n"); - } }