linux-mm.kvack.org archive mirror
 help / color / mirror / Atom feed
* [linux-next:master 5094/7430] arch/riscv/mm/init.c:454:25: error: expected '=', ',', ';', 'asm' or '__attribute__' before '__inidata'
@ 2021-06-04 12:59 kernel test robot
  2021-06-04 14:08 ` Jisheng Zhang
  0 siblings, 1 reply; 2+ messages in thread
From: kernel test robot @ 2021-06-04 12:59 UTC (permalink / raw)
  To: Jisheng Zhang; +Cc: kbuild-all, Linux Memory Management List, Palmer Dabbelt

[-- Attachment #1: Type: text/plain, Size: 7957 bytes --]

tree:   https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git master
head:   ccc252d2e818f6a479441119ad453c3ce7c7c461
commit: 010623568222bd144eb73aa9f3b46c79b63d7676 [5094/7430] riscv: mm: init: Consolidate vars, functions
config: riscv-randconfig-r002-20210604 (attached as .config)
compiler: riscv32-linux-gcc (GCC) 9.3.0
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
        # https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/commit/?id=010623568222bd144eb73aa9f3b46c79b63d7676
        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 010623568222bd144eb73aa9f3b46c79b63d7676
        # save the attached .config to linux build tree
        COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-9.3.0 make.cross ARCH=riscv 

If you fix the issue, kindly add following tag as appropriate
Reported-by: kernel test robot <lkp@intel.com>

All errors (new ones prefixed by >>):

   In file included from include/linux/pgtable.h:6,
                    from include/linux/mm.h:33,
                    from arch/riscv/mm/init.c:10:
   arch/riscv/include/asm/pgtable.h: In function 'mk_pmd':
   arch/riscv/include/asm/pgtable.h:518:9: error: implicit declaration of function 'pfn_pmd'; did you mean 'pfn_pgd'? [-Werror=implicit-function-declaration]
     518 |  return pfn_pmd(page_to_pfn(page), prot);
         |         ^~~~~~~
         |         pfn_pgd
   In file included from arch/riscv/include/asm/page.h:185,
                    from arch/riscv/include/asm/thread_info.h:11,
                    from include/linux/thread_info.h:59,
                    from include/asm-generic/preempt.h:5,
                    from ./arch/riscv/include/generated/asm/preempt.h:1,
                    from include/linux/preempt.h:78,
                    from include/linux/spinlock.h:51,
                    from include/linux/mmzone.h:8,
                    from include/linux/gfp.h:6,
                    from include/linux/mm.h:10,
                    from arch/riscv/mm/init.c:10:
   include/asm-generic/memory_model.h:64:14: error: implicit declaration of function 'page_to_section'; did you mean 'present_section'? [-Werror=implicit-function-declaration]
      64 |  int __sec = page_to_section(__pg);   \
         |              ^~~~~~~~~~~~~~~
   include/asm-generic/memory_model.h:81:21: note: in expansion of macro '__page_to_pfn'
      81 | #define page_to_pfn __page_to_pfn
         |                     ^~~~~~~~~~~~~
   arch/riscv/include/asm/pgtable.h:518:17: note: in expansion of macro 'page_to_pfn'
     518 |  return pfn_pmd(page_to_pfn(page), prot);
         |                 ^~~~~~~~~~~
   In file included from include/linux/pgtable.h:6,
                    from include/linux/mm.h:33,
                    from arch/riscv/mm/init.c:10:
   arch/riscv/include/asm/pgtable.h:518:9: error: incompatible types when returning type 'int' but 'pmd_t' {aka 'struct <anonymous>'} was expected
     518 |  return pfn_pmd(page_to_pfn(page), prot);
         |         ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
   In file included from arch/riscv/mm/init.c:10:
   include/linux/mm.h: At top level:
   include/linux/mm.h:1552:29: error: conflicting types for 'page_to_section'
    1552 | static inline unsigned long page_to_section(const struct page *page)
         |                             ^~~~~~~~~~~~~~~
   In file included from arch/riscv/include/asm/page.h:185,
                    from arch/riscv/include/asm/thread_info.h:11,
                    from include/linux/thread_info.h:59,
                    from include/asm-generic/preempt.h:5,
                    from ./arch/riscv/include/generated/asm/preempt.h:1,
                    from include/linux/preempt.h:78,
                    from include/linux/spinlock.h:51,
                    from include/linux/mmzone.h:8,
                    from include/linux/gfp.h:6,
                    from include/linux/mm.h:10,
                    from arch/riscv/mm/init.c:10:
   include/asm-generic/memory_model.h:64:14: note: previous implicit declaration of 'page_to_section' was here
      64 |  int __sec = page_to_section(__pg);   \
         |              ^~~~~~~~~~~~~~~
   include/asm-generic/memory_model.h:81:21: note: in expansion of macro '__page_to_pfn'
      81 | #define page_to_pfn __page_to_pfn
         |                     ^~~~~~~~~~~~~
   arch/riscv/include/asm/pgtable.h:518:17: note: in expansion of macro 'page_to_pfn'
     518 |  return pfn_pmd(page_to_pfn(page), prot);
         |                 ^~~~~~~~~~~
   In file included from include/linux/kexec.h:28,
                    from include/linux/crash_dump.h:5,
                    from arch/riscv/mm/init.c:20:
   arch/riscv/include/asm/kexec.h:45:1: warning: 'extern' is not at beginning of declaration [-Wold-style-declaration]
      45 | const extern unsigned char riscv_kexec_relocate[];
         | ^~~~~
   arch/riscv/include/asm/kexec.h:46:1: warning: 'extern' is not at beginning of declaration [-Wold-style-declaration]
      46 | const extern unsigned int riscv_kexec_relocate_size;
         | ^~~~~
>> arch/riscv/mm/init.c:454:25: error: expected '=', ',', ';', 'asm' or '__attribute__' before '__inidata'
     454 | static uintptr_t xiprom __inidata;
         |                         ^~~~~~~~~
   In file included from include/linux/pgtable.h:6,
                    from include/linux/mm.h:33,
                    from arch/riscv/mm/init.c:10:
   arch/riscv/mm/init.c: In function 'create_kernel_page_table':
>> arch/riscv/mm/init.c:457:51: error: 'xiprom' undeclared (first use in this function); did you mean '_xiprom'?
     457 | #define xiprom         (*((uintptr_t *)XIP_FIXUP(&xiprom)))
         |                                                   ^~~~~~
   arch/riscv/include/asm/pgtable.h:98:30: note: in definition of macro 'XIP_FIXUP'
      98 |  uintptr_t __a = (uintptr_t)(addr);     \
         |                              ^~~~
   arch/riscv/mm/init.c:467:8: note: in expansion of macro 'xiprom'
     467 |        xiprom + (va - kernel_virt_addr),
         |        ^~~~~~
   arch/riscv/mm/init.c:457:51: note: each undeclared identifier is reported only once for each function it appears in
     457 | #define xiprom         (*((uintptr_t *)XIP_FIXUP(&xiprom)))
         |                                                   ^~~~~~
   arch/riscv/include/asm/pgtable.h:98:30: note: in definition of macro 'XIP_FIXUP'
      98 |  uintptr_t __a = (uintptr_t)(addr);     \
         |                              ^~~~
   arch/riscv/mm/init.c:467:8: note: in expansion of macro 'xiprom'
     467 |        xiprom + (va - kernel_virt_addr),
         |        ^~~~~~
   arch/riscv/mm/init.c: In function 'setup_vm':
>> arch/riscv/mm/init.c:457:51: error: 'xiprom' undeclared (first use in this function); did you mean '_xiprom'?
     457 | #define xiprom         (*((uintptr_t *)XIP_FIXUP(&xiprom)))
         |                                                   ^~~~~~
   arch/riscv/include/asm/pgtable.h:98:30: note: in definition of macro 'XIP_FIXUP'
      98 |  uintptr_t __a = (uintptr_t)(addr);     \
         |                              ^~~~
   arch/riscv/mm/init.c:499:2: note: in expansion of macro 'xiprom'
     499 |  xiprom = (uintptr_t)CONFIG_XIP_PHYS_ADDR;
         |  ^~~~~~
   cc1: some warnings being treated as errors


vim +454 arch/riscv/mm/init.c

   452	
   453	#ifdef CONFIG_XIP_KERNEL
 > 454	static uintptr_t xiprom __inidata;
   455	static uintptr_t xiprom_sz __initdata;
   456	#define xiprom_sz      (*((uintptr_t *)XIP_FIXUP(&xiprom_sz)))
 > 457	#define xiprom         (*((uintptr_t *)XIP_FIXUP(&xiprom)))
   458	

---
0-DAY CI Kernel Test Service, Intel Corporation
https://lists.01.org/hyperkitty/list/kbuild-all@lists.01.org

[-- Attachment #2: .config.gz --]
[-- Type: application/gzip, Size: 22266 bytes --]

^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [linux-next:master 5094/7430] arch/riscv/mm/init.c:454:25: error: expected '=', ',', ';', 'asm' or '__attribute__' before '__inidata'
  2021-06-04 12:59 [linux-next:master 5094/7430] arch/riscv/mm/init.c:454:25: error: expected '=', ',', ';', 'asm' or '__attribute__' before '__inidata' kernel test robot
@ 2021-06-04 14:08 ` Jisheng Zhang
  0 siblings, 0 replies; 2+ messages in thread
