Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp7002137ybi; Thu, 13 Jun 2019 08:00:16 -0700 (PDT) X-Google-Smtp-Source: APXvYqxYboYcPHvvyBnq5XyVUWMF5qCk+HJ64dOysYLtAzMvbSPsZ35lKe1C1GdH/usFncGfA81z X-Received: by 2002:a17:902:42d:: with SMTP id 42mr84624240ple.228.1560438016389; Thu, 13 Jun 2019 08:00:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560438016; cv=none; d=google.com; s=arc-20160816; b=QmRxG/KWsbTNiv7MjYqU4ZvVfmHHvLpjwS0Z65rV/g+t3DS9uG+ksMw1roDPk0Z3iW OevMrYVJKxJ26BonREMFe6hHmFj3JzlqXkVjhJNKHALmurf9CqpWP1PARMEukpruo6EI RkGcNCkGTYTbOrMJA/iGVbsWkz9IKJmPycfEXGylgO5itoyidMta6IvQr3PHyUOIB6Ih +876Y/f0+qC0/pE0JOC0zRh6QmlVUJ2wEsU6hF5BJONPApAOInKzca3BzUmHHVvz9+h0 cIsgliyrcWnuJPhM1/LXZzGXusI9Bssh9tl957hPqkNDZjWhTggoNuJmopDJrROX1qBc QjXA== 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=KF31RQGeE7j6CW5roMSraYiI0XvflVt0y9YdpmipQLc=; b=BuvNdeFCVr3jP/KfZFu8MUFVUes6OLfm30VVGjJ6GV6RLE70uv8xYy3+joqsuRn5GP 7OwJJC3+/eFrZiNXd2mN7PFVelWF9Q0VvrYCVWXmwDTIc+QLs8/CSIsZwmtDdafBlYIq ekN8vWTwyUs8IfvvKpzkuqaUu9U64Bo4/PQIFMfnFN904y6XTK18Ror4TEmBuSAP5jlt rRVszS5H0rF8Za42CbyfIZWBp4cGN8zsYnvTrXONTXNtYQzYASk21jZOPplTrW5XwOU/ bjZdb8niIJ+AvmFC6aWX2Ncm6ninjiDaazydGkc3WgpF17zeD/1wBOQ0GUAa0RKwRIqn Ao0w== 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 99si3222162pla.397.2019.06.13.07.59.13; Thu, 13 Jun 2019 08:00:16 -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 S1732671AbfFMO7B (ORCPT + 99 others); Thu, 13 Jun 2019 10:59:01 -0400 Received: from mx1.redhat.com ([209.132.183.28]:40622 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732610AbfFMOzJ (ORCPT ); Thu, 13 Jun 2019 10:55:09 -0400 Received: from smtp.corp.redhat.com (int-mx03.intmail.prod.int.phx2.redhat.com [10.5.11.13]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id AB71680494; Thu, 13 Jun 2019 14:55:06 +0000 (UTC) Received: from jsavitz.bos.com (dhcp-17-175.bos.redhat.com [10.18.17.175]) by smtp.corp.redhat.com (Postfix) with ESMTP id F0F8D6061E; Thu, 13 Jun 2019 14:55:00 +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 , linux-mm@kvack.org, linux-fsdevel@vger.kernel.org Subject: [PATCH v4] fs/proc: add VmTaskSize field to /proc/$$/status Date: Thu, 13 Jun 2019 10:54:50 -0400 Message-Id: <1560437690-13919-1-git-send-email-jsavitz@redhat.com> X-Scanned-By: MIMEDefang 2.79 on 10.5.11.13 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.28]); Thu, 13 Jun 2019 14:55:08 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The kernel provides no architecture-independent mechanism to get the size of the virtual address space of a task (userspace process) without brute-force calculation. This patch allows a user to easily retrieve this value via a new VmTaskSize entry in /proc/$$/status. 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 size of task (userspace process) vm space 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