mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-02 12:06:50 +00:00
kernel: bump 5.15 to 5.15.47
Deleted (upstreamed): generic/backport-5.15/702-v5.19-32-net-ethernet-mtk_eth_soc-out-of-bounds-read-in-mtk_h.patch [01] [01] https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.47&id=b24ca1cf846273361d5bd73a35de95a486a54b6d Signed-off-by: Rui Salvaterra <rsalvaterra@gmail.com> [Removed 702-v5.19-32-net-ethernet-mtk_eth_soc-out-of-bounds-read-in-mtk_h.patch] Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
This commit is contained in:
parent
251a382c28
commit
b55efebb1f
@ -1,2 +1,2 @@
|
|||||||
LINUX_VERSION-5.15 = .46
|
LINUX_VERSION-5.15 = .47
|
||||||
LINUX_KERNEL_HASH-5.15.46 = eb455746779bb79533e6c1afcd0d5e8ad2295898b786f47d718f087a3d07376b
|
LINUX_KERNEL_HASH-5.15.47 = 8b235e3aadeb5f8d5b3623b35a99179498e2f3d7f4e9457e46bd461f8496009c
|
||||||
|
@ -706,7 +706,7 @@
|
|||||||
EXPORT_SYMBOL(xfrm_parse_spi);
|
EXPORT_SYMBOL(xfrm_parse_spi);
|
||||||
--- a/net/ipv4/tcp_input.c
|
--- a/net/ipv4/tcp_input.c
|
||||||
+++ b/net/ipv4/tcp_input.c
|
+++ b/net/ipv4/tcp_input.c
|
||||||
@@ -4130,14 +4130,16 @@ static bool tcp_parse_aligned_timestamp(
|
@@ -4133,14 +4133,16 @@ static bool tcp_parse_aligned_timestamp(
|
||||||
{
|
{
|
||||||
const __be32 *ptr = (const __be32 *)(th + 1);
|
const __be32 *ptr = (const __be32 *)(th + 1);
|
||||||
|
|
||||||
|
@ -244,7 +244,7 @@ bcm2835-mmc: uninitialized_var is no more
|
|||||||
static inline int mmc_blk_part_switch(struct mmc_card *card,
|
static inline int mmc_blk_part_switch(struct mmc_card *card,
|
||||||
unsigned int part_type);
|
unsigned int part_type);
|
||||||
static void mmc_blk_rw_rq_prep(struct mmc_queue_req *mqrq,
|
static void mmc_blk_rw_rq_prep(struct mmc_queue_req *mqrq,
|
||||||
@@ -2924,6 +2931,8 @@ static int mmc_blk_probe(struct mmc_card
|
@@ -2923,6 +2930,8 @@ static int mmc_blk_probe(struct mmc_card
|
||||||
{
|
{
|
||||||
struct mmc_blk_data *md;
|
struct mmc_blk_data *md;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
@ -253,7 +253,7 @@ bcm2835-mmc: uninitialized_var is no more
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Check that the card supports the command class(es) we need.
|
* Check that the card supports the command class(es) we need.
|
||||||
@@ -2931,7 +2940,16 @@ static int mmc_blk_probe(struct mmc_card
|
@@ -2930,7 +2939,16 @@ static int mmc_blk_probe(struct mmc_card
|
||||||
if (!(card->csd.cmdclass & CCC_BLOCK_READ))
|
if (!(card->csd.cmdclass & CCC_BLOCK_READ))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
@ -271,7 +271,7 @@ bcm2835-mmc: uninitialized_var is no more
|
|||||||
|
|
||||||
card->complete_wq = alloc_workqueue("mmc_complete",
|
card->complete_wq = alloc_workqueue("mmc_complete",
|
||||||
WQ_MEM_RECLAIM | WQ_HIGHPRI, 0);
|
WQ_MEM_RECLAIM | WQ_HIGHPRI, 0);
|
||||||
@@ -2946,6 +2964,17 @@ static int mmc_blk_probe(struct mmc_card
|
@@ -2945,6 +2963,17 @@ static int mmc_blk_probe(struct mmc_card
|
||||||
goto out_free;
|
goto out_free;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ Signed-off-by: Maxime Ripard <maxime@cerno.tech>
|
|||||||
|
|
||||||
--- a/drivers/gpu/drm/drm_atomic_helper.c
|
--- a/drivers/gpu/drm/drm_atomic_helper.c
|
||||||
+++ b/drivers/gpu/drm/drm_atomic_helper.c
|
+++ b/drivers/gpu/drm/drm_atomic_helper.c
|
||||||
@@ -1488,13 +1488,6 @@ drm_atomic_helper_wait_for_vblanks(struc
|
@@ -1498,13 +1498,6 @@ drm_atomic_helper_wait_for_vblanks(struc
|
||||||
int i, ret;
|
int i, ret;
|
||||||
unsigned int crtc_mask = 0;
|
unsigned int crtc_mask = 0;
|
||||||
|
|
||||||
@ -73,7 +73,7 @@ Signed-off-by: Maxime Ripard <maxime@cerno.tech>
|
|||||||
for_each_oldnew_crtc_in_state(old_state, crtc, old_crtc_state, new_crtc_state, i) {
|
for_each_oldnew_crtc_in_state(old_state, crtc, old_crtc_state, new_crtc_state, i) {
|
||||||
if (!new_crtc_state->active)
|
if (!new_crtc_state->active)
|
||||||
continue;
|
continue;
|
||||||
@@ -2122,12 +2115,6 @@ int drm_atomic_helper_setup_commit(struc
|
@@ -2132,12 +2125,6 @@ int drm_atomic_helper_setup_commit(struc
|
||||||
complete_all(&commit->flip_done);
|
complete_all(&commit->flip_done);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -23,7 +23,7 @@ Signed-off-by: Jonathan Bell <jonathan@raspberrypi.com>
|
|||||||
|
|
||||||
--- a/drivers/mmc/core/block.c
|
--- a/drivers/mmc/core/block.c
|
||||||
+++ b/drivers/mmc/core/block.c
|
+++ b/drivers/mmc/core/block.c
|
||||||
@@ -1871,7 +1871,11 @@ static void mmc_blk_mq_rw_recovery(struc
|
@@ -1870,7 +1870,11 @@ static void mmc_blk_mq_rw_recovery(struc
|
||||||
}
|
}
|
||||||
|
|
||||||
/* FIXME: Missing single sector read for large sector size */
|
/* FIXME: Missing single sector read for large sector size */
|
||||||
|
@ -49,7 +49,7 @@ Signed-off-by: Rafał Miłecki <zajec5@gmail.com>
|
|||||||
return UBI_IO_BAD_HDR_EBADMSG;
|
return UBI_IO_BAD_HDR_EBADMSG;
|
||||||
--- a/drivers/mtd/ubi/ubi.h
|
--- a/drivers/mtd/ubi/ubi.h
|
||||||
+++ b/drivers/mtd/ubi/ubi.h
|
+++ b/drivers/mtd/ubi/ubi.h
|
||||||
@@ -822,6 +822,7 @@ extern struct mutex ubi_devices_mutex;
|
@@ -820,6 +820,7 @@ extern struct mutex ubi_devices_mutex;
|
||||||
extern struct blocking_notifier_head ubi_notifiers;
|
extern struct blocking_notifier_head ubi_notifiers;
|
||||||
|
|
||||||
/* attach.c */
|
/* attach.c */
|
||||||
|
@ -41,7 +41,7 @@ Link: https://lore.kernel.org/linux-mtd/20220529110714.189732-1-csharper2005@gma
|
|||||||
+ number and location of bad blocks on NAND.
|
+ number and location of bad blocks on NAND.
|
||||||
--- a/drivers/mtd/parsers/Makefile
|
--- a/drivers/mtd/parsers/Makefile
|
||||||
+++ b/drivers/mtd/parsers/Makefile
|
+++ b/drivers/mtd/parsers/Makefile
|
||||||
@@ -10,6 +10,7 @@ ofpart-$(CONFIG_MTD_OF_PARTS_LINKSYS_NS)+= ofpart_linksys_ns.o
|
@@ -10,6 +10,7 @@ ofpart-$(CONFIG_MTD_OF_PARTS_LINKSYS_NS)
|
||||||
obj-$(CONFIG_MTD_PARSER_IMAGETAG) += parser_imagetag.o
|
obj-$(CONFIG_MTD_PARSER_IMAGETAG) += parser_imagetag.o
|
||||||
obj-$(CONFIG_MTD_AFS_PARTS) += afs.o
|
obj-$(CONFIG_MTD_AFS_PARTS) += afs.o
|
||||||
obj-$(CONFIG_MTD_PARSER_TRX) += parser_trx.o
|
obj-$(CONFIG_MTD_PARSER_TRX) += parser_trx.o
|
||||||
|
@ -196,7 +196,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
ring->dma_size * sizeof(*ring->dma),
|
ring->dma_size * sizeof(*ring->dma),
|
||||||
ring->dma,
|
ring->dma,
|
||||||
ring->phys);
|
ring->phys);
|
||||||
@@ -2141,7 +2142,7 @@ static void mtk_dma_free(struct mtk_eth
|
@@ -2144,7 +2145,7 @@ static void mtk_dma_free(struct mtk_eth
|
||||||
if (eth->netdev[i])
|
if (eth->netdev[i])
|
||||||
netdev_reset_queue(eth->netdev[i]);
|
netdev_reset_queue(eth->netdev[i]);
|
||||||
if (eth->scratch_ring) {
|
if (eth->scratch_ring) {
|
||||||
@ -205,7 +205,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
MTK_DMA_SIZE * sizeof(struct mtk_tx_dma),
|
MTK_DMA_SIZE * sizeof(struct mtk_tx_dma),
|
||||||
eth->scratch_ring,
|
eth->scratch_ring,
|
||||||
eth->phy_scratch_ring);
|
eth->phy_scratch_ring);
|
||||||
@@ -2491,6 +2492,8 @@ static void mtk_dim_tx(struct work_struc
|
@@ -2494,6 +2495,8 @@ static void mtk_dim_tx(struct work_struc
|
||||||
|
|
||||||
static int mtk_hw_init(struct mtk_eth *eth)
|
static int mtk_hw_init(struct mtk_eth *eth)
|
||||||
{
|
{
|
||||||
@ -214,7 +214,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
int i, val, ret;
|
int i, val, ret;
|
||||||
|
|
||||||
if (test_and_set_bit(MTK_HW_INIT, ð->state))
|
if (test_and_set_bit(MTK_HW_INIT, ð->state))
|
||||||
@@ -2503,6 +2506,10 @@ static int mtk_hw_init(struct mtk_eth *e
|
@@ -2506,6 +2509,10 @@ static int mtk_hw_init(struct mtk_eth *e
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err_disable_pm;
|
goto err_disable_pm;
|
||||||
|
|
||||||
@ -225,7 +225,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
if (MTK_HAS_CAPS(eth->soc->caps, MTK_SOC_MT7628)) {
|
if (MTK_HAS_CAPS(eth->soc->caps, MTK_SOC_MT7628)) {
|
||||||
ret = device_reset(eth->dev);
|
ret = device_reset(eth->dev);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
@@ -3056,6 +3063,35 @@ free_netdev:
|
@@ -3059,6 +3066,35 @@ free_netdev:
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -261,7 +261,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
static int mtk_probe(struct platform_device *pdev)
|
static int mtk_probe(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
struct device_node *mac_np;
|
struct device_node *mac_np;
|
||||||
@@ -3069,6 +3105,7 @@ static int mtk_probe(struct platform_dev
|
@@ -3072,6 +3108,7 @@ static int mtk_probe(struct platform_dev
|
||||||
eth->soc = of_device_get_match_data(&pdev->dev);
|
eth->soc = of_device_get_match_data(&pdev->dev);
|
||||||
|
|
||||||
eth->dev = &pdev->dev;
|
eth->dev = &pdev->dev;
|
||||||
@ -269,7 +269,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
eth->base = devm_platform_ioremap_resource(pdev, 0);
|
eth->base = devm_platform_ioremap_resource(pdev, 0);
|
||||||
if (IS_ERR(eth->base))
|
if (IS_ERR(eth->base))
|
||||||
return PTR_ERR(eth->base);
|
return PTR_ERR(eth->base);
|
||||||
@@ -3117,6 +3154,16 @@ static int mtk_probe(struct platform_dev
|
@@ -3120,6 +3157,16 @@ static int mtk_probe(struct platform_dev
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,7 +56,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
|
|
||||||
static int mtk_msg_level = -1;
|
static int mtk_msg_level = -1;
|
||||||
module_param_named(msg_level, mtk_msg_level, int, 0);
|
module_param_named(msg_level, mtk_msg_level, int, 0);
|
||||||
@@ -3186,6 +3187,22 @@ static int mtk_probe(struct platform_dev
|
@@ -3189,6 +3190,22 @@ static int mtk_probe(struct platform_dev
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,7 +10,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
|
|
||||||
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
||||||
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
||||||
@@ -2312,7 +2312,7 @@ static int mtk_open(struct net_device *d
|
@@ -2315,7 +2315,7 @@ static int mtk_open(struct net_device *d
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
@ -19,7 +19,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
gdm_config = MTK_GDMA_TO_PPE;
|
gdm_config = MTK_GDMA_TO_PPE;
|
||||||
|
|
||||||
mtk_gdm_config(eth, gdm_config);
|
mtk_gdm_config(eth, gdm_config);
|
||||||
@@ -2386,7 +2386,7 @@ static int mtk_stop(struct net_device *d
|
@@ -2389,7 +2389,7 @@ static int mtk_stop(struct net_device *d
|
||||||
mtk_dma_free(eth);
|
mtk_dma_free(eth);
|
||||||
|
|
||||||
if (eth->soc->offload_version)
|
if (eth->soc->offload_version)
|
||||||
@ -28,7 +28,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -3278,10 +3278,11 @@ static int mtk_probe(struct platform_dev
|
@@ -3281,10 +3281,11 @@ static int mtk_probe(struct platform_dev
|
||||||
}
|
}
|
||||||
|
|
||||||
if (eth->soc->offload_version) {
|
if (eth->soc->offload_version) {
|
||||||
|
@ -54,7 +54,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
if (netdev->features & NETIF_F_HW_VLAN_CTAG_RX &&
|
if (netdev->features & NETIF_F_HW_VLAN_CTAG_RX &&
|
||||||
(trxd.rxd2 & RX_DMA_VTAG))
|
(trxd.rxd2 & RX_DMA_VTAG))
|
||||||
__vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q),
|
__vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q),
|
||||||
@@ -3278,7 +3284,7 @@ static int mtk_probe(struct platform_dev
|
@@ -3281,7 +3287,7 @@ static int mtk_probe(struct platform_dev
|
||||||
}
|
}
|
||||||
|
|
||||||
if (eth->soc->offload_version) {
|
if (eth->soc->offload_version) {
|
||||||
|
@ -24,7 +24,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
mediatek,hifsys = <&hifsys>;
|
mediatek,hifsys = <&hifsys>;
|
||||||
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
||||||
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
||||||
@@ -3165,7 +3165,7 @@ static int mtk_probe(struct platform_dev
|
@@ -3168,7 +3168,7 @@ static int mtk_probe(struct platform_dev
|
||||||
struct regmap *cci;
|
struct regmap *cci;
|
||||||
|
|
||||||
cci = syscon_regmap_lookup_by_phandle(pdev->dev.of_node,
|
cci = syscon_regmap_lookup_by_phandle(pdev->dev.of_node,
|
||||||
|
@ -65,7 +65,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
}
|
}
|
||||||
|
|
||||||
mtk_w32(eth, eth->phy_scratch_ring, MTK_QDMA_FQ_HEAD);
|
mtk_w32(eth, eth->phy_scratch_ring, MTK_QDMA_FQ_HEAD);
|
||||||
@@ -2149,6 +2152,7 @@ static int mtk_dma_init(struct mtk_eth *
|
@@ -2152,6 +2155,7 @@ static int mtk_dma_init(struct mtk_eth *
|
||||||
|
|
||||||
static void mtk_dma_free(struct mtk_eth *eth)
|
static void mtk_dma_free(struct mtk_eth *eth)
|
||||||
{
|
{
|
||||||
@ -73,7 +73,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < MTK_MAC_COUNT; i++)
|
for (i = 0; i < MTK_MAC_COUNT; i++)
|
||||||
@@ -2156,9 +2160,8 @@ static void mtk_dma_free(struct mtk_eth
|
@@ -2159,9 +2163,8 @@ static void mtk_dma_free(struct mtk_eth
|
||||||
netdev_reset_queue(eth->netdev[i]);
|
netdev_reset_queue(eth->netdev[i]);
|
||||||
if (eth->scratch_ring) {
|
if (eth->scratch_ring) {
|
||||||
dma_free_coherent(eth->dma_dev,
|
dma_free_coherent(eth->dma_dev,
|
||||||
@ -85,7 +85,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
eth->scratch_ring = NULL;
|
eth->scratch_ring = NULL;
|
||||||
eth->phy_scratch_ring = 0;
|
eth->phy_scratch_ring = 0;
|
||||||
}
|
}
|
||||||
@@ -3368,6 +3371,9 @@ static const struct mtk_soc_data mt2701_
|
@@ -3371,6 +3374,9 @@ static const struct mtk_soc_data mt2701_
|
||||||
.hw_features = MTK_HW_FEATURES,
|
.hw_features = MTK_HW_FEATURES,
|
||||||
.required_clks = MT7623_CLKS_BITMAP,
|
.required_clks = MT7623_CLKS_BITMAP,
|
||||||
.required_pctl = true,
|
.required_pctl = true,
|
||||||
@ -95,7 +95,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
};
|
};
|
||||||
|
|
||||||
static const struct mtk_soc_data mt7621_data = {
|
static const struct mtk_soc_data mt7621_data = {
|
||||||
@@ -3376,6 +3382,9 @@ static const struct mtk_soc_data mt7621_
|
@@ -3379,6 +3385,9 @@ static const struct mtk_soc_data mt7621_
|
||||||
.required_clks = MT7621_CLKS_BITMAP,
|
.required_clks = MT7621_CLKS_BITMAP,
|
||||||
.required_pctl = false,
|
.required_pctl = false,
|
||||||
.offload_version = 2,
|
.offload_version = 2,
|
||||||
@ -105,7 +105,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
};
|
};
|
||||||
|
|
||||||
static const struct mtk_soc_data mt7622_data = {
|
static const struct mtk_soc_data mt7622_data = {
|
||||||
@@ -3385,6 +3394,9 @@ static const struct mtk_soc_data mt7622_
|
@@ -3388,6 +3397,9 @@ static const struct mtk_soc_data mt7622_
|
||||||
.required_clks = MT7622_CLKS_BITMAP,
|
.required_clks = MT7622_CLKS_BITMAP,
|
||||||
.required_pctl = false,
|
.required_pctl = false,
|
||||||
.offload_version = 2,
|
.offload_version = 2,
|
||||||
@ -115,7 +115,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
};
|
};
|
||||||
|
|
||||||
static const struct mtk_soc_data mt7623_data = {
|
static const struct mtk_soc_data mt7623_data = {
|
||||||
@@ -3393,6 +3405,9 @@ static const struct mtk_soc_data mt7623_
|
@@ -3396,6 +3408,9 @@ static const struct mtk_soc_data mt7623_
|
||||||
.required_clks = MT7623_CLKS_BITMAP,
|
.required_clks = MT7623_CLKS_BITMAP,
|
||||||
.required_pctl = true,
|
.required_pctl = true,
|
||||||
.offload_version = 2,
|
.offload_version = 2,
|
||||||
@ -125,7 +125,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
};
|
};
|
||||||
|
|
||||||
static const struct mtk_soc_data mt7629_data = {
|
static const struct mtk_soc_data mt7629_data = {
|
||||||
@@ -3401,6 +3416,9 @@ static const struct mtk_soc_data mt7629_
|
@@ -3404,6 +3419,9 @@ static const struct mtk_soc_data mt7629_
|
||||||
.hw_features = MTK_HW_FEATURES,
|
.hw_features = MTK_HW_FEATURES,
|
||||||
.required_clks = MT7629_CLKS_BITMAP,
|
.required_clks = MT7629_CLKS_BITMAP,
|
||||||
.required_pctl = false,
|
.required_pctl = false,
|
||||||
@ -135,7 +135,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
};
|
};
|
||||||
|
|
||||||
static const struct mtk_soc_data rt5350_data = {
|
static const struct mtk_soc_data rt5350_data = {
|
||||||
@@ -3408,6 +3426,9 @@ static const struct mtk_soc_data rt5350_
|
@@ -3411,6 +3429,9 @@ static const struct mtk_soc_data rt5350_
|
||||||
.hw_features = MTK_HW_FEATURES_MT7628,
|
.hw_features = MTK_HW_FEATURES_MT7628,
|
||||||
.required_clks = MT7628_CLKS_BITMAP,
|
.required_clks = MT7628_CLKS_BITMAP,
|
||||||
.required_pctl = false,
|
.required_pctl = false,
|
||||||
|
@ -34,7 +34,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
ring->dma = NULL;
|
ring->dma = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -3383,6 +3382,7 @@ static const struct mtk_soc_data mt2701_
|
@@ -3386,6 +3385,7 @@ static const struct mtk_soc_data mt2701_
|
||||||
.required_pctl = true,
|
.required_pctl = true,
|
||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
@ -42,7 +42,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -3394,6 +3394,7 @@ static const struct mtk_soc_data mt7621_
|
@@ -3397,6 +3397,7 @@ static const struct mtk_soc_data mt7621_
|
||||||
.offload_version = 2,
|
.offload_version = 2,
|
||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
@ -50,7 +50,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -3406,6 +3407,7 @@ static const struct mtk_soc_data mt7622_
|
@@ -3409,6 +3410,7 @@ static const struct mtk_soc_data mt7622_
|
||||||
.offload_version = 2,
|
.offload_version = 2,
|
||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
@ -58,7 +58,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -3417,6 +3419,7 @@ static const struct mtk_soc_data mt7623_
|
@@ -3420,6 +3422,7 @@ static const struct mtk_soc_data mt7623_
|
||||||
.offload_version = 2,
|
.offload_version = 2,
|
||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
@ -66,7 +66,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -3428,6 +3431,7 @@ static const struct mtk_soc_data mt7629_
|
@@ -3431,6 +3434,7 @@ static const struct mtk_soc_data mt7629_
|
||||||
.required_pctl = false,
|
.required_pctl = false,
|
||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
@ -74,7 +74,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -3438,6 +3442,7 @@ static const struct mtk_soc_data rt5350_
|
@@ -3441,6 +3445,7 @@ static const struct mtk_soc_data rt5350_
|
||||||
.required_pctl = false,
|
.required_pctl = false,
|
||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
|
@ -345,7 +345,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -2105,9 +2164,9 @@ static int mtk_dma_busy_wait(struct mtk_
|
@@ -2108,9 +2167,9 @@ static int mtk_dma_busy_wait(struct mtk_
|
||||||
u32 val;
|
u32 val;
|
||||||
|
|
||||||
if (MTK_HAS_CAPS(eth->soc->caps, MTK_QDMA))
|
if (MTK_HAS_CAPS(eth->soc->caps, MTK_QDMA))
|
||||||
@ -357,7 +357,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
|
|
||||||
ret = readx_poll_timeout_atomic(__raw_readl, eth->base + reg, val,
|
ret = readx_poll_timeout_atomic(__raw_readl, eth->base + reg, val,
|
||||||
!(val & (MTK_RX_DMA_BUSY | MTK_TX_DMA_BUSY)),
|
!(val & (MTK_RX_DMA_BUSY | MTK_TX_DMA_BUSY)),
|
||||||
@@ -2165,8 +2224,8 @@ static int mtk_dma_init(struct mtk_eth *
|
@@ -2168,8 +2227,8 @@ static int mtk_dma_init(struct mtk_eth *
|
||||||
* automatically
|
* automatically
|
||||||
*/
|
*/
|
||||||
mtk_w32(eth, FC_THRES_DROP_MODE | FC_THRES_DROP_EN |
|
mtk_w32(eth, FC_THRES_DROP_MODE | FC_THRES_DROP_EN |
|
||||||
@ -368,7 +368,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@@ -2240,13 +2299,14 @@ static irqreturn_t mtk_handle_irq_tx(int
|
@@ -2243,13 +2302,14 @@ static irqreturn_t mtk_handle_irq_tx(int
|
||||||
static irqreturn_t mtk_handle_irq(int irq, void *_eth)
|
static irqreturn_t mtk_handle_irq(int irq, void *_eth)
|
||||||
{
|
{
|
||||||
struct mtk_eth *eth = _eth;
|
struct mtk_eth *eth = _eth;
|
||||||
@ -387,7 +387,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
mtk_handle_irq_tx(irq, _eth);
|
mtk_handle_irq_tx(irq, _eth);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2270,6 +2330,7 @@ static void mtk_poll_controller(struct n
|
@@ -2273,6 +2333,7 @@ static void mtk_poll_controller(struct n
|
||||||
static int mtk_start_dma(struct mtk_eth *eth)
|
static int mtk_start_dma(struct mtk_eth *eth)
|
||||||
{
|
{
|
||||||
u32 rx_2b_offset = (NET_IP_ALIGN == 2) ? MTK_RX_2B_OFFSET : 0;
|
u32 rx_2b_offset = (NET_IP_ALIGN == 2) ? MTK_RX_2B_OFFSET : 0;
|
||||||
@ -395,7 +395,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
int err;
|
int err;
|
||||||
|
|
||||||
err = mtk_dma_init(eth);
|
err = mtk_dma_init(eth);
|
||||||
@@ -2284,16 +2345,15 @@ static int mtk_start_dma(struct mtk_eth
|
@@ -2287,16 +2348,15 @@ static int mtk_start_dma(struct mtk_eth
|
||||||
MTK_TX_BT_32DWORDS | MTK_NDP_CO_PRO |
|
MTK_TX_BT_32DWORDS | MTK_NDP_CO_PRO |
|
||||||
MTK_RX_DMA_EN | MTK_RX_2B_OFFSET |
|
MTK_RX_DMA_EN | MTK_RX_2B_OFFSET |
|
||||||
MTK_RX_BT_32DWORDS,
|
MTK_RX_BT_32DWORDS,
|
||||||
@ -415,7 +415,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@@ -2417,8 +2477,8 @@ static int mtk_stop(struct net_device *d
|
@@ -2420,8 +2480,8 @@ static int mtk_stop(struct net_device *d
|
||||||
cancel_work_sync(ð->tx_dim.work);
|
cancel_work_sync(ð->tx_dim.work);
|
||||||
|
|
||||||
if (MTK_HAS_CAPS(eth->soc->caps, MTK_QDMA))
|
if (MTK_HAS_CAPS(eth->soc->caps, MTK_QDMA))
|
||||||
@ -426,7 +426,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
|
|
||||||
mtk_dma_free(eth);
|
mtk_dma_free(eth);
|
||||||
|
|
||||||
@@ -2472,6 +2532,7 @@ static void mtk_dim_rx(struct work_struc
|
@@ -2475,6 +2535,7 @@ static void mtk_dim_rx(struct work_struc
|
||||||
{
|
{
|
||||||
struct dim *dim = container_of(work, struct dim, work);
|
struct dim *dim = container_of(work, struct dim, work);
|
||||||
struct mtk_eth *eth = container_of(dim, struct mtk_eth, rx_dim);
|
struct mtk_eth *eth = container_of(dim, struct mtk_eth, rx_dim);
|
||||||
@ -434,7 +434,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
struct dim_cq_moder cur_profile;
|
struct dim_cq_moder cur_profile;
|
||||||
u32 val, cur;
|
u32 val, cur;
|
||||||
|
|
||||||
@@ -2479,7 +2540,7 @@ static void mtk_dim_rx(struct work_struc
|
@@ -2482,7 +2543,7 @@ static void mtk_dim_rx(struct work_struc
|
||||||
dim->profile_ix);
|
dim->profile_ix);
|
||||||
spin_lock_bh(ð->dim_lock);
|
spin_lock_bh(ð->dim_lock);
|
||||||
|
|
||||||
@ -443,7 +443,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
val &= MTK_PDMA_DELAY_TX_MASK;
|
val &= MTK_PDMA_DELAY_TX_MASK;
|
||||||
val |= MTK_PDMA_DELAY_RX_EN;
|
val |= MTK_PDMA_DELAY_RX_EN;
|
||||||
|
|
||||||
@@ -2489,9 +2550,9 @@ static void mtk_dim_rx(struct work_struc
|
@@ -2492,9 +2553,9 @@ static void mtk_dim_rx(struct work_struc
|
||||||
cur = min_t(u32, cur_profile.pkts, MTK_PDMA_DELAY_PINT_MASK);
|
cur = min_t(u32, cur_profile.pkts, MTK_PDMA_DELAY_PINT_MASK);
|
||||||
val |= cur << MTK_PDMA_DELAY_RX_PINT_SHIFT;
|
val |= cur << MTK_PDMA_DELAY_RX_PINT_SHIFT;
|
||||||
|
|
||||||
@ -455,7 +455,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
|
|
||||||
spin_unlock_bh(ð->dim_lock);
|
spin_unlock_bh(ð->dim_lock);
|
||||||
|
|
||||||
@@ -2502,6 +2563,7 @@ static void mtk_dim_tx(struct work_struc
|
@@ -2505,6 +2566,7 @@ static void mtk_dim_tx(struct work_struc
|
||||||
{
|
{
|
||||||
struct dim *dim = container_of(work, struct dim, work);
|
struct dim *dim = container_of(work, struct dim, work);
|
||||||
struct mtk_eth *eth = container_of(dim, struct mtk_eth, tx_dim);
|
struct mtk_eth *eth = container_of(dim, struct mtk_eth, tx_dim);
|
||||||
@ -463,7 +463,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
struct dim_cq_moder cur_profile;
|
struct dim_cq_moder cur_profile;
|
||||||
u32 val, cur;
|
u32 val, cur;
|
||||||
|
|
||||||
@@ -2509,7 +2571,7 @@ static void mtk_dim_tx(struct work_struc
|
@@ -2512,7 +2574,7 @@ static void mtk_dim_tx(struct work_struc
|
||||||
dim->profile_ix);
|
dim->profile_ix);
|
||||||
spin_lock_bh(ð->dim_lock);
|
spin_lock_bh(ð->dim_lock);
|
||||||
|
|
||||||
@ -472,7 +472,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
val &= MTK_PDMA_DELAY_RX_MASK;
|
val &= MTK_PDMA_DELAY_RX_MASK;
|
||||||
val |= MTK_PDMA_DELAY_TX_EN;
|
val |= MTK_PDMA_DELAY_TX_EN;
|
||||||
|
|
||||||
@@ -2519,9 +2581,9 @@ static void mtk_dim_tx(struct work_struc
|
@@ -2522,9 +2584,9 @@ static void mtk_dim_tx(struct work_struc
|
||||||
cur = min_t(u32, cur_profile.pkts, MTK_PDMA_DELAY_PINT_MASK);
|
cur = min_t(u32, cur_profile.pkts, MTK_PDMA_DELAY_PINT_MASK);
|
||||||
val |= cur << MTK_PDMA_DELAY_TX_PINT_SHIFT;
|
val |= cur << MTK_PDMA_DELAY_TX_PINT_SHIFT;
|
||||||
|
|
||||||
@ -484,7 +484,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
|
|
||||||
spin_unlock_bh(ð->dim_lock);
|
spin_unlock_bh(ð->dim_lock);
|
||||||
|
|
||||||
@@ -2532,6 +2594,7 @@ static int mtk_hw_init(struct mtk_eth *e
|
@@ -2535,6 +2597,7 @@ static int mtk_hw_init(struct mtk_eth *e
|
||||||
{
|
{
|
||||||
u32 dma_mask = ETHSYS_DMA_AG_MAP_PDMA | ETHSYS_DMA_AG_MAP_QDMA |
|
u32 dma_mask = ETHSYS_DMA_AG_MAP_PDMA | ETHSYS_DMA_AG_MAP_QDMA |
|
||||||
ETHSYS_DMA_AG_MAP_PPE;
|
ETHSYS_DMA_AG_MAP_PPE;
|
||||||
@ -492,7 +492,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
int i, val, ret;
|
int i, val, ret;
|
||||||
|
|
||||||
if (test_and_set_bit(MTK_HW_INIT, ð->state))
|
if (test_and_set_bit(MTK_HW_INIT, ð->state))
|
||||||
@@ -2606,10 +2669,10 @@ static int mtk_hw_init(struct mtk_eth *e
|
@@ -2609,10 +2672,10 @@ static int mtk_hw_init(struct mtk_eth *e
|
||||||
mtk_rx_irq_disable(eth, ~0);
|
mtk_rx_irq_disable(eth, ~0);
|
||||||
|
|
||||||
/* FE int grouping */
|
/* FE int grouping */
|
||||||
@ -507,7 +507,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
mtk_w32(eth, 0x21021000, MTK_FE_INT_GRP);
|
mtk_w32(eth, 0x21021000, MTK_FE_INT_GRP);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@@ -3148,14 +3211,6 @@ static int mtk_probe(struct platform_dev
|
@@ -3151,14 +3214,6 @@ static int mtk_probe(struct platform_dev
|
||||||
if (IS_ERR(eth->base))
|
if (IS_ERR(eth->base))
|
||||||
return PTR_ERR(eth->base);
|
return PTR_ERR(eth->base);
|
||||||
|
|
||||||
@ -522,7 +522,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
if (MTK_HAS_CAPS(eth->soc->caps, MTK_SOC_MT7628)) {
|
if (MTK_HAS_CAPS(eth->soc->caps, MTK_SOC_MT7628)) {
|
||||||
eth->rx_dma_l4_valid = RX_DMA_L4_VALID_PDMA;
|
eth->rx_dma_l4_valid = RX_DMA_L4_VALID_PDMA;
|
||||||
eth->ip_align = NET_IP_ALIGN;
|
eth->ip_align = NET_IP_ALIGN;
|
||||||
@@ -3389,6 +3444,7 @@ static int mtk_remove(struct platform_de
|
@@ -3392,6 +3447,7 @@ static int mtk_remove(struct platform_de
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct mtk_soc_data mt2701_data = {
|
static const struct mtk_soc_data mt2701_data = {
|
||||||
@ -530,7 +530,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
.caps = MT7623_CAPS | MTK_HWLRO,
|
.caps = MT7623_CAPS | MTK_HWLRO,
|
||||||
.hw_features = MTK_HW_FEATURES,
|
.hw_features = MTK_HW_FEATURES,
|
||||||
.required_clks = MT7623_CLKS_BITMAP,
|
.required_clks = MT7623_CLKS_BITMAP,
|
||||||
@@ -3400,6 +3456,7 @@ static const struct mtk_soc_data mt2701_
|
@@ -3403,6 +3459,7 @@ static const struct mtk_soc_data mt2701_
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct mtk_soc_data mt7621_data = {
|
static const struct mtk_soc_data mt7621_data = {
|
||||||
@ -538,7 +538,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
.caps = MT7621_CAPS,
|
.caps = MT7621_CAPS,
|
||||||
.hw_features = MTK_HW_FEATURES,
|
.hw_features = MTK_HW_FEATURES,
|
||||||
.required_clks = MT7621_CLKS_BITMAP,
|
.required_clks = MT7621_CLKS_BITMAP,
|
||||||
@@ -3412,6 +3469,7 @@ static const struct mtk_soc_data mt7621_
|
@@ -3415,6 +3472,7 @@ static const struct mtk_soc_data mt7621_
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct mtk_soc_data mt7622_data = {
|
static const struct mtk_soc_data mt7622_data = {
|
||||||
@ -546,7 +546,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
.ana_rgc3 = 0x2028,
|
.ana_rgc3 = 0x2028,
|
||||||
.caps = MT7622_CAPS | MTK_HWLRO,
|
.caps = MT7622_CAPS | MTK_HWLRO,
|
||||||
.hw_features = MTK_HW_FEATURES,
|
.hw_features = MTK_HW_FEATURES,
|
||||||
@@ -3425,6 +3483,7 @@ static const struct mtk_soc_data mt7622_
|
@@ -3428,6 +3486,7 @@ static const struct mtk_soc_data mt7622_
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct mtk_soc_data mt7623_data = {
|
static const struct mtk_soc_data mt7623_data = {
|
||||||
@ -554,7 +554,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
.caps = MT7623_CAPS | MTK_HWLRO,
|
.caps = MT7623_CAPS | MTK_HWLRO,
|
||||||
.hw_features = MTK_HW_FEATURES,
|
.hw_features = MTK_HW_FEATURES,
|
||||||
.required_clks = MT7623_CLKS_BITMAP,
|
.required_clks = MT7623_CLKS_BITMAP,
|
||||||
@@ -3437,6 +3496,7 @@ static const struct mtk_soc_data mt7623_
|
@@ -3440,6 +3499,7 @@ static const struct mtk_soc_data mt7623_
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct mtk_soc_data mt7629_data = {
|
static const struct mtk_soc_data mt7629_data = {
|
||||||
@ -562,7 +562,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
.ana_rgc3 = 0x128,
|
.ana_rgc3 = 0x128,
|
||||||
.caps = MT7629_CAPS | MTK_HWLRO,
|
.caps = MT7629_CAPS | MTK_HWLRO,
|
||||||
.hw_features = MTK_HW_FEATURES,
|
.hw_features = MTK_HW_FEATURES,
|
||||||
@@ -3449,6 +3509,7 @@ static const struct mtk_soc_data mt7629_
|
@@ -3452,6 +3512,7 @@ static const struct mtk_soc_data mt7629_
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct mtk_soc_data rt5350_data = {
|
static const struct mtk_soc_data rt5350_data = {
|
||||||
|
@ -403,7 +403,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -2277,7 +2385,7 @@ static irqreturn_t mtk_handle_irq_rx(int
|
@@ -2280,7 +2388,7 @@ static irqreturn_t mtk_handle_irq_rx(int
|
||||||
eth->rx_events++;
|
eth->rx_events++;
|
||||||
if (likely(napi_schedule_prep(ð->rx_napi))) {
|
if (likely(napi_schedule_prep(ð->rx_napi))) {
|
||||||
__napi_schedule(ð->rx_napi);
|
__napi_schedule(ð->rx_napi);
|
||||||
@ -412,7 +412,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
}
|
}
|
||||||
|
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
@@ -2301,8 +2409,10 @@ static irqreturn_t mtk_handle_irq(int ir
|
@@ -2304,8 +2412,10 @@ static irqreturn_t mtk_handle_irq(int ir
|
||||||
struct mtk_eth *eth = _eth;
|
struct mtk_eth *eth = _eth;
|
||||||
const struct mtk_reg_map *reg_map = eth->soc->reg_map;
|
const struct mtk_reg_map *reg_map = eth->soc->reg_map;
|
||||||
|
|
||||||
@ -425,7 +425,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
mtk_handle_irq_rx(irq, _eth);
|
mtk_handle_irq_rx(irq, _eth);
|
||||||
}
|
}
|
||||||
if (mtk_r32(eth, reg_map->tx_irq_mask) & MTK_TX_DONE_INT) {
|
if (mtk_r32(eth, reg_map->tx_irq_mask) & MTK_TX_DONE_INT) {
|
||||||
@@ -2320,16 +2430,16 @@ static void mtk_poll_controller(struct n
|
@@ -2323,16 +2433,16 @@ static void mtk_poll_controller(struct n
|
||||||
struct mtk_eth *eth = mac->hw;
|
struct mtk_eth *eth = mac->hw;
|
||||||
|
|
||||||
mtk_tx_irq_disable(eth, MTK_TX_DONE_INT);
|
mtk_tx_irq_disable(eth, MTK_TX_DONE_INT);
|
||||||
@ -445,7 +445,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
const struct mtk_reg_map *reg_map = eth->soc->reg_map;
|
const struct mtk_reg_map *reg_map = eth->soc->reg_map;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
@@ -2340,12 +2450,19 @@ static int mtk_start_dma(struct mtk_eth
|
@@ -2343,12 +2453,19 @@ static int mtk_start_dma(struct mtk_eth
|
||||||
}
|
}
|
||||||
|
|
||||||
if (MTK_HAS_CAPS(eth->soc->caps, MTK_QDMA)) {
|
if (MTK_HAS_CAPS(eth->soc->caps, MTK_QDMA)) {
|
||||||
@ -471,7 +471,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
mtk_w32(eth,
|
mtk_w32(eth,
|
||||||
MTK_RX_DMA_EN | rx_2b_offset |
|
MTK_RX_DMA_EN | rx_2b_offset |
|
||||||
MTK_RX_BT_32DWORDS | MTK_MULTI_EN,
|
MTK_RX_BT_32DWORDS | MTK_MULTI_EN,
|
||||||
@@ -2417,7 +2534,7 @@ static int mtk_open(struct net_device *d
|
@@ -2420,7 +2537,7 @@ static int mtk_open(struct net_device *d
|
||||||
napi_enable(ð->tx_napi);
|
napi_enable(ð->tx_napi);
|
||||||
napi_enable(ð->rx_napi);
|
napi_enable(ð->rx_napi);
|
||||||
mtk_tx_irq_enable(eth, MTK_TX_DONE_INT);
|
mtk_tx_irq_enable(eth, MTK_TX_DONE_INT);
|
||||||
@ -480,7 +480,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
refcount_set(ð->dma_refcnt, 1);
|
refcount_set(ð->dma_refcnt, 1);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -2469,7 +2586,7 @@ static int mtk_stop(struct net_device *d
|
@@ -2472,7 +2589,7 @@ static int mtk_stop(struct net_device *d
|
||||||
mtk_gdm_config(eth, MTK_GDMA_DROP_ALL);
|
mtk_gdm_config(eth, MTK_GDMA_DROP_ALL);
|
||||||
|
|
||||||
mtk_tx_irq_disable(eth, MTK_TX_DONE_INT);
|
mtk_tx_irq_disable(eth, MTK_TX_DONE_INT);
|
||||||
@ -489,7 +489,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
napi_disable(ð->tx_napi);
|
napi_disable(ð->tx_napi);
|
||||||
napi_disable(ð->rx_napi);
|
napi_disable(ð->rx_napi);
|
||||||
|
|
||||||
@@ -2629,9 +2746,25 @@ static int mtk_hw_init(struct mtk_eth *e
|
@@ -2632,9 +2749,25 @@ static int mtk_hw_init(struct mtk_eth *e
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -518,7 +518,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
|
|
||||||
if (eth->pctl) {
|
if (eth->pctl) {
|
||||||
/* Set GE2 driving and slew rate */
|
/* Set GE2 driving and slew rate */
|
||||||
@@ -2670,11 +2803,47 @@ static int mtk_hw_init(struct mtk_eth *e
|
@@ -2673,11 +2806,47 @@ static int mtk_hw_init(struct mtk_eth *e
|
||||||
|
|
||||||
/* FE int grouping */
|
/* FE int grouping */
|
||||||
mtk_w32(eth, MTK_TX_DONE_INT, reg_map->pdma.int_grp);
|
mtk_w32(eth, MTK_TX_DONE_INT, reg_map->pdma.int_grp);
|
||||||
@ -568,7 +568,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
err_disable_pm:
|
err_disable_pm:
|
||||||
@@ -3211,12 +3380,8 @@ static int mtk_probe(struct platform_dev
|
@@ -3214,12 +3383,8 @@ static int mtk_probe(struct platform_dev
|
||||||
if (IS_ERR(eth->base))
|
if (IS_ERR(eth->base))
|
||||||
return PTR_ERR(eth->base);
|
return PTR_ERR(eth->base);
|
||||||
|
|
||||||
@ -582,7 +582,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
|
|
||||||
spin_lock_init(ð->page_lock);
|
spin_lock_init(ð->page_lock);
|
||||||
spin_lock_init(ð->tx_irq_lock);
|
spin_lock_init(ð->tx_irq_lock);
|
||||||
@@ -3452,6 +3617,10 @@ static const struct mtk_soc_data mt2701_
|
@@ -3455,6 +3620,10 @@ static const struct mtk_soc_data mt2701_
|
||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
.rxd_size = sizeof(struct mtk_rx_dma),
|
.rxd_size = sizeof(struct mtk_rx_dma),
|
||||||
@ -593,7 +593,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -3465,6 +3634,10 @@ static const struct mtk_soc_data mt7621_
|
@@ -3468,6 +3637,10 @@ static const struct mtk_soc_data mt7621_
|
||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
.rxd_size = sizeof(struct mtk_rx_dma),
|
.rxd_size = sizeof(struct mtk_rx_dma),
|
||||||
@ -604,7 +604,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -3479,6 +3652,10 @@ static const struct mtk_soc_data mt7622_
|
@@ -3482,6 +3655,10 @@ static const struct mtk_soc_data mt7622_
|
||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
.rxd_size = sizeof(struct mtk_rx_dma),
|
.rxd_size = sizeof(struct mtk_rx_dma),
|
||||||
@ -615,7 +615,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -3492,6 +3669,10 @@ static const struct mtk_soc_data mt7623_
|
@@ -3495,6 +3672,10 @@ static const struct mtk_soc_data mt7623_
|
||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
.rxd_size = sizeof(struct mtk_rx_dma),
|
.rxd_size = sizeof(struct mtk_rx_dma),
|
||||||
@ -626,7 +626,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -3505,6 +3686,10 @@ static const struct mtk_soc_data mt7629_
|
@@ -3508,6 +3689,10 @@ static const struct mtk_soc_data mt7629_
|
||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
.rxd_size = sizeof(struct mtk_rx_dma),
|
.rxd_size = sizeof(struct mtk_rx_dma),
|
||||||
@ -637,7 +637,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -3517,6 +3702,10 @@ static const struct mtk_soc_data rt5350_
|
@@ -3520,6 +3705,10 @@ static const struct mtk_soc_data rt5350_
|
||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
.rxd_size = sizeof(struct mtk_rx_dma),
|
.rxd_size = sizeof(struct mtk_rx_dma),
|
||||||
|
@ -65,7 +65,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
};
|
};
|
||||||
|
|
||||||
void mtk_w32(struct mtk_eth *eth, u32 val, unsigned reg)
|
void mtk_w32(struct mtk_eth *eth, u32 val, unsigned reg)
|
||||||
@@ -3689,6 +3726,21 @@ static const struct mtk_soc_data mt7629_
|
@@ -3692,6 +3729,21 @@ static const struct mtk_soc_data mt7629_
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -87,7 +87,7 @@ Signed-off-by: David S. Miller <davem@davemloft.net>
|
|||||||
static const struct mtk_soc_data rt5350_data = {
|
static const struct mtk_soc_data rt5350_data = {
|
||||||
.reg_map = &mt7628_reg_map,
|
.reg_map = &mt7628_reg_map,
|
||||||
.caps = MT7628_CAPS,
|
.caps = MT7628_CAPS,
|
||||||
@@ -3711,6 +3763,7 @@ const struct of_device_id of_mtk_match[]
|
@@ -3714,6 +3766,7 @@ const struct of_device_id of_mtk_match[]
|
||||||
{ .compatible = "mediatek,mt7622-eth", .data = &mt7622_data},
|
{ .compatible = "mediatek,mt7622-eth", .data = &mt7622_data},
|
||||||
{ .compatible = "mediatek,mt7623-eth", .data = &mt7623_data},
|
{ .compatible = "mediatek,mt7623-eth", .data = &mt7623_data},
|
||||||
{ .compatible = "mediatek,mt7629-eth", .data = &mt7629_data},
|
{ .compatible = "mediatek,mt7629-eth", .data = &mt7629_data},
|
||||||
|
@ -1,25 +0,0 @@
|
|||||||
From: Dan Carpenter <dan.carpenter@oracle.com>
|
|
||||||
Date: Thu, 26 May 2022 11:02:42 +0300
|
|
||||||
Subject: [PATCH] net: ethernet: mtk_eth_soc: out of bounds read in
|
|
||||||
mtk_hwlro_get_fdir_entry()
|
|
||||||
|
|
||||||
The "fsp->location" variable comes from user via ethtool_get_rxnfc().
|
|
||||||
Check that it is valid to prevent an out of bounds read.
|
|
||||||
|
|
||||||
Fixes: 7aab747e5563 ("net: ethernet: mediatek: add ethtool functions to configure RX flows of HW LRO")
|
|
||||||
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
|
|
||||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
|
||||||
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
|
||||||
@@ -2230,6 +2230,9 @@ static int mtk_hwlro_get_fdir_entry(stru
|
|
||||||
struct ethtool_rx_flow_spec *fsp =
|
|
||||||
(struct ethtool_rx_flow_spec *)&cmd->fs;
|
|
||||||
|
|
||||||
+ if (fsp->location >= ARRAY_SIZE(mac->hwlro_ip))
|
|
||||||
+ return -EINVAL;
|
|
||||||
+
|
|
||||||
/* only tcp dst ipv4 is meaningful, others are meaningless */
|
|
||||||
fsp->flow_type = TCP_V4_FLOW;
|
|
||||||
fsp->h_u.tcp_ip4_spec.ip4dst = ntohl(mac->hwlro_ip[fsp->location]);
|
|
@ -143,7 +143,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
|
|
||||||
--- a/scripts/mod/modpost.c
|
--- a/scripts/mod/modpost.c
|
||||||
+++ b/scripts/mod/modpost.c
|
+++ b/scripts/mod/modpost.c
|
||||||
@@ -2033,7 +2033,9 @@ static void read_symbols(const char *mod
|
@@ -2034,7 +2034,9 @@ static void read_symbols(const char *mod
|
||||||
symname = remove_dot(info.strtab + sym->st_name);
|
symname = remove_dot(info.strtab + sym->st_name);
|
||||||
|
|
||||||
handle_symbol(mod, &info, sym, symname);
|
handle_symbol(mod, &info, sym, symname);
|
||||||
@ -153,7 +153,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (sym = info.symtab_start; sym < info.symtab_stop; sym++) {
|
for (sym = info.symtab_start; sym < info.symtab_stop; sym++) {
|
||||||
@@ -2212,8 +2214,10 @@ static void add_header(struct buffer *b,
|
@@ -2213,8 +2215,10 @@ static void add_header(struct buffer *b,
|
||||||
buf_printf(b, "BUILD_SALT;\n");
|
buf_printf(b, "BUILD_SALT;\n");
|
||||||
buf_printf(b, "BUILD_LTO_INFO;\n");
|
buf_printf(b, "BUILD_LTO_INFO;\n");
|
||||||
buf_printf(b, "\n");
|
buf_printf(b, "\n");
|
||||||
@ -164,7 +164,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
buf_printf(b, "\n");
|
buf_printf(b, "\n");
|
||||||
buf_printf(b, "__visible struct module __this_module\n");
|
buf_printf(b, "__visible struct module __this_module\n");
|
||||||
buf_printf(b, "__section(\".gnu.linkonce.this_module\") = {\n");
|
buf_printf(b, "__section(\".gnu.linkonce.this_module\") = {\n");
|
||||||
@@ -2230,8 +2234,10 @@ static void add_header(struct buffer *b,
|
@@ -2231,8 +2235,10 @@ static void add_header(struct buffer *b,
|
||||||
|
|
||||||
static void add_intree_flag(struct buffer *b, int is_intree)
|
static void add_intree_flag(struct buffer *b, int is_intree)
|
||||||
{
|
{
|
||||||
@ -175,7 +175,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Cannot check for assembler */
|
/* Cannot check for assembler */
|
||||||
@@ -2244,8 +2250,10 @@ static void add_retpoline(struct buffer
|
@@ -2245,8 +2251,10 @@ static void add_retpoline(struct buffer
|
||||||
|
|
||||||
static void add_staging_flag(struct buffer *b, const char *name)
|
static void add_staging_flag(struct buffer *b, const char *name)
|
||||||
{
|
{
|
||||||
@ -186,7 +186,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -2325,11 +2333,13 @@ static void add_depends(struct buffer *b
|
@@ -2326,11 +2334,13 @@ static void add_depends(struct buffer *b
|
||||||
|
|
||||||
static void add_srcversion(struct buffer *b, struct module *mod)
|
static void add_srcversion(struct buffer *b, struct module *mod)
|
||||||
{
|
{
|
||||||
@ -200,7 +200,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void write_buf(struct buffer *b, const char *fname)
|
static void write_buf(struct buffer *b, const char *fname)
|
||||||
@@ -2578,7 +2588,9 @@ int main(int argc, char **argv)
|
@@ -2579,7 +2589,9 @@ int main(int argc, char **argv)
|
||||||
add_staging_flag(&buf, mod->name);
|
add_staging_flag(&buf, mod->name);
|
||||||
add_versions(&buf, mod);
|
add_versions(&buf, mod);
|
||||||
add_depends(&buf, mod);
|
add_depends(&buf, mod);
|
||||||
|
@ -67,7 +67,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
*(.modinfo) \
|
*(.modinfo) \
|
||||||
--- a/include/linux/export.h
|
--- a/include/linux/export.h
|
||||||
+++ b/include/linux/export.h
|
+++ b/include/linux/export.h
|
||||||
@@ -82,6 +82,12 @@ struct kernel_symbol {
|
@@ -84,6 +84,12 @@ struct kernel_symbol {
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
@ -80,7 +80,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
/*
|
/*
|
||||||
* For every exported symbol, do the following:
|
* For every exported symbol, do the following:
|
||||||
*
|
*
|
||||||
@@ -99,7 +105,7 @@ struct kernel_symbol {
|
@@ -101,7 +107,7 @@ struct kernel_symbol {
|
||||||
extern const char __kstrtab_##sym[]; \
|
extern const char __kstrtab_##sym[]; \
|
||||||
extern const char __kstrtabns_##sym[]; \
|
extern const char __kstrtabns_##sym[]; \
|
||||||
__CRC_SYMBOL(sym, sec); \
|
__CRC_SYMBOL(sym, sec); \
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/drivers/net/dsa/mv88e6xxx/chip.c
|
--- a/drivers/net/dsa/mv88e6xxx/chip.c
|
||||||
+++ b/drivers/net/dsa/mv88e6xxx/chip.c
|
+++ b/drivers/net/dsa/mv88e6xxx/chip.c
|
||||||
@@ -2983,6 +2983,9 @@ static int mv88e6xxx_setup_port(struct m
|
@@ -2981,6 +2981,9 @@ static int mv88e6xxx_setup_port(struct m
|
||||||
else
|
else
|
||||||
reg = 1 << port;
|
reg = 1 << port;
|
||||||
|
|
||||||
|
@ -14,7 +14,7 @@ Signed-off-by: Pawel Dembicki <paweldembicki@gmail.com>
|
|||||||
|
|
||||||
--- a/arch/powerpc/Kconfig
|
--- a/arch/powerpc/Kconfig
|
||||||
+++ b/arch/powerpc/Kconfig
|
+++ b/arch/powerpc/Kconfig
|
||||||
@@ -222,7 +222,7 @@ config PPC
|
@@ -221,7 +221,7 @@ config PPC
|
||||||
select HAVE_KERNEL_GZIP
|
select HAVE_KERNEL_GZIP
|
||||||
select HAVE_KERNEL_LZMA if DEFAULT_UIMAGE
|
select HAVE_KERNEL_LZMA if DEFAULT_UIMAGE
|
||||||
select HAVE_KERNEL_LZO if DEFAULT_UIMAGE
|
select HAVE_KERNEL_LZO if DEFAULT_UIMAGE
|
||||||
|
@ -50,7 +50,7 @@ Signed-off-by: Gabor Juhos <juhosg@openwrt.org>
|
|||||||
break;
|
break;
|
||||||
--- a/drivers/mtd/ubi/ubi.h
|
--- a/drivers/mtd/ubi/ubi.h
|
||||||
+++ b/drivers/mtd/ubi/ubi.h
|
+++ b/drivers/mtd/ubi/ubi.h
|
||||||
@@ -780,6 +780,7 @@ struct ubi_attach_info {
|
@@ -778,6 +778,7 @@ struct ubi_attach_info {
|
||||||
int mean_ec;
|
int mean_ec;
|
||||||
uint64_t ec_sum;
|
uint64_t ec_sum;
|
||||||
int ec_count;
|
int ec_count;
|
||||||
|
@ -32,7 +32,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
__u8 inner_protocol_type:1;
|
__u8 inner_protocol_type:1;
|
||||||
--- a/net/core/dev.c
|
--- a/net/core/dev.c
|
||||||
+++ b/net/core/dev.c
|
+++ b/net/core/dev.c
|
||||||
@@ -6055,6 +6055,9 @@ static enum gro_result dev_gro_receive(s
|
@@ -6059,6 +6059,9 @@ static enum gro_result dev_gro_receive(s
|
||||||
int same_flow;
|
int same_flow;
|
||||||
int grow;
|
int grow;
|
||||||
|
|
||||||
@ -42,7 +42,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
if (netif_elide_gro(skb->dev))
|
if (netif_elide_gro(skb->dev))
|
||||||
goto normal;
|
goto normal;
|
||||||
|
|
||||||
@@ -8069,6 +8072,48 @@ static void __netdev_adjacent_dev_unlink
|
@@ -8073,6 +8076,48 @@ static void __netdev_adjacent_dev_unlink
|
||||||
&upper_dev->adj_list.lower);
|
&upper_dev->adj_list.lower);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -91,7 +91,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
static int __netdev_upper_dev_link(struct net_device *dev,
|
static int __netdev_upper_dev_link(struct net_device *dev,
|
||||||
struct net_device *upper_dev, bool master,
|
struct net_device *upper_dev, bool master,
|
||||||
void *upper_priv, void *upper_info,
|
void *upper_priv, void *upper_info,
|
||||||
@@ -8120,6 +8165,7 @@ static int __netdev_upper_dev_link(struc
|
@@ -8124,6 +8169,7 @@ static int __netdev_upper_dev_link(struc
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
@ -99,7 +99,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
ret = call_netdevice_notifiers_info(NETDEV_CHANGEUPPER,
|
ret = call_netdevice_notifiers_info(NETDEV_CHANGEUPPER,
|
||||||
&changeupper_info.info);
|
&changeupper_info.info);
|
||||||
ret = notifier_to_errno(ret);
|
ret = notifier_to_errno(ret);
|
||||||
@@ -8216,6 +8262,7 @@ static void __netdev_upper_dev_unlink(st
|
@@ -8220,6 +8266,7 @@ static void __netdev_upper_dev_unlink(st
|
||||||
|
|
||||||
__netdev_adjacent_dev_unlink_neighbour(dev, upper_dev);
|
__netdev_adjacent_dev_unlink_neighbour(dev, upper_dev);
|
||||||
|
|
||||||
@ -107,7 +107,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
call_netdevice_notifiers_info(NETDEV_CHANGEUPPER,
|
call_netdevice_notifiers_info(NETDEV_CHANGEUPPER,
|
||||||
&changeupper_info.info);
|
&changeupper_info.info);
|
||||||
|
|
||||||
@@ -9035,6 +9082,7 @@ int dev_set_mac_address(struct net_devic
|
@@ -9039,6 +9086,7 @@ int dev_set_mac_address(struct net_devic
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
dev->addr_assign_type = NET_ADDR_SET;
|
dev->addr_assign_type = NET_ADDR_SET;
|
||||||
|
@ -17,7 +17,7 @@ Signed-off-by: Tobias Waldekranz <tobias@waldekranz.com>
|
|||||||
|
|
||||||
--- a/drivers/net/dsa/mv88e6xxx/chip.c
|
--- a/drivers/net/dsa/mv88e6xxx/chip.c
|
||||||
+++ b/drivers/net/dsa/mv88e6xxx/chip.c
|
+++ b/drivers/net/dsa/mv88e6xxx/chip.c
|
||||||
@@ -6319,6 +6319,7 @@ static int mv88e6xxx_register_switch(str
|
@@ -6320,6 +6320,7 @@ static int mv88e6xxx_register_switch(str
|
||||||
ds->ops = &mv88e6xxx_switch_ops;
|
ds->ops = &mv88e6xxx_switch_ops;
|
||||||
ds->ageing_time_min = chip->info->age_time_coeff;
|
ds->ageing_time_min = chip->info->age_time_coeff;
|
||||||
ds->ageing_time_max = chip->info->age_time_coeff * U8_MAX;
|
ds->ageing_time_max = chip->info->age_time_coeff * U8_MAX;
|
||||||
|
@ -14,7 +14,7 @@ Signed-off-by: Frank Wunderlich <frank-w@public-files.de>
|
|||||||
|
|
||||||
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
||||||
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
||||||
@@ -3675,6 +3675,7 @@ static const struct mtk_soc_data mt2701_
|
@@ -3678,6 +3678,7 @@ static const struct mtk_soc_data mt2701_
|
||||||
.hw_features = MTK_HW_FEATURES,
|
.hw_features = MTK_HW_FEATURES,
|
||||||
.required_clks = MT7623_CLKS_BITMAP,
|
.required_clks = MT7623_CLKS_BITMAP,
|
||||||
.required_pctl = true,
|
.required_pctl = true,
|
||||||
|
@ -14,7 +14,7 @@ Signed-off-by: René van Dorst <opensource@vdorst.com>
|
|||||||
|
|
||||||
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
||||||
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
||||||
@@ -2968,6 +2968,7 @@ static const struct net_device_ops mtk_n
|
@@ -3293,6 +3293,7 @@ static const struct net_device_ops mtk_n
|
||||||
|
|
||||||
static int mtk_add_mac(struct mtk_eth *eth, struct device_node *np)
|
static int mtk_add_mac(struct mtk_eth *eth, struct device_node *np)
|
||||||
{
|
{
|
||||||
@ -22,7 +22,7 @@ Signed-off-by: René van Dorst <opensource@vdorst.com>
|
|||||||
const __be32 *_id = of_get_property(np, "reg", NULL);
|
const __be32 *_id = of_get_property(np, "reg", NULL);
|
||||||
phy_interface_t phy_mode;
|
phy_interface_t phy_mode;
|
||||||
struct phylink *phylink;
|
struct phylink *phylink;
|
||||||
@@ -3063,6 +3064,9 @@ static int mtk_add_mac(struct mtk_eth *e
|
@@ -3388,6 +3389,9 @@ static int mtk_add_mac(struct mtk_eth *e
|
||||||
else
|
else
|
||||||
eth->netdev[id]->max_mtu = MTK_MAX_RX_LENGTH_2K - MTK_RX_ETH_HLEN;
|
eth->netdev[id]->max_mtu = MTK_MAX_RX_LENGTH_2K - MTK_RX_ETH_HLEN;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user