From: John Fastabend on
If the fcoe protocol handler fcoe_rcv() is already executing
on the correct CPU, SCSI-FCP frames can avoid context switching
from the NET_RX softirq to the receive processing thread.

To avoid this context switch this patch uses the affinity_hint
callback to align the interrupt with the FCoE receive processing
threads.

To properly align interrupts for FCoE knowledge of how the
FCoE receive processing threads are setup as well as which
rx rings are dedicated to FCoE and their associated vectors
is needed. Additionally if the FCoE application TLV moves
the FCoE priority this alignment will also need to change.
Handling this in irqbalance alone would required irqbalance
to be aware of DCB, the tx/rx ring mapping for FCoE in
ixgbe and FCoE recv thread CPU mappings. For these reasons
allowing irqbalance to accept hints from ixgbe is ideal for
this case.

Some quick investigative performance numbers show that by
aligning the interrupt correctly an increase in ~50k IOPS
and a decrease in ~10-15% CPU usage can be seen from a
standard default configuration setup by todays irqbalance.

This is a test patch to illustrate how using irq
affininty_hints in ixgbe can benifit FCoE. This patch does
not consider the case where multiple CPU threads can map
to the same queue this case would need further work.
However, I think it does show the benefit of having
an interface to provide affinity_hints.

This patch applies on top of Peter P Waskiewicz Jr previous
series of two patches to implement the affinity hint callback
framework and sample implementation in ixgbe.

Signed-off-by: John Fastabend <john.r.fastabend(a)intel.com>
---

drivers/net/ixgbe/ixgbe_main.c | 16 +++++++++++++++-
1 files changed, 15 insertions(+), 1 deletions(-)

diff --git a/drivers/net/ixgbe/ixgbe_main.c b/drivers/net/ixgbe/ixgbe_main.c
index e4cff48..a680424 100644
--- a/drivers/net/ixgbe/ixgbe_main.c
+++ b/drivers/net/ixgbe/ixgbe_main.c
@@ -1420,6 +1420,7 @@ static void ixgbe_configure_msix(struct ixgbe_adapter *adapter)
struct ixgbe_q_vector *q_vector;
int i, j, q_vectors, v_idx, r_idx;
u32 mask;
+ struct ixgbe_ring_feature *f = &adapter->ring_feature[RING_F_FCOE];

q_vectors = adapter->num_msix_vectors - NON_Q_VECTORS;

@@ -1463,9 +1464,22 @@ static void ixgbe_configure_msix(struct ixgbe_adapter *adapter)
/*
* Allocate the affinity_hint cpumask, assign the mask for
* this vector, and register our affinity_hint callback.
+ *
+ * JF: Add a check for FCoE enabled adapter to catch rings
+ * that are enabled for FCoE and align them to their
+ * corresponding FCoE recv processing thread.
*/
alloc_cpumask_var(&q_vector->affinity_mask, GFP_KERNEL);
- cpumask_set_cpu(v_idx, q_vector->affinity_mask);
+
+ r_idx = find_first_bit(q_vector->rxr_idx,
+ adapter->num_rx_queues);
+ if (adapter->flags & IXGBE_FLAG_FCOE_ENABLED &&
+ (r_idx >= f->mask) && (r_idx < f->mask + f->indices))
+ cpumask_set_cpu(r_idx - f->mask,
+ q_vector->affinity_mask);
+ else
+ cpumask_set_cpu(v_idx, q_vector->affinity_mask);
+
irq_register_affinity_hint(adapter->msix_entries[v_idx].vector,
adapter,
&ixgbe_irq_affinity_callback);

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo(a)vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/