Files
ubports_kernel_google_msm/include/linux
Oleg Nesterov 901608d904 mm: introduce get_mm_hiwater_xxx(), fix taskstats->hiwater_xxx accounting
xacct_add_tsk() relies on do_exit()->update_hiwater_xxx() and uses
mm->hiwater_xxx directly, this leads to 2 problems:

- taskstats_user_cmd() can call fill_pid()->xacct_add_tsk() at any
  moment before the task exits, so we should check the current values of
  rss/vm anyway.

- do_exit()->update_hiwater_xxx() calls are racy.  An exiting thread can
  be preempted right before mm->hiwater_xxx = new_val, and another thread
  can use A_LOT of memory and exit in between.  When the first thread
  resumes it can be the last thread in the thread group, in that case we
  report the wrong hiwater_xxx values which do not take A_LOT into
  account.

Introduce get_mm_hiwater_rss() and get_mm_hiwater_vm() helpers and change
xacct_add_tsk() to use them.  The first helper will also be used by
rusage->ru_maxrss accounting.

Kill do_exit()->update_hiwater_xxx() calls.  Unless we are going to
decrease rss/vm there is no point to update mm->hiwater_xxx, and nobody
can look at this mm_struct when exit_mmap() actually unmaps the memory.

Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Acked-by: Hugh Dickins <hugh@veritas.com>
Reviewed-by: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com>
Acked-by: Balbir Singh <balbir@linux.vnet.ibm.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2009-01-06 15:59:09 -08:00
..
2009-01-04 12:17:43 +01:00
2009-01-04 12:17:42 +01:00
2008-10-13 21:51:51 +01:00
2009-01-04 13:33:20 -08:00
2008-12-30 16:51:43 -05:00
2008-11-11 21:15:50 -05:00
2008-10-20 11:01:52 -07:00
2008-12-29 08:29:50 +01:00
2008-12-03 22:12:38 -08:00
2008-12-03 22:12:38 -08:00
2008-10-20 08:52:42 -07:00
2009-01-01 10:12:19 +10:30
2008-12-29 08:29:50 +01:00
2008-11-26 12:13:34 +01:00
2009-01-04 13:33:20 -08:00
2008-11-12 17:17:18 -08:00
2008-11-14 10:39:23 +11:00
2009-01-06 15:59:01 -08:00
2008-10-16 11:21:32 -07:00
2008-11-30 11:00:15 -08:00
2009-01-02 12:19:34 -08:00
2008-12-29 17:47:23 +10:00
2008-12-25 11:01:43 +11:00
2008-11-24 18:57:41 -05:00
2008-12-31 18:07:38 -05:00
2008-12-29 07:39:34 -05:00
2008-10-16 16:53:13 +02:00
2008-10-12 12:05:55 +02:00
2008-12-15 23:44:31 -08:00
2009-01-04 13:33:20 -08:00
2009-01-04 13:33:20 -08:00
2008-12-29 11:27:46 +02:00
2008-12-31 18:07:42 -05:00
2009-01-06 15:59:09 -08:00
2008-10-16 16:08:57 +02:00
2009-01-06 15:59:01 -08:00
2008-10-16 11:21:40 -07:00
2008-12-08 01:14:16 -08:00
2008-10-14 23:51:02 +02:00
2008-10-22 20:21:33 +02:00
2008-10-16 11:21:38 -07:00
2008-12-31 18:07:42 -05:00
2008-10-29 22:02:09 +01:00
2008-11-03 18:21:45 +01:00
2008-10-15 14:24:08 +02:00
2009-01-05 08:40:30 -08:00
2009-01-05 08:40:30 -08:00
2008-12-31 15:11:46 +01:00
2009-01-03 14:11:07 +01:00
2008-10-20 22:34:12 +01:00
2008-12-28 22:43:21 -05:00
2008-10-13 09:47:43 +11:00
2008-10-20 08:52:31 -07:00
2009-01-06 15:58:58 -08:00
2008-10-22 10:00:23 +11:00
2008-11-06 15:41:21 -08:00
2008-12-08 14:31:59 +01:00
2008-11-19 18:49:57 -08:00
2009-01-04 16:13:40 -08:00
2008-12-23 15:21:45 -05:00
2008-12-19 15:22:54 -05:00
2008-12-21 14:21:14 +11:00
2008-11-30 10:03:35 -08:00
2008-10-16 11:21:49 -07:00
2008-10-22 16:42:43 -07:00
2008-11-28 16:24:56 -08:00
2008-12-04 09:09:37 +01:00
2008-11-07 22:56:00 -08:00
2008-11-20 04:10:00 -08:00
2008-10-23 00:11:07 -04:00
2008-10-23 18:54:05 +04:00
2008-12-20 09:15:46 +01:00
2009-01-05 18:31:12 -08:00
2008-11-12 17:17:17 -08:00
2008-11-16 19:39:21 -08:00
2009-01-04 13:33:20 -08:00
2008-12-15 23:42:33 -08:00
2008-12-30 09:05:16 +10:30
2008-11-24 21:27:22 -08:00
2008-11-02 10:15:07 -08:00
2008-10-16 11:21:47 -07:00
2008-10-13 09:51:40 -07:00
2009-01-01 10:12:25 +10:30
2008-12-12 17:01:38 +01:00
2009-01-02 10:19:36 -08:00
2008-12-29 08:29:51 +01:00
2008-10-16 11:21:31 -07:00
2009-01-06 15:59:09 -08:00