增加测试代码

oprofile:
内核需要打开
CONFIG_PERF_EVENTS=y
CONFIG_PERF_COUNTERS=y
CONFIG_HW_PERF_EVENTS=y

重新编译内核。
重新编译你的程序。

操作步骤:

  1. 加载内核模块: insmod /lib/modules/3.0.8/oprofile.ko timer=1
    (使用定时中断方式, 因为内核中 mach_hi3520d 未初始化pmu)
  2. opcontrol --init
  3. opcontrol --setup --no-vmlinux
  4. opcontrol --start
  5. 运行测试程序足够长时间
  6. opcontrol --shutdown
  7. 运行opreport,打印出报告

采样的时间精度是怎样的?
oprofile完。

DMALLOC:

+#ifdef DMALLOC

+#define DMALLOC_SETUP       "debug=log-stats,log-non-free,log-bad-space,\

+log-elapsed-time,check-fence,check-heap,check-blank,check-funcs,\

+realloc-copy,free-blank,error-abort,alloc-blank,catch-null,\

+inter=100,log=/tmp/myprog.log"

+

+	dmalloc_debug_setup(DMALLOC_SETUP);

+

+	unsigned long mark;

+	mark = dmalloc_mark();

+	dmalloc_message("%s-%d: dmalloc_mark\n", __FUNCTION__, __LINE__);

+#endif

+

 	SLOG(SLOG_SYSLOG, "My program start up - OK.\n");

 	/* code to test */

 	xxx_func(arg);

 

+#ifdef DMALLOC

+	/*

+	* log unfreed pointers that have been added to 

+	* the heap since mark

+	*/

+	dmalloc_log_changed(mark,

+	1 /* log unfreed pointers */,

+	0 /* do not log freed pointers */,

+	1 /* log each pnt otherwise summary */);

+	dmalloc_message("%s-%d: dmalloc_log_changed\n", __FUNCTION__, __LINE__);

+

+	dmalloc_shutdown();

+#endif 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值