Skip to content

Commit d0dd9d1

Browse files
rogerqgregkh
authored andcommitted
dmaengine: ti: k3-udma-glue: Drop skip_fdq argument from k3_udma_glue_reset_rx_chn
[ Upstream commit 0da3087 ] The user of k3_udma_glue_reset_rx_chn() e.g. ti_am65_cpsw_nuss can run on multiple platforms having different DMA architectures. On some platforms there can be one FDQ for all flows in the RX channel while for others there is a separate FDQ for each flow in the RX channel. So far we have been relying on the skip_fdq argument of k3_udma_glue_reset_rx_chn(). Instead of relying on the user to provide this information, infer it based on DMA architecture during k3_udma_glue_request_rx_chn() and save it in an internal flag 'single_fdq'. Use that flag at k3_udma_glue_reset_rx_chn() to deicide if the FDQ needs to be cleared for every flow or just for flow 0. Fixes the below issue on ti_am65_cpsw_nuss driver on AM62-SK. > ip link set eth1 down > ip link set eth0 down > ethtool -L eth0 rx 8 > ip link set eth0 up > modprobe -r ti_am65_cpsw_nuss [ 103.045726] ------------[ cut here ]------------ [ 103.050505] k3_knav_desc_pool size 512000 != avail 64000 [ 103.050703] WARNING: CPU: 1 PID: 450 at drivers/net/ethernet/ti/k3-cppi-desc-pool.c:33 k3_cppi_desc_pool_destroy+0xa0/0xa8 [k3_cppi_desc_pool] [ 103.068810] Modules linked in: ti_am65_cpsw_nuss(-) k3_cppi_desc_pool snd_soc_hdmi_codec crct10dif_ce snd_soc_simple_card snd_soc_simple_card_utils display_connector rtc_ti_k3 k3_j72xx_bandgap tidss drm_client_lib snd_soc_davinci_mcas p drm_dma_helper tps6598x phylink snd_soc_ti_udma rti_wdt drm_display_helper snd_soc_tlv320aic3x_i2c typec at24 phy_gmii_sel snd_soc_ti_edma snd_soc_tlv320aic3x sii902x snd_soc_ti_sdma sa2ul omap_mailbox drm_kms_helper authenc cfg80211 r fkill fuse drm drm_panel_orientation_quirks backlight ip_tables x_tables ipv6 [last unloaded: k3_cppi_desc_pool] [ 103.119950] CPU: 1 UID: 0 PID: 450 Comm: modprobe Not tainted 6.13.0-rc7-00001-g9c5e3435fa66 #1011 [ 103.119968] Hardware name: Texas Instruments AM625 SK (DT) [ 103.119974] pstate: 80000005 (Nzcv daif -PAN -UAO -TCO -DIT -SSBS BTYPE=--) [ 103.119983] pc : k3_cppi_desc_pool_destroy+0xa0/0xa8 [k3_cppi_desc_pool] [ 103.148007] lr : k3_cppi_desc_pool_destroy+0xa0/0xa8 [k3_cppi_desc_pool] [ 103.154709] sp : ffff8000826ebbc0 [ 103.158015] x29: ffff8000826ebbc0 x28: ffff0000090b6300 x27: 0000000000000000 [ 103.165145] x26: 0000000000000000 x25: 0000000000000000 x24: ffff0000019df6b0 [ 103.172271] x23: ffff0000019df6b8 x22: ffff0000019df410 x21: ffff8000826ebc88 [ 103.179397] x20: 000000000007d000 x19: ffff00000a3b3000 x18: 0000000000000000 [ 103.186522] x17: 0000000000000000 x16: 0000000000000000 x15: 000001e8c35e1cde [ 103.193647] x14: 0000000000000396 x13: 000000000000035c x12: 0000000000000000 [ 103.200772] x11: 000000000000003a x10: 00000000000009c0 x9 : ffff8000826eba20 [ 103.207897] x8 : ffff0000090b6d20 x7 : ffff00007728c180 x6 : ffff00007728c100 [ 103.215022] x5 : 0000000000000001 x4 : ffff000000508a50 x3 : ffff7ffff6146000 [ 103.222147] x2 : 0000000000000000 x1 : e300b4173ee6b200 x0 : 0000000000000000 [ 103.229274] Call trace: [ 103.231714] k3_cppi_desc_pool_destroy+0xa0/0xa8 [k3_cppi_desc_pool] (P) [ 103.238408] am65_cpsw_nuss_free_rx_chns+0x28/0x4c [ti_am65_cpsw_nuss] [ 103.244942] devm_action_release+0x14/0x20 [ 103.249040] release_nodes+0x3c/0x68 [ 103.252610] devres_release_all+0x8c/0xdc [ 103.256614] device_unbind_cleanup+0x18/0x60 [ 103.260876] device_release_driver_internal+0xf8/0x178 [ 103.266004] driver_detach+0x50/0x9c [ 103.269571] bus_remove_driver+0x6c/0xbc [ 103.273485] driver_unregister+0x30/0x60 [ 103.277401] platform_driver_unregister+0x14/0x20 [ 103.282096] am65_cpsw_nuss_driver_exit+0x18/0xff4 [ti_am65_cpsw_nuss] [ 103.288620] __arm64_sys_delete_module+0x17c/0x25c [ 103.293404] invoke_syscall+0x44/0x100 [ 103.297149] el0_svc_common.constprop.0+0xc0/0xe0 [ 103.301845] do_el0_svc+0x1c/0x28 [ 103.305155] el0_svc+0x28/0x98 [ 103.308207] el0t_64_sync_handler+0xc8/0xcc [ 103.312384] el0t_64_sync+0x198/0x19c [ 103.316040] ---[ end trace 0000000000000000 ]--- Signed-off-by: Roger Quadros <[email protected]> Acked-by: Jakub Kicinski <[email protected]> Acked-by: Peter Ujfalusi <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Vinod Koul <[email protected]> Signed-off-by: Sasha Levin <[email protected]>
1 parent d13bda8 commit d0dd9d1

