Re: [EXT] Re: [PATCH v2 rdma-next 1/2] RDMA/qedr: Add doorbell overflow recovery support

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, May 28, 2019 at 06:41:28PM +0000, Michal Kalderon wrote:
> > From: Jason Gunthorpe <jgg@xxxxxxxx>
> > Sent: Tuesday, May 28, 2019 7:16 PM
> > 
> > On Tue, May 28, 2019 at 02:24:00PM +0300, Michal Kalderon wrote:
> > 
> > > +static int qedr_init_user_db_rec(struct ib_udata *udata,
> > > +				 struct qedr_dev *dev, struct qedr_userq *q,
> > > +				 u64 db_rec_addr, int access, int dmasync) {
> > > +	/* Aborting for non doorbell userqueue (SRQ) */
> > > +	if (db_rec_addr == 0)
> > > +		return 0;
> > > +
> > > +	q->db_rec_addr = db_rec_addr;
> > > +	q->db_rec_umem = ib_umem_get(udata, q->db_rec_addr,
> > PAGE_SIZE,
> > > +				     access, dmasync);
> > > +
> > > +	if (IS_ERR(q->db_rec_umem)) {
> > > +		DP_ERR(dev,
> > > +		       "create user queue: failed db_rec ib_umem_get, error
> > was %ld, db_rec_addr was %llx\n",
> > > +		       PTR_ERR(q->db_rec_umem), db_rec_addr);
> > > +		return PTR_ERR(q->db_rec_umem);
> > > +	}
> > > +
> > > +	q->db_rec_page = sg_page(q->db_rec_umem->sg_head.sgl);
> > > +	q->db_rec_virt = kmap(q->db_rec_page);
> > 
> > Is this something new? You are much better to use user-triggered mmap to
> > get a shared page than to use long term kmap.
>
> This was the fix for previously using sg_virt which as you stated won't always work.
> Just to make sure I understand, by user-triggered mmap do you mean allocating the
> memory in kernel and passing the physical pointer to user to mmap it
> ?

Yes, if the ABI allows for it, this is a better choice for this kind
of long lived usage.

> > >  		cq->ibcq.cqe = chain_entries;
> > > +		cq->q.db_addr = (void __iomem *)(uintptr_t)ctx->dpi_addr +
> > > +			db_offset;
> > 
> > Seems like something has gone wrong here if you have to type __iomem like
> > this
> The dpi_addr is an io address to the doorbell-bar received from the qed module,
> the qed/qedr interface passes it as a u64 ( it is casted from u8 __iomem * to u64)
> so I need to cast it back.

Don't cast __iommem * to u8. Make a patch to fix it.

Jason



[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Photo]     [Yosemite News]     [Yosemite Photos]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux