This simplifies the code as well as adding a probe deferral message.
Signed-off-by: Alexander Stein <[email protected]>
---
drivers/gpu/drm/bridge/nwl-dsi.c | 114 +++++++++++--------------------
1 file changed, 40 insertions(+), 74 deletions(-)
diff --git a/drivers/gpu/drm/bridge/nwl-dsi.c b/drivers/gpu/drm/bridge/nwl-dsi.c
index 2f7429b24fc20..0a39643b128ba 100644
--- a/drivers/gpu/drm/bridge/nwl-dsi.c
+++ b/drivers/gpu/drm/bridge/nwl-dsi.c
@@ -9,6 +9,7 @@
#include <linux/bitfield.h>
#include <linux/bits.h>
#include <linux/clk.h>
+#include <linux/dev_printk.h>
#include <linux/irq.h>
#include <linux/math64.h>
#include <linux/mfd/syscon.h>
@@ -975,68 +976,46 @@ static int nwl_dsi_parse_dt(struct nwl_dsi *dsi)
struct platform_device *pdev = to_platform_device(dsi->dev);
struct clk *clk;
void __iomem *base;
- int ret;
dsi->phy = devm_phy_get(dsi->dev, "dphy");
- if (IS_ERR(dsi->phy)) {
- ret = PTR_ERR(dsi->phy);
- if (ret != -EPROBE_DEFER)
- DRM_DEV_ERROR(dsi->dev, "Could not get PHY: %d\n", ret);
- return ret;
- }
+ if (IS_ERR(dsi->phy))
+ return dev_err_probe(dsi->dev, PTR_ERR(dsi->phy),
+ "Could not get PHY\n");
clk = devm_clk_get(dsi->dev, "lcdif");
- if (IS_ERR(clk)) {
- ret = PTR_ERR(clk);
- DRM_DEV_ERROR(dsi->dev, "Failed to get lcdif clock: %d\n",
- ret);
- return ret;
- }
+ if (IS_ERR(clk))
+ return dev_err_probe(dsi->dev, PTR_ERR(clk),
+ "Failed to get lcdif clock\n");
dsi->lcdif_clk = clk;
clk = devm_clk_get(dsi->dev, "core");
- if (IS_ERR(clk)) {
- ret = PTR_ERR(clk);
- DRM_DEV_ERROR(dsi->dev, "Failed to get core clock: %d\n",
- ret);
- return ret;
- }
+ if (IS_ERR(clk))
+ return dev_err_probe(dsi->dev, PTR_ERR(clk),
+ "Failed to get core clock\n");
dsi->core_clk = clk;
clk = devm_clk_get(dsi->dev, "phy_ref");
- if (IS_ERR(clk)) {
- ret = PTR_ERR(clk);
- DRM_DEV_ERROR(dsi->dev, "Failed to get phy_ref clock: %d\n",
- ret);
- return ret;
- }
+ if (IS_ERR(clk))
+ return dev_err_probe(dsi->dev, PTR_ERR(clk),
+ "Failed to get phy_ref clock\n");
dsi->phy_ref_clk = clk;
clk = devm_clk_get(dsi->dev, "rx_esc");
- if (IS_ERR(clk)) {
- ret = PTR_ERR(clk);
- DRM_DEV_ERROR(dsi->dev, "Failed to get rx_esc clock: %d\n",
- ret);
- return ret;
- }
+ if (IS_ERR(clk))
+ return dev_err_probe(dsi->dev, PTR_ERR(clk),
+ "Failed to get rx_esc clock\n");
dsi->rx_esc_clk = clk;
clk = devm_clk_get(dsi->dev, "tx_esc");
- if (IS_ERR(clk)) {
- ret = PTR_ERR(clk);
- DRM_DEV_ERROR(dsi->dev, "Failed to get tx_esc clock: %d\n",
- ret);
- return ret;
- }
+ if (IS_ERR(clk))
+ return dev_err_probe(dsi->dev, PTR_ERR(clk),
+ "Failed to get tx_esc clock\n");
dsi->tx_esc_clk = clk;
dsi->mux = devm_mux_control_get(dsi->dev, NULL);
- if (IS_ERR(dsi->mux)) {
- ret = PTR_ERR(dsi->mux);
- if (ret != -EPROBE_DEFER)
- DRM_DEV_ERROR(dsi->dev, "Failed to get mux: %d\n", ret);
- return ret;
- }
+ if (IS_ERR(dsi->mux))
+ return dev_err_probe(dsi->dev, PTR_ERR(dsi->mux),
+ "Failed to get mux\n");
base = devm_platform_ioremap_resource(pdev, 0);
if (IS_ERR(base))
@@ -1044,44 +1023,31 @@ static int nwl_dsi_parse_dt(struct nwl_dsi *dsi)
dsi->regmap =
devm_regmap_init_mmio(dsi->dev, base, &nwl_dsi_regmap_config);
- if (IS_ERR(dsi->regmap)) {
- ret = PTR_ERR(dsi->regmap);
- DRM_DEV_ERROR(dsi->dev, "Failed to create NWL DSI regmap: %d\n",
- ret);
- return ret;
- }
+ if (IS_ERR(dsi->regmap))
+ return dev_err_probe(dsi->dev, PTR_ERR(dsi->regmap),
+ "Failed to create NWL DSI regmap\n");
dsi->irq = platform_get_irq(pdev, 0);
- if (dsi->irq < 0) {
- DRM_DEV_ERROR(dsi->dev, "Failed to get device IRQ: %d\n",
- dsi->irq);
- return dsi->irq;
- }
+ if (dsi->irq < 0)
+ return dev_err_probe(dsi->dev, dsi->irq,
+ "Failed to get device IRQ\n");
dsi->rst_pclk = devm_reset_control_get_exclusive(dsi->dev, "pclk");
- if (IS_ERR(dsi->rst_pclk)) {
- DRM_DEV_ERROR(dsi->dev, "Failed to get pclk reset: %ld\n",
- PTR_ERR(dsi->rst_pclk));
- return PTR_ERR(dsi->rst_pclk);
- }
+ if (IS_ERR(dsi->rst_pclk))
+ return dev_err_probe(dsi->dev, PTR_ERR(dsi->rst_pclk),
+ "Failed to get pclk reset\n");
dsi->rst_byte = devm_reset_control_get_exclusive(dsi->dev, "byte");
- if (IS_ERR(dsi->rst_byte)) {
- DRM_DEV_ERROR(dsi->dev, "Failed to get byte reset: %ld\n",
- PTR_ERR(dsi->rst_byte));
- return PTR_ERR(dsi->rst_byte);
- }
+ if (IS_ERR(dsi->rst_byte))
+ return dev_err_probe(dsi->dev, PTR_ERR(dsi->rst_byte),
+ "Failed to get byte reset\n");
dsi->rst_esc = devm_reset_control_get_exclusive(dsi->dev, "esc");
- if (IS_ERR(dsi->rst_esc)) {
- DRM_DEV_ERROR(dsi->dev, "Failed to get esc reset: %ld\n",
- PTR_ERR(dsi->rst_esc));
- return PTR_ERR(dsi->rst_esc);
- }
+ if (IS_ERR(dsi->rst_esc))
+ return dev_err_probe(dsi->dev, PTR_ERR(dsi->rst_esc),
+ "Failed to get esc reset\n");
dsi->rst_dpi = devm_reset_control_get_exclusive(dsi->dev, "dpi");
- if (IS_ERR(dsi->rst_dpi)) {
- DRM_DEV_ERROR(dsi->dev, "Failed to get dpi reset: %ld\n",
- PTR_ERR(dsi->rst_dpi));
- return PTR_ERR(dsi->rst_dpi);
- }
+ if (IS_ERR(dsi->rst_dpi))
+ return dev_err_probe(dsi->dev, PTR_ERR(dsi->rst_dpi),
+ "Failed to get dpi reset\n");
return 0;
}
--
2.43.0