Page MenuHomeFreeBSD

Fix ips_localout counter for SCTP
ClosedPublic

Authored by tuexen on Oct 4 2018, 1:41 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Jan 21, 10:16 PM
Unknown Object (File)
Mon, Jan 20, 8:38 PM
Unknown Object (File)
Fri, Jan 17, 10:18 PM
Unknown Object (File)
Fri, Jan 17, 12:31 PM
Unknown Object (File)
Tue, Jan 14, 10:02 AM
Unknown Object (File)
Sun, Jan 12, 1:30 PM
Unknown Object (File)
Dec 11 2024, 8:22 PM
Unknown Object (File)
Oct 2 2024, 2:16 PM
Subscribers

Details

Summary

When sending SCTP packets, the SCTP stack provides an IPv4 or IPv6 header when calling ip_output() or ipv6_output(). Currently, the IPv4 stack does not count these packets using the ips_localout counter whereas the IPv6 stack does count them correctly in the ip6s_localout counter.

This patch ensures that packets sent via IPv4 with an IPv4 header provided by the caller of ip_output() are counted in the ips_localout counter.

Test Plan

Run an SCTP capable test program on the loopback interface and watch the counter using systat -ip.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 19958

Event Timeline

Looking at the how IP_FORWARDING flag is used, I think gif/gre/me interfaces should not use this flag. What you think?

This revision is now accepted and ready to land.Oct 4 2018, 2:00 PM
This revision was automatically updated to reflect the committed changes.
In D17406#371337, @ae wrote:

Looking at the how IP_FORWARDING flag is used, I think gif/gre/me interfaces should not use this flag. What you think?

Need to look into this. Will report in the next days.