驱动调试中,很多时候是二进制的,这个时候hexdump就是个非常有用的工具了。
不要再自己去实现类似的功能,kernel代码里面就有:
参考: kernel/lib/hexdump.c
// 0Xxx转换成 ASCII ,实现简单巧妙

  1. const char hex_asc[] = "0123456789abcdef";
  2. #define hex_asc_lo(x) hex_asc[((x) & 0x0f)]
  3. #define hex_asc_hi(x) hex_asc[((x) & 0xf0) >> 4]
  1. void hex_dump_to_buffer(const void *buf, size_t len, int rowsize,
  2. int groupsize, char *linebuf, size_t linebuflen,
  3. bool ascii)
  4. {
  5. const u8 *ptr = buf;
  6. u8 ch;
  7. int j, lx = 0;
  8. int ascii_column;
  9. // 每行固定16或者32个字节,符合国际审美观
  10. if (rowsize != 16 && rowsize != 32)
  11. rowsize = 16;
  12.  
  13. if (!len)
  14. goto nil;
  15. if (len > rowsize) /* limit to one line at a time */
  16. len = rowsize;
  17. if ((len % groupsize) != 0) /* no mixed size output */
  18. groupsize = 1;
  19.  
  20. switch (groupsize) {
  21. ......
  22. default:
  23. // 转换成ASCii 形式
  24. for (j = 0; (j < len) && (lx + 3) <= linebuflen; j++) {
  25. ch = ptr[j];
  26. linebuf[lx++] = hex_asc_hi(ch);
  27. linebuf[lx++] = hex_asc_lo(ch);
  28. linebuf[lx++] = ' ';
  29. }
  30. if (j)
  31. lx--;
  32.  
  33. ascii_column = 3 * rowsize + 2;
  34. break;
  35. }
  36. if (!ascii)
  37. goto nil;
  38. // 加上对应的ASCII字符串,区别如下:
  39. // 0009ab42: 40 41 42 43 44 45 46 47 48 49 4a 4b 4c 4d 4e 4f @ABCDEFGHIJKLMNO
  40. // 0009ab42: 40 41 42 43 44 45 46 47 48 49 4a 4b 4c 4d 4e 4f
  41. while (lx < (linebuflen - 1) && lx < (ascii_column - 1))
  42. linebuf[lx++] = ' ';
  43. for (j = 0; (j < len) && (lx + 2) < linebuflen; j++) {
  44. ch = ptr[j];
  45. linebuf[lx++] = (isascii(ch) && isprint(ch)) ? ch : '.';
  46. }
  47. nil:
  48. // 记得加上结束符号,有可能导致printk --> kernel panic
  49. linebuf[lx++] = '\0';
  50. }
  1. void print_hex_dump(const char *level, const char *prefix_str, int prefix_type,
  2. int rowsize, int groupsize,
  3. const void *buf, size_t len, bool ascii)
  4. {
  5. const u8 *ptr = buf;
  6. int i, linelen, remaining = len;
  7. /* 每行数据类似下面
  8. 40 41 42 43 44 45 46 47 48 49 4a 4b 4c 4d 4e 4f @ABCDEFGHIJKLMNO
  9. | | | |
  10. -----------------------------------------------
  11. 16*3 or 32*3 2 32+1
  12. */
  13. unsigned char linebuf[32 * 3 + 2 + 32 + 1];
  14.  
  15. if (rowsize != 16 && rowsize != 32)
  16. rowsize = 16;
  17.  
  18. for (i = 0; i < len; i += rowsize) {
  19. linelen = min(remaining, rowsize);
  20. remaining -= rowsize;
  21. // linebuf 返回需要打印的字符串
  22. hex_dump_to_buffer(ptr + i, linelen, rowsize, groupsize,
  23. linebuf, sizeof(linebuf), ascii);
  24.  
  25. // 是否使用前缀
  26. switch (prefix_type) {
  27. // 加上绝对地址
  28. case DUMP_PREFIX_ADDRESS:
  29. printk("%s%s%p: %s\n",
  30. level, prefix_str, ptr + i, linebuf);
  31. break;
  32. // 只是简单地加上偏移量而已
  33. case DUMP_PREFIX_OFFSET:
  34. printk("%s%s%.8x: %s\n", level, prefix_str, i, linebuf);
  35. break;
  36. default:
  37. printk("%s%s%s\n", level, prefix_str, linebuf);
  38. break;
  39. }
  40. }
  41. }
  1. // 一般在kernel代码中,调用此接口,许多参数用默认的,不需要了解太多细节
  2. void print_hex_dump_bytes(const char *prefix_str, int prefix_type,
  3. const void *buf, size_t len)
  4. {
  5. print_hex_dump(KERN_DEBUG, prefix_str, prefix_type, 16, 1,
  6. buf, len, true);
  7. }

