You've already forked linux-apfs
mirror of
https://github.com/linux-apfs/linux-apfs.git
synced 2026-05-01 15:00:59 -07:00
amd-xgbe: Prepare for supporting PCI devices
Update the driver framework to separate out platform/ACPI specific code from general code during device initialization. This will allow for the introduction of PCI device support. Signed-off-by: Tom Lendacky <thomas.lendacky@amd.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
4b8acdf5fe
commit
bd8255d8ba
@@ -3,7 +3,8 @@ obj-$(CONFIG_AMD_XGBE) += amd-xgbe.o
|
||||
amd-xgbe-objs := xgbe-main.o xgbe-drv.o xgbe-dev.o \
|
||||
xgbe-desc.o xgbe-ethtool.o xgbe-mdio.o \
|
||||
xgbe-ptp.o \
|
||||
xgbe-phy-v1.o
|
||||
xgbe-phy-v1.o \
|
||||
xgbe-platform.o
|
||||
|
||||
amd-xgbe-$(CONFIG_AMD_XGBE_DCB) += xgbe-dcb.o
|
||||
amd-xgbe-$(CONFIG_DEBUG_FS) += xgbe-debugfs.o
|
||||
|
||||
@@ -2088,24 +2088,16 @@ static void xgbe_config_flow_control_threshold(struct xgbe_prv_data *pdata)
|
||||
|
||||
static unsigned int xgbe_get_tx_fifo_size(struct xgbe_prv_data *pdata)
|
||||
{
|
||||
unsigned int fifo_size;
|
||||
|
||||
/* Calculate the configured fifo size */
|
||||
fifo_size = 1 << (pdata->hw_feat.tx_fifo_size + 7);
|
||||
|
||||
/* The configured value may not be the actual amount of fifo RAM */
|
||||
return min_t(unsigned int, XGMAC_FIFO_TX_MAX, fifo_size);
|
||||
return min_t(unsigned int, pdata->tx_max_fifo_size,
|
||||
pdata->hw_feat.tx_fifo_size);
|
||||
}
|
||||
|
||||
static unsigned int xgbe_get_rx_fifo_size(struct xgbe_prv_data *pdata)
|
||||
{
|
||||
unsigned int fifo_size;
|
||||
|
||||
/* Calculate the configured fifo size */
|
||||
fifo_size = 1 << (pdata->hw_feat.rx_fifo_size + 7);
|
||||
|
||||
/* The configured value may not be the actual amount of fifo RAM */
|
||||
return min_t(unsigned int, XGMAC_FIFO_RX_MAX, fifo_size);
|
||||
return min_t(unsigned int, pdata->rx_max_fifo_size,
|
||||
pdata->hw_feat.rx_fifo_size);
|
||||
}
|
||||
|
||||
static void xgbe_calculate_equal_fifo(unsigned int fifo_size,
|
||||
|
||||
@@ -114,7 +114,6 @@
|
||||
* THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/spinlock.h>
|
||||
#include <linux/tcp.h>
|
||||
#include <linux/if_vlan.h>
|
||||
@@ -160,18 +159,8 @@ static int xgbe_alloc_channels(struct xgbe_prv_data *pdata)
|
||||
channel->dma_regs = pdata->xgmac_regs + DMA_CH_BASE +
|
||||
(DMA_CH_INC * i);
|
||||
|
||||
if (pdata->per_channel_irq) {
|
||||
/* Get the DMA interrupt (offset 1) */
|
||||
ret = platform_get_irq(pdata->pdev, i + 1);
|
||||
if (ret < 0) {
|
||||
netdev_err(pdata->netdev,
|
||||
"platform_get_irq %u failed\n",
|
||||
i + 1);
|
||||
goto err_irq;
|
||||
}
|
||||
|
||||
channel->dma_irq = ret;
|
||||
}
|
||||
if (pdata->per_channel_irq)
|
||||
channel->dma_irq = pdata->channel_irq[i];
|
||||
|
||||
if (i < pdata->tx_ring_count) {
|
||||
spin_lock_init(&tx_ring->lock);
|
||||
@@ -194,9 +183,6 @@ static int xgbe_alloc_channels(struct xgbe_prv_data *pdata)
|
||||
|
||||
return 0;
|
||||
|
||||
err_irq:
|
||||
kfree(rx_ring);
|
||||
|
||||
err_rx_ring:
|
||||
kfree(tx_ring);
|
||||
|
||||
@@ -590,6 +576,10 @@ void xgbe_get_all_hw_features(struct xgbe_prv_data *pdata)
|
||||
hw_feat->tx_ch_cnt++;
|
||||
hw_feat->tc_cnt++;
|
||||
|
||||
/* Translate the fifo sizes into actual numbers */
|
||||
hw_feat->rx_fifo_size = 1 << (hw_feat->rx_fifo_size + 7);
|
||||
hw_feat->tx_fifo_size = 1 << (hw_feat->tx_fifo_size + 7);
|
||||
|
||||
DBGPR("<--xgbe_get_all_hw_features\n");
|
||||
}
|
||||
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@@ -210,8 +210,6 @@
|
||||
#define XGMAC_DRIVER_CONTEXT 1
|
||||
#define XGMAC_IOCTL_CONTEXT 2
|
||||
|
||||
#define XGMAC_FIFO_RX_MAX 81920
|
||||
#define XGMAC_FIFO_TX_MAX 81920
|
||||
#define XGMAC_FIFO_MIN_ALLOC 2048
|
||||
#define XGMAC_FIFO_UNIT 256
|
||||
#define XGMAC_FIFO_ALIGN(_x) \
|
||||
@@ -805,14 +803,16 @@ struct xgbe_version_data {
|
||||
void (*init_function_ptrs_phy_impl)(struct xgbe_phy_if *);
|
||||
enum xgbe_xpcs_access xpcs_access;
|
||||
unsigned int mmc_64bit;
|
||||
unsigned int tx_max_fifo_size;
|
||||
unsigned int rx_max_fifo_size;
|
||||
};
|
||||
|
||||
struct xgbe_prv_data {
|
||||
struct net_device *netdev;
|
||||
struct platform_device *pdev;
|
||||
struct platform_device *platdev;
|
||||
struct acpi_device *adev;
|
||||
struct device *dev;
|
||||
struct platform_device *phy_pdev;
|
||||
struct platform_device *phy_platdev;
|
||||
struct device *phy_dev;
|
||||
|
||||
/* Version related data */
|
||||
@@ -845,6 +845,7 @@ struct xgbe_prv_data {
|
||||
|
||||
int dev_irq;
|
||||
unsigned int per_channel_irq;
|
||||
int channel_irq[XGBE_MAX_DMA_CHANNELS];
|
||||
|
||||
struct xgbe_hw_if hw_if;
|
||||
struct xgbe_phy_if phy_if;
|
||||
@@ -863,12 +864,16 @@ struct xgbe_prv_data {
|
||||
|
||||
/* Rings for Tx/Rx on a DMA channel */
|
||||
struct xgbe_channel *channel;
|
||||
unsigned int tx_max_channel_count;
|
||||
unsigned int rx_max_channel_count;
|
||||
unsigned int channel_count;
|
||||
unsigned int tx_ring_count;
|
||||
unsigned int tx_desc_count;
|
||||
unsigned int rx_ring_count;
|
||||
unsigned int rx_desc_count;
|
||||
|
||||
unsigned int tx_max_q_count;
|
||||
unsigned int rx_max_q_count;
|
||||
unsigned int tx_q_count;
|
||||
unsigned int rx_q_count;
|
||||
|
||||
@@ -880,11 +885,13 @@ struct xgbe_prv_data {
|
||||
unsigned int tx_threshold;
|
||||
unsigned int tx_pbl;
|
||||
unsigned int tx_osp_mode;
|
||||
unsigned int tx_max_fifo_size;
|
||||
|
||||
/* Rx settings */
|
||||
unsigned int rx_sf_mode;
|
||||
unsigned int rx_threshold;
|
||||
unsigned int rx_pbl;
|
||||
unsigned int rx_max_fifo_size;
|
||||
|
||||
/* Tx coalescing settings */
|
||||
unsigned int tx_usecs;
|
||||
@@ -1005,6 +1012,14 @@ struct xgbe_prv_data {
|
||||
};
|
||||
|
||||
/* Function prototypes*/
|
||||
struct xgbe_prv_data *xgbe_alloc_pdata(struct device *);
|
||||
void xgbe_free_pdata(struct xgbe_prv_data *);
|
||||
void xgbe_set_counts(struct xgbe_prv_data *);
|
||||
int xgbe_config_netdev(struct xgbe_prv_data *);
|
||||
void xgbe_deconfig_netdev(struct xgbe_prv_data *);
|
||||
|
||||
int xgbe_platform_init(void);
|
||||
void xgbe_platform_exit(void);
|
||||
|
||||
void xgbe_init_function_ptrs_dev(struct xgbe_hw_if *);
|
||||
void xgbe_init_function_ptrs_phy(struct xgbe_phy_if *);
|
||||
|
||||
Reference in New Issue
Block a user