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]

 



> 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 ? 
thanks


> 
> >  		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. 

> 
> 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