/[base]
ViewVC logotype

Revision 275326


Jump to revision: Previous Next
Author: glebius
Date: Sun Nov 30 12:52:33 2014 UTC (9 years, 7 months ago)
Changed paths: 21
Log Message:
Merge from projects/sendfile:

o Introduce a notion of "not ready" mbufs in socket buffers.  These
mbufs are now being populated by some I/O in background and are
referenced outside.  This forces following implications:
- An mbuf which is "not ready" can't be taken out of the buffer.
- An mbuf that is behind a "not ready" in the queue neither.
- If sockbet buffer is flushed, then "not ready" mbufs shouln't be
  freed.

o In struct sockbuf the sb_cc field is split into sb_ccc and sb_acc.
  The sb_ccc stands for ""claimed character count", or "committed
  character count".  And the sb_acc is "available character count".
  Consumers of socket buffer API shouldn't already access them directly,
  but use sbused() and sbavail() respectively.
o Not ready mbufs are marked with M_NOTREADY, and ready but blocked ones
  with M_BLOCKED.
o New field sb_fnrdy points to the first not ready mbuf, to avoid linear
  search.
o New function sbready() is provided to activate certain amount of mbufs
  in a socket buffer.

A special note on SCTP:
  SCTP has its own sockbufs.  Unfortunately, FreeBSD stack doesn't yet
allow protocol specific sockbufs.  Thus, SCTP does some hacks to make
itself compatible with FreeBSD: it manages sockbufs on its own, but keeps
sb_cc updated to inform the stack of amount of data in them.  The new
notion of "not ready" data isn't supported by SCTP.  Instead, only a
mechanical substitute is done: s/sb_cc/sb_ccc/.
  A proper solution would be to take away struct sockbuf from struct
socket and allow protocols to implement their own socket buffers, like
SCTP already does.  This was discussed with rrs@.

Sponsored by:	Netflix
Sponsored by:	Nginx, Inc.


Changed paths

Path Details
Directoryhead/sys/dev/cxgbe/tom/t4_ddp.c modified , text changed
Directoryhead/sys/kern/uipc_debug.c modified , text changed
Directoryhead/sys/kern/uipc_sockbuf.c modified , text changed
Directoryhead/sys/kern/uipc_socket.c modified , text changed
Directoryhead/sys/netinet/sctp_indata.c modified , text changed
Directoryhead/sys/netinet/sctp_input.c modified , text changed
Directoryhead/sys/netinet/sctp_os_bsd.h modified , text changed
Directoryhead/sys/netinet/sctp_output.c modified , text changed
Directoryhead/sys/netinet/sctp_pcb.c modified , text changed
Directoryhead/sys/netinet/sctp_pcb.h modified , text changed
Directoryhead/sys/netinet/sctp_structs.h modified , text changed
Directoryhead/sys/netinet/sctp_usrreq.c modified , text changed
Directoryhead/sys/netinet/sctp_var.h modified , text changed
Directoryhead/sys/netinet/sctputil.c modified , text changed
Directoryhead/sys/netinet/sctputil.h modified , text changed
Directoryhead/sys/sys/sockbuf.h modified , text changed
Directoryhead/usr.bin/bluetooth/btsockstat/btsockstat.c modified , text changed
Directoryhead/usr.bin/netstat/inet.c modified , text changed
Directoryhead/usr.bin/netstat/netgraph.c modified , text changed
Directoryhead/usr.bin/netstat/unix.c modified , text changed
Directoryhead/usr.bin/systat/netstat.c modified , text changed

  ViewVC Help
Powered by ViewVC 1.1.27