[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <202212201942.k85ZwkoA-lkp@intel.com>
Date:   Tue, 20 Dec 2022 20:00:24 +0800
From:   kernel test robot <lkp@...el.com>
To:     Chih-En Lin <shiyn.lin@...il.com>,
        Andrew Morton <akpm@...ux-foundation.org>,
        Qi Zheng <zhengqi.arch@...edance.com>,
        David Hildenbrand <david@...hat.com>,
        Matthew Wilcox <willy@...radead.org>,
        Christophe Leroy <christophe.leroy@...roup.eu>,
        John Hubbard <jhubbard@...dia.com>,
        Nadav Amit <namit@...are.com>
Cc:     oe-kbuild-all@...ts.linux.dev,
        Linux Memory Management List <linux-mm@...ck.org>,
        linux-kernel@...r.kernel.org, Steven Rostedt <rostedt@...dmis.org>,
        Masami Hiramatsu <mhiramat@...nel.org>,
        Peter Zijlstra <peterz@...radead.org>,
        Ingo Molnar <mingo@...hat.com>,
        Arnaldo Carvalho de Melo <acme@...nel.org>,
        Mark Rutland <mark.rutland@....com>,
        Alexander Shishkin <alexander.shishkin@...ux.intel.com>,
        Jiri Olsa <jolsa@...nel.org>,
        Namhyung Kim <namhyung@...nel.org>,
        Yang Shi <shy828301@...il.com>, Peter Xu <peterx@...hat.com>,
        Zach O'Keefe <zokeefe@...gle.com>,
        "Liam R . Howlett" <Liam.Howlett@...cle.com>,
        Alex Sierra <alex.sierra@....com>,
        Xianting Tian <xianting.tian@...ux.alibaba.com>,
        Colin Cross <ccross@...gle.com>,
        Suren Baghdasaryan <surenb@...gle.com>,
        Barry Song <baohua@...nel.org>,
        Pasha Tatashin <pasha.tatashin@...een.com>,
        Suleiman Souhlal <suleiman@...gle.com>,
        Brian Geffon <bgeffon@...gle.com>
Subject: Re: [PATCH v3 03/14] mm: Add break COW PTE fault and helper functions
Hi Chih-En,
Thank you for the patch! Yet something to improve:
[auto build test ERROR on v6.1-rc7]
[also build test ERROR on next-20221220]
[cannot apply to akpm-mm/mm-everything tip/perf/core acme/perf/core linus/master v6.1 v6.1-rc8]
[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/Chih-En-Lin/Introduce-Copy-On-Write-to-Page-Table/20221220-153207
patch link:    https://lore.kernel.org/r/20221220072743.3039060-4-shiyn.lin%40gmail.com
patch subject: [PATCH v3 03/14] mm: Add break COW PTE fault and helper functions
config: powerpc-allnoconfig
compiler: powerpc-linux-gcc (GCC) 12.1.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://github.com/intel-lab-lkp/linux/commit/18accecf2701f7705ada53938cc2005fa15cc063
        git remote add linux-review https://github.com/intel-lab-lkp/linux
        git fetch --no-tags linux-review Chih-En-Lin/Introduce-Copy-On-Write-to-Page-Table/20221220-153207
        git checkout 18accecf2701f7705ada53938cc2005fa15cc063
        # save the config file
        mkdir build_dir && cp config build_dir/.config
        COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-12.1.0 make.cross W=1 O=build_dir ARCH=powerpc olddefconfig
        COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-12.1.0 make.cross W=1 O=build_dir ARCH=powerpc SHELL=/bin/bash
If you fix the issue, kindly add following tag where applicable
| Reported-by: kernel test robot <lkp@...el.com>
All errors (new ones prefixed by >>):
   mm/memory.c: In function 'free_pmd_range':
>> mm/memory.c:255:53: error: implicit declaration of function 'pmd_mkwrite'; did you mean 'pmd_write'? [-Werror=implicit-function-declaration]
     255 |                                         pmd_t new = pmd_mkwrite(*pmd);
         |                                                     ^~~~~~~~~~~
         |                                                     pmd_write
>> mm/memory.c:255:53: error: invalid initializer
   mm/memory.c:257:41: error: implicit declaration of function 'set_pmd_at'; did you mean 'set_pte_at'? [-Werror=implicit-function-declaration]
     257 |                                         set_pmd_at(tlb->mm, addr, pmd, new);
         |                                         ^~~~~~~~~~
         |                                         set_pte_at
>> mm/memory.c:266:33: error: implicit declaration of function 'flush_tlb_mm_range'; did you mean 'flush_tlb_range'? [-Werror=implicit-function-declaration]
     266 |                                 flush_tlb_mm_range(tlb->mm, addr, next,
         |                                 ^~~~~~~~~~~~~~~~~~
         |                                 flush_tlb_range
   In file included from arch/powerpc/include/asm/page.h:331,
                    from arch/powerpc/include/asm/thread_info.h:13,
                    from include/linux/thread_info.h:60,
                    from arch/powerpc/include/asm/ptrace.h:328,
                    from arch/powerpc/include/asm/hw_irq.h:12,
                    from arch/powerpc/include/asm/irqflags.h:12,
                    from include/linux/irqflags.h:16,
                    from include/asm-generic/cmpxchg-local.h:6,
                    from arch/powerpc/include/asm/cmpxchg.h:526,
                    from arch/powerpc/include/asm/atomic.h:11,
                    from include/linux/atomic.h:7,
                    from include/linux/cpumask.h:13,
                    from include/linux/smp.h:13,
                    from include/linux/kernel_stat.h:5,
                    from mm/memory.c:42:
   mm/memory.c: In function 'copy_cow_pte_range':
   include/asm-generic/memory_model.h:18:33: error: initialization of 'pgtable_t' {aka 'long unsigned int *'} from incompatible pointer type 'struct page *' [-Werror=incompatible-pointer-types]
      18 | #define __pfn_to_page(pfn)      (mem_map + ((pfn) - ARCH_PFN_OFFSET))
         |                                 ^
   include/asm-generic/memory_model.h:53:21: note: in expansion of macro '__pfn_to_page'
      53 | #define pfn_to_page __pfn_to_page
         |                     ^~~~~~~~~~~~~
   arch/powerpc/include/asm/book3s/32/pgtable.h:363:33: note: in expansion of macro 'pfn_to_page'
     363 | #define pmd_page(pmd)           pfn_to_page(pmd_pfn(pmd))
         |                                 ^~~~~~~~~~~
   mm/memory.c:1217:31: note: in expansion of macro 'pmd_page'
    1217 |         pgtable_t pte_table = pmd_page(*src_pmd);
         |                               ^~~~~~~~
   mm/memory.c:1329:48: error: implicit declaration of function 'pmd_wrprotect'; did you mean 'pte_wrprotect'? [-Werror=implicit-function-declaration]
    1329 |         set_pmd_at(dst_mm, orig_addr, dst_pmd, pmd_wrprotect(*src_pmd));
         |                                                ^~~~~~~~~~~~~
         |                                                pte_wrprotect
   mm/memory.c: In function 'zap_pte_range':
   mm/memory.c:1722:45: error: invalid initializer
    1722 |                                 pmd_t new = pmd_mkwrite(*pmd);
         |                                             ^~~~~~~~~~~
   mm/memory.c: In function 'handle_cow_pte_fault':
   mm/memory.c:5261:29: error: invalid initializer
    5261 |                 pmd_t new = pmd_mkwrite(*pmd);
         |                             ^~~~~~~~~~~
   mm/memory.c:5313:29: error: invalid initializer
    5313 |                 pmd_t new = pmd_mkwrite(cowed_entry);
         |                             ^~~~~~~~~~~
   cc1: some warnings being treated as errors
vim +255 mm/memory.c
   229	
   230	static inline void free_pmd_range(struct mmu_gather *tlb, pud_t *pud,
   231					unsigned long addr, unsigned long end,
   232					unsigned long floor, unsigned long ceiling)
   233	{
   234		pmd_t *pmd;
   235		unsigned long next;
   236		unsigned long start;
   237	
   238		start = addr;
   239		pmd = pmd_offset(pud, addr);
   240		do {
   241			next = pmd_addr_end(addr, end);
   242			/*
   243			 * For COW-ed PTE, the pte entries still mapping to pages.
   244			 * However, we should did de-accounting to all of it. So,
   245			 * even if the refcount is not the same as zapping, we
   246			 * could still fall back to normal PTE and handle it
   247			 * without traversing entries to do the de-accounting.
   248			 */
   249			if (test_bit(MMF_COW_PTE, &tlb->mm->flags)) {
   250				if (!pmd_none(*pmd) && !pmd_write(*pmd)) {
   251					spinlock_t *ptl = pte_lockptr(tlb->mm, pmd);
   252	
   253					spin_lock(ptl);
   254					if (!pmd_put_pte(pmd)) {
 > 255						pmd_t new = pmd_mkwrite(*pmd);
   256	
   257						set_pmd_at(tlb->mm, addr, pmd, new);
   258						spin_unlock(ptl);
   259						free_pte_range(tlb, pmd, addr);
   260						continue;
   261					}
   262					spin_unlock(ptl);
   263	
   264					pmd_clear(pmd);
   265					mm_dec_nr_ptes(tlb->mm);
 > 266					flush_tlb_mm_range(tlb->mm, addr, next,
   267							   PAGE_SHIFT, false);
   268				} else
   269					VM_WARN_ON(cow_pte_count(pmd) != 1);
   270			}
   271			if (pmd_none_or_clear_bad(pmd))
   272				continue;
   273			free_pte_range(tlb, pmd, addr);
   274		} while (pmd++, addr = next, addr != end);
   275	
   276		start &= PUD_MASK;
   277		if (start < floor)
   278			return;
   279		if (ceiling) {
   280			ceiling &= PUD_MASK;
   281			if (!ceiling)
   282				return;
   283		}
   284		if (end - 1 > ceiling - 1)
   285			return;
   286	
   287		pmd = pmd_offset(pud, start);
   288		pud_clear(pud);
   289		pmd_free_tlb(tlb, pmd, start);
   290		mm_dec_nr_pmds(tlb->mm);
   291	}
   292	
-- 
0-DAY CI Kernel Test Service
https://01.org/lkp
View attachment "config" of type "text/plain" (30788 bytes)
Powered by blists - more mailing lists
 
