diff options
| author | Takashi Iwai <tiwai@suse.de> | 2013-04-18 16:24:31 +0200 | 
|---|---|---|
| committer | Takashi Iwai <tiwai@suse.de> | 2013-04-18 16:24:31 +0200 | 
| commit | 8dd2b66d1a961231685a3bfe5937c85d846fbf5d (patch) | |
| tree | 8117553488bf4ef09b048a4b343cf37cc16bf46d /drivers/net/hyperv/netvsc.c | |
| parent | 126825e7ea271ae8e3172e10ca1fc22c908b5385 (diff) | |
| parent | 24568ea4bef5ab8106206eddf5512434421c00ed (diff) | |
| download | olio-linux-3.10-8dd2b66d1a961231685a3bfe5937c85d846fbf5d.tar.xz olio-linux-3.10-8dd2b66d1a961231685a3bfe5937c85d846fbf5d.zip  | |
Merge tag 'asoc-v3.10-2' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound into for-next
ASoC: More updates for v3.10
The main additional change here is Lars-Peter's DMA work plus the
platform conversions which have been tested - getting this in mainline
will make life easier for development after the merge window.  These
factor a large chunk of code out of the drivers for the platforms using
dmaengine, greatly simplifying development.
Diffstat (limited to 'drivers/net/hyperv/netvsc.c')
| -rw-r--r-- | drivers/net/hyperv/netvsc.c | 17 | 
1 files changed, 12 insertions, 5 deletions
diff --git a/drivers/net/hyperv/netvsc.c b/drivers/net/hyperv/netvsc.c index 1cd77483da5..f5f0f09e4cc 100644 --- a/drivers/net/hyperv/netvsc.c +++ b/drivers/net/hyperv/netvsc.c @@ -470,8 +470,10 @@ static void netvsc_send_completion(struct hv_device *device,  			packet->trans_id;  		/* Notify the layer above us */ -		nvsc_packet->completion.send.send_completion( -			nvsc_packet->completion.send.send_completion_ctx); +		if (nvsc_packet) +			nvsc_packet->completion.send.send_completion( +				nvsc_packet->completion.send. +				send_completion_ctx);  		num_outstanding_sends =  			atomic_dec_return(&net_device->num_outstanding_sends); @@ -498,6 +500,7 @@ int netvsc_send(struct hv_device *device,  	int ret = 0;  	struct nvsp_message sendMessage;  	struct net_device *ndev; +	u64 req_id;  	net_device = get_outbound_net_device(device);  	if (!net_device) @@ -518,20 +521,24 @@ int netvsc_send(struct hv_device *device,  		0xFFFFFFFF;  	sendMessage.msg.v1_msg.send_rndis_pkt.send_buf_section_size = 0; +	if (packet->completion.send.send_completion) +		req_id = (u64)packet; +	else +		req_id = 0; +  	if (packet->page_buf_cnt) {  		ret = vmbus_sendpacket_pagebuffer(device->channel,  						  packet->page_buf,  						  packet->page_buf_cnt,  						  &sendMessage,  						  sizeof(struct nvsp_message), -						  (unsigned long)packet); +						  req_id);  	} else {  		ret = vmbus_sendpacket(device->channel, &sendMessage,  				sizeof(struct nvsp_message), -				(unsigned long)packet, +				req_id,  				VM_PKT_DATA_INBAND,  				VMBUS_DATA_PACKET_FLAG_COMPLETION_REQUESTED); -  	}  	if (ret == 0) {  |