File tree

4 files changed

+15
-9
lines changed

4 files changed

+15
-9
lines changed

drivers/dma/ti/k3-udma-glue.c

Lines changed: 11 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -84,6 +84,7 @@ struct k3_udma_glue_rx_channel {
8484
struct k3_udma_glue_rx_flow *flows;
8585
u32 flow_num;
8686
u32 flows_ready;
87+
bool single_fdq; /* one FDQ for all flows */
8788
};
8889

8990
static void k3_udma_chan_dev_release(struct device *dev)
@@ -970,10 +971,13 @@ k3_udma_glue_request_rx_chn_priv(struct device *dev, const char *name,
970971

971972
ep_cfg = rx_chn->common.ep_config;
972973

973-
if (xudma_is_pktdma(rx_chn->common.udmax))
974+
if (xudma_is_pktdma(rx_chn->common.udmax)) {
974975
rx_chn->udma_rchan_id = ep_cfg->mapped_channel_id;
975-
else
976+
rx_chn->single_fdq = false;
977+
} else {
976978
rx_chn->udma_rchan_id = -1;
979+
rx_chn->single_fdq = true;
980+
}
977981

978982
/* request and cfg UDMAP RX channel */
979983
rx_chn->udma_rchanx = xudma_rchan_get(rx_chn->common.udmax,
@@ -1103,6 +1107,9 @@ k3_udma_glue_request_remote_rx_chn_common(struct k3_udma_glue_rx_channel *rx_chn
11031107
rx_chn->common.chan_dev.dma_coherent = true;
11041108
dma_coerce_mask_and_coherent(&rx_chn->common.chan_dev,
11051109
DMA_BIT_MASK(48));
1110+
rx_chn->single_fdq = false;
1111+
} else {
1112+
rx_chn->single_fdq = true;
11061113
}
11071114

11081115
ret = k3_udma_glue_allocate_rx_flows(rx_chn, cfg);
@@ -1453,7 +1460,7 @@ EXPORT_SYMBOL_GPL(k3_udma_glue_tdown_rx_chn);
14531460

14541461
void k3_udma_glue_reset_rx_chn(struct k3_udma_glue_rx_channel *rx_chn,
14551462
u32 flow_num, void *data,
1456-
void (*cleanup)(void *data, dma_addr_t desc_dma), bool skip_fdq)
1463+
void (*cleanup)(void *data, dma_addr_t desc_dma))
14571464
{
14581465
struct k3_udma_glue_rx_flow *flow = &rx_chn->flows[flow_num];
14591466
struct device *dev = rx_chn->common.dev;
@@ -1465,7 +1472,7 @@ void k3_udma_glue_reset_rx_chn(struct k3_udma_glue_rx_channel *rx_chn,
14651472
dev_dbg(dev, "RX reset flow %u occ_rx %u\n", flow_num, occ_rx);
14661473

14671474
/* Skip RX FDQ in case one FDQ is used for the set of flows */
1468-
if (skip_fdq)
1475+
if (rx_chn->single_fdq && flow_num)
14691476
goto do_reset;
14701477

14711478
/*

drivers/net/ethernet/ti/am65-cpsw-nuss.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -515,7 +515,7 @@ static void am65_cpsw_destroy_rxq(struct am65_cpsw_common *common, int id)
515515
napi_disable(&flow->napi_rx);
516516
hrtimer_cancel(&flow->rx_hrtimer);
517517
k3_udma_glue_reset_rx_chn(rx_chn->rx_chn, id, rx_chn,
518-
am65_cpsw_nuss_rx_cleanup, !!id);
518+
am65_cpsw_nuss_rx_cleanup);
519519

520520
for (port = 0; port < common->port_num; port++) {
521521
if (!common->ports[port].ndev)
@@ -3433,7 +3433,7 @@ static int am65_cpsw_nuss_register_ndevs(struct am65_cpsw_common *common)
34333433
for (i = 0; i < common->rx_ch_num_flows; i++)
34343434
k3_udma_glue_reset_rx_chn(rx_chan->rx_chn, i,
34353435
rx_chan,
3436-
am65_cpsw_nuss_rx_cleanup, !!i);
3436+
am65_cpsw_nuss_rx_cleanup);
34373437

34383438
k3_udma_glue_disable_rx_chn(rx_chan->rx_chn);
34393439

drivers/net/ethernet/ti/icssg/icssg_common.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -955,7 +955,7 @@ void prueth_reset_rx_chan(struct prueth_rx_chn *chn,
955955

956956
for (i = 0; i < num_flows; i++)
957957
k3_udma_glue_reset_rx_chn(chn->rx_chn, i, chn,
958-
prueth_rx_cleanup, !!i);
958+
prueth_rx_cleanup);
959959
if (disable)
960960
k3_udma_glue_disable_rx_chn(chn->rx_chn);
961961
}

include/linux/dma/k3-udma-glue.h

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -138,8 +138,7 @@ int k3_udma_glue_rx_get_irq(struct k3_udma_glue_rx_channel *rx_chn,
138138
u32 flow_num);
139139
void k3_udma_glue_reset_rx_chn(struct k3_udma_glue_rx_channel *rx_chn,
140140
u32 flow_num, void *data,
141-
void (*cleanup)(void *data, dma_addr_t desc_dma),
142-
bool skip_fdq);
141+
void (*cleanup)(void *data, dma_addr_t desc_dma));
143142
int k3_udma_glue_rx_flow_enable(struct k3_udma_glue_rx_channel *rx_chn,
144143
u32 flow_idx);
145144
int k3_udma_glue_rx_flow_disable(struct k3_udma_glue_rx_channel *rx_chn,

0 commit comments

Comments
 (0)