Re: Linux Kernel GDB tracepoint module 2010-8-30 release

From: Steven
Date: Fri Sep 03 2010 - 05:06:20 EST


Dear Hui,

I encountered two issue when I use your GTP.

1) Following your HOWTO, I collect the two variables jiffies_64(global),
*file(argument), the result are as following, where you may see
jiffies_64 = 4298520928, that's OK, but the members of *file are all 0.
What's the problem? Thank you very much!
-------------------------------------------------------------------
(gdb) trace vfs_readdir
Tracepoint 3 at 0xc1175690: file fs/readdir.c, line 23.
(gdb) actions
Enter actions for tracepoint 3, one per line.
End with a line saying just "end".
> collect jiffies_64
> collect *file
> end
(gdb) tstart
(gdb) tstop
(gdb) tfind
#0 0xc1175691 i (file=0x0, filler=0, buf=0x0) at
fs/readdir.c:23
23 {
(gdb) p jiffies_64
$7 = 4298520928
(gdb) p *file
$8 = {f_u = {fu_list = {next = 0x0, prev = 0x0}, fu_rcuhead =
{next = 0x0, func = 0}}, f_path = {mnt = 0x0, dentry = 0x0},
f_op = 0x0, f_lock = {{ rlock = {raw_lock = {slock = 0}}}},
f_count = {counter = 0}, f_flags = 0, f_mode = 0, f_pos = 0,
f_owner = {lock = {raw_lock = { lock = 0}}, pid = 0x0, pid_type
= PIDTYPE_PID, uid = 0, euid = 0, signum = 0}, f_cred = 0x0,
f_ra = {stra_pages = 00, f_security = 0x0, private_data = 0x0,
f_ep_links = {next = 0x0, prev = 0x0}, f_mapping = 0x0}
-------------------------------------------------------------------


2) I can not collect local variable, despite I rebuild the kernel with
-O0 optimization option. what is the problem? Many thanks
-------------------------------------------------------------------
(gdb) trace fs/readdir.c:29
Tracepoint 2 at 0xc11756ca: file fs/readdir.c, line 29.
(gdb) actions
Enter actions for tracepoint 2, one per line.
End with a line saying just "end".
> collect res
> end
(gdb) tstart
res: don't know symbol class 20
-------------------------------------------------------------------

Code fragment of readdir.c
-------------------------------------------------------------------
22 int vfs_readdir(struct file *file, filldir_t filler, void
*buf)
23 {
24 struct inode *inode = file->f_path.dentry->d_inode;
25 int res = -ENOTDIR;
26 if (!file->f_op || !file->f_op->readdir)
27 goto out;
28
29 res = security_file_permission(file, MAY_READ);
30 if (res)
31 goto out;
-------------------------------------------------------------------

Best Regards,
Steven


On Mon, 2010-08-30 at 15:00 +0800, Hui Zhu wrote:
> http://kgtp.googlecode.com/files/kgtp_20100830.tar.bz2
> or
> svn co https://kgtp.googlecode.com/svn/tags/20100830
> to get it.
>
> Fix bug in ref16, ref32, ref64 in issue
> https://code.google.com/p/kgtp/issues/detail?id=2
> Fix bug that disable some tracepoint will make "tstart" get error.
>
> Support qtstatus. Then KGTP support GDB command "tstatus".
> Add support for "make install" and "make uninstall".
> Add support for qtro. Fix a bug about GTP_GDBRSP_REG_SIZE.
>
> Change gtp_list make it more efficient.
>
> Please goto http://code.google.com/p/kgtp/wiki/HOWTO to get more info
> about how to use KGTP.


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/