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:
		 Rui Salvaterra
					Rui Salvaterra
				
			
				
					committed by
					
						 Hauke Mehrtens
						Hauke Mehrtens
					
				
			
			
				
	
			
			
			 Hauke Mehrtens
						Hauke Mehrtens
					
				
			
						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; | ||||||
|   |   | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user