Commit b925f6a8 authored by Roland Dreier's avatar Roland Dreier Committed by Linus Torvalds

[PATCH] IB/mthca: mem-free CQ initialization

Update CQ initialization and cleanup to handle mem-free mode: we need
to make sure the HCA has memory mapped for the entry in the CQ context
table we will use and also allocate doorbell records.
Signed-off-by: default avatarRoland Dreier <roland@topspin.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 8688ff94
...@@ -39,6 +39,7 @@ ...@@ -39,6 +39,7 @@
#include "mthca_dev.h" #include "mthca_dev.h"
#include "mthca_cmd.h" #include "mthca_cmd.h"
#include "mthca_memfree.h"
enum { enum {
MTHCA_MAX_DIRECT_CQ_SIZE = 4 * PAGE_SIZE MTHCA_MAX_DIRECT_CQ_SIZE = 4 * PAGE_SIZE
...@@ -55,7 +56,7 @@ struct mthca_cq_context { ...@@ -55,7 +56,7 @@ struct mthca_cq_context {
u32 flags; u32 flags;
u64 start; u64 start;
u32 logsize_usrpage; u32 logsize_usrpage;
u32 error_eqn; u32 error_eqn; /* Tavor only */
u32 comp_eqn; u32 comp_eqn;
u32 pd; u32 pd;
u32 lkey; u32 lkey;
...@@ -64,7 +65,9 @@ struct mthca_cq_context { ...@@ -64,7 +65,9 @@ struct mthca_cq_context {
u32 consumer_index; u32 consumer_index;
u32 producer_index; u32 producer_index;
u32 cqn; u32 cqn;
u32 reserved[3]; u32 ci_db; /* Arbel only */
u32 state_db; /* Arbel only */
u32 reserved;
} __attribute__((packed)); } __attribute__((packed));
#define MTHCA_CQ_STATUS_OK ( 0 << 28) #define MTHCA_CQ_STATUS_OK ( 0 << 28)
...@@ -685,10 +688,30 @@ int mthca_init_cq(struct mthca_dev *dev, int nent, ...@@ -685,10 +688,30 @@ int mthca_init_cq(struct mthca_dev *dev, int nent,
if (cq->cqn == -1) if (cq->cqn == -1)
return -ENOMEM; return -ENOMEM;
if (dev->hca_type == ARBEL_NATIVE) {
cq->arm_sn = 1;
err = mthca_table_get(dev, dev->cq_table.table, cq->cqn);
if (err)
goto err_out;
err = -ENOMEM;
cq->set_ci_db_index = mthca_alloc_db(dev, MTHCA_DB_TYPE_CQ_SET_CI,
cq->cqn, &cq->set_ci_db);
if (cq->set_ci_db_index < 0)
goto err_out_icm;
cq->arm_db_index = mthca_alloc_db(dev, MTHCA_DB_TYPE_CQ_ARM,
cq->cqn, &cq->arm_db);
if (cq->arm_db_index < 0)
goto err_out_ci;
}
mailbox = kmalloc(sizeof (struct mthca_cq_context) + MTHCA_CMD_MAILBOX_EXTRA, mailbox = kmalloc(sizeof (struct mthca_cq_context) + MTHCA_CMD_MAILBOX_EXTRA,
GFP_KERNEL); GFP_KERNEL);
if (!mailbox) if (!mailbox)
goto err_out; goto err_out_mailbox;
cq_context = MAILBOX_ALIGN(mailbox); cq_context = MAILBOX_ALIGN(mailbox);
...@@ -716,6 +739,11 @@ int mthca_init_cq(struct mthca_dev *dev, int nent, ...@@ -716,6 +739,11 @@ int mthca_init_cq(struct mthca_dev *dev, int nent,
cq_context->lkey = cpu_to_be32(cq->mr.ibmr.lkey); cq_context->lkey = cpu_to_be32(cq->mr.ibmr.lkey);
cq_context->cqn = cpu_to_be32(cq->cqn); cq_context->cqn = cpu_to_be32(cq->cqn);
if (dev->hca_type == ARBEL_NATIVE) {
cq_context->ci_db = cpu_to_be32(cq->set_ci_db_index);
cq_context->state_db = cpu_to_be32(cq->arm_db_index);
}
err = mthca_SW2HW_CQ(dev, cq_context, cq->cqn, &status); err = mthca_SW2HW_CQ(dev, cq_context, cq->cqn, &status);
if (err) { if (err) {
mthca_warn(dev, "SW2HW_CQ failed (%d)\n", err); mthca_warn(dev, "SW2HW_CQ failed (%d)\n", err);
...@@ -751,6 +779,14 @@ int mthca_init_cq(struct mthca_dev *dev, int nent, ...@@ -751,6 +779,14 @@ int mthca_init_cq(struct mthca_dev *dev, int nent,
err_out_mailbox: err_out_mailbox:
kfree(mailbox); kfree(mailbox);
mthca_free_db(dev, MTHCA_DB_TYPE_CQ_ARM, cq->arm_db_index);
err_out_ci:
mthca_free_db(dev, MTHCA_DB_TYPE_CQ_SET_CI, cq->set_ci_db_index);
err_out_icm:
mthca_table_put(dev, dev->cq_table.table, cq->cqn);
err_out: err_out:
mthca_free(&dev->cq_table.alloc, cq->cqn); mthca_free(&dev->cq_table.alloc, cq->cqn);
...@@ -806,6 +842,12 @@ void mthca_free_cq(struct mthca_dev *dev, ...@@ -806,6 +842,12 @@ void mthca_free_cq(struct mthca_dev *dev,
mthca_free_mr(dev, &cq->mr); mthca_free_mr(dev, &cq->mr);
mthca_free_cq_buf(dev, cq); mthca_free_cq_buf(dev, cq);
if (dev->hca_type == ARBEL_NATIVE) {
mthca_free_db(dev, MTHCA_DB_TYPE_CQ_ARM, cq->arm_db_index);
mthca_free_db(dev, MTHCA_DB_TYPE_CQ_SET_CI, cq->set_ci_db_index);
mthca_table_put(dev, dev->cq_table.table, cq->cqn);
}
mthca_free(&dev->cq_table.alloc, cq->cqn); mthca_free(&dev->cq_table.alloc, cq->cqn);
kfree(mailbox); kfree(mailbox);
} }
......
...@@ -143,6 +143,14 @@ struct mthca_cq { ...@@ -143,6 +143,14 @@ struct mthca_cq {
int cqn; int cqn;
int cons_index; int cons_index;
int is_direct; int is_direct;
/* Next fields are Arbel only */
int set_ci_db_index;
u32 *set_ci_db;
int arm_db_index;
u32 *arm_db;
int arm_sn;
union { union {
struct mthca_buf_list direct; struct mthca_buf_list direct;
struct mthca_buf_list *page_list; struct mthca_buf_list *page_list;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment