Hi Wei, kernel test robot noticed the following build warnings: [auto build test WARNING on char-misc/char-misc-testing] [also build test WARNING on char-misc/char-misc-next char-misc/char-misc-linus linus/master v6.4-rc6 next-20230614] [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/Wei-Chin-Tsai/kernel-process-fork-exit-export-symbol-for-fork-exit-tracing-functions/20230614-112218 base: char-misc/char-misc-testing patch link: https://lore.kernel.org/r/20230614032038.11699-3-Wei-chin.Tsai%40mediatek.com patch subject: [PATCH v2 2/3] memory: export symbols for memory related functions config: csky-randconfig-r011-20230612 (https://download.01.org/0day-ci/archive/20230614/202306141627.fYoZPKxi-lkp@xxxxxxxxx/config) compiler: csky-linux-gcc (GCC) 12.3.0 reproduce (this is a W=1 build): mkdir -p ~/bin wget https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross -O ~/bin/make.cross chmod +x ~/bin/make.cross git remote add char-misc https://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc.git git fetch char-misc char-misc-testing git checkout char-misc/char-misc-testing b4 shazam https://lore.kernel.org/r/20230614032038.11699-3-Wei-chin.Tsai@xxxxxxxxxxxx # save the config file mkdir build_dir && cp config build_dir/.config COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-12.3.0 ~/bin/make.cross W=1 O=build_dir ARCH=csky olddefconfig COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-12.3.0 ~/bin/make.cross W=1 O=build_dir ARCH=csky SHELL=/bin/bash fs/proc/ 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/202306141627.fYoZPKxi-lkp@xxxxxxxxx/ All warnings (new ones prefixed by >>): >> fs/proc/task_mmu.c:776:6: warning: no previous prototype for 'smap_gather_stats' [-Wmissing-prototypes] 776 | void smap_gather_stats(struct vm_area_struct *vma, | ^~~~~~~~~~~~~~~~~ vim +/smap_gather_stats +776 fs/proc/task_mmu.c 769 770 /* 771 * Gather mem stats from @vma with the indicated beginning 772 * address @start, and keep them in @mss. 773 * 774 * Use vm_start of @vma as the beginning address if @start is 0. 775 */ > 776 void smap_gather_stats(struct vm_area_struct *vma, 777 struct mem_size_stats *mss, unsigned long start) 778 { 779 const struct mm_walk_ops *ops = &smaps_walk_ops; 780 781 /* Invalid start */ 782 if (start >= vma->vm_end) 783 return; 784 785 if (vma->vm_file && shmem_mapping(vma->vm_file->f_mapping)) { 786 /* 787 * For shared or readonly shmem mappings we know that all 788 * swapped out pages belong to the shmem object, and we can 789 * obtain the swap value much more efficiently. For private 790 * writable mappings, we might have COW pages that are 791 * not affected by the parent swapped out pages of the shmem 792 * object, so we have to distinguish them during the page walk. 793 * Unless we know that the shmem object (or the part mapped by 794 * our VMA) has no swapped out pages at all. 795 */ 796 unsigned long shmem_swapped = shmem_swap_usage(vma); 797 798 if (!start && (!shmem_swapped || (vma->vm_flags & VM_SHARED) || 799 !(vma->vm_flags & VM_WRITE))) { 800 mss->swap += shmem_swapped; 801 } else { 802 ops = &smaps_shmem_walk_ops; 803 } 804 } 805 806 /* mmap_lock is held in m_start */ 807 if (!start) 808 walk_page_vma(vma, ops, mss); 809 else 810 walk_page_range(vma->vm_mm, start, vma->vm_end, ops, mss); 811 } 812 EXPORT_SYMBOL_GPL(smap_gather_stats); 813 -- 0-DAY CI Kernel Test Service https://github.com/intel/lkp-tests/wiki