lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <201710271401.5Tw0VxMq%fengguang.wu@intel.com>
Date:   Fri, 27 Oct 2017 14:48:55 +0800
From:   kbuild test robot <lkp@...el.com>
To:     Fan Du <fan.du@...el.com>
Cc:     kbuild-all@...org, akpm@...ux-foundation.org, hch@....de,
        dan.j.williams@...el.com, dave.hansen@...el.com,
        linux-kernel@...r.kernel.org, Fan Du <fan.du@...el.com>
Subject: Re: [PATCHv2 2/2] Add /proc/PID/{smaps, numa_maps} support for DAX

Hi Fan,

Thank you for the patch! Yet we hit a small issue.
[auto build test WARNING on linus/master]
[also build test WARNING on v4.14-rc6 next-20171018]
[if your patch is applied to the wrong git tree, please drop us a note to help improve the system]

url:    https://github.com/0day-ci/linux/commits/Fan-Du/proc-mm-export-PTE-sizes-directly-in-smaps/20171027-141157
config: x86_64-randconfig-x011-201743 (attached as .config)
compiler: gcc-6 (Debian 6.2.0-3) 6.2.0 20160901
reproduce:
        # save the attached .config to linux build tree
        make ARCH=x86_64 

Note: it may well be a FALSE warning. FWIW you are at least aware of it now.
http://gcc.gnu.org/wiki/Better_Uninitialized_Warnings

All warnings (new ones prefixed by >>):

   fs/proc/task_mmu.c: In function 'gather_pte_stats':
>> fs/proc/task_mmu.c:1805:6: warning: 'page' may be used uninitialized in this function [-Wmaybe-uninitialized]
      if (!page)
         ^

vim +/page +1805 fs/proc/task_mmu.c

