cvs commit: src/sys/netinet tcp.h tcp_input.c tcp_subr.c tcp_var.h
Andre Oppermann
andre at FreeBSD.org
Fri May 18 19:58:38 UTC 2007
andre 2007-05-18 19:58:37 UTC
FreeBSD src repository
Modified files:
sys/netinet tcp.h tcp_input.c tcp_subr.c tcp_var.h
Log:
Add tcp_log_addrs() function to generate and standardized TCP log line
for use thoughout the tcp subsystem.
It is IPv4 and IPv6 aware creates a line in the following format:
"TCP: [1.2.3.4]:50332 to [1.2.3.4]:80 tcpflags <RST>"
A "\n" is not included at the end. The caller is supposed to add
further information after the standard tcp log header.
The function returns a NUL terminated string which the caller has
to free(s, M_TCPLOG) after use. All memory allocation is done
with M_NOWAIT and the return value may be NULL in memory shortage
situations.
Either struct in_conninfo || (struct tcphdr && (struct ip || struct
ip6_hdr) have to be supplied.
Due to ip[6].h header inclusion limitations and ordering issues the
struct ip and struct ip6_hdr parameters have to be casted and passed
as void * pointers.
tcp_log_addrs(struct in_conninfo *inc, struct tcphdr *th, void *ip4hdr,
void *ip6hdr)
Usage example:
struct ip *ip;
char *tcplog;
if (tcplog = tcp_log_addrs(NULL, th, (void *)ip, NULL)) {
log(LOG_DEBUG, "%s; %s: Connection attempt to closed port\n",
tcplog, __func__);
free(s, M_TCPLOG);
}
Revision Changes Path
1.38 +1 -0 src/sys/netinet/tcp.h
1.352 +8 -22 src/sys/netinet/tcp_input.c
1.284 +89 -0 src/sys/netinet/tcp_subr.c
1.151 +3 -0 src/sys/netinet/tcp_var.h
More information about the cvs-src
mailing list