scaling.rst 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593
  1. .. SPDX-License-Identifier: GPL-2.0
  2. =====================================
  3. Scaling in the Linux Networking Stack
  4. =====================================
  5. Introduction
  6. ============
  7. This document describes a set of complementary techniques in the Linux
  8. networking stack to increase parallelism and improve performance for
  9. multi-processor systems.
  10. The following technologies are described:
  11. - RSS: Receive Side Scaling
  12. - RPS: Receive Packet Steering
  13. - RFS: Receive Flow Steering
  14. - Accelerated Receive Flow Steering
  15. - XPS: Transmit Packet Steering
  16. RSS: Receive Side Scaling
  17. =========================
  18. Contemporary NICs support multiple receive and transmit descriptor queues
  19. (multi-queue). On reception, a NIC can send different packets to different
  20. queues to distribute processing among CPUs. The NIC distributes packets by
  21. applying a filter to each packet that assigns it to one of a small number
  22. of logical flows. Packets for each flow are steered to a separate receive
  23. queue, which in turn can be processed by separate CPUs. This mechanism is
  24. generally known as “Receive-side Scaling” (RSS). The goal of RSS and
  25. the other scaling techniques is to increase performance uniformly.
  26. Multi-queue distribution can also be used for traffic prioritization, but
  27. that is not the focus of these techniques.
  28. The filter used in RSS is typically a hash function over the network
  29. and/or transport layer headers-- for example, a 4-tuple hash over
  30. IP addresses and TCP ports of a packet. The most common hardware
  31. implementation of RSS uses an indirection table where each entry
  32. stores a queue number. The receive queue for a packet is determined
  33. by indexing the indirection table with the low order bits of the
  34. computed hash for the packet (usually a Toeplitz hash).
  35. The indirection table helps even out the traffic distribution when queue
  36. count is not a power of two. NICs should provide an indirection table
  37. at least 4 times larger than the queue count. 4x table results in ~16%
  38. imbalance between the queues, which is acceptable for most applications.
  39. Some NICs support symmetric RSS hashing where, if the IP (source address,
  40. destination address) and TCP/UDP (source port, destination port) tuples
  41. are swapped, the computed hash is the same. This is beneficial in some
  42. applications that monitor TCP/IP flows (IDS, firewalls, ...etc) and need
  43. both directions of the flow to land on the same Rx queue (and CPU). The
  44. "Symmetric-XOR" and "Symmetric-OR-XOR" are types of RSS algorithms that
  45. achieve this hash symmetry by XOR/ORing the input source and destination
  46. fields of the IP and/or L4 protocols. This, however, results in reduced
  47. input entropy and could potentially be exploited.
  48. Specifically, the "Symmetric-XOR" algorithm XORs the input
  49. as follows::
  50. # (SRC_IP ^ DST_IP, SRC_IP ^ DST_IP, SRC_PORT ^ DST_PORT, SRC_PORT ^ DST_PORT)
  51. The "Symmetric-OR-XOR" algorithm, on the other hand, transforms the input as
  52. follows::
  53. # (SRC_IP | DST_IP, SRC_IP ^ DST_IP, SRC_PORT | DST_PORT, SRC_PORT ^ DST_PORT)
  54. The result is then fed to the underlying RSS algorithm.
  55. Some advanced NICs allow steering packets to queues based on
  56. programmable filters. For example, webserver bound TCP port 80 packets
  57. can be directed to their own receive queue. Such “n-tuple” filters can
  58. be configured from ethtool (--config-ntuple).
  59. RSS Configuration
  60. -----------------
  61. The driver for a multi-queue capable NIC typically provides a kernel
  62. module parameter for specifying the number of hardware queues to
  63. configure. In the bnx2x driver, for instance, this parameter is called
  64. num_queues. A typical RSS configuration would be to have one receive queue
  65. for each CPU if the device supports enough queues, or otherwise at least
  66. one for each memory domain, where a memory domain is a set of CPUs that
  67. share a particular memory level (L1, L2, NUMA node, etc.).
  68. The indirection table of an RSS device, which resolves a queue by masked
  69. hash, is usually programmed by the driver at initialization. The
  70. default mapping is to distribute the queues evenly in the table, but the
  71. indirection table can be retrieved and modified at runtime using ethtool
  72. commands (--show-rxfh-indir and --set-rxfh-indir). Modifying the
  73. indirection table could be done to give different queues different
  74. relative weights.
  75. RSS IRQ Configuration
  76. ~~~~~~~~~~~~~~~~~~~~~
  77. Each receive queue has a separate IRQ associated with it. The NIC triggers
  78. this to notify a CPU when new packets arrive on the given queue. The
  79. signaling path for PCIe devices uses message signaled interrupts (MSI-X),
  80. that can route each interrupt to a particular CPU. The active mapping
  81. of queues to IRQs can be determined from /proc/interrupts. By default,
  82. an IRQ may be handled on any CPU. Because a non-negligible part of packet
  83. processing takes place in receive interrupt handling, it is advantageous
  84. to spread receive interrupts between CPUs. To manually adjust the IRQ
  85. affinity of each interrupt see Documentation/core-api/irq/irq-affinity.rst. Some systems
  86. will be running irqbalance, a daemon that dynamically optimizes IRQ
  87. assignments and as a result may override any manual settings.
  88. Suggested Configuration
  89. ~~~~~~~~~~~~~~~~~~~~~~~
  90. RSS should be enabled when latency is a concern or whenever receive
  91. interrupt processing forms a bottleneck. Spreading load between CPUs
  92. decreases queue length. For low latency networking, the optimal setting
  93. is to allocate as many queues as there are CPUs in the system (or the
  94. NIC maximum, if lower). The most efficient high-rate configuration
  95. is likely the one with the smallest number of receive queues where no
  96. receive queue overflows due to a saturated CPU, because in default
  97. mode with interrupt coalescing enabled, the aggregate number of
  98. interrupts (and thus work) grows with each additional queue.
  99. Per-cpu load can be observed using the mpstat utility, but note that on
  100. processors with hyperthreading (HT), each hyperthread is represented as
  101. a separate CPU. For interrupt handling, HT has shown no benefit in
  102. initial tests, so limit the number of queues to the number of CPU cores
  103. in the system.
  104. Dedicated RSS contexts
  105. ~~~~~~~~~~~~~~~~~~~~~~
  106. Modern NICs support creating multiple co-existing RSS configurations
  107. which are selected based on explicit matching rules. This can be very
  108. useful when application wants to constrain the set of queues receiving
  109. traffic for e.g. a particular destination port or IP address.
  110. The example below shows how to direct all traffic to TCP port 22
  111. to queues 0 and 1.
  112. To create an additional RSS context use::
  113. # ethtool -X eth0 hfunc toeplitz context new
  114. New RSS context is 1
  115. Kernel reports back the ID of the allocated context (the default, always
  116. present RSS context has ID of 0). The new context can be queried and
  117. modified using the same APIs as the default context::
  118. # ethtool -x eth0 context 1
  119. RX flow hash indirection table for eth0 with 13 RX ring(s):
  120. 0: 0 1 2 3 4 5 6 7
  121. 8: 8 9 10 11 12 0 1 2
  122. [...]
  123. # ethtool -X eth0 equal 2 context 1
  124. # ethtool -x eth0 context 1
  125. RX flow hash indirection table for eth0 with 13 RX ring(s):
  126. 0: 0 1 0 1 0 1 0 1
  127. 8: 0 1 0 1 0 1 0 1
  128. [...]
  129. To make use of the new context direct traffic to it using an n-tuple
  130. filter::
  131. # ethtool -N eth0 flow-type tcp6 dst-port 22 context 1
  132. Added rule with ID 1023
  133. When done, remove the context and the rule::
  134. # ethtool -N eth0 delete 1023
  135. # ethtool -X eth0 context 1 delete
  136. RPS: Receive Packet Steering
  137. ============================
  138. Receive Packet Steering (RPS) is logically a software implementation of
  139. RSS. Being in software, it is necessarily called later in the datapath.
  140. Whereas RSS selects the queue and hence CPU that will run the hardware
  141. interrupt handler, RPS selects the CPU to perform protocol processing
  142. above the interrupt handler. This is accomplished by placing the packet
  143. on the desired CPU’s backlog queue and waking up the CPU for processing.
  144. RPS has some advantages over RSS:
  145. 1) it can be used with any NIC
  146. 2) software filters can easily be added to hash over new protocols
  147. 3) it does not increase hardware device interrupt rate (although it does
  148. introduce inter-processor interrupts (IPIs))
  149. RPS is called during bottom half of the receive interrupt handler, when
  150. a driver sends a packet up the network stack with netif_rx() or
  151. netif_receive_skb(). These call the get_rps_cpu() function, which
  152. selects the queue that should process a packet.
  153. The first step in determining the target CPU for RPS is to calculate a
  154. flow hash over the packet’s addresses or ports (2-tuple or 4-tuple hash
  155. depending on the protocol). This serves as a consistent hash of the
  156. associated flow of the packet. The hash is either provided by hardware
  157. or will be computed in the stack. Capable hardware can pass the hash in
  158. the receive descriptor for the packet; this would usually be the same
  159. hash used for RSS (e.g. computed Toeplitz hash). The hash is saved in
  160. skb->hash and can be used elsewhere in the stack as a hash of the
  161. packet’s flow.
  162. Each receive hardware queue has an associated list of CPUs to which
  163. RPS may enqueue packets for processing. For each received packet,
  164. an index into the list is computed from the flow hash modulo the size
  165. of the list. The indexed CPU is the target for processing the packet,
  166. and the packet is queued to the tail of that CPU’s backlog queue. At
  167. the end of the bottom half routine, IPIs are sent to any CPUs for which
  168. packets have been queued to their backlog queue. The IPI wakes backlog
  169. processing on the remote CPU, and any queued packets are then processed
  170. up the networking stack.
  171. RPS Configuration
  172. -----------------
  173. RPS requires a kernel compiled with the CONFIG_RPS kconfig symbol (on
  174. by default for SMP). Even when compiled in, RPS remains disabled until
  175. explicitly configured. The list of CPUs to which RPS may forward traffic
  176. can be configured for each receive queue using a sysfs file entry::
  177. /sys/class/net/<dev>/queues/rx-<n>/rps_cpus
  178. This file implements a bitmap of CPUs. RPS is disabled when it is zero
  179. (the default), in which case packets are processed on the interrupting
  180. CPU. Documentation/core-api/irq/irq-affinity.rst explains how CPUs are assigned to
  181. the bitmap.
  182. Suggested Configuration
  183. ~~~~~~~~~~~~~~~~~~~~~~~
  184. For a single queue device, a typical RPS configuration would be to set
  185. the rps_cpus to the CPUs in the same memory domain of the interrupting
  186. CPU. If NUMA locality is not an issue, this could also be all CPUs in
  187. the system. At high interrupt rate, it might be wise to exclude the
  188. interrupting CPU from the map since that already performs much work.
  189. For a multi-queue system, if RSS is configured so that a hardware
  190. receive queue is mapped to each CPU, then RPS is probably redundant
  191. and unnecessary. If there are fewer hardware queues than CPUs, then
  192. RPS might be beneficial if the rps_cpus for each queue are the ones that
  193. share the same memory domain as the interrupting CPU for that queue.
  194. RPS Flow Limit
  195. --------------
  196. RPS scales kernel receive processing across CPUs without introducing
  197. reordering. The trade-off to sending all packets from the same flow
  198. to the same CPU is CPU load imbalance if flows vary in packet rate.
  199. In the extreme case a single flow dominates traffic. Especially on
  200. common server workloads with many concurrent connections, such
  201. behavior indicates a problem such as a misconfiguration or spoofed
  202. source Denial of Service attack.
  203. Flow Limit is an optional RPS feature that prioritizes small flows
  204. during CPU contention by dropping packets from large flows slightly
  205. ahead of those from small flows. It is active only when an RPS or RFS
  206. destination CPU approaches saturation. Once a CPU's input packet
  207. queue exceeds half the maximum queue length (as set by sysctl
  208. net.core.netdev_max_backlog), the kernel starts a per-flow packet
  209. count over the last 256 packets. If a flow exceeds a set ratio (by
  210. default, half) of these packets when a new packet arrives, then the
  211. new packet is dropped. Packets from other flows are still only
  212. dropped once the input packet queue reaches netdev_max_backlog.
  213. No packets are dropped when the input packet queue length is below
  214. the threshold, so flow limit does not sever connections outright:
  215. even large flows maintain connectivity.
  216. Interface
  217. ~~~~~~~~~
  218. Flow limit is compiled in by default (CONFIG_NET_FLOW_LIMIT), but not
  219. turned on. It is implemented for each CPU independently (to avoid lock
  220. and cache contention) and toggled per CPU by setting the relevant bit
  221. in sysctl net.core.flow_limit_cpu_bitmap. It exposes the same CPU
  222. bitmap interface as rps_cpus (see above) when called from procfs::
  223. /proc/sys/net/core/flow_limit_cpu_bitmap
  224. Per-flow rate is calculated by hashing each packet into a hashtable
  225. bucket and incrementing a per-bucket counter. The hash function is
  226. the same that selects a CPU in RPS, but as the number of buckets can
  227. be much larger than the number of CPUs, flow limit has finer-grained
  228. identification of large flows and fewer false positives. The default
  229. table has 4096 buckets. This value can be modified through sysctl::
  230. net.core.flow_limit_table_len
  231. The value is only consulted when a new table is allocated. Modifying
  232. it does not update active tables.
  233. Suggested Configuration
  234. ~~~~~~~~~~~~~~~~~~~~~~~
  235. Flow limit is useful on systems with many concurrent connections,
  236. where a single connection taking up 50% of a CPU indicates a problem.
  237. In such environments, enable the feature on all CPUs that handle
  238. network rx interrupts (as set in /proc/irq/N/smp_affinity).
  239. The feature depends on the input packet queue length to exceed
  240. the flow limit threshold (50%) + the flow history length (256).
  241. Setting net.core.netdev_max_backlog to either 1000 or 10000
  242. performed well in experiments.
  243. RFS: Receive Flow Steering
  244. ==========================
  245. While RPS steers packets solely based on hash, and thus generally
  246. provides good load distribution, it does not take into account
  247. application locality. This is accomplished by Receive Flow Steering
  248. (RFS). The goal of RFS is to increase datacache hitrate by steering
  249. kernel processing of packets to the CPU where the application thread
  250. consuming the packet is running. RFS relies on the same RPS mechanisms
  251. to enqueue packets onto the backlog of another CPU and to wake up that
  252. CPU.
  253. In RFS, packets are not forwarded directly by the value of their hash,
  254. but the hash is used as index into a flow lookup table. This table maps
  255. flows to the CPUs where those flows are being processed. The flow hash
  256. (see RPS section above) is used to calculate the index into this table.
  257. The CPU recorded in each entry is the one which last processed the flow.
  258. If an entry does not hold a valid CPU, then packets mapped to that entry
  259. are steered using plain RPS. Multiple table entries may point to the
  260. same CPU. Indeed, with many flows and few CPUs, it is very likely that
  261. a single application thread handles flows with many different flow hashes.
  262. rps_sock_flow_table is a global flow table that contains the *desired* CPU
  263. for flows: the CPU that is currently processing the flow in userspace.
  264. Each table value is a CPU index that is updated during calls to recvmsg
  265. and sendmsg (specifically, inet_recvmsg(), inet_sendmsg() and
  266. tcp_splice_read()).
  267. When the scheduler moves a thread to a new CPU while it has outstanding
  268. receive packets on the old CPU, packets may arrive out of order. To
  269. avoid this, RFS uses a second flow table to track outstanding packets
  270. for each flow: rps_dev_flow_table is a table specific to each hardware
  271. receive queue of each device. Each table value stores a CPU index and a
  272. counter. The CPU index represents the *current* CPU onto which packets
  273. for this flow are enqueued for further kernel processing. Ideally, kernel
  274. and userspace processing occur on the same CPU, and hence the CPU index
  275. in both tables is identical. This is likely false if the scheduler has
  276. recently migrated a userspace thread while the kernel still has packets
  277. enqueued for kernel processing on the old CPU.
  278. The counter in rps_dev_flow_table values records the length of the current
  279. CPU's backlog when a packet in this flow was last enqueued. Each backlog
  280. queue has a head counter that is incremented on dequeue. A tail counter
  281. is computed as head counter + queue length. In other words, the counter
  282. in rps_dev_flow[i] records the last element in flow i that has
  283. been enqueued onto the currently designated CPU for flow i (of course,
  284. entry i is actually selected by hash and multiple flows may hash to the
  285. same entry i).
  286. And now the trick for avoiding out of order packets: when selecting the
  287. CPU for packet processing (from get_rps_cpu()) the rps_sock_flow table
  288. and the rps_dev_flow table of the queue that the packet was received on
  289. are compared. If the desired CPU for the flow (found in the
  290. rps_sock_flow table) matches the current CPU (found in the rps_dev_flow
  291. table), the packet is enqueued onto that CPU’s backlog. If they differ,
  292. the current CPU is updated to match the desired CPU if one of the
  293. following is true:
  294. - The current CPU's queue head counter >= the recorded tail counter
  295. value in rps_dev_flow[i]
  296. - The current CPU is unset (>= nr_cpu_ids)
  297. - The current CPU is offline
  298. After this check, the packet is sent to the (possibly updated) current
  299. CPU. These rules aim to ensure that a flow only moves to a new CPU when
  300. there are no packets outstanding on the old CPU, as the outstanding
  301. packets could arrive later than those about to be processed on the new
  302. CPU.
  303. RFS Configuration
  304. -----------------
  305. RFS is only available if the kconfig symbol CONFIG_RPS is enabled (on
  306. by default for SMP). The functionality remains disabled until explicitly
  307. configured. The number of entries in the global flow table is set through::
  308. /proc/sys/net/core/rps_sock_flow_entries
  309. The number of entries in the per-queue flow table are set through::
  310. /sys/class/net/<dev>/queues/rx-<n>/rps_flow_cnt
  311. Suggested Configuration
  312. ~~~~~~~~~~~~~~~~~~~~~~~
  313. Both of these need to be set before RFS is enabled for a receive queue.
  314. Values for both are rounded up to the nearest power of two. The
  315. suggested flow count depends on the expected number of active connections
  316. at any given time, which may be significantly less than the number of open
  317. connections. We have found that a value of 32768 for rps_sock_flow_entries
  318. works fairly well on a moderately loaded server.
  319. For a single queue device, the rps_flow_cnt value for the single queue
  320. would normally be configured to the same value as rps_sock_flow_entries.
  321. For a multi-queue device, the rps_flow_cnt for each queue might be
  322. configured as rps_sock_flow_entries / N, where N is the number of
  323. queues. So for instance, if rps_sock_flow_entries is set to 32768 and there
  324. are 16 configured receive queues, rps_flow_cnt for each queue might be
  325. configured as 2048.
  326. Accelerated RFS
  327. ===============
  328. Accelerated RFS is to RFS what RSS is to RPS: a hardware-accelerated load
  329. balancing mechanism that uses soft state to steer flows based on where
  330. the application thread consuming the packets of each flow is running.
  331. Accelerated RFS should perform better than RFS since packets are sent
  332. directly to a CPU local to the thread consuming the data. The target CPU
  333. will either be the same CPU where the application runs, or at least a CPU
  334. which is local to the application thread’s CPU in the cache hierarchy.
  335. To enable accelerated RFS, the networking stack calls the
  336. ndo_rx_flow_steer driver function to communicate the desired hardware
  337. queue for packets matching a particular flow. The network stack
  338. automatically calls this function every time a flow entry in
  339. rps_dev_flow_table is updated. The driver in turn uses a device specific
  340. method to program the NIC to steer the packets.
  341. The hardware queue for a flow is derived from the CPU recorded in
  342. rps_dev_flow_table. The stack consults a CPU to hardware queue map which
  343. is maintained by the NIC driver. This is an auto-generated reverse map of
  344. the IRQ affinity table shown by /proc/interrupts. Drivers can use
  345. functions in the cpu_rmap (“CPU affinity reverse map”) kernel library
  346. to populate the map. Alternatively, drivers can delegate the cpu_rmap
  347. management to the Kernel by calling netif_enable_cpu_rmap(). For each CPU,
  348. the corresponding queue in the map is set to be one whose processing CPU is
  349. closest in cache locality.
  350. Accelerated RFS Configuration
  351. -----------------------------
  352. Accelerated RFS is only available if the kernel is compiled with
  353. CONFIG_RFS_ACCEL and support is provided by the NIC device and driver.
  354. It also requires that ntuple filtering is enabled via ethtool. The map
  355. of CPU to queues is automatically deduced from the IRQ affinities
  356. configured for each receive queue by the driver, so no additional
  357. configuration should be necessary.
  358. Suggested Configuration
  359. ~~~~~~~~~~~~~~~~~~~~~~~
  360. This technique should be enabled whenever one wants to use RFS and the
  361. NIC supports hardware acceleration.
  362. XPS: Transmit Packet Steering
  363. =============================
  364. Transmit Packet Steering is a mechanism for intelligently selecting
  365. which transmit queue to use when transmitting a packet on a multi-queue
  366. device. This can be accomplished by recording two kinds of maps, either
  367. a mapping of CPU to hardware queue(s) or a mapping of receive queue(s)
  368. to hardware transmit queue(s).
  369. 1. XPS using CPUs map
  370. The goal of this mapping is usually to assign queues
  371. exclusively to a subset of CPUs, where the transmit completions for
  372. these queues are processed on a CPU within this set. This choice
  373. provides two benefits. First, contention on the device queue lock is
  374. significantly reduced since fewer CPUs contend for the same queue
  375. (contention can be eliminated completely if each CPU has its own
  376. transmit queue). Secondly, cache miss rate on transmit completion is
  377. reduced, in particular for data cache lines that hold the sk_buff
  378. structures.
  379. 2. XPS using receive queues map
  380. This mapping is used to pick transmit queue based on the receive
  381. queue(s) map configuration set by the administrator. A set of receive
  382. queues can be mapped to a set of transmit queues (many:many), although
  383. the common use case is a 1:1 mapping. This will enable sending packets
  384. on the same queue associations for transmit and receive. This is useful for
  385. busy polling multi-threaded workloads where there are challenges in
  386. associating a given CPU to a given application thread. The application
  387. threads are not pinned to CPUs and each thread handles packets
  388. received on a single queue. The receive queue number is cached in the
  389. socket for the connection. In this model, sending the packets on the same
  390. transmit queue corresponding to the associated receive queue has benefits
  391. in keeping the CPU overhead low. Transmit completion work is locked into
  392. the same queue-association that a given application is polling on. This
  393. avoids the overhead of triggering an interrupt on another CPU. When the
  394. application cleans up the packets during the busy poll, transmit completion
  395. may be processed along with it in the same thread context and so result in
  396. reduced latency.
  397. XPS is configured per transmit queue by setting a bitmap of
  398. CPUs/receive-queues that may use that queue to transmit. The reverse
  399. mapping, from CPUs to transmit queues or from receive-queues to transmit
  400. queues, is computed and maintained for each network device. When
  401. transmitting the first packet in a flow, the function get_xps_queue() is
  402. called to select a queue. This function uses the ID of the receive queue
  403. for the socket connection for a match in the receive queue-to-transmit queue
  404. lookup table. Alternatively, this function can also use the ID of the
  405. running CPU as a key into the CPU-to-queue lookup table. If the
  406. ID matches a single queue, that is used for transmission. If multiple
  407. queues match, one is selected by using the flow hash to compute an index
  408. into the set. When selecting the transmit queue based on receive queue(s)
  409. map, the transmit device is not validated against the receive device as it
  410. requires expensive lookup operation in the datapath.
  411. The queue chosen for transmitting a particular flow is saved in the
  412. corresponding socket structure for the flow (e.g. a TCP connection).
  413. This transmit queue is used for subsequent packets sent on the flow to
  414. prevent out of order (ooo) packets. The choice also amortizes the cost
  415. of calling get_xps_queues() over all packets in the flow. To avoid
  416. ooo packets, the queue for a flow can subsequently only be changed if
  417. skb->ooo_okay is set for a packet in the flow. This flag indicates that
  418. there are no outstanding packets in the flow, so the transmit queue can
  419. change without the risk of generating out of order packets. The
  420. transport layer is responsible for setting ooo_okay appropriately. TCP,
  421. for instance, sets the flag when all data for a connection has been
  422. acknowledged.
  423. XPS Configuration
  424. -----------------
  425. XPS is only available if the kconfig symbol CONFIG_XPS is enabled (on by
  426. default for SMP). If compiled in, it is driver dependent whether, and
  427. how, XPS is configured at device init. The mapping of CPUs/receive-queues
  428. to transmit queue can be inspected and configured using sysfs:
  429. For selection based on CPUs map::
  430. /sys/class/net/<dev>/queues/tx-<n>/xps_cpus
  431. For selection based on receive-queues map::
  432. /sys/class/net/<dev>/queues/tx-<n>/xps_rxqs
  433. Suggested Configuration
  434. ~~~~~~~~~~~~~~~~~~~~~~~
  435. For a network device with a single transmission queue, XPS configuration
  436. has no effect, since there is no choice in this case. In a multi-queue
  437. system, XPS is preferably configured so that each CPU maps onto one queue.
  438. If there are as many queues as there are CPUs in the system, then each
  439. queue can also map onto one CPU, resulting in exclusive pairings that
  440. experience no contention. If there are fewer queues than CPUs, then the
  441. best CPUs to share a given queue are probably those that share the cache
  442. with the CPU that processes transmit completions for that queue
  443. (transmit interrupts).
  444. For transmit queue selection based on receive queue(s), XPS has to be
  445. explicitly configured mapping receive-queue(s) to transmit queue(s). If the
  446. user configuration for receive-queue map does not apply, then the transmit
  447. queue is selected based on the CPUs map.
  448. Per TX Queue rate limitation
  449. ============================
  450. These are rate-limitation mechanisms implemented by HW, where currently
  451. a max-rate attribute is supported, by setting a Mbps value to::
  452. /sys/class/net/<dev>/queues/tx-<n>/tx_maxrate
  453. A value of zero means disabled, and this is the default.
  454. Further Information
  455. ===================
  456. RPS and RFS were introduced in kernel 2.6.35. XPS was incorporated into
  457. 2.6.38. Original patches were submitted by Tom Herbert
  458. (therbert@google.com)
  459. Accelerated RFS was introduced in 2.6.35. Original patches were
  460. submitted by Ben Hutchings (bwh@kernel.org)
  461. Authors:
  462. - Tom Herbert (therbert@google.com)
  463. - Willem de Bruijn (willemb@google.com)