From: Jisheng Zhang @ 2021-06-04 14:08 UTC (permalink / raw)
  To: kernel test robot
  Cc: Jisheng Zhang, kbuild-all, Linux Memory Management List, Palmer Dabbelt

On Fri, 4 Jun 2021 20:59:42 +0800
kernel test robot <lkp@intel.com> wrote:

> tree:   https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git master
> head:   ccc252d2e818f6a479441119ad453c3ce7c7c461
> commit: 010623568222bd144eb73aa9f3b46c79b63d7676 [5094/7430] riscv: mm: init: Consolidate vars, functions
> config: riscv-randconfig-r002-20210604 (attached as .config)
> compiler: riscv32-linux-gcc (GCC) 9.3.0

This is the key, RV32GC platform! the pfn_pmd() is only defined in pgtable-64.h,
so we need one more fix patch for commit e88b333142e ("riscv: mm: add THP
support on 64-bit"). I'll send out a fix

> 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
>         # https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/commit/?id=010623568222bd144eb73aa9f3b46c79b63d7676
>         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 010623568222bd144eb73aa9f3b46c79b63d7676
>         # save the attached .config to linux build tree
>         COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-9.3.0 make.cross ARCH=riscv 
> 
> If you fix the issue, kindly add following tag as appropriate
> Reported-by: kernel test robot <lkp@intel.com>
> 
> All errors (new ones prefixed by >>):
> 
>    In file included from include/linux/pgtable.h:6,
>                     from include/linux/mm.h:33,
>                     from arch/riscv/mm/init.c:10:
>    arch/riscv/include/asm/pgtable.h: In function 'mk_pmd':
>    arch/riscv/include/asm/pgtable.h:518:9: error: implicit declaration of function 'pfn_pmd'; did you mean 'pfn_pgd'? [-Werror=implicit-function-declaration]
>      518 |  return pfn_pmd(page_to_pfn(page), prot);
>          |         ^~~~~~~
>          |         pfn_pgd
>    In file included from arch/riscv/include/asm/page.h:185,
>                     from arch/riscv/include/asm/thread_info.h:11,
>                     from include/linux/thread_info.h:59,
>                     from include/asm-generic/preempt.h:5,
>                     from ./arch/riscv/include/generated/asm/preempt.h:1,
>                     from include/linux/preempt.h:78,
>                     from include/linux/spinlock.h:51,
>                     from include/linux/mmzone.h:8,
>                     from include/linux/gfp.h:6,
>                     from include/linux/mm.h:10,
>                     from arch/riscv/mm/init.c:10:
>    include/asm-generic/memory_model.h:64:14: error: implicit declaration of function 'page_to_section'; did you mean 'present_section'? [-Werror=implicit-function-declaration]
>       64 |  int __sec = page_to_section(__pg);   \
>          |              ^~~~~~~~~~~~~~~
>    include/asm-generic/memory_model.h:81:21: note: in expansion of macro '__page_to_pfn'
>       81 | #define page_to_pfn __page_to_pfn
>          |                     ^~~~~~~~~~~~~
>    arch/riscv/include/asm/pgtable.h:518:17: note: in expansion of macro 'page_to_pfn'
>      518 |  return pfn_pmd(page_to_pfn(page), prot);
>          |                 ^~~~~~~~~~~
>    In file included from include/linux/pgtable.h:6,
>                     from include/linux/mm.h:33,
>                     from arch/riscv/mm/init.c:10:
>    arch/riscv/include/asm/pgtable.h:518:9: error: incompatible types when returning type 'int' but 'pmd_t' {aka 'struct <anonymous>'} was expected
>      518 |  return pfn_pmd(page_to_pfn(page), prot);
>          |         ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
>    In file included from arch/riscv/mm/init.c:10:
>    include/linux/mm.h: At top level:
>    include/linux/mm.h:1552:29: error: conflicting types for 'page_to_section'
>     1552 | static inline unsigned long page_to_section(const struct page *page)
>          |                             ^~~~~~~~~~~~~~~
>    In file included from arch/riscv/include/asm/page.h:185,
>                     from arch/riscv/include/asm/thread_info.h:11,
>                     from include/linux/thread_info.h:59,
>                     from include/asm-generic/preempt.h:5,
>                     from ./arch/riscv/include/generated/asm/preempt.h:1,
>                     from include/linux/preempt.h:78,
>                     from include/linux/spinlock.h:51,
>                     from include/linux/mmzone.h:8,
>                     from include/linux/gfp.h:6,
>                     from include/linux/mm.h:10,
>                     from arch/riscv/mm/init.c:10:
>    include/asm-generic/memory_model.h:64:14: note: previous implicit declaration of 'page_to_section' was here
>       64 |  int __sec = page_to_section(__pg);   \
>          |              ^~~~~~~~~~~~~~~
>    include/asm-generic/memory_model.h:81:21: note: in expansion of macro '__page_to_pfn'
>       81 | #define page_to_pfn __page_to_pfn
>          |                     ^~~~~~~~~~~~~
>    arch/riscv/include/asm/pgtable.h:518:17: note: in expansion of macro 'page_to_pfn'
>      518 |  return pfn_pmd(page_to_pfn(page), prot);
>          |                 ^~~~~~~~~~~
>    In file included from include/linux/kexec.h:28,
>                     from include/linux/crash_dump.h:5,
>                     from arch/riscv/mm/init.c:20:
>    arch/riscv/include/asm/kexec.h:45:1: warning: 'extern' is not at beginning of declaration [-Wold-style-declaration]
>       45 | const extern unsigned char riscv_kexec_relocate[];
>          | ^~~~~
>    arch/riscv/include/asm/kexec.h:46:1: warning: 'extern' is not at beginning of declaration [-Wold-style-declaration]
>       46 | const extern unsigned int riscv_kexec_relocate_size;
>          | ^~~~~
> >> arch/riscv/mm/init.c:454:25: error: expected '=', ',', ';', 'asm' or '__attribute__' before '__inidata'  
>      454 | static uintptr_t xiprom __inidata;

Vitaly has sent a patch to fix this typo.

>          |                         ^~~~~~~~~
>    In file included from include/linux/pgtable.h:6,
>                     from include/linux/mm.h:33,
>                     from arch/riscv/mm/init.c:10:
>    arch/riscv/mm/init.c: In function 'create_kernel_page_table':
> >> arch/riscv/mm/init.c:457:51: error: 'xiprom' undeclared (first use in this function); did you mean '_xiprom'?  
>      457 | #define xiprom         (*((uintptr_t *)XIP_FIXUP(&xiprom)))
>          |                                                   ^~~~~~
>    arch/riscv/include/asm/pgtable.h:98:30: note: in definition of macro 'XIP_FIXUP'
>       98 |  uintptr_t __a = (uintptr_t)(addr);     \
>          |                              ^~~~
>    arch/riscv/mm/init.c:467:8: note: in expansion of macro 'xiprom'
>      467 |        xiprom + (va - kernel_virt_addr),
>          |        ^~~~~~
>    arch/riscv/mm/init.c:457:51: note: each undeclared identifier is reported only once for each function it appears in
>      457 | #define xiprom         (*((uintptr_t *)XIP_FIXUP(&xiprom)))
>          |                                                   ^~~~~~
>    arch/riscv/include/asm/pgtable.h:98:30: note: in definition of macro 'XIP_FIXUP'
>       98 |  uintptr_t __a = (uintptr_t)(addr);     \
>          |                              ^~~~
>    arch/riscv/mm/init.c:467:8: note: in expansion of macro 'xiprom'
>      467 |        xiprom + (va - kernel_virt_addr),
>          |        ^~~~~~
>    arch/riscv/mm/init.c: In function 'setup_vm':
> >> arch/riscv/mm/init.c:457:51: error: 'xiprom' undeclared (first use in this function); did you mean '_xiprom'?  
>      457 | #define xiprom         (*((uintptr_t *)XIP_FIXUP(&xiprom)))
>          |                                                   ^~~~~~
>    arch/riscv/include/asm/pgtable.h:98:30: note: in definition of macro 'XIP_FIXUP'
>       98 |  uintptr_t __a = (uintptr_t)(addr);     \
>          |                              ^~~~
>    arch/riscv/mm/init.c:499:2: note: in expansion of macro 'xiprom'
>      499 |  xiprom = (uintptr_t)CONFIG_XIP_PHYS_ADDR;
>          |  ^~~~~~
>    cc1: some warnings being treated as errors
> 
> 
> vim +454 arch/riscv/mm/init.c
> 
>    452	
>    453	#ifdef CONFIG_XIP_KERNEL
>  > 454	static uintptr_t xiprom __inidata;  
>    455	static uintptr_t xiprom_sz __initdata;
>    456	#define xiprom_sz      (*((uintptr_t *)XIP_FIXUP(&xiprom_sz)))
>  > 457	#define xiprom         (*((uintptr_t *)XIP_FIXUP(&xiprom)))  
>    458	
> 
> ---
> 0-DAY CI Kernel Test Service, Intel Corporation
> https://lists.01.org/hyperkitty/list/kbuild-all@lists.01.org




^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2021-06-04 14:13 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-06-04 12:59 [linux-next:master 5094/7430] arch/riscv/mm/init.c:454:25: error: expected '=', ',', ';', 'asm' or '__attribute__' before '__inidata' kernel test robot
2021-06-04 14:08 ` Jisheng Zhang

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).