Skip to content

Commit

Permalink
[WIP] NC/SI debugging
Browse files Browse the repository at this point in the history
Sometimes ncsi_free_request schedules ndp->work when the NCSI device
state is ncsi_dev_state_functional.

Change ncsi_dev_work to expect being called in this state.
  • Loading branch information
neuschaefer committed Apr 12, 2023
1 parent 9fef463 commit b8ddb6b
Show file tree
Hide file tree
Showing 3 changed files with 37 additions and 9 deletions.
27 changes: 20 additions & 7 deletions drivers/net/ethernet/nuvoton/nuvoton-emc.c
Original file line number Diff line number Diff line change
Expand Up @@ -222,6 +222,20 @@ static void emc_link_change(struct net_device *netdev)
__raw_writel(val, priv->reg + REG_MCMDR);
}

static void emc_set_link_mode_for_ncsi(struct net_device *netdev)
{
struct emc_priv *priv = netdev_priv(netdev);
unsigned int val;

val = __raw_readl(priv->reg + REG_MCMDR);

/* Force 100 Mbit/s and full duplex */
val |= MCMDR_OPMOD | MCMDR_FDUP;

__raw_writel(val, priv->reg + REG_MCMDR);
}


static void emc_write_cam(struct net_device *netdev,
unsigned int x, const unsigned char *pval)
{
Expand Down Expand Up @@ -342,13 +356,11 @@ static void emc_enable_mac_interrupt(struct net_device *netdev)
}

static void emc_get_and_clear_int(struct net_device *netdev,
unsigned int *val)
unsigned int mask, unsigned int *val)
{
struct emc_priv *priv = netdev_priv(netdev);

// TODO: clear interrupts selectively, so we don't clear TX interrupts in the RX ISR
// (add mask param)
*val = __raw_readl(priv->reg + REG_MISTA);
*val = __raw_readl(priv->reg + REG_MISTA) & mask;
__raw_writel(*val, priv->reg + REG_MISTA);
}

Expand Down Expand Up @@ -569,7 +581,7 @@ static irqreturn_t emc_tx_interrupt(int irq, void *dev_id)
priv = netdev_priv(netdev);
pdev = priv->pdev;

emc_get_and_clear_int(netdev, &status);
emc_get_and_clear_int(netdev, MISTA_TXBERR | MISTA_TDU | MISTA_TXCP, &status);

cur_entry = __raw_readl(priv->reg + REG_CTXDSA);

Expand Down Expand Up @@ -693,7 +705,7 @@ static irqreturn_t emc_rx_interrupt(int irq, void *dev_id)
priv = netdev_priv(netdev);
pdev = priv->pdev;

emc_get_and_clear_int(netdev, &status);
emc_get_and_clear_int(netdev, MISTA_RXGD, &status);

