drivers/gpu/drm/xlnx/zynqmp_dp.c:2312:46: error: 'snprintf' output may be truncated before the last format character

From: kernel test robot
Date: Sat Dec 28 2024 - 14:30:46 EST


tree: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git master
head: fd0584d220fe285dc45be43eede55df89ad6a3d9
commit: 28edaacb821c69241f6c0be6bbd29f7145f1b44f drm: zynqmp_dp: Add debugfs interface for compliance testing
date: 8 weeks ago
config: x86_64-buildonly-randconfig-006-20241229 (https://download.01.org/0day-ci/archive/20241229/202412290337.iiDfMw5z-lkp@xxxxxxxxx/config)
compiler: gcc-12 (Debian 12.2.0-14) 12.2.0
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20241229/202412290337.iiDfMw5z-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/202412290337.iiDfMw5z-lkp@xxxxxxxxx/

All errors (new ones prefixed by >>):

drivers/gpu/drm/xlnx/zynqmp_dp.c: In function 'zynqmp_dp_bridge_debugfs_init':
>> drivers/gpu/drm/xlnx/zynqmp_dp.c:2312:46: error: 'snprintf' output may be truncated before the last format character [-Werror=format-truncation=]
2312 | snprintf(name, sizeof(name), fmt, i);
| ^~~
drivers/gpu/drm/xlnx/zynqmp_dp.c:2312:17: note: 'snprintf' output between 18 and 20 bytes into a destination of size 19
2312 | snprintf(name, sizeof(name), fmt, i);
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
cc1: all warnings being treated as errors


vim +/snprintf +2312 drivers/gpu/drm/xlnx/zynqmp_dp.c

2278
2279 DEFINE_DEBUGFS_ATTRIBUTE(fops_zynqmp_dp_ignore_hpd, zynqmp_dp_ignore_hpd_get,
2280 zynqmp_dp_ignore_hpd_set, "%llu\n");
2281
2282 static void zynqmp_dp_bridge_debugfs_init(struct drm_bridge *bridge,
2283 struct dentry *root)
2284 {
2285 struct zynqmp_dp *dp = bridge_to_dp(bridge);
2286 struct dentry *test;
2287 int i;
2288
2289 dp->test.bw_code = DP_LINK_BW_5_4;
2290 dp->test.link_cnt = dp->num_lanes;
2291
2292 test = debugfs_create_dir("test", root);
2293 #define CREATE_FILE(name) \
2294 debugfs_create_file(#name, 0600, test, dp, &fops_zynqmp_dp_##name)
2295 CREATE_FILE(pattern);
2296 CREATE_FILE(enhanced);
2297 CREATE_FILE(downspread);
2298 CREATE_FILE(active);
2299 CREATE_FILE(custom);
2300 CREATE_FILE(rate);
2301 CREATE_FILE(lanes);
2302 CREATE_FILE(ignore_aux_errors);
2303 CREATE_FILE(ignore_hpd);
2304
2305 for (i = 0; i < dp->num_lanes; i++) {
2306 static const char fmt[] = "lane%d_preemphasis";
2307 char name[sizeof(fmt)];
2308
2309 dp->debugfs_train_set[i].dp = dp;
2310 dp->debugfs_train_set[i].lane = i;
2311
> 2312 snprintf(name, sizeof(name), fmt, i);
2313 debugfs_create_file(name, 0600, test,
2314 &dp->debugfs_train_set[i],
2315 &fops_zynqmp_dp_preemphasis);
2316
2317 snprintf(name, sizeof(name), "lane%d_swing", i);
2318 debugfs_create_file(name, 0600, test,
2319 &dp->debugfs_train_set[i],
2320 &fops_zynqmp_dp_swing);
2321 }
2322 }
2323

--
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests/wiki