Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp2620924yba; Mon, 6 May 2019 08:56:28 -0700 (PDT) X-Google-Smtp-Source: APXvYqxJQxJTHTVFYfhILhwQzHUgMwtCi1oImNUATx5vKU5dD5t0ur48mi8kL3xTeVF3sPfwof+U X-Received: by 2002:a65:6282:: with SMTP id f2mr32777243pgv.152.1557158188056; Mon, 06 May 2019 08:56:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1557158188; cv=none; d=google.com; s=arc-20160816; b=njAKxjWiRRskObJxrn2VUdgLW2Sed9mO/bkHWsskWAJIESm4yUs9W51zOJbPZbj5RI QNmr92rYOnkdlDQnN6wpvV8O2npRaP4VsyRzMcPkaz0Ji9X1fwDgXaC+wDcXD+OjtjM7 BDF4sY5R8JtT5U4cx9WrsWvHAchX8gUiQGMUAsgVcP1jMqUEgV1mRAbWHzuGuBtAvx1q 3Q1GRu2SOjXOK3N5IFVJu/C6joFcYvRY2IRlEt+6nq/MRxLnS5MQzzes2HZuymWj3Au8 HkFm4hzz2LqfodG9zkcbrdMCqTq4SwKJ6JQl6bp9kvMmf773PkorseDJ6sF+nPsQd7yF Gp8g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=Unqkz8cFxOiiiqMOYYA1LetxQjYYdRnCxiqq3EJhN7k=; b=d7unuWyH7d24zKvWyQXDD5SsLeV+gk7mKt6TYYJRhf9BjiZrXDj/F2ZgDQABOHIdqT N8bSQoP/IVAm77WjNivhE1KhzyKaXjvWwSK703aUyTEdcTHQoNUvw+0s/iZ61St2sEET 3+CbmLA+RU/7G5K9jYGel8p3mAsMQO/1SEoOSWa96vuNsBQI819HYJW7LvKk4vrO6dWP UZsDryFpV1S92Ixcr349+Ytxlqbd99oGaBbwVtZPlMq4/n3R/XWpCm/uLvTSetbPMuqe 9HIfl9Fn09FW0TPjLsEEAAX/QhvA1/vM9BMfET4+QYu5VajIkkxDJROVit08i0k9UQl/ JpFg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f12si14410680pgo.388.2019.05.06.08.56.10; Mon, 06 May 2019 08:56:28 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726932AbfEFPx6 (ORCPT + 99 others); Mon, 6 May 2019 11:53:58 -0400 Received: from mx1.redhat.com ([209.132.183.28]:3346 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726321AbfEFPx6 (ORCPT ); Mon, 6 May 2019 11:53:58 -0400 Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.12]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 7C482306D334; Mon, 6 May 2019 15:53:57 +0000 (UTC) Received: from jsavitz.bos.com (dhcp-17-161.bos.redhat.com [10.18.17.161]) by smtp.corp.redhat.com (Postfix) with ESMTP id 3793560BEC; Mon, 6 May 2019 15:53:48 +0000 (UTC) From: Joel Savitz To: linux-kernel@vger.kernel.org Cc: Joel Savitz , Alexey Dobriyan , Andrew Morton , Vlastimil Babka , "Aneesh Kumar K.V" , Michael Ellerman , Ram Pai , Andrea Arcangeli , Huang Ying , Sandeep Patil , Rafael Aquini , Yury Norov , linux-fsdevel@vger.kernel.org Subject: [PATCH v3] fs/proc: add VmTaskSize field to /proc/$$/status Date: Mon, 6 May 2019 11:53:43 -0400 Message-Id: <1557158023-23021-1-git-send-email-jsavitz@redhat.com> X-Scanned-By: MIMEDefang 2.79 on 10.5.11.12 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.47]); Mon, 06 May 2019 15:53:58 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org There is currently no easy and architecture-independent way to find the lowest unusable virtual address available to a process without brute-force calculation. This patch allows a user to easily retrieve this value via /proc//status. Using this patch, any program that previously needed to waste cpu cycles recalculating a non-sensitive process-dependent value already known to the kernel can now be optimized to use this mechanism. Signed-off-by: Joel Savitz --- Documentation/filesystems/proc.txt | 2 ++ fs/proc/task_mmu.c | 2 ++ 2 files changed, 4 insertions(+) diff --git a/Documentation/filesystems/proc.txt b/Documentation/filesystems/proc.txt index 66cad5c86171..1c6a912e3975 100644 --- a/Documentation/filesystems/proc.txt +++ b/Documentation/filesystems/proc.txt @@ -187,6 +187,7 @@ read the file /proc/PID/status: VmLib: 1412 kB VmPTE: 20 kb VmSwap: 0 kB + VmTaskSize: 137438953468 kB HugetlbPages: 0 kB CoreDumping: 0 THP_enabled: 1 @@ -263,6 +264,7 @@ Table 1-2: Contents of the status files (as of 4.19) VmPTE size of page table entries VmSwap amount of swap used by anonymous private data (shmem swap usage is not included) + VmTaskSize lowest unusable address in process virtual memory HugetlbPages size of hugetlb memory portions CoreDumping process's memory is currently being dumped (killing the process may lead to a corrupted core) diff --git a/fs/proc/task_mmu.c b/fs/proc/task_mmu.c index 95ca1fe7283c..0af7081f7b19 100644 --- a/fs/proc/task_mmu.c +++ b/fs/proc/task_mmu.c @@ -74,6 +74,8 @@ void task_mem(struct seq_file *m, struct mm_struct *mm) seq_put_decimal_ull_width(m, " kB\nVmPTE:\t", mm_pgtables_bytes(mm) >> 10, 8); SEQ_PUT_DEC(" kB\nVmSwap:\t", swap); + seq_put_decimal_ull_width(m, + " kB\nVmTaskSize:\t", mm->task_size >> 10, 8); seq_puts(m, " kB\n"); hugetlb_report_usage(m, mm); } -- 2.18.1