question about sockfd_lookup( )

From: MingJie Chang
Date: Tue Mar 01 2005 - 01:04:15 EST


Dear all,

I want to get socket information by the sockfd while accetping,

so I write a module to test sockfd_lookup(),

but I got some problems when I test it.

I hope someone can help me...

Thank you

following text is my code and error message
===========================================
=== code ===

int my_socketcall(int call,unsigned long *args)
{
int ret,err;
struct socket * sock;

ret = run_org_socket_call(call,args); //orignal sys_sockcall()

if(call==SYS_ACCEPT&&ret>=0)
{
sock=sockfd_lookup(ret,&err);
printk("lookup done\n");
}
return ret;
}


======================================
=== test and state ===

after inserting module, I use "ftp localhost" to test it.

And it has some error when I use "ls" or "mget"(I just try the 2 commands)

EX1: ls :file list is printed, but it will block until ctrl + c

ftp> ls
227 Entering Passive Mode (127,0,0,1,68,186)
150 Here comes the directory listing.
-rwxr-xr-x 1 0 0 13744 Feb 28 05:22 socktest
-rw-r--r-- 1 501 0 76288 Feb 27 19:05 vsftpd-1.1.0-1.i386.rpm
-rw------- 1 501 0 3778 Feb 27 19:29 vsftpd.conf
(blocking until ctrl+c)

after ctrl+c
receive aborted
waiting for remote to finish abort
226 Directory send OK.
500 Unknown command.
663 bytes received in 51 secs (0.013 Kbytes/sec)

ftp>
------------------------------------------------------------
EX2:mget: block until ctrl + c ,and file is not got

ftp> mget *
(blocking until ctrl+c)
receive aborted
waiting for remote to finish abort
Unknown command.

ftp>
(file is not got)

==================================================
== kernel message ==
and than I remove the module, try to ftp localhost again,
and kernel will print some messages

Unable to handle kernel paging request at virtual address c845a089
printing eip:
c845a089
*pde=02ab4067(01194067)
*pte=00000000(00000000)
Oops: 0000
CPU: 0
EIP: 0819:[<c845a089>] Not tainted
EFLAGS: 00213296
eax: 00000004 ebx: c6f18000 ecx: 00000004 edx: 00000004
esi: 00000005 edi: ffffffff ebp: c6f19fbc esp: c6f19f94
ds: 0821 es: 0821 ss: 0821
Process vsftpd (pid: 606, stackpage=c6f19000)<1>
Stack: 00000005 bffffb80 00000000 00000000 c6f18000 00000000 00000000 c6f18000
c6f18000 00000004 bffffc58 c00ae4eb 00000005 bffffb80 bffffc30 00000004
ffffffff bffffc58 00000066 00000833 00000833 00000066 420daa02 0000082b
Call Trace: [<c00ae4eb>]

==================
End of mail
-
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/