if (status & MISTA_RDU) {
emc_netdev_rx(netdev);
Expand Down Expand Up @@ -746,6 +758,7 @@ static int emc_open(struct net_device *netdev)
if (priv->phy)
phy_start(priv->phy);
else if (priv->ncsi) {
emc_set_link_mode_for_ncsi(netdev);
netif_carrier_on(netdev);

int err = ncsi_start_dev(priv->ncsi);
Expand Down Expand Up @@ -915,7 +928,7 @@ static int emc_init_mdio(struct emc_priv *priv, struct device_node *np)
val |= MCMDR_ENMDC;
__raw_writel(val, priv->reg + REG_MCMDR);

res = of_mdiobus_register(mdio, np);
res = devm_of_mdiobus_register(&pdev->dev, mdio, np);
if (res) {
dev_info(&pdev->dev, "failed to register MDIO bus: %d\n", res);
return res;
Expand Down
18 changes: 16 additions & 2 deletions net/ncsi/ncsi-manage.c
Original file line number Diff line number Diff line change
Expand Up @@ -390,6 +390,7 @@ struct ncsi_request *ncsi_alloc_request(struct ncsi_dev_priv *ndp,
void ncsi_free_request(struct ncsi_request *nr)
{
struct ncsi_dev_priv *ndp = nr->ndp;
struct ncsi_dev *nd = &ndp->ndev;
struct sk_buff *cmd, *rsp;
unsigned long flags;
bool driven;
Expand All @@ -408,8 +409,10 @@ void ncsi_free_request(struct ncsi_request *nr)
driven = !!(nr->flags & NCSI_REQ_FLAG_EVENT_DRIVEN);
spin_unlock_irqrestore(&ndp->lock, flags);

if (driven && cmd && --ndp->pending_req_num == 0)
if (driven && cmd && --ndp->pending_req_num == 0) {
pr_info("%s: schedule_work, state=%#x, cmd=%p, pending_req_num=%d\n", __func__, nd->state, cmd, ndp->pending_req_num);
schedule_work(&ndp->work);
}

/* Release command and response */
consume_skb(cmd);
Expand Down Expand Up @@ -1055,8 +1058,10 @@ static void ncsi_configure_channel(struct ncsi_dev_priv *ndp)
ret = ncsi_gma_handler(&nca, nc->version.mf_id);
#endif /* CONFIG_NCSI_OEM_CMD_GET_MAC */

if (ret < 0)
if (ret < 0) {
pr_info("%s: schedule_work, state=%#x\n", __func__, nd->state);
schedule_work(&ndp->work);
}

break;
case ncsi_dev_state_config_clear_vids:
Expand All @@ -1079,6 +1084,7 @@ static void ncsi_configure_channel(struct ncsi_dev_priv *ndp)
ret = clear_one_vid(ndp, nc, &nca);
if (ret) {
nd->state = ncsi_dev_state_config_svf;
pr_info("%s: schedule_work, state=%#x\n", __func__, nd->state);
schedule_work(&ndp->work);
break;
}
Expand All @@ -1089,6 +1095,7 @@ static void ncsi_configure_channel(struct ncsi_dev_priv *ndp)
ret = set_one_vid(ndp, nc, &nca);
if (ret) {
nd->state = ncsi_dev_state_config_ev;
pr_info("%s: schedule_work, state=%#x\n", __func__, nd->state);
schedule_work(&ndp->work);
break;
}
Expand Down Expand Up @@ -1396,6 +1403,7 @@ static void ncsi_probe_channel(struct ncsi_dev_priv *ndp)
if (!ndp->active_package) {
/* No response */
nd->state = ncsi_dev_state_probe_dp;
pr_info("%s: schedule_work, state=%#x\n", __func__, nd->state);
schedule_work(&ndp->work);
break;
}
Expand All @@ -1404,6 +1412,7 @@ static void ncsi_probe_channel(struct ncsi_dev_priv *ndp)
ndp->mlx_multi_host)
nd->state = ncsi_dev_state_probe_mlx_gma;

pr_info("%s: schedule_work, state=%#x\n", __func__, nd->state);
schedule_work(&ndp->work);
break;
#if IS_ENABLED(CONFIG_NCSI_OEM_CMD_GET_MAC)
Expand Down Expand Up @@ -1539,6 +1548,9 @@ static void ncsi_dev_work(struct work_struct *work)
struct ncsi_dev *nd = &ndp->ndev;

switch (nd->state & ncsi_dev_state_major) {
case ncsi_dev_state_functional:
/* nothing to do. */
break;
case ncsi_dev_state_probe:
ncsi_probe_channel(ndp);
break;
Expand Down Expand Up @@ -1826,6 +1838,7 @@ int ncsi_start_dev(struct ncsi_dev *nd)
ndp->package_probe_id = 0;
nd->state = ncsi_dev_state_probe;
schedule_work(&ndp->work);
pr_info("%s: schedule_work, state=%#x\n", __func__, nd->state);
return 0;
}

Expand Down Expand Up @@ -1947,6 +1960,7 @@ int ncsi_reset_dev(struct ncsi_dev *nd)
spin_unlock_irqrestore(&ndp->lock, flags);

nd->state = ncsi_dev_state_suspend;
pr_info("%s: schedule_work, state=%#x\n", __func__, nd->state);
schedule_work(&ndp->work);
return 0;
}
Expand Down
1 change: 1 addition & 0 deletions net/ncsi/ncsi-rsp.c
Original file line number Diff line number Diff line change
Expand Up @@ -813,6 +813,7 @@ static int ncsi_rsp_handler_gvi(struct ncsi_request *nr)
for (i = 0; i < ARRAY_SIZE(ncv->pci_ids); i++)
ncv->pci_ids[i] = ntohs(rsp->pci_ids[i]);
ncv->mf_id = ntohl(rsp->mf_id);
pr_info("%s: got mfid=%#x\n", __func__, ncv->mf_id);

return 0;
}
Expand Down

0 comments on commit b8ddb6b

Please sign in to comment.