kernel hexdump分析的更多相关文章

  1. kernel hexdump分析 (2.0)

    有的时候print_hex_dump_bytes循环打印很多信息的时候(大于1K) 用UART串口打印的信息总是会有丢失,估计是printk缓冲区的问题把,具体原因不是太清楚 于是自己写了个比较笨的d ...

  2. u-boot bootz 加载kernel 流程分析

    u-boot 加载 kernel 的流程分析. image重要结构体头文件 // include/image.h * * Legacy and FIT format headers used by d ...

  3. Minix2.0操作系统kernel文件分析

    详细分析  MINIX消息机制的核心: mpx386.s start.c proc.c 保护模式分析: src/kernel/exception.c src/kernel/protect.c src/ ...

  4. Linux kernel kfifo分析【转】

    转自:https://zohead.com/archives/linux-kernel-kfifo/ 本文同步自(如浏览不正常请点击跳转):https://zohead.com/archives/li ...

  5. Linux Kernel PANIC(三)--Soft Panic/Oops调试及实例分析【转】

    转自:https://blog.csdn.net/gatieme/article/details/73715860 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原 ...

  6. linux 代码分析工具 gprof - 以wpa_supplicant为例

        当我们遇到一个新的程序的时候,经常会无从下手,需要debug一个功能的时候,我们不知道函数的运行流程是怎么样的,这就需要借助工具来帮助我们加快流程了.这里以分析wpa_supplicant为例 ...

  7. MIT JOS学习笔记03:kernel 02(2016.11.08)

    未经许可谢绝以任何形式对本文内容进行转载! 本篇接着上一篇对kernel的分析. (5)pte_t * pgdir_walk(pde_t *pgdir, const void *va, int cre ...

  8. MIT JOS学习笔记02:kernel 01(2016.10.28)

    未经许可谢绝以任何形式对本文内容进行转载! 在文章开头不得不说的是,因为这部分的代码需要仔细理清的东西太多,所以导致这篇分析显得很啰嗦,还请谅解. 我们在上一篇文章已经分析了Boot Loader的功 ...

  9. 【UVALive 7334】Kernel Knights

    题 题意 有两个队的骑士1到n和n+1到2n,每个骑士只能互相攻击对手队的一个骑士.kernel的意思是在这个kernel里的骑士不会互相攻击,在kernel外的骑士被kernel里的骑士攻击. 现在 ...

随机推荐

  1. [HDU 2553]--N皇后问题(回溯)/N皇后问题的分析

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2553 N皇后问题 Time Limit: 2000/1000 MS (Java/Others)     ...

  2. 基于visual Studio2013解决算法导论之028散列表开放寻址

     题目 散列表 解决代码及点评 #include <iostream> #include <time.h> using namespace std; template & ...

  3. [置顶] Android开发之XML文件的解析

    Android系统开发之XML文件的解析 我们知道Http在网络传输中的数据组织方式有三种分别为:XML方式.HTML方式.JSON方式.其中XML为可扩展标记语言,如下: <?xml vers ...

  4. Actor::updateMassFromShapes

    unity报错Actor::updateMassFromShapes: Compute mesh inertia tensor failed for one of the actor's mesh s ...

  5. 另外一种方式装win2008r2

    装系统有很多方法,但是这种,我很少用. 注意第二个红圈处,是要启动的电话引导盘符.容易选择你的启动U盘,如果是后者,表现出的结果就是引导U盘不能引导,且安装的电脑也会显示ntdl丢失.当然,也可以解决 ...

  6. eclipse如何设置成保护眼的背景色

    链接地址:http://jingyan.baidu.com/article/2a138328b5d9ea074a134fc7.html 长时间的使用eclipse开发会很累吧  设置一个保护眼睛的豆沙 ...

  7. 为学Linux,我看了这些书

    为学Linux,我看了这些书   去年开始,抱着学习的态度开始了我的Linux学习,到现在,差不多一年了,收获很多,不敢说精通Linux,但是,还是对得起"略懂"这两个字的.这一年 ...

  8. AOP编程

    <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...

  9. 我的Python成长之路---第一天---Python基础(1)---2015年12月26日(雾霾)

    2015年12月26日是个特别的日子,我的Python成之路迈出第一步.见到了心目中的Python大神(Alex),也认识到了新的志向相投的伙伴,非常开心. 尽管之前看过一些Python的视频.书,算 ...

  10. HDOJ 1598 Kruscal

    贪心思想的Kruscal:先对边排序,再从第一条边开始,一旦start point 和 end poiont 连上,就break #include <stdio.h> #include & ...