用strace工具跟踪系统调用
2016-08-17 11:10
603 查看
1、先解压:
strace-4.8.tar.xz 由于在ubuntu上没有装xz后缀的压缩文件的解压工具,可先直接在windows下解压
2、拷贝到服务器上去
3、修改strace-4.8目录下的configure的执行权限(在windows上复制过来是没有执行权限的)
chmod +x configure
4、配置:
--build=BUILD configure for building on BUILD [guessed] /* 在哪个平台上进行编译,默认pc机,这里不用修改 */
--host=HOST cross-compile to build programs to run on HOST [BUILD] /* 编译出的文件运行在哪里,默认pc机 */
--prefix=PREFIX install architecture-independent files in PREFIX /* 安装的文件路径,自己指定 */
/*
--prefix=$PWD/tmp是在当前路径下面创建了一个tmp文件目录,安装在tmp目录*/
/* --host=arm-linux 运行环境 (交叉编译成arm)
./configure --host=arm-linux --prefix=$PWD/tmp
4、编译:
make
5、安装(安装在tmp目录)
make install
6、把 tmp/bin目录(有一大堆工具)下的文件拷贝到网络文件系统的bin目录下
tmp$ sudo cp bin/* /work/nfs_root/fs_mini_mdev_new/bin/
7、在开发板环境下使用strace工具
strace -h 查看能调用的参数
//-o aplay.log 是指定跟踪信息存放在aplay.log中,aplay windows.wav是指要跟踪的命令
strace -o aplay.log aplay windows.wav
8、把生成的log文件拷贝回windows下进行分析
主要分析open函数和ioctl函数、close函数
9、举例:用UltraEdit打开log文件进行分析
(1)这里蓝色部分的内容可以在内核文件中找到并有相应的实现形式
(2)这里的3是文件描述符,用于对同一文件的操作
open("/dev/snd/controlC0", O_RDONLY|O_CLOEXEC) =3
fcntl64(3, F_SETFD, FD_CLOEXEC) = 0
ioctl(3, SNDRV_CTL_IOCTL_CARD_INFO orUI_DEV_CREATE, 0xbef922f8) = 0
close(3)
open("/dev/snd/controlC0", O_RDONLY|O_CLOEXEC) = 3
fcntl64(3, F_SETFD, FD_CLOEXEC) = 0
ioctl(3, SNDRV_CTL_IOCTL_CARD_INFO orUI_DEV_CREATE, 0xbef921a0) = 0
close(3) = 0
strace-4.8.tar.xz 由于在ubuntu上没有装xz后缀的压缩文件的解压工具,可先直接在windows下解压
2、拷贝到服务器上去
3、修改strace-4.8目录下的configure的执行权限(在windows上复制过来是没有执行权限的)
chmod +x configure
4、配置:
--build=BUILD configure for building on BUILD [guessed] /* 在哪个平台上进行编译,默认pc机,这里不用修改 */
--host=HOST cross-compile to build programs to run on HOST [BUILD] /* 编译出的文件运行在哪里,默认pc机 */
--prefix=PREFIX install architecture-independent files in PREFIX /* 安装的文件路径,自己指定 */
/*
--prefix=$PWD/tmp是在当前路径下面创建了一个tmp文件目录,安装在tmp目录*/
/* --host=arm-linux 运行环境 (交叉编译成arm)
./configure --host=arm-linux --prefix=$PWD/tmp
4、编译:
make
5、安装(安装在tmp目录)
make install
6、把 tmp/bin目录(有一大堆工具)下的文件拷贝到网络文件系统的bin目录下
tmp$ sudo cp bin/* /work/nfs_root/fs_mini_mdev_new/bin/
7、在开发板环境下使用strace工具
strace -h 查看能调用的参数
//-o aplay.log 是指定跟踪信息存放在aplay.log中,aplay windows.wav是指要跟踪的命令
strace -o aplay.log aplay windows.wav
8、把生成的log文件拷贝回windows下进行分析
主要分析open函数和ioctl函数、close函数
9、举例:用UltraEdit打开log文件进行分析
(1)这里蓝色部分的内容可以在内核文件中找到并有相应的实现形式
(2)这里的3是文件描述符,用于对同一文件的操作
open("/dev/snd/controlC0", O_RDONLY|O_CLOEXEC) =3
fcntl64(3, F_SETFD, FD_CLOEXEC) = 0
ioctl(3, SNDRV_CTL_IOCTL_CARD_INFO orUI_DEV_CREATE, 0xbef922f8) = 0
close(3)
open("/dev/snd/controlC0", O_RDONLY|O_CLOEXEC) = 3
fcntl64(3, F_SETFD, FD_CLOEXEC) = 0
ioctl(3, SNDRV_CTL_IOCTL_CARD_INFO orUI_DEV_CREATE, 0xbef921a0) = 0
close(3) = 0
相关文章推荐
- 在Xamarin开发,使用MessageCenter在ViewModel和View之间传递值
- SuperMap iObject常见问题解答集锦 (一)
- 站在数学之巅沐浴计算机的阳光
- Openwrt的在pppd上遇到的resolv.conf.auto问题
- java 通过流的方式读取远程图片并显示在jsp页面(类型以jpg、png等结尾的图片)
- 站在数学之巅沐浴计算机的阳光
- 高效程序员的45个习惯 敏捷开发修炼之道 读书笔记 第六章 敏捷编码
- Missing Ranges -- LeetCode
- 苹果手机屏幕一览
- C# Enum,Int,String的互相转换 枚举转换
- poj 1141 区间dp+递归打印路径
- activity进入动画
- Expedition
- ActionContext与ServletActionContext
- .Net语言 APP开发平台——Smobiler学习日志:用Gridview控件设计较复杂的表单
- 自定义buttonView的酷炫效果
- java线程——ThreadPoolExecutor详解
- 记一次Marathon被黑过程
- 平台免费接口,非常实用
- 微信分享的两个问题