lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date:   Mon, 7 Jun 2021 12:43:11 +0800
From:   kernel test robot <lkp@...el.com>
To:     linux-kernel@...r.kernel.org
Cc:     kbuild-all@...ts.01.org, Saravana Kannan <saravanak@...gle.com>,
        Ondrej Jirman <megous@...ous.com>
Subject: Re: [PATCH] drm/sun4i: dw-hdmi: Make HDMI PHY into a platform device

Hi Ondrej,

I love your patch! Perhaps something to improve:

[auto build test WARNING on sunxi/sunxi/for-next]
[also build test WARNING on drm-intel/for-linux-next drm-tip/drm-tip v5.13-rc5 next-20210604]
[cannot apply to mripard/sunxi/for-next]
[If your patch is applied to the wrong git tree, kindly drop us a note.
And when submitting patch, we suggest to use '--base' as documented in
https://git-scm.com/docs/git-format-patch]

url:    https://github.com/0day-ci/linux/commits/Ondrej-Jirman/drm-sun4i-dw-hdmi-Make-HDMI-PHY-into-a-platform-device/20210607-073052
base:   https://git.kernel.org/pub/scm/linux/kernel/git/sunxi/linux.git sunxi/for-next
config: arm64-allyesconfig (attached as .config)
compiler: aarch64-linux-gcc (GCC) 9.3.0
reproduce (this is a W=1 build):
        wget https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross -O ~/bin/make.cross
        chmod +x ~/bin/make.cross
        # https://github.com/0day-ci/linux/commit/c6089f30e38cc9cc85d5c5856420a8c429cdfa23
        git remote add linux-review https://github.com/0day-ci/linux
        git fetch --no-tags linux-review Ondrej-Jirman/drm-sun4i-dw-hdmi-Make-HDMI-PHY-into-a-platform-device/20210607-073052
        git checkout c6089f30e38cc9cc85d5c5856420a8c429cdfa23
        # save the attached .config to linux build tree
        COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-9.3.0 make.cross ARCH=arm64 

If you fix the issue, kindly add following tag as appropriate
Reported-by: kernel test robot <lkp@...el.com>

All warnings (new ones prefixed by >>):

>> drivers/gpu/drm/sun4i/sun8i_hdmi_phy.c:620:5: warning: no previous prototype for 'sun8i_hdmi_phy_probe' [-Wmissing-prototypes]
     620 | int sun8i_hdmi_phy_probe(struct platform_device *pdev)
         |     ^~~~~~~~~~~~~~~~~~~~
>> drivers/gpu/drm/sun4i/sun8i_hdmi_phy.c:752:5: warning: no previous prototype for 'sun8i_hdmi_phy_remove' [-Wmissing-prototypes]
     752 | int sun8i_hdmi_phy_remove(struct platform_device *pdev)
         |     ^~~~~~~~~~~~~~~~~~~~~


vim +/sun8i_hdmi_phy_probe +620 drivers/gpu/drm/sun4i/sun8i_hdmi_phy.c

   619	
 > 620	int sun8i_hdmi_phy_probe(struct platform_device *pdev)
   621	{
   622		const struct of_device_id *match;
   623		struct device *dev = &pdev->dev;
   624		struct device_node *node = dev->of_node;
   625		struct sun8i_hdmi_phy *phy;
   626		struct resource res;
   627		void __iomem *regs;
   628		int ret;
   629	
   630		match = of_match_node(sun8i_hdmi_phy_of_table, node);
   631		if (!match) {
   632			dev_err(dev, "Incompatible HDMI PHY\n");
   633			return -EINVAL;
   634		}
   635	
   636		phy = devm_kzalloc(dev, sizeof(*phy), GFP_KERNEL);
   637		if (!phy)
   638			return -ENOMEM;
   639	
   640		phy->variant = (struct sun8i_hdmi_phy_variant *)match->data;
   641	
   642		ret = of_address_to_resource(node, 0, &res);
   643		if (ret) {
   644			dev_err(dev, "phy: Couldn't get our resources\n");
   645			return ret;
   646		}
   647	
   648		regs = devm_ioremap_resource(dev, &res);
   649		if (IS_ERR(regs)) {
   650			dev_err(dev, "Couldn't map the HDMI PHY registers\n");
   651			return PTR_ERR(regs);
   652		}
   653	
   654		phy->regs = devm_regmap_init_mmio(dev, regs,
   655						  &sun8i_hdmi_phy_regmap_config);
   656		if (IS_ERR(phy->regs)) {
   657			dev_err(dev, "Couldn't create the HDMI PHY regmap\n");
   658			return PTR_ERR(phy->regs);
   659		}
   660	
   661		phy->clk_bus = of_clk_get_by_name(node, "bus");
   662		if (IS_ERR(phy->clk_bus)) {
   663			dev_err(dev, "Could not get bus clock\n");
   664			return PTR_ERR(phy->clk_bus);
   665		}
   666	
   667		phy->clk_mod = of_clk_get_by_name(node, "mod");
   668		if (IS_ERR(phy->clk_mod)) {
   669			dev_err(dev, "Could not get mod clock\n");
   670			ret = PTR_ERR(phy->clk_mod);
   671			goto err_put_clk_bus;
   672		}
   673	
   674		if (phy->variant->has_phy_clk) {
   675			phy->clk_pll0 = of_clk_get_by_name(node, "pll-0");
   676			if (IS_ERR(phy->clk_pll0)) {
   677				dev_err(dev, "Could not get pll-0 clock\n");
   678				ret = PTR_ERR(phy->clk_pll0);
   679				goto err_put_clk_mod;
   680			}
   681	
   682			if (phy->variant->has_second_pll) {
   683				phy->clk_pll1 = of_clk_get_by_name(node, "pll-1");
   684				if (IS_ERR(phy->clk_pll1)) {
   685					dev_err(dev, "Could not get pll-1 clock\n");
   686					ret = PTR_ERR(phy->clk_pll1);
   687					goto err_put_clk_pll0;
   688				}
   689			}
   690		}
   691	
   692		phy->rst_phy = of_reset_control_get_shared(node, "phy");
   693		if (IS_ERR(phy->rst_phy)) {
   694			dev_err(dev, "Could not get phy reset control\n");
   695			ret = PTR_ERR(phy->rst_phy);
   696			goto err_put_clk_pll1;
   697		}
   698	
   699		ret = reset_control_deassert(phy->rst_phy);
   700		if (ret) {
   701			dev_err(dev, "Cannot deassert phy reset control: %d\n", ret);
   702			goto err_put_rst_phy;
   703		}
   704	
   705		ret = clk_prepare_enable(phy->clk_bus);
   706		if (ret) {
   707			dev_err(dev, "Cannot enable bus clock: %d\n", ret);
   708			goto err_deassert_rst_phy;
   709		}
   710	
   711		ret = clk_prepare_enable(phy->clk_mod);
   712		if (ret) {
   713			dev_err(dev, "Cannot enable mod clock: %d\n", ret);
   714			goto err_disable_clk_bus;
   715		}
   716	
   717		if (phy->variant->has_phy_clk) {
   718			ret = sun8i_phy_clk_create(phy, dev,
   719						   phy->variant->has_second_pll);
   720			if (ret) {
   721				dev_err(dev, "Couldn't create the PHY clock\n");
   722				goto err_disable_clk_mod;
   723			}
   724	
   725			clk_prepare_enable(phy->clk_phy);
   726		}
   727	
   728		platform_set_drvdata(pdev, phy);
   729	
   730		return 0;
   731	
   732	err_disable_clk_mod:
   733		clk_disable_unprepare(phy->clk_mod);
   734	err_disable_clk_bus:
   735		clk_disable_unprepare(phy->clk_bus);
   736	err_deassert_rst_phy:
   737		reset_control_assert(phy->rst_phy);
   738	err_put_rst_phy:
   739		reset_control_put(phy->rst_phy);
   740	err_put_clk_pll1:
   741		clk_put(phy->clk_pll1);
   742	err_put_clk_pll0:
   743		clk_put(phy->clk_pll0);
   744	err_put_clk_mod:
   745		clk_put(phy->clk_mod);
   746	err_put_clk_bus:
   747		clk_put(phy->clk_bus);
   748	
   749		return ret;
   750	}
   751	
 > 752	int sun8i_hdmi_phy_remove(struct platform_device *pdev)
   753	{
   754		struct sun8i_hdmi_phy *phy = platform_get_drvdata(pdev);
   755	
   756		clk_disable_unprepare(phy->clk_mod);
   757		clk_disable_unprepare(phy->clk_bus);
   758		clk_disable_unprepare(phy->clk_phy);
   759	
   760		reset_control_assert(phy->rst_phy);
   761	
   762		reset_control_put(phy->rst_phy);
   763	
   764		clk_put(phy->clk_pll0);
   765		clk_put(phy->clk_pll1);
   766		clk_put(phy->clk_mod);
   767		clk_put(phy->clk_bus);
   768		return 0;
   769	}
   770	

---
0-DAY CI Kernel Test Service, Intel Corporation
https://lists.01.org/hyperkitty/list/kbuild-all@lists.01.org

Download attachment ".config.gz" of type "application/gzip" (77666 bytes)

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