summaryrefslogtreecommitdiffstats
path: root/lib/libc/string/memccpy.c
diff options
context:
space:
mode:
authorluigi <luigi@FreeBSD.org>2006-12-08 10:36:45 +0000
committerluigi <luigi@FreeBSD.org>2006-12-08 10:36:45 +0000
commitc238e1bacef3e58cfbd59aa04b9bd15ab038c867 (patch)
treec023500c0339b43644074e72f434ee8d4b3f8819 /lib/libc/string/memccpy.c
parentd0a44b7b7c631f9cc61cbe41be7ade0ec80293d7 (diff)
downloadFreeBSD-src-c238e1bacef3e58cfbd59aa04b9bd15ab038c867.zip
FreeBSD-src-c238e1bacef3e58cfbd59aa04b9bd15ab038c867.tar.gz
Fix an oscure bug triggered by a recent change in kern_socket.c.
The symptoms were that outgoing DHCP requests for diskless kernels had the IP header corrupt. After long investigations, the source of the problem was found in ether_output() - for SIMPLEX interfaces and broadcast traffic, a copy of the packet is passed back to the kernel through if_simloop(). However if_simloop() modifies the mbuf, while the copy obtained through m_copym() is a readonly one. The bug has been there forever, but it has been triggered only recently by a change in sosend_dgram() which passed down mbufs with sufficient space to prepend the header. This fix is trivial - use m_dup() instead of m_copy() to create the copy. As an alternative, we could try and modify if_simloop() to play safely with readonly mbufs, but i don't think it is worthwhile because 1) this is a relatively infrequent code path so we do not need to worry too much about performance, and 2) the cost of doing an extra m_pullup in if_simloop() is probably the same as doing the copy of the cluster, anyways. MFC after: 1 week
Diffstat (limited to 'lib/libc/string/memccpy.c')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud