Re: How to find a certain socket?
- From: Robert Watson <rwatson@xxxxxxxxxxx>
- Date: Thu, 21 Sep 2006 18:06:13 +0100 (BST)
On Wed, 20 Sep 2006, Taras Danko wrote:
I need to find and close a certain socket from kernel module. My current implementation iterates over the "allproc" list and checks every process' file descriptors list to find needed socket. But maybe there is an easier way to do this? Some nixes have "inpcbtable" which holds all the open sockets on the system. Is there anything similar in FreeBSD?
What are you trying to do, exactly?
The semantics of closing sockets open in processes are a bit tricky -- first off, you really don't want to actually close the file descriptor, as the application may misbehave in rather unfortunate ways, such as writing data to the wrong files, etc. So in that sense, what you're doing is better than actually closing the file descriptor, which would cause that to happen. If you're interested only in closing TCP sockets, then the existing tcpkill command may well do what you want.
And the second question: whats the correct way to close the socket which was found?
I'm not sure there's really a "correct" way to go about ripping a socket out from under an application. tcpkill does the next closest thing, which is to simulate a RST on the TCP connection and force it to close, which is propagated up the stack in a way the application will understand.
Robert N M Watson
Computer Laboratory
University of Cambridge
_______________________________________________
My implementation:
.....
mysocket = myproc->p_fd->fd_ofiles[i]->f_data;
myproc->p_fd->fd_ofiles[i]->f_data = NULL;
myproc->p_fd->fd_ofiles[i]->f_ops = &badfileops;
soclose(mysocket);
.....
The socket closes but it causes a kernel panic in 90% of cases and
file descriptor doesnt actualy released (as fstat shows), but is
marked as "error" (because of "badfileops" I suppose). Maybe I should
acqure some mutex lock or something before starting manipulations with
socket? Any exampe code will be very much appreciated.
Its my first steps in fbsd kernel programming so please xcuse me for
newbie questions.
Taras Danko.
- - - - - - - - - - - - - - - - - - - - - -
contact me:
email: gortaur@xxxxxxxxx
icq: 166956956
_______________________________________________
freebsd-hackers@xxxxxxxxxxx mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-hackers
To unsubscribe, send any mail to "freebsd-hackers-unsubscribe@xxxxxxxxxxx"
freebsd-hackers@xxxxxxxxxxx mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-hackers
To unsubscribe, send any mail to "freebsd-hackers-unsubscribe@xxxxxxxxxxx"
- Follow-Ups:
- Re: How to find a certain socket?
- From: Taras Danko
- Re: How to find a certain socket?
- From: Maxim Konovalov
- Re: How to find a certain socket?
- References:
- How to find a certain socket?
- From: Taras Danko
- How to find a certain socket?
- Prev by Date: Re: numbers don't lie ...
- Next by Date: Re: How to find a certain socket?
- Previous by thread: How to find a certain socket?
- Next by thread: Re: How to find a certain socket?
- Index(es):
Relevant Pages
|