28093f9f3 Gerald Schaefer    2016-04-28  1771  
f69ff943d Stephen Wilson     2011-05-24  1772  static int gather_pte_stats(pmd_t *pmd, unsigned long addr,
f69ff943d Stephen Wilson     2011-05-24  1773  		unsigned long end, struct mm_walk *walk)
f69ff943d Stephen Wilson     2011-05-24  1774  {
d85f4d6d3 Naoya Horiguchi    2015-02-11  1775  	struct numa_maps *md = walk->private;
d85f4d6d3 Naoya Horiguchi    2015-02-11  1776  	struct vm_area_struct *vma = walk->vma;
f69ff943d Stephen Wilson     2011-05-24  1777  	spinlock_t *ptl;
f69ff943d Stephen Wilson     2011-05-24  1778  	pte_t *orig_pte;
f69ff943d Stephen Wilson     2011-05-24  1779  	pte_t *pte;
3bf801467 Fan Du             2017-10-24  1780  	struct page *page;
f69ff943d Stephen Wilson     2011-05-24  1781  
28093f9f3 Gerald Schaefer    2016-04-28  1782  #ifdef CONFIG_TRANSPARENT_HUGEPAGE
b6ec57f4b Kirill A. Shutemov 2016-01-21  1783  	ptl = pmd_trans_huge_lock(pmd, vma);
b6ec57f4b Kirill A. Shutemov 2016-01-21  1784  	if (ptl) {
3bf801467 Fan Du             2017-10-24  1785  		if (!vma_is_dax(vma))
28093f9f3 Gerald Schaefer    2016-04-28  1786  			page = can_gather_numa_stats_pmd(*pmd, vma, addr);
3bf801467 Fan Du             2017-10-24  1787  		else if (pmd_devmap(*pmd))
3bf801467 Fan Du             2017-10-24  1788  			page = pmd_page(*pmd);
32ef43848 Dave Hansen        2011-09-20  1789  		if (page)
28093f9f3 Gerald Schaefer    2016-04-28  1790  			gather_stats(page, md, pmd_dirty(*pmd),
32ef43848 Dave Hansen        2011-09-20  1791  				     HPAGE_PMD_SIZE/PAGE_SIZE);
bf929152e Kirill A. Shutemov 2013-11-14  1792  		spin_unlock(ptl);
32ef43848 Dave Hansen        2011-09-20  1793  		return 0;
32ef43848 Dave Hansen        2011-09-20  1794  	}
32ef43848 Dave Hansen        2011-09-20  1795  
1a5a9906d Andrea Arcangeli   2012-03-21  1796  	if (pmd_trans_unstable(pmd))
1a5a9906d Andrea Arcangeli   2012-03-21  1797  		return 0;
28093f9f3 Gerald Schaefer    2016-04-28  1798  #endif
f69ff943d Stephen Wilson     2011-05-24  1799  	orig_pte = pte = pte_offset_map_lock(walk->mm, pmd, addr, &ptl);
f69ff943d Stephen Wilson     2011-05-24  1800  	do {
3bf801467 Fan Du             2017-10-24  1801  		if (!vma_is_dax(vma))
3bf801467 Fan Du             2017-10-24  1802  			page = can_gather_numa_stats(*pte, vma, addr);
3bf801467 Fan Du             2017-10-24  1803  		else if (pte_devmap(*pte))
3bf801467 Fan Du             2017-10-24  1804  			page = pte_page(*pte);
f69ff943d Stephen Wilson     2011-05-24 @1805  		if (!page)
f69ff943d Stephen Wilson     2011-05-24  1806  			continue;
eb4866d00 Dave Hansen        2011-09-20  1807  		gather_stats(page, md, pte_dirty(*pte), 1);
f69ff943d Stephen Wilson     2011-05-24  1808  
f69ff943d Stephen Wilson     2011-05-24  1809  	} while (pte++, addr += PAGE_SIZE, addr != end);
f69ff943d Stephen Wilson     2011-05-24  1810  	pte_unmap_unlock(orig_pte, ptl);
a66c0410b Hugh Dickins       2016-12-12  1811  	cond_resched();
f69ff943d Stephen Wilson     2011-05-24  1812  	return 0;
f69ff943d Stephen Wilson     2011-05-24  1813  }
f69ff943d Stephen Wilson     2011-05-24  1814  #ifdef CONFIG_HUGETLB_PAGE
632fd60fe Naoya Horiguchi    2015-02-11  1815  static int gather_hugetlb_stats(pte_t *pte, unsigned long hmask,
f69ff943d Stephen Wilson     2011-05-24  1816  		unsigned long addr, unsigned long end, struct mm_walk *walk)
f69ff943d Stephen Wilson     2011-05-24  1817  {
5c2ff95e4 Michael Holzheu    2016-02-02  1818  	pte_t huge_pte = huge_ptep_get(pte);
f69ff943d Stephen Wilson     2011-05-24  1819  	struct numa_maps *md;
f69ff943d Stephen Wilson     2011-05-24  1820  	struct page *page;
f69ff943d Stephen Wilson     2011-05-24  1821  
5c2ff95e4 Michael Holzheu    2016-02-02  1822  	if (!pte_present(huge_pte))
f69ff943d Stephen Wilson     2011-05-24  1823  		return 0;
f69ff943d Stephen Wilson     2011-05-24  1824  
5c2ff95e4 Michael Holzheu    2016-02-02  1825  	page = pte_page(huge_pte);
f69ff943d Stephen Wilson     2011-05-24  1826  	if (!page)
f69ff943d Stephen Wilson     2011-05-24  1827  		return 0;
f69ff943d Stephen Wilson     2011-05-24  1828  
f69ff943d Stephen Wilson     2011-05-24  1829  	md = walk->private;
5c2ff95e4 Michael Holzheu    2016-02-02  1830  	gather_stats(page, md, pte_dirty(huge_pte), 1);
f69ff943d Stephen Wilson     2011-05-24  1831  	return 0;
f69ff943d Stephen Wilson     2011-05-24  1832  }
f69ff943d Stephen Wilson     2011-05-24  1833  

:::::: The code at line 1805 was first introduced by commit
:::::: f69ff943df6972aae96c10733b6847fa094d8a59 mm: proc: move show_numa_map() to fs/proc/task_mmu.c

:::::: TO: Stephen Wilson <wilsons@...rt.ca>
:::::: CC: Linus Torvalds <torvalds@...ux-foundation.org>

---
0-DAY kernel test infrastructure                Open Source Technology Center
https://lists.01.org/pipermail/kbuild-all                   Intel Corporation

Download attachment ".config.gz" of type "application/gzip" (30524 bytes)

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