diff options
Diffstat (limited to 'drivers/infiniband/hw/hfi1/pio.c')
| -rw-r--r-- | drivers/infiniband/hw/hfi1/pio.c | 23 | 
1 files changed, 3 insertions, 20 deletions
| diff --git a/drivers/infiniband/hw/hfi1/pio.c b/drivers/infiniband/hw/hfi1/pio.c index 7108a4b5e94c..4c1198bc5e70 100644 --- a/drivers/infiniband/hw/hfi1/pio.c +++ b/drivers/infiniband/hw/hfi1/pio.c @@ -703,7 +703,6 @@ struct send_context *sc_alloc(struct hfi1_devdata *dd, int type,  {  	struct send_context_info *sci;  	struct send_context *sc = NULL; -	int req_type = type;  	dma_addr_t dma;  	unsigned long flags;  	u64 reg; @@ -730,13 +729,6 @@ struct send_context *sc_alloc(struct hfi1_devdata *dd, int type,  		return NULL;  	} -	/* -	 * VNIC contexts are dynamically allocated. -	 * Hence, pick a user context for VNIC. -	 */ -	if (type == SC_VNIC) -		type = SC_USER; -  	spin_lock_irqsave(&dd->sc_lock, flags);  	ret = sc_hw_alloc(dd, type, &sw_index, &hw_context);  	if (ret) { @@ -746,15 +738,6 @@ struct send_context *sc_alloc(struct hfi1_devdata *dd, int type,  		return NULL;  	} -	/* -	 * VNIC contexts are used by kernel driver. -	 * Hence, mark them as kernel contexts. -	 */ -	if (req_type == SC_VNIC) { -		dd->send_contexts[sw_index].type = SC_KERNEL; -		type = SC_KERNEL; -	} -  	sci = &dd->send_contexts[sw_index];  	sci->sc = sc; @@ -1423,14 +1406,14 @@ retry:  			goto done;  		}  		/* copy from receiver cache line and recalculate */ -		sc->alloc_free = ACCESS_ONCE(sc->free); +		sc->alloc_free = READ_ONCE(sc->free);  		avail =  			(unsigned long)sc->credits -  			(sc->fill - sc->alloc_free);  		if (blocks > avail) {  			/* still no room, actively update */  			sc_release_update(sc); -			sc->alloc_free = ACCESS_ONCE(sc->free); +			sc->alloc_free = READ_ONCE(sc->free);  			trycount++;  			goto retry;  		} @@ -1667,7 +1650,7 @@ void sc_release_update(struct send_context *sc)  	/* call sent buffer callbacks */  	code = -1;				/* code not yet set */ -	head = ACCESS_ONCE(sc->sr_head);	/* snapshot the head */ +	head = READ_ONCE(sc->sr_head);	/* snapshot the head */  	tail = sc->sr_tail;  	while (head != tail) {  		pbuf = &sc->sr[tail].pbuf; | 

