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 \
|
amd-xgbe-objs := xgbe-main.o xgbe-drv.o xgbe-dev.o \
|
||||||
xgbe-desc.o xgbe-ethtool.o xgbe-mdio.o \
|
xgbe-desc.o xgbe-ethtool.o xgbe-mdio.o \
|
||||||
xgbe-ptp.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_AMD_XGBE_DCB) += xgbe-dcb.o
|
||||||
amd-xgbe-$(CONFIG_DEBUG_FS) += xgbe-debugfs.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)
|
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 */
|
/* 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)
|
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 */
|
/* 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,
|
static void xgbe_calculate_equal_fifo(unsigned int fifo_size,
|
||||||
|
|||||||
@@ -114,7 +114,6 @@
|
|||||||
* THE POSSIBILITY OF SUCH DAMAGE.
|
* THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/platform_device.h>
|
|
||||||
#include <linux/spinlock.h>
|
#include <linux/spinlock.h>
|
||||||
#include <linux/tcp.h>
|
#include <linux/tcp.h>
|
||||||
#include <linux/if_vlan.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 +
|
channel->dma_regs = pdata->xgmac_regs + DMA_CH_BASE +
|
||||||
(DMA_CH_INC * i);
|
(DMA_CH_INC * i);
|
||||||
|
|
||||||
if (pdata->per_channel_irq) {
|
if (pdata->per_channel_irq)
|
||||||
/* Get the DMA interrupt (offset 1) */
|
channel->dma_irq = pdata->channel_irq[i];
|
||||||
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 (i < pdata->tx_ring_count) {
|
if (i < pdata->tx_ring_count) {
|
||||||
spin_lock_init(&tx_ring->lock);
|
spin_lock_init(&tx_ring->lock);
|
||||||
@@ -194,9 +183,6 @@ static int xgbe_alloc_channels(struct xgbe_prv_data *pdata)
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
err_irq:
|
|
||||||
kfree(rx_ring);
|
|
||||||
|
|
||||||
err_rx_ring:
|
err_rx_ring:
|
||||||
kfree(tx_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->tx_ch_cnt++;
|
||||||
hw_feat->tc_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");
|
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_DRIVER_CONTEXT 1
|
||||||
#define XGMAC_IOCTL_CONTEXT 2
|
#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_MIN_ALLOC 2048
|
||||||
#define XGMAC_FIFO_UNIT 256
|
#define XGMAC_FIFO_UNIT 256
|
||||||
#define XGMAC_FIFO_ALIGN(_x) \
|
#define XGMAC_FIFO_ALIGN(_x) \
|
||||||
@@ -805,14 +803,16 @@ struct xgbe_version_data {
|
|||||||
void (*init_function_ptrs_phy_impl)(struct xgbe_phy_if *);
|
void (*init_function_ptrs_phy_impl)(struct xgbe_phy_if *);
|
||||||
enum xgbe_xpcs_access xpcs_access;
|
enum xgbe_xpcs_access xpcs_access;
|
||||||
unsigned int mmc_64bit;
|
unsigned int mmc_64bit;
|
||||||
|
unsigned int tx_max_fifo_size;
|
||||||
|
unsigned int rx_max_fifo_size;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct xgbe_prv_data {
|
struct xgbe_prv_data {
|
||||||
struct net_device *netdev;
|
struct net_device *netdev;
|
||||||
struct platform_device *pdev;
|
struct platform_device *platdev;
|
||||||
struct acpi_device *adev;
|
struct acpi_device *adev;
|
||||||
struct device *dev;
|
struct device *dev;
|
||||||
struct platform_device *phy_pdev;
|
struct platform_device *phy_platdev;
|
||||||
struct device *phy_dev;
|
struct device *phy_dev;
|
||||||
|
|
||||||
/* Version related data */
|
/* Version related data */
|
||||||
@@ -845,6 +845,7 @@ struct xgbe_prv_data {
|
|||||||
|
|
||||||
int dev_irq;
|
int dev_irq;
|
||||||
unsigned int per_channel_irq;
|
unsigned int per_channel_irq;
|
||||||
|
int channel_irq[XGBE_MAX_DMA_CHANNELS];
|
||||||
|
|
||||||
struct xgbe_hw_if hw_if;
|
struct xgbe_hw_if hw_if;
|
||||||
struct xgbe_phy_if phy_if;
|
struct xgbe_phy_if phy_if;
|
||||||
@@ -863,12 +864,16 @@ struct xgbe_prv_data {
|
|||||||
|
|
||||||
/* Rings for Tx/Rx on a DMA channel */
|
/* Rings for Tx/Rx on a DMA channel */
|
||||||
struct xgbe_channel *channel;
|
struct xgbe_channel *channel;
|
||||||
|
unsigned int tx_max_channel_count;
|
||||||
|
unsigned int rx_max_channel_count;
|
||||||
unsigned int channel_count;
|
unsigned int channel_count;
|
||||||
unsigned int tx_ring_count;
|
unsigned int tx_ring_count;
|
||||||
unsigned int tx_desc_count;
|
unsigned int tx_desc_count;
|
||||||
unsigned int rx_ring_count;
|
unsigned int rx_ring_count;
|
||||||
unsigned int rx_desc_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 tx_q_count;
|
||||||
unsigned int rx_q_count;
|
unsigned int rx_q_count;
|
||||||
|
|
||||||
@@ -880,11 +885,13 @@ struct xgbe_prv_data {
|
|||||||
unsigned int tx_threshold;
|
unsigned int tx_threshold;
|
||||||
unsigned int tx_pbl;
|
unsigned int tx_pbl;
|
||||||
unsigned int tx_osp_mode;
|
unsigned int tx_osp_mode;
|
||||||
|
unsigned int tx_max_fifo_size;
|
||||||
|
|
||||||
/* Rx settings */
|
/* Rx settings */
|
||||||
unsigned int rx_sf_mode;
|
unsigned int rx_sf_mode;
|
||||||
unsigned int rx_threshold;
|
unsigned int rx_threshold;
|
||||||
unsigned int rx_pbl;
|
unsigned int rx_pbl;
|
||||||
|
unsigned int rx_max_fifo_size;
|
||||||
|
|
||||||
/* Tx coalescing settings */
|
/* Tx coalescing settings */
|
||||||
unsigned int tx_usecs;
|
unsigned int tx_usecs;
|
||||||
@@ -1005,6 +1012,14 @@ struct xgbe_prv_data {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* Function prototypes*/
|
/* 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_dev(struct xgbe_hw_if *);
|
||||||
void xgbe_init_function_ptrs_phy(struct xgbe_phy_if *);
|
void xgbe_init_function_ptrs_phy(struct xgbe_phy_if *);
|
||||||
|
|||||||
Reference in New Issue
Block a user