Gleb Smirnoff 1fbe6a82f4 Improve reference counting of EXT_SFBUF pages attached to mbufs.
o Do not use UMA refcount zone. The problem with this zone is that
  several refcounting words (16 on amd64) share the same cache line,
  and issueing atomic(9) updates on them creates cache line contention.
  Also, allocating and freeing them is extra CPU cycles.
  Instead, refcount the page directly via vm_page_wire() and the sfbuf
  via sf_buf_alloc(sf_buf_page(sf)) [1].

o Call refcounting/freeing function for EXT_SFBUF via direct function
  call, instead of function pointer. This removes barrier for CPU
  branch predictor.

o Do not cleanup the mbuf to be freed in mb_free_ext(), merely to
  satisfy assertion in mb_dtor_mbuf(). Remove the assertion from
  mb_dtor_mbuf(). Use bcopy() instead of manual assignments to
  copy m_ext in mb_dupcl().

[1] This has some problems for now. Using sf_buf_alloc() merely to
    increase refcount is expensive, and is broken on sparc64. To be
    fixed.

Sponsored by:	Netflix
Sponsored by:	Nginx, Inc.
2014-07-11 19:40:50 +00:00
..
2014-07-10 00:15:50 +00:00
2014-04-07 20:44:00 +00:00
2014-07-09 23:14:59 +00:00
2014-07-07 00:27:09 +00:00
2014-07-07 00:27:09 +00:00
2014-07-07 00:27:09 +00:00
2014-07-11 06:34:15 +00:00
2014-04-17 12:22:08 +00:00
2014-06-14 12:26:12 +00:00
2014-06-28 17:36:18 +00:00
2014-02-06 13:28:06 +00:00
2014-07-07 00:27:09 +00:00
2014-07-07 00:27:09 +00:00
2014-07-07 00:27:09 +00:00