Re: truncated lines in /proc/net/tcp

From: Randy.Dunlap
Date: Tue Sep 14 2004 - 23:39:56 EST


On Fri, 10 Sep 2004 18:30:03 +0200 Arnout Engelen wrote:

Note: netdev@xxxxxxxxxxx would be more appropriate for this.


| Hi,
|
| I noticed lines in the output of /proc/net/tcp sometimes appear 'truncated', like
| this:
|
| 52: 010310AC:9D95 030310AC:1770 06 00000000:00000000 03:0000146C
| 00000000 0 0 0 2 c4e3f0c0
|
| (also notice that the inode is '0' instead of some large integer)
|
| This is print by the code at:
|
| http://lxr.linux.no/source/net/ipv4/tcp_ipv4.c?v=2.6.8.1#L2504

That line is used/printed if socket state is case TCP_SEQ_STATE_ESTABLISHED:
or case TCP_SEQ_STATE_LISTENING:
(line 2559). However, if socket state is case TCP_SEQ_STATE_OPENREQ:,
get_openreq4() is called to print the info, and if socket state is
case TCP_SEQ_STATE_TIME_WAIT:, get_timewait4_sock() is called to
print the info. The first case includes 5 fields after the %p (pointer),
while the 2nd and 3rd cases do not. Is that the truncation that you
are referring to?

| Maybe the value of 'tp' gets invalidated at some point during the
| gathering of the data to be printed there?

That doesn't quite explain it.

| (note that I'm not myself a kernel developer. I ran into this when
| writing a userspace application and decided I wanted to know why this
| happened. I saw this behaviour on a 2.4.26 kernel, but the code
| doesn't appear to be significantly different in 2.6. I'm not subscribed
| to the LKML, so if you want to ask me something please CC me personally).

Expect different output formats depending on socket state.

--
~Randy
-
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/