Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp2199839ybe; Tue, 3 Sep 2019 09:18:23 -0700 (PDT) X-Google-Smtp-Source: APXvYqyWMkNdlMyLJcYIFl8KniE+TiyKJidO324T98j/mBjEWQ8oRHAHWBaOwlbnK3XPpM3BFD3B X-Received: by 2002:a63:2784:: with SMTP id n126mr30065027pgn.92.1567527503331; Tue, 03 Sep 2019 09:18:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567527503; cv=none; d=google.com; s=arc-20160816; b=uzeUTh19eHO5rCwwKv4GjnwWFby+3xJfK+S5ytihgP22sGwv3c5nu2ZFO8bBzEDTWA WMvZ+FzzpYlLYyFq1ffFgNIYcU6J4U8xe0DvuMY/EGCWUVUMVjTG1OY6uXpBTlgDyBNG hqEbau47k6SFkj4lOiWfZ4Iv4nxO8hribeifU+NWFvBNAaKA4PenORsQN3s88IE+OzWv bS7XjLvhwOLmYOVvB0Fuk+eQ+Ztd8nYGdaxs4Br3L+m0yJmccH6gVYd5cGcSXTFs53Dn QCALJof8ZkKNDtjIYEEzCZTVwJYNUG+Vpeg8M3f1LLLZEj2rG9/tR0d+b9UvXtJiZJod VXDA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:from:subject:references :mime-version:message-id:in-reply-to:date:dkim-signature; bh=x8dW1eobv46xxf8Qk5whq589HTl41TDtcRbBhNUlvgA=; b=IikVrgfsM/ev1xLgczE57utuedUDlprlQHbUprYAcWh9uCkezUekqCsgddqoyz3Wif 02/8SAVaTrtSSEo+ZUOAHD5E35aR3wQSwqu4fv6lmr8k/Cy2gJOmrq7UQpbglcfK0vqa OLcZ4VWviiCEt8R4jL2yuoT7FJsaJIW+r7w3YeVPWuGugLSb3qlXvE8V9GiyntwTaFM/ evxxpbEgMCusvAjB2SNSwm33y4Izlrtb+r/ysQuzhKoB2STpB+ErcY2DDplNSiSNR3l4 eE0E0AldW6vZbsjgYkcIvnNalGKvJkPYeIpNLyMJ6fuNOUL4ioLY1eRPRhw1K9PkexsJ s9Dw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b="iWg3lB/g"; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f131si18502441pfa.11.2019.09.03.09.18.08; Tue, 03 Sep 2019 09:18:23 -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; dkim=pass header.i=@google.com header.s=20161025 header.b="iWg3lB/g"; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730021AbfICQRJ (ORCPT + 99 others); Tue, 3 Sep 2019 12:17:09 -0400 Received: from mail-qt1-f201.google.com ([209.85.160.201]:36579 "EHLO mail-qt1-f201.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728571AbfICQRJ (ORCPT ); Tue, 3 Sep 2019 12:17:09 -0400 Received: by mail-qt1-f201.google.com with SMTP id 38so19538870qtx.3 for ; Tue, 03 Sep 2019 09:17:08 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc; bh=x8dW1eobv46xxf8Qk5whq589HTl41TDtcRbBhNUlvgA=; b=iWg3lB/gimxrwQvHqRpk41oUEw7gODwiTIRgz/H8vwbj0lL3q8OSi8BSoAdngHXedF dAXKwG3OhxcSTjOyW7EhvMbzD+RjZeRBN/9r1WHbnhuqrluYLz2ZfZchh0ZQIkZe8uDR uzfopMYYCEKeaLgXtR5CQwXIMAFtITmme2uKVVGSzGvrrAlgyUhO3CXulS6wuSqImeiS e1yLYAp1v9fj6UtLOIEAgpsyQgq3CZ1ETjmbmw8yvso675rj1S7SPR2BoBMjR0mae/dB MC3A1XqFwMU8PAq0U6FvJNp/+diNM54GF0nen3rwnURcGAO8DljeBPkhd2p36zuC056B 83vg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=x8dW1eobv46xxf8Qk5whq589HTl41TDtcRbBhNUlvgA=; b=saOQESANyDSd130RLl4GY8DMM85Ij62E/HVhFckb0Iz86TX1mG/c+S2kTSUjXcOqoT mpBr2Ibl6DM04QtuJfBbqUuNUwIkbgpZ5sAXZB7XmhxSSwSiiEv1OSoPVwV4U2BKJjUC m6i/vCcRoMW8kgIpSzAoqe4QClU3ASVKoxjrtx9JPaIKUHEGaHsN2lhKfwp3Rd8PEtep IYtvhspBgUJY7QKMXcClsMONr5QSYqDkxvz6HcK1+nzQq2hyr69nbhqlSsimbnjOKj8I k8QNb1Y0v1X8oj65U6GMZ7RZCCW3t1QDe5I1uwa93G2tHgmIEIeRfBWY+xKZURSSNwiu DBsA== X-Gm-Message-State: APjAAAUkKnEbH1XksE8nL8QxBodncqLojOc7STTTcNTyLcxW+8Tqg8sf rhrMzDln4x+SFfQ2RDtvaU4jqGM7+Wk= X-Received: by 2002:a0c:9638:: with SMTP id 53mr18528892qvx.13.1567527428298; Tue, 03 Sep 2019 09:17:08 -0700 (PDT) Date: Tue, 3 Sep 2019 09:16:52 -0700 In-Reply-To: <20190903161655.107408-1-hridya@google.com> Message-Id: <20190903161655.107408-2-hridya@google.com> Mime-Version: 1.0 References: <20190903161655.107408-1-hridya@google.com> X-Mailer: git-send-email 2.23.0.187.g17f5b7556c-goog Subject: [PATCH v3 1/4] binder: add a mount option to show global stats From: Hridya Valsaraju To: Greg Kroah-Hartman , "=?UTF-8?q?Arve=20Hj=C3=B8nnev=C3=A5g?=" , Todd Kjos , Martijn Coenen , Joel Fernandes , Christian Brauner , devel@driverdev.osuosl.org, linux-kernel@vger.kernel.org Cc: kernel-team@android.com, Hridya Valsaraju Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently, all binder state and statistics live in debugfs. We need this information even when debugfs is not mounted. This patch adds the mount option 'stats' to enable a binderfs instance to have binder debug information present in the same. 'stats=global' will enable the global binder statistics. In the future, 'stats=local' will enable binder statistics local to the binderfs instance. The two modes 'global' and 'local' will be mutually exclusive. 'stats=global' option is only available for a binderfs instance mounted in the initial user namespace. An attempt to use the option to mount a binderfs instance in another user namespace will return an EPERM error. Signed-off-by: Hridya Valsaraju --- Changes in v2: - Improve error check in binderfs_parse_mount_opts() as per Greg Kroah-Hartman. - Change pr_info() log before failure to pr_err() as per Greg Kroah-Hartman. drivers/android/binderfs.c | 45 ++++++++++++++++++++++++++++++++++++-- 1 file changed, 43 insertions(+), 2 deletions(-) diff --git a/drivers/android/binderfs.c b/drivers/android/binderfs.c index cc2e71576396..7045bfe5b52b 100644 --- a/drivers/android/binderfs.c +++ b/drivers/android/binderfs.c @@ -51,18 +51,27 @@ static DEFINE_IDA(binderfs_minors); /** * binderfs_mount_opts - mount options for binderfs * @max: maximum number of allocatable binderfs binder devices + * @stats_mode: enable binder stats in binderfs. */ struct binderfs_mount_opts { int max; + int stats_mode; }; enum { Opt_max, + Opt_stats_mode, Opt_err }; +enum binderfs_stats_mode { + STATS_NONE, + STATS_GLOBAL, +}; + static const match_table_t tokens = { { Opt_max, "max=%d" }, + { Opt_stats_mode, "stats=%s" }, { Opt_err, NULL } }; @@ -290,8 +299,9 @@ static void binderfs_evict_inode(struct inode *inode) static int binderfs_parse_mount_opts(char *data, struct binderfs_mount_opts *opts) { - char *p; + char *p, *stats; opts->max = BINDERFS_MAX_MINOR; + opts->stats_mode = STATS_NONE; while ((p = strsep(&data, ",")) != NULL) { substring_t args[MAX_OPT_ARGS]; @@ -311,6 +321,22 @@ static int binderfs_parse_mount_opts(char *data, opts->max = max_devices; break; + case Opt_stats_mode: + if (!capable(CAP_SYS_ADMIN)) + return -EINVAL; + + stats = match_strdup(&args[0]); + if (!stats) + return -ENOMEM; + + if (strcmp(stats, "global") != 0) { + kfree(stats); + return -EINVAL; + } + + opts->stats_mode = STATS_GLOBAL; + kfree(stats); + break; default: pr_err("Invalid mount options\n"); return -EINVAL; @@ -322,8 +348,21 @@ static int binderfs_parse_mount_opts(char *data, static int binderfs_remount(struct super_block *sb, int *flags, char *data) { + int prev_stats_mode, ret; struct binderfs_info *info = sb->s_fs_info; - return binderfs_parse_mount_opts(data, &info->mount_opts); + + prev_stats_mode = info->mount_opts.stats_mode; + ret = binderfs_parse_mount_opts(data, &info->mount_opts); + if (ret) + return ret; + + if (prev_stats_mode != info->mount_opts.stats_mode) { + pr_err("Binderfs stats mode cannot be changed during a remount\n"); + info->mount_opts.stats_mode = prev_stats_mode; + return -EINVAL; + } + + return 0; } static int binderfs_show_mount_opts(struct seq_file *seq, struct dentry *root) @@ -333,6 +372,8 @@ static int binderfs_show_mount_opts(struct seq_file *seq, struct dentry *root) info = root->d_sb->s_fs_info; if (info->mount_opts.max <= BINDERFS_MAX_MINOR) seq_printf(seq, ",max=%d", info->mount_opts.max); + if (info->mount_opts.stats_mode == STATS_GLOBAL) + seq_printf(seq, ",stats=global"); return 0; } -- 2.23.0.187.g17f5b7556c-goog