diff options
Diffstat (limited to 'drivers/net/ethernet/intel/e1000e/netdev.c')
| -rw-r--r-- | drivers/net/ethernet/intel/e1000e/netdev.c | 27 | 
1 files changed, 15 insertions, 12 deletions
diff --git a/drivers/net/ethernet/intel/e1000e/netdev.c b/drivers/net/ethernet/intel/e1000e/netdev.c index db4ea58bac82..177c6da80c57 100644 --- a/drivers/net/ethernet/intel/e1000e/netdev.c +++ b/drivers/net/ethernet/intel/e1000e/netdev.c @@ -3280,10 +3280,10 @@ static void e1000_configure_rx(struct e1000_adapter *adapter)  		dev_info(&adapter->pdev->dev,  			 "Some CPU C-states have been disabled in order to enable jumbo frames\n"); -		pm_qos_update_request(&adapter->pm_qos_req, lat); +		cpu_latency_qos_update_request(&adapter->pm_qos_req, lat);  	} else { -		pm_qos_update_request(&adapter->pm_qos_req, -				      PM_QOS_DEFAULT_VALUE); +		cpu_latency_qos_update_request(&adapter->pm_qos_req, +					       PM_QOS_DEFAULT_VALUE);  	}  	/* Enable Receives */ @@ -3536,6 +3536,7 @@ s32 e1000e_get_base_timinca(struct e1000_adapter *adapter, u32 *timinca)  		break;  	case e1000_pch_cnp:  	case e1000_pch_tgp: +	case e1000_pch_adp:  		if (er32(TSYNCRXCTL) & E1000_TSYNCRXCTL_SYSCFI) {  			/* Stable 24MHz frequency */  			incperiod = INCPERIOD_24MHZ; @@ -3807,7 +3808,7 @@ static void e1000_flush_tx_ring(struct e1000_adapter *adapter)  	tdt = er32(TDT(0));  	BUG_ON(tdt != tx_ring->next_to_use);  	tx_desc =  E1000_TX_DESC(*tx_ring, tx_ring->next_to_use); -	tx_desc->buffer_addr = tx_ring->dma; +	tx_desc->buffer_addr = cpu_to_le64(tx_ring->dma);  	tx_desc->lower.data = cpu_to_le32(txd_lower | size);  	tx_desc->upper.data = 0; @@ -4049,6 +4050,7 @@ void e1000e_reset(struct e1000_adapter *adapter)  	case e1000_pch_cnp:  		/* fall-through */  	case e1000_pch_tgp: +	case e1000_pch_adp:  		fc->refresh_time = 0xFFFF;  		fc->pause_time = 0xFFFF; @@ -4636,8 +4638,7 @@ int e1000e_open(struct net_device *netdev)  		e1000_update_mng_vlan(adapter);  	/* DMA latency requirement to workaround jumbo issue */ -	pm_qos_add_request(&adapter->pm_qos_req, PM_QOS_CPU_DMA_LATENCY, -			   PM_QOS_DEFAULT_VALUE); +	cpu_latency_qos_add_request(&adapter->pm_qos_req, PM_QOS_DEFAULT_VALUE);  	/* before we allocate an interrupt, we must be ready to handle it.  	 * Setting DEBUG_SHIRQ in the kernel makes it fire an interrupt @@ -4679,7 +4680,7 @@ int e1000e_open(struct net_device *netdev)  	return 0;  err_req_irq: -	pm_qos_remove_request(&adapter->pm_qos_req); +	cpu_latency_qos_remove_request(&adapter->pm_qos_req);  	e1000e_release_hw_control(adapter);  	e1000_power_down_phy(adapter);  	e1000e_free_rx_resources(adapter->rx_ring); @@ -4743,7 +4744,7 @@ int e1000e_close(struct net_device *netdev)  	    !test_bit(__E1000_TESTING, &adapter->state))  		e1000e_release_hw_control(adapter); -	pm_qos_remove_request(&adapter->pm_qos_req); +	cpu_latency_qos_remove_request(&adapter->pm_qos_req);  	pm_runtime_put_sync(&pdev->dev); @@ -5462,10 +5463,7 @@ static int e1000_tso(struct e1000_ring *tx_ring, struct sk_buff *skb,  		cmd_length = E1000_TXD_CMD_IP;  		ipcse = skb_transport_offset(skb) - 1;  	} else if (skb_is_gso_v6(skb)) { -		ipv6_hdr(skb)->payload_len = 0; -		tcp_hdr(skb)->check = ~csum_ipv6_magic(&ipv6_hdr(skb)->saddr, -						       &ipv6_hdr(skb)->daddr, -						       0, IPPROTO_TCP, 0); +		tcp_v6_gso_csum_prep(skb);  		ipcse = 0;  	}  	ipcss = skb_network_offset(skb); @@ -7760,6 +7758,11 @@ static const struct pci_device_id e1000_pci_tbl[] = {  	{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_TGP_I219_LM14), board_pch_cnp },  	{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_TGP_I219_V14), board_pch_cnp },  	{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_TGP_I219_LM15), board_pch_cnp }, +	{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_TGP_I219_V15), board_pch_cnp }, +	{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_ADP_I219_LM16), board_pch_cnp }, +	{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_ADP_I219_V16), board_pch_cnp }, +	{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_ADP_I219_LM17), board_pch_cnp }, +	{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_ADP_I219_V17), board_pch_cnp },  	{ 0, 0, 0, 0, 0, 0, 0 }	/* terminate list */  };  |