On 2024/6/4 5:25, kernel test robot wrote: > Hi Xiu, > > kernel test robot noticed the following build warnings: > > [auto build test WARNING on akpm-mm/mm-everything] > > url: https://github.com/intel-lab-lkp/linux/commits/Xiu-Jianfeng/mm-hugetlb_cgroup-identify-the-legacy-using-cgroup_subsys_on_dfl/20240603-201513 > base: https://git.kernel.org/pub/scm/linux/kernel/git/akpm/mm.git mm-everything > patch link: https://lore.kernel.org/r/20240603120506.1837322-3-xiujianfeng%40huawei.com > patch subject: [PATCH -next 2/3] mm/hugetlb_cgroup: prepare cftypes based on template > config: arm64-defconfig (https://download.01.org/0day-ci/archive/20240604/202406040437.z2Iel9db-lkp@xxxxxxxxx/config) > compiler: aarch64-linux-gcc (GCC) 13.2.0 > reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20240604/202406040437.z2Iel9db-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/202406040437.z2Iel9db-lkp@xxxxxxxxx/ > > All warnings (new ones prefixed by >>): > > mm/hugetlb_cgroup.c: In function 'hugetlb_cgroup_cfttypes_init': >>> mm/hugetlb_cgroup.c:828:21: warning: the comparison will always evaluate as 'true' for the address of 'name' will never be NULL [-Waddress] > 828 | if (tmpl->name) > | ^~~~ > In file included from include/linux/cgroup.h:27, > from mm/hugetlb_cgroup.c:20: > include/linux/cgroup-defs.h:605:14: note: 'name' declared here > 605 | char name[MAX_CFTYPE_NAME]; > | ^~~~ > Thanks, will fix in the next version. > > vim +828 mm/hugetlb_cgroup.c > > 814 > 815 static void __init > 816 hugetlb_cgroup_cfttypes_init(struct hstate *h, struct cftype *cft, > 817 struct cftype *tmpl, int tmpl_size) > 818 { > 819 char buf[32]; > 820 int i, idx = hstate_index(h); > 821 > 822 /* format the size */ > 823 mem_fmt(buf, sizeof(buf), huge_page_size(h)); > 824 > 825 for (i = 0; i < tmpl_size; cft++, tmpl++, i++) { > 826 *cft = *tmpl; > 827 /* rebuild the name */ > > 828 if (tmpl->name) > 829 snprintf(cft->name, MAX_CFTYPE_NAME, "%s.%s", buf, tmpl->name); > 830 /* rebuild the private */ > 831 if (tmpl->private) > 832 cft->private = MEMFILE_PRIVATE(idx, tmpl->private); > 833 /* rebuild the file_offset */ > 834 if (tmpl->file_offset) { > 835 unsigned int offset = tmpl->file_offset; > 836 > 837 cft->file_offset = MEMFILE_OFFSET0(offset) + > 838 MEMFILE_FIELD_SIZE(offset) * idx; > 839 } > 840 } > 841 } > 842 >