Commit 7f8a6a1b authored by Madalin Bucur's avatar Madalin Bucur

dpaa_eth: do not ignore port api return value

Reported-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarMadalin Bucur <madalin.bucur@nxp.com>
parent 5accb282
...@@ -1063,9 +1063,9 @@ static int dpaa_fq_free(struct device *dev, struct list_head *list) ...@@ -1063,9 +1063,9 @@ static int dpaa_fq_free(struct device *dev, struct list_head *list)
return err; return err;
} }
static void dpaa_eth_init_tx_port(struct fman_port *port, struct dpaa_fq *errq, static int dpaa_eth_init_tx_port(struct fman_port *port, struct dpaa_fq *errq,
struct dpaa_fq *defq, struct dpaa_fq *defq,
struct dpaa_buffer_layout *buf_layout) struct dpaa_buffer_layout *buf_layout)
{ {
struct fman_buffer_prefix_content buf_prefix_content; struct fman_buffer_prefix_content buf_prefix_content;
struct fman_port_params params; struct fman_port_params params;
...@@ -1084,23 +1084,29 @@ static void dpaa_eth_init_tx_port(struct fman_port *port, struct dpaa_fq *errq, ...@@ -1084,23 +1084,29 @@ static void dpaa_eth_init_tx_port(struct fman_port *port, struct dpaa_fq *errq,
params.specific_params.non_rx_params.dflt_fqid = defq->fqid; params.specific_params.non_rx_params.dflt_fqid = defq->fqid;
err = fman_port_config(port, &params); err = fman_port_config(port, &params);
if (err) if (err) {
pr_err("%s: fman_port_config failed\n", __func__); pr_err("%s: fman_port_config failed\n", __func__);
return err;
}
err = fman_port_cfg_buf_prefix_content(port, &buf_prefix_content); err = fman_port_cfg_buf_prefix_content(port, &buf_prefix_content);
if (err) if (err) {
pr_err("%s: fman_port_cfg_buf_prefix_content failed\n", pr_err("%s: fman_port_cfg_buf_prefix_content failed\n",
__func__); __func__);
return err;
}
err = fman_port_init(port); err = fman_port_init(port);
if (err) if (err)
pr_err("%s: fm_port_init failed\n", __func__); pr_err("%s: fm_port_init failed\n", __func__);
return err;
} }
static void dpaa_eth_init_rx_port(struct fman_port *port, struct dpaa_bp **bps, static int dpaa_eth_init_rx_port(struct fman_port *port, struct dpaa_bp **bps,
size_t count, struct dpaa_fq *errq, size_t count, struct dpaa_fq *errq,
struct dpaa_fq *defq, struct dpaa_fq *defq,
struct dpaa_buffer_layout *buf_layout) struct dpaa_buffer_layout *buf_layout)
{ {
struct fman_buffer_prefix_content buf_prefix_content; struct fman_buffer_prefix_content buf_prefix_content;
struct fman_port_rx_params *rx_p; struct fman_port_rx_params *rx_p;
...@@ -1128,32 +1134,44 @@ static void dpaa_eth_init_rx_port(struct fman_port *port, struct dpaa_bp **bps, ...@@ -1128,32 +1134,44 @@ static void dpaa_eth_init_rx_port(struct fman_port *port, struct dpaa_bp **bps,
} }
err = fman_port_config(port, &params); err = fman_port_config(port, &params);
if (err) if (err) {
pr_err("%s: fman_port_config failed\n", __func__); pr_err("%s: fman_port_config failed\n", __func__);
return err;
}
err = fman_port_cfg_buf_prefix_content(port, &buf_prefix_content); err = fman_port_cfg_buf_prefix_content(port, &buf_prefix_content);
if (err) if (err) {
pr_err("%s: fman_port_cfg_buf_prefix_content failed\n", pr_err("%s: fman_port_cfg_buf_prefix_content failed\n",
__func__); __func__);
return err;
}
err = fman_port_init(port); err = fman_port_init(port);
if (err) if (err)
pr_err("%s: fm_port_init failed\n", __func__); pr_err("%s: fm_port_init failed\n", __func__);
return err;
} }
static void dpaa_eth_init_ports(struct mac_device *mac_dev, static int dpaa_eth_init_ports(struct mac_device *mac_dev,
struct dpaa_bp **bps, size_t count, struct dpaa_bp **bps, size_t count,
struct fm_port_fqs *port_fqs, struct fm_port_fqs *port_fqs,
struct dpaa_buffer_layout *buf_layout, struct dpaa_buffer_layout *buf_layout,
struct device *dev) struct device *dev)
{ {
struct fman_port *rxport = mac_dev->port[RX]; struct fman_port *rxport = mac_dev->port[RX];
struct fman_port *txport = mac_dev->port[TX]; struct fman_port *txport = mac_dev->port[TX];
int err;
dpaa_eth_init_tx_port(txport, port_fqs->tx_errq, err = dpaa_eth_init_tx_port(txport, port_fqs->tx_errq,
port_fqs->tx_defq, &buf_layout[TX]); port_fqs->tx_defq, &buf_layout[TX]);
dpaa_eth_init_rx_port(rxport, bps, count, port_fqs->rx_errq, if (err)
port_fqs->rx_defq, &buf_layout[RX]); return err;
err = dpaa_eth_init_rx_port(rxport, bps, count, port_fqs->rx_errq,
port_fqs->rx_defq, &buf_layout[RX]);
return err;
} }
static int dpaa_bman_release(const struct dpaa_bp *dpaa_bp, static int dpaa_bman_release(const struct dpaa_bp *dpaa_bp,
...@@ -2649,8 +2667,10 @@ static int dpaa_eth_probe(struct platform_device *pdev) ...@@ -2649,8 +2667,10 @@ static int dpaa_eth_probe(struct platform_device *pdev)
priv->rx_headroom = dpaa_get_headroom(&priv->buf_layout[RX]); priv->rx_headroom = dpaa_get_headroom(&priv->buf_layout[RX]);
/* All real interfaces need their ports initialized */ /* All real interfaces need their ports initialized */
dpaa_eth_init_ports(mac_dev, dpaa_bps, DPAA_BPS_NUM, &port_fqs, err = dpaa_eth_init_ports(mac_dev, dpaa_bps, DPAA_BPS_NUM, &port_fqs,
&priv->buf_layout[0], dev); &priv->buf_layout[0], dev);
if (err)
goto init_ports_failed;
priv->percpu_priv = devm_alloc_percpu(dev, *priv->percpu_priv); priv->percpu_priv = devm_alloc_percpu(dev, *priv->percpu_priv);
if (!priv->percpu_priv) { if (!priv->percpu_priv) {
...@@ -2683,6 +2703,7 @@ static int dpaa_eth_probe(struct platform_device *pdev) ...@@ -2683,6 +2703,7 @@ static int dpaa_eth_probe(struct platform_device *pdev)
napi_add_failed: napi_add_failed:
dpaa_napi_del(net_dev); dpaa_napi_del(net_dev);
alloc_percpu_failed: alloc_percpu_failed:
init_ports_failed:
dpaa_fq_free(dev, &priv->dpaa_fq_list); dpaa_fq_free(dev, &priv->dpaa_fq_list);
fq_alloc_failed: fq_alloc_failed:
qman_delete_cgr_safe(&priv->ingress_cgr); qman_delete_cgr_safe(&priv->ingress_cgr);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment