提交 99c7abfb 编写于 作者: M Mike Marciniszyn 提交者: Doug Ledford

IB/hfi1: Optimize pio cachelines

Move buffers_allocated pcpu pointer to allocator line.

Move hw_free pointer to releaser line.

Fill other holes revealed by pahole.
Reviewed-by: NSebastian Sanchez <sebastian.sanchez@intel.com>
Signed-off-by: NMike Marciniszyn <mike.marciniszyn@intel.com>
Signed-off-by: NDennis Dalessandro <dennis.dalessandro@intel.com>
Signed-off-by: NDoug Ledford <dledford@redhat.com>
上级 be5d740b
...@@ -104,7 +104,6 @@ struct send_context { ...@@ -104,7 +104,6 @@ struct send_context {
void __iomem *base_addr; /* start of PIO memory */ void __iomem *base_addr; /* start of PIO memory */
union pio_shadow_ring *sr; /* shadow ring */ union pio_shadow_ring *sr; /* shadow ring */
volatile __le64 *hw_free; /* HW free counter */
struct work_struct halt_work; /* halted context work queue entry */ struct work_struct halt_work; /* halted context work queue entry */
unsigned long flags; /* flags */ unsigned long flags; /* flags */
int node; /* context home node */ int node; /* context home node */
...@@ -116,19 +115,20 @@ struct send_context { ...@@ -116,19 +115,20 @@ struct send_context {
u32 group; /* credit return group */ u32 group; /* credit return group */
/* allocator fields */ /* allocator fields */
spinlock_t alloc_lock ____cacheline_aligned_in_smp; spinlock_t alloc_lock ____cacheline_aligned_in_smp;
u32 sr_head; /* shadow ring head */
unsigned long fill; /* official alloc count */ unsigned long fill; /* official alloc count */
unsigned long alloc_free; /* copy of free (less cache thrash) */ unsigned long alloc_free; /* copy of free (less cache thrash) */
u32 sr_head; /* shadow ring head */ u32 __percpu *buffers_allocated;/* count of buffers allocated */
/* releaser fields */ /* releaser fields */
spinlock_t release_lock ____cacheline_aligned_in_smp; spinlock_t release_lock ____cacheline_aligned_in_smp;
unsigned long free; /* official free count */
u32 sr_tail; /* shadow ring tail */ u32 sr_tail; /* shadow ring tail */
unsigned long free; /* official free count */
volatile __le64 *hw_free; /* HW free counter */
/* list for PIO waiters */ /* list for PIO waiters */
struct list_head piowait ____cacheline_aligned_in_smp; struct list_head piowait ____cacheline_aligned_in_smp;
spinlock_t credit_ctrl_lock ____cacheline_aligned_in_smp; spinlock_t credit_ctrl_lock ____cacheline_aligned_in_smp;
u64 credit_ctrl; /* cache for credit control */
u32 credit_intr_count; /* count of credit intr users */ u32 credit_intr_count; /* count of credit intr users */
u32 __percpu *buffers_allocated;/* count of buffers allocated */ u64 credit_ctrl; /* cache for credit control */
wait_queue_head_t halt_wait; /* wait until kernel sees interrupt */ wait_queue_head_t halt_wait; /* wait until kernel sees interrupt */
}; };
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册