Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 20 Apr 2012 22:27:11 +0000 (UTC)
From:      Xin LI <delphij@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-stable@freebsd.org, svn-src-stable-8@freebsd.org
Subject:   svn commit: r234513 - stable/8/sys/fs/tmpfs
Message-ID:  <201204202227.q3KMRBOM058668@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: delphij
Date: Fri Apr 20 22:27:10 2012
New Revision: 234513
URL: http://svn.freebsd.org/changeset/base/234513

Log:
  MFC r227802:
  
  Improve the way to calculate available pages in tmpfs:
  
   - Don't deduct wired pages from total usable counts because it does not
     make any sense.  To make things worse, on systems where swap size is
     smaller than physical memory and use a lot of wired pages (e.g. ZFS),
     tmpfs can suddenly have free space of 0 because of this;
   - Count cached pages as available; [1]
   - Don't count inactive pages as available, technically we could but that
     might be too aggressive; [1]
  
  [1] Suggested by kib@

Modified:
  stable/8/sys/fs/tmpfs/tmpfs.h
Directory Properties:
  stable/8/sys/   (props changed)

Modified: stable/8/sys/fs/tmpfs/tmpfs.h
==============================================================================
--- stable/8/sys/fs/tmpfs/tmpfs.h	Fri Apr 20 22:16:08 2012	(r234512)
+++ stable/8/sys/fs/tmpfs/tmpfs.h	Fri Apr 20 22:27:10 2012	(r234513)
@@ -483,11 +483,8 @@ int	tmpfs_truncate(struct vnode *, off_t
 static __inline size_t
 tmpfs_mem_info(void)
 {
-	size_t size;
 
-	size = swap_pager_avail + cnt.v_free_count + cnt.v_inactive_count;
-	size -= size > cnt.v_wire_count ? cnt.v_wire_count : size;
-	return size;
+	return (swap_pager_avail + cnt.v_free_count + cnt.v_cache_count);
 }
 
 /* Returns the maximum size allowed for a tmpfs file system.  This macro



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201204202227.q3KMRBOM058668>