[bug report] scsi: ufs: ufs-exynos: Add UFS host support for Exynos SoCs

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hello Alim Akhtar,

The patch 55f4b1f73631: "scsi: ufs: ufs-exynos: Add UFS host support
for Exynos SoCs" from May 28, 2020, leads to the following static
checker warning:

	drivers/scsi/ufs/ufs-exynos.c:286 exynos_ufs_get_clk_info()
	warn: wrong type for 'ufs->mclk_rate' (should be 'ulong')

	drivers/scsi/ufs/ufs-exynos.c:287 exynos_ufs_get_clk_info()
	warn: wrong type for 'pclk_rate' (should be 'ulong')

drivers/scsi/ufs/ufs-exynos.c
    258 static int exynos_ufs_get_clk_info(struct exynos_ufs *ufs)
    259 {
    260 	struct ufs_hba *hba = ufs->hba;
    261 	struct list_head *head = &hba->clk_list_head;
    262 	struct ufs_clk_info *clki;
    263 	u32 pclk_rate;
                ^^^^^^^^^^^^^

    264 	u32 f_min, f_max;
    265 	u8 div = 0;
    266 	int ret = 0;
    267 
    268 	if (list_empty(head))
    269 		goto out;
    270 
    271 	list_for_each_entry(clki, head, list) {
    272 		if (!IS_ERR(clki->clk)) {
    273 			if (!strcmp(clki->name, "core_clk"))
    274 				ufs->clk_hci_core = clki->clk;
    275 			else if (!strcmp(clki->name, "sclk_unipro_main"))
    276 				ufs->clk_unipro_main = clki->clk;
    277 		}
    278 	}
    279 
    280 	if (!ufs->clk_hci_core || !ufs->clk_unipro_main) {
    281 		dev_err(hba->dev, "failed to get clk info\n");
    282 		ret = -EINVAL;
    283 		goto out;
    284 	}
    285 
--> 286 	ufs->mclk_rate = clk_get_rate(ufs->clk_unipro_main);
--> 287 	pclk_rate = clk_get_rate(ufs->clk_hci_core);

This a new Smatch warning which is not yet pushed.  The clk_get_rate()
function returns unsigned long so I guess ufs->mclk_rate and pclk_rate
should be changed from u32.  Not sure the runtime impact.

    288 	f_min = ufs->pclk_avail_min;
    289 	f_max = ufs->pclk_avail_max;
    290 
    291 	if (ufs->opts & EXYNOS_UFS_OPT_HAS_APB_CLK_CTRL) {
    292 		do {
    293 			pclk_rate /= (div + 1);
    294 
    295 			if (pclk_rate <= f_max)
    296 				break;
    297 			div++;
    298 		} while (pclk_rate >= f_min);
    299 	}
    300 
    301 	if (unlikely(pclk_rate < f_min || pclk_rate > f_max)) {
    302 		dev_err(hba->dev, "not available pclk range %d\n", pclk_rate);
    303 		ret = -EINVAL;
    304 		goto out;
    305 	}
    306 
    307 	ufs->pclk_rate = pclk_rate;
    308 	ufs->pclk_div = div;
    309 
    310 out:
    311 	return ret;
    312 }

regards,
dan carpenter



[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [SCSI Target Devel]     [Linux SCSI Target Infrastructure]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Linux IIO]     [Samba]     [Device Mapper]

  Powered by Linux