Re: [PATCH v18 03/10] soc: mediatek: add mtk-mmsys support for mt8195 vdosys0
From: Jason-JH Lin
Date: Wed Apr 13 2022 - 04:43:25 EST
Hi Dan,
Thanks for the reviews.
On Wed, 2022-04-13 at 09:07 +0300, Dan Carpenter wrote:
> Hi "jason-jh.lin",
>
> url:
> https://urldefense.com/v3/__https://github.com/intel-lab-lkp/linux/commits/jason-jh-lin/Add-Mediatek-Soc-DRM-vdosys0-support-for-mt8195/20220412-183359__;!!CTRNKA9wMg0ARbw!wAjdEcyQM5SvYaLtDA1d-7DTP-0V0x2EYmyKkpr3QDeGXEknO3vUGir-oiGEYodb6RAr$
>
> base: git://anongit.freedesktop.org/drm/drm drm-next
> config: arc-randconfig-m031-20220411 (
> https://urldefense.com/v3/__https://download.01.org/0day-ci/archive/20220413/202204130935.urqkcDrG-lkp@xxxxxxxxx/config__;!!CTRNKA9wMg0ARbw!wAjdEcyQM5SvYaLtDA1d-7DTP-0V0x2EYmyKkpr3QDeGXEknO3vUGir-oiGEYvQ-IvSq$
> )
> compiler: arc-elf-gcc (GCC) 11.2.0
>
> If you fix the issue, kindly add following tag as appropriate
> Reported-by: kernel test robot <lkp@xxxxxxxxx>
> Reported-by: Dan Carpenter <dan.carpenter@xxxxxxxxxx>
>
> smatch warnings:
> drivers/soc/mediatek/mtk-mmsys.c:315 mtk_mmsys_probe() warn: passing
> zero to 'PTR_ERR'
>
> vim +/PTR_ERR +315 drivers/soc/mediatek/mtk-mmsys.c
>
> 13032709e23285 Matthias Brugger 2020-03-25 281 static int
> mtk_mmsys_probe(struct platform_device *pdev)
> 13032709e23285 Matthias Brugger 2020-03-25 282 {
> 2c758e301ed95a Enric Balletbo i Serra 2020-03-25 283 struct
> device *dev = &pdev->dev;
> 13032709e23285 Matthias Brugger 2020-03-25 284 struct
> platform_device *clks;
> 667c769246b01c Enric Balletbo i Serra 2020-03-25 285 struct
> platform_device *drm;
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 286 const
> struct mtk_mmsys_match_data *match_data;
> ce15e7faa2fc54 CK Hu 2021-03-17 287 struct
> mtk_mmsys *mmsys;
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 288 struct
> resource *res;
> 2c758e301ed95a Enric Balletbo i Serra 2020-03-25 289 int
> ret;
> 2c758e301ed95a Enric Balletbo i Serra 2020-03-25 290
> ce15e7faa2fc54 CK Hu 2021-03-17 291 mmsys =
> devm_kzalloc(dev, sizeof(*mmsys), GFP_KERNEL);
> ce15e7faa2fc54 CK Hu 2021-03-17 292 if
> (!mmsys)
> ce15e7faa2fc54 CK Hu 2021-03-17 293
> return -ENOMEM;
> ce15e7faa2fc54 CK Hu 2021-03-17 294
> ce15e7faa2fc54 CK Hu 2021-03-17 295 mmsys-
> >regs = devm_platform_ioremap_resource(pdev, 0);
> ce15e7faa2fc54 CK Hu 2021-03-17 296 if
> (IS_ERR(mmsys->regs)) {
> ce15e7faa2fc54 CK Hu 2021-03-17 297
> ret = PTR_ERR(mmsys->regs);
> cc6576029aedc7 Enric Balletbo i Serra 2020-10-06 298
> dev_err(dev, "Failed to ioremap mmsys registers: %d\n", ret);
> 2c758e301ed95a Enric Balletbo i Serra 2020-03-25 299
> return ret;
> 2c758e301ed95a Enric Balletbo i Serra 2020-03-25 300 }
> 2c758e301ed95a Enric Balletbo i Serra 2020-03-25 301
> f27ef2856343e2 Enric Balletbo i Serra 2021-09-30 302 spin_lo
> ck_init(&mmsys->lock);
> f27ef2856343e2 Enric Balletbo i Serra 2021-09-30 303
> f27ef2856343e2 Enric Balletbo i Serra 2021-09-30 304 mmsys-
> >rcdev.owner = THIS_MODULE;
> f27ef2856343e2 Enric Balletbo i Serra 2021-09-30 305 mmsys-
> >rcdev.nr_resets = 32;
> f27ef2856343e2 Enric Balletbo i Serra 2021-09-30 306 mmsys-
> >rcdev.ops = &mtk_mmsys_reset_ops;
> f27ef2856343e2 Enric Balletbo i Serra 2021-09-30 307 mmsys-
> >rcdev.of_node = pdev->dev.of_node;
> f27ef2856343e2 Enric Balletbo i Serra 2021-09-30 308 ret =
> devm_reset_controller_register(&pdev->dev, &mmsys->rcdev);
> f27ef2856343e2 Enric Balletbo i Serra 2021-09-30 309 if
> (ret) {
> f27ef2856343e2 Enric Balletbo i Serra 2021-09-30 310
> dev_err(&pdev->dev, "Couldn't register mmsys reset controller: %d\n",
> ret);
> f27ef2856343e2 Enric Balletbo i Serra 2021-09-30 311
> return ret;
> f27ef2856343e2 Enric Balletbo i Serra 2021-09-30 312 }
> f27ef2856343e2 Enric Balletbo i Serra 2021-09-30 313
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 314 res =
> platform_get_resource(pdev, IORESOURCE_MEM, 0);
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 @315 if
> (PTR_ERR(res)) {
>
> You probably meant IS_ERR() instead of PTR_ERR(). But actually
> platform_get_resource() does not return error pointers, it returns
> NULL so the correct check is:
>
> if (!res) {
>
Yes, I missed this fix and I will also apply the fix to
mtk_drm_drv.c:639 in [v18,07/10] of this series.
Thank you!
Regards,
Jason-JH.Lin
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 316
> dev_err(dev, "Couldn't get mmsys resource\n");
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 317
> return -EINVAL;
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 318 }
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 319 mmsys-
> >io_start = res->start;
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 320
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 321 match_d
> ata = of_device_get_match_data(dev);
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 322 if
> (match_data->num_drv_data > 1) {
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 323
> /* This SoC has multiple mmsys channels */
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 324
> ret = mtk_mmsys_find_match_drvdata(mmsys, match_data);
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 325
> if (ret < 0) {
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 326
> dev_err(dev, "Couldn't get match driver data\n");
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 327
> return ret;
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 328
> }
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 329
> mmsys->data = match_data->drv_data[ret];
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 330 } else
> {
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 331
> dev_dbg(dev, "Using single mmsys channel\n");
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 332
> mmsys->data = match_data->drv_data[0];
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 333 }
> 8cfc54a36d3e79 jason-jh.lin 2022-04-12 334
> ce15e7faa2fc54 CK Hu 2021-03-17 335 platfor
> m_set_drvdata(pdev, mmsys);
> 13032709e23285 Matthias Brugger 2020-03-25 336
> ce15e7faa2fc54 CK Hu 2021-03-17 337 clks =
> platform_device_register_data(&pdev->dev, mmsys->data->clk_driver,
> 13032709e23285 Matthias Brugger 2020-03-25 338
> PLATFORM_DEVID_AUTO, NULL, 0);
> 13032709e23285 Matthias Brugger 2020-03-25 339 if
> (IS_ERR(clks))
> 13032709e23285 Matthias Brugger 2020-03-25 340
> return PTR_ERR(clks);
> 13032709e23285 Matthias Brugger 2020-03-25 341
> 667c769246b01c Enric Balletbo i Serra 2020-03-25 342 drm =
> platform_device_register_data(&pdev->dev, "mediatek-drm",
> 667c769246b01c Enric Balletbo i Serra 2020-03-25 343
> PLATFORM_DEVID_AUTO, NULL, 0);
> ff34e17cf9bce8 Wei Yongjun 2020-05-06 344 if
> (IS_ERR(drm)) {
> ff34e17cf9bce8 Wei Yongjun 2020-05-06 345
> platform_device_unregister(clks);
> 667c769246b01c Enric Balletbo i Serra 2020-03-25 346
> return PTR_ERR(drm);
> ff34e17cf9bce8 Wei Yongjun 2020-05-06 347 }
> 667c769246b01c Enric Balletbo i Serra 2020-03-25 348
> 13032709e23285 Matthias Brugger 2020-03-25 349 return
> 0;
> 13032709e23285 Matthias Brugger 2020-03-25 350 }
>
--
Jason-JH Lin <jason-jh.lin@xxxxxxxxxxxx>