aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/infiniband/hw/mthca/mthca_dev.h
diff options
context:
space:
mode:
authorEli Cohen <eli@mellanox.co.il>2006-02-26 17:36:06 -0500
committerRoland Dreier <rolandd@cisco.com>2006-03-20 13:08:17 -0500
commit14abdffcc0a0ca9c5bb3274648d073e09a6fd2ba (patch)
treefe934450412ed70f627e9d98bb881b03c7b31222 /drivers/infiniband/hw/mthca/mthca_dev.h
parentea88fd16d6e85f4bc71b6053180b64f04be1ff14 (diff)
IB/mthca: Write FW commands through doorbell page
This patch is checks whether the HCA supports posting FW commands through a doorbell page (user access region 0, or "UAR0"). If this is supported, the driver maps UAR0 and uses it for FW commands. This can be controlled by the value of a writable module parameter fw_cmd_doorbell. When the parameter is 0, the commands are posted through HCR using the old method; otherwise if HCA is capable commands go through UAR0. This use of UAR0 to post commands eliminates the need for polling the "go" bit prior to posting a new command. Since reading from a PCI device is much more expensive then issuing a posted write, it is expected that issuing FW commands this way will provide better CPU utilization. Signed-off-by: Eli Cohen <eli@mellanox.co.il> Signed-off-by: Roland Dreier <rolandd@cisco.com>
Diffstat (limited to 'drivers/infiniband/hw/mthca/mthca_dev.h')
-rw-r--r--drivers/infiniband/hw/mthca/mthca_dev.h13
1 files changed, 12 insertions, 1 deletions
diff --git a/drivers/infiniband/hw/mthca/mthca_dev.h b/drivers/infiniband/hw/mthca/mthca_dev.h
index 7f0dc221fa47..b2aea80a683f 100644
--- a/drivers/infiniband/hw/mthca/mthca_dev.h
+++ b/drivers/infiniband/hw/mthca/mthca_dev.h
@@ -110,9 +110,17 @@ enum {
110 MTHCA_OPCODE_INVALID = 0xff 110 MTHCA_OPCODE_INVALID = 0xff
111}; 111};
112 112
113enum {
114 MTHCA_CMD_USE_EVENTS = 1 << 0,
115 MTHCA_CMD_POST_DOORBELLS = 1 << 1
116};
117
118enum {
119 MTHCA_CMD_NUM_DBELL_DWORDS = 8
120};
121
113struct mthca_cmd { 122struct mthca_cmd {
114 struct pci_pool *pool; 123 struct pci_pool *pool;
115 int use_events;
116 struct mutex hcr_mutex; 124 struct mutex hcr_mutex;
117 struct semaphore poll_sem; 125 struct semaphore poll_sem;
118 struct semaphore event_sem; 126 struct semaphore event_sem;
@@ -121,6 +129,9 @@ struct mthca_cmd {
121 int free_head; 129 int free_head;
122 struct mthca_cmd_context *context; 130 struct mthca_cmd_context *context;
123 u16 token_mask; 131 u16 token_mask;
132 u32 flags;
133 void __iomem *dbell_map;
134 u16 dbell_offsets[MTHCA_CMD_NUM_DBELL_DWORDS];
124}; 135};
125 136
126struct mthca_limits { 137struct mthca_limits {