On 2/24/21 1:02 PM, Randy Dunlap wrote: > On 2/24/21 12:42 PM, Nick Desaulniers wrote: >> On Wed, Feb 24, 2021 at 12:03 PM Randy Dunlap <rdunlap@xxxxxxxxxxxxx> wrote: >>> >>> On 2/24/21 4:46 AM, kernel test robot wrote: >>>> Hi Randy, >>>> >>>> FYI, the error/warning still remains. >>>> >>>> tree: https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git master >>>> head: 577c283560fe8a81a23a95654c6d13e8412d22f1 >>>> commit: bfa5782b9caa26f93f42ad79804e1f75a1ce9f18 [11942/12503] fbdev: atyfb: add stubs for aty_{ld,st}_lcd() >>>> config: arm64-randconfig-r004-20210223 (attached as .config) >>>> compiler: clang version 13.0.0 (https://github.com/llvm/llvm-project f14a14dd2564703db02f80c00db8ae492b594f77) >>>> reproduce (this is a W=1 build): >>>> wget https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross -O ~/bin/make.cross >>>> chmod +x ~/bin/make.cross >>>> # install arm64 cross compiling tool for clang build >>>> # apt-get install binutils-aarch64-linux-gnu >>>> # https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/commit/?id=bfa5782b9caa26f93f42ad79804e1f75a1ce9f18 >>>> git remote add linux-next https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git >>>> git fetch --no-tags linux-next master >>>> git checkout bfa5782b9caa26f93f42ad79804e1f75a1ce9f18 >>>> # save the attached .config to linux build tree >>>> COMPILER_INSTALL_PATH=$HOME/0day COMPILER=clang make.cross ARCH=arm64 >>>> >>>> If you fix the issue, kindly add following tag as appropriate >>>> Reported-by: kernel test robot <lkp@xxxxxxxxx> >>>> >>>> All warnings (new ones prefixed by >>): >>>> >>>>>> drivers/video/fbdev/aty/atyfb_base.c:180:6: warning: no previous prototype for function 'aty_st_lcd' [-Wmissing-prototypes] >>>> void aty_st_lcd(int index, u32 val, const struct atyfb_par *par) >>>> ^ >>>> drivers/video/fbdev/aty/atyfb_base.c:180:1: note: declare 'static' if the function is not intended to be used outside of this translation unit >>>> void aty_st_lcd(int index, u32 val, const struct atyfb_par *par) >>>> ^ >>>> static >>>>>> drivers/video/fbdev/aty/atyfb_base.c:183:5: warning: no previous prototype for function 'aty_ld_lcd' [-Wmissing-prototypes] >>>> u32 aty_ld_lcd(int index, const struct atyfb_par *par) >>>> ^ >>>> drivers/video/fbdev/aty/atyfb_base.c:183:1: note: declare 'static' if the function is not intended to be used outside of this translation unit >>>> u32 aty_ld_lcd(int index, const struct atyfb_par *par) >>>> ^ >>>> static >>>> 2 warnings generated. >>>> >>> >>> These 2 functions are also used/usable (depending on CONFIG options) in >>> mach64_ct.c so they can't be static. >>> >>> AFAIK, we don't make functions have different qualifiers depending on >>> config options. >> >> Is there a shared header included by both mach64_ct.c and atyfb_base.c >> you could provide a declaration in, that way should the definition >> change we'd catch such a change in order to not break the callers? >> > > atyfb.h: > > #if defined(CONFIG_PMAC_BACKLIGHT) || defined (CONFIG_FB_ATY_GENERIC_LCD) || \ > defined (CONFIG_FB_ATY_BACKLIGHT) > extern void aty_st_lcd(int index, u32 val, const struct atyfb_par *par); > extern u32 aty_ld_lcd(int index, const struct atyfb_par *par); > #endif > > so it's already there unless the .config did not include those #ifdef CONFIG_s. > I'll recheck that. OK, none of those 3 kconfig symbols is set. I'll check again where the usage is. -- ~Randy