Hi Christian, kernel test robot noticed the following build warnings: [auto build test WARNING on mtd/nand/next] [also build test WARNING on mani-mhi/mhi-next linus/master v6.14-rc1 next-20250207] [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#_base_tree_information] url: https://github.com/intel-lab-lkp/linux/commits/Christian-Marangi/mtd-rawnand-qcom-fix-broken-config-in-qcom_param_page_type_exec/20250208-035717 base: https://git.kernel.org/pub/scm/linux/kernel/git/mtd/linux.git nand/next patch link: https://lore.kernel.org/r/20250207195442.19157-1-ansuelsmth%40gmail.com patch subject: [PATCH] mtd: rawnand: qcom: fix broken config in qcom_param_page_type_exec config: sh-randconfig-r133-20250208 (https://download.01.org/0day-ci/archive/20250209/202502090258.EVrsPFF7-lkp@xxxxxxxxx/config) compiler: sh4-linux-gcc (GCC) 14.2.0 reproduce: (https://download.01.org/0day-ci/archive/20250209/202502090258.EVrsPFF7-lkp@xxxxxxxxx/reproduce) If you fix the issue in a separate patch/commit (i.e. not just a new version of the same patch/commit), kindly add following tags | Reported-by: kernel test robot <lkp@xxxxxxxxx> | Closes: https://lore.kernel.org/oe-kbuild-all/202502090258.EVrsPFF7-lkp@xxxxxxxxx/ sparse warnings: (new ones prefixed by >>) >> drivers/mtd/nand/raw/qcom_nandc.c:1884:27: sparse: sparse: incorrect type in assignment (different base types) @@ expected restricted __le32 [usertype] cfg0 @@ got unsigned long @@ drivers/mtd/nand/raw/qcom_nandc.c:1884:27: sparse: expected restricted __le32 [usertype] cfg0 drivers/mtd/nand/raw/qcom_nandc.c:1884:27: sparse: got unsigned long >> drivers/mtd/nand/raw/qcom_nandc.c:1889:27: sparse: sparse: incorrect type in assignment (different base types) @@ expected restricted __le32 [usertype] cfg1 @@ got unsigned long @@ drivers/mtd/nand/raw/qcom_nandc.c:1889:27: sparse: expected restricted __le32 [usertype] cfg1 drivers/mtd/nand/raw/qcom_nandc.c:1889:27: sparse: got unsigned long vim +1884 drivers/mtd/nand/raw/qcom_nandc.c 1857 1858 static int qcom_param_page_type_exec(struct nand_chip *chip, const struct nand_subop *subop) 1859 { 1860 struct qcom_nand_host *host = to_qcom_nand_host(chip); 1861 struct qcom_nand_controller *nandc = get_qcom_nand_controller(chip); 1862 struct qcom_op q_op = {}; 1863 const struct nand_op_instr *instr = NULL; 1864 unsigned int op_id = 0; 1865 unsigned int len = 0; 1866 int ret; 1867 1868 ret = qcom_parse_instructions(chip, subop, &q_op); 1869 if (ret) 1870 return ret; 1871 1872 q_op.cmd_reg |= cpu_to_le32(PAGE_ACC | LAST_PAGE); 1873 1874 nandc->buf_count = 0; 1875 nandc->buf_start = 0; 1876 host->use_ecc = false; 1877 qcom_clear_read_regs(nandc); 1878 qcom_clear_bam_transaction(nandc); 1879 1880 nandc->regs->cmd = q_op.cmd_reg; 1881 nandc->regs->addr0 = 0; 1882 nandc->regs->addr1 = 0; 1883 > 1884 nandc->regs->cfg0 = FIELD_PREP(CW_PER_PAGE_MASK, 0) | 1885 FIELD_PREP(UD_SIZE_BYTES_MASK, 512) | 1886 FIELD_PREP(NUM_ADDR_CYCLES_MASK, 5) | 1887 FIELD_PREP(SPARE_SIZE_BYTES_MASK, 0); 1888 > 1889 nandc->regs->cfg1 = FIELD_PREP(NAND_RECOVERY_CYCLES_MASK, 7) | 1890 FIELD_PREP(BAD_BLOCK_BYTE_NUM_MASK, 17) | 1891 FIELD_PREP(CS_ACTIVE_BSY, 0) | 1892 FIELD_PREP(BAD_BLOCK_IN_SPARE_AREA, 1) | 1893 FIELD_PREP(WR_RD_BSY_GAP_MASK, 2) | 1894 FIELD_PREP(WIDE_FLASH, 0) | 1895 FIELD_PREP(DEV0_CFG1_ECC_DISABLE, 1); 1896 1897 if (!nandc->props->qpic_version2) 1898 nandc->regs->ecc_buf_cfg = cpu_to_le32(ECC_CFG_ECC_DISABLE); 1899 1900 /* configure CMD1 and VLD for ONFI param probing in QPIC v1 */ 1901 if (!nandc->props->qpic_version2) { 1902 nandc->regs->vld = cpu_to_le32((nandc->vld & ~READ_START_VLD)); 1903 nandc->regs->cmd1 = cpu_to_le32((nandc->cmd1 & ~(0xFF << READ_ADDR)) 1904 | NAND_CMD_PARAM << READ_ADDR); 1905 } 1906 1907 nandc->regs->exec = cpu_to_le32(1); 1908 1909 if (!nandc->props->qpic_version2) { 1910 nandc->regs->orig_cmd1 = cpu_to_le32(nandc->cmd1); 1911 nandc->regs->orig_vld = cpu_to_le32(nandc->vld); 1912 } 1913 1914 instr = q_op.data_instr; 1915 op_id = q_op.data_instr_idx; 1916 len = nand_subop_get_data_len(subop, op_id); 1917 1918 nandc_set_read_loc(chip, 0, 0, 0, len, 1); 1919 1920 if (!nandc->props->qpic_version2) { 1921 qcom_write_reg_dma(nandc, &nandc->regs->vld, NAND_DEV_CMD_VLD, 1, 0); 1922 qcom_write_reg_dma(nandc, &nandc->regs->cmd1, NAND_DEV_CMD1, 1, NAND_BAM_NEXT_SGL); 1923 } 1924 1925 nandc->buf_count = len; 1926 memset(nandc->data_buffer, 0xff, nandc->buf_count); 1927 1928 config_nand_single_cw_page_read(chip, false, 0); 1929 1930 qcom_read_data_dma(nandc, FLASH_BUF_ACC, nandc->data_buffer, 1931 nandc->buf_count, 0); 1932 1933 /* restore CMD1 and VLD regs */ 1934 if (!nandc->props->qpic_version2) { 1935 qcom_write_reg_dma(nandc, &nandc->regs->orig_cmd1, NAND_DEV_CMD1_RESTORE, 1, 0); 1936 qcom_write_reg_dma(nandc, &nandc->regs->orig_vld, NAND_DEV_CMD_VLD_RESTORE, 1, 1937 NAND_BAM_NEXT_SGL); 1938 } 1939 1940 ret = qcom_submit_descs(nandc); 1941 if (ret) { 1942 dev_err(nandc->dev, "failure in submitting param page descriptor\n"); 1943 goto err_out; 1944 } 1945 1946 ret = qcom_wait_rdy_poll(chip, q_op.rdy_timeout_ms); 1947 if (ret) 1948 goto err_out; 1949 1950 memcpy(instr->ctx.data.buf.in, nandc->data_buffer, len); 1951 1952 err_out: 1953 return ret; 1954 } 1955 -- 0-DAY CI Kernel Test Service https://github.com/intel/lkp-tests/wiki