From: Todd Kjos <tkjos@google.com>
To: Martijn Coenen <maco@android.com>
Cc: "Greg Kroah-Hartman" <gregkh@linuxfoundation.org>,
"Arve Hjønnevåg" <arve@android.com>,
"Dan Carpenter" <dan.carpenter@oracle.com>,
"John Stultz" <john.stultz@linaro.org>,
"Amit Pundir" <amit.pundir@linaro.org>,
"Steven Moreland" <smoreland@google.com>,
"Peter Kalauskas" <peskal@google.com>,
"Robert Benea" <robenea@google.com>,
LKML <linux-kernel@vger.kernel.org>,
"open list:ANDROID DRIVERS" <devel@driverdev.osuosl.org>,
"Martijn Coenen" <maco@google.com>
Subject: Re: [PATCH v2] ANDROID: binder: Add BINDER_GET_NODE_INFO_FOR_REF ioctl.
Date: Wed, 17 Oct 2018 09:17:30 -0700 [thread overview]
Message-ID: <CAHRSSEx1vAMWBH3t0uS3CcrBi+zkVmcU0o_+QWP+vW_=+73anA@mail.gmail.com> (raw)
In-Reply-To: <20180907133837.66047-1-maco@android.com>
On Fri, Sep 7, 2018 at 6:38 AM Martijn Coenen <maco@android.com> wrote:
>
> This allows the context manager to retrieve information about nodes
> that it holds a reference to, such as the current number of
> references to those nodes.
>
> Such information can for example be used to determine whether the
> servicemanager is the only process holding a reference to a node.
> This information can then be passed on to the process holding the
> node, which can in turn decide whether it wants to shut down to
> reduce resource usage.
>
> Signed-off-by: Martijn Coenen <maco@android.com>
> ---
> v2: made sure reserved fields are aligned, and enforce caller zeroes
> all fields except handle, as suggested by Dan Carpenter.
>
> drivers/android/binder.c | 55 +++++++++++++++++++++++++++++
> include/uapi/linux/android/binder.h | 10 ++++++
> 2 files changed, 65 insertions(+)
>
> diff --git a/drivers/android/binder.c b/drivers/android/binder.c
> index d58763b6b0090..5b25412e15ccf 100644
> --- a/drivers/android/binder.c
> +++ b/drivers/android/binder.c
> @@ -4544,6 +4544,42 @@ static int binder_ioctl_set_ctx_mgr(struct file *filp)
> return ret;
> }
>
> +static int binder_ioctl_get_node_info_for_ref(struct binder_proc *proc,
> + struct binder_node_info_for_ref *info)
> +{
> + struct binder_node *node;
> + struct binder_context *context = proc->context;
> + __u32 handle = info->handle;
> +
> + if (info->strong_count || info->weak_count || info->reserved1 ||
> + info->reserved2 || info->reserved3) {
> + binder_user_error("%d BINDER_GET_NODE_INFO_FOR_REF: only handle may be non-zero.",
> + proc->pid);
> + return -EINVAL;
> + }
> +
> + /* This ioctl may only be used by the context manager */
> + mutex_lock(&context->context_mgr_node_lock);
> + if (!context->binder_context_mgr_node ||
> + context->binder_context_mgr_node->proc != proc) {
> + mutex_unlock(&context->context_mgr_node_lock);
> + return -EPERM;
> + }
> + mutex_unlock(&context->context_mgr_node_lock);
> +
> + node = binder_get_node_from_ref(proc, handle, true, NULL);
> + if (!node)
> + return -EINVAL;
> +
> + info->strong_count = node->local_strong_refs +
> + node->internal_strong_refs;
> + info->weak_count = node->local_weak_refs;
Aren't we under-reporting the weak refs here? The "internal weak" refs
are the count of elements in node->refs, so we need to add something
like:
hlist_for_each_entry(ref, &node->refs, node_entry)
info->weak_count++;
> +
> + binder_put_node(node);
> +
> + return 0;
> +}
> +
> static int binder_ioctl_get_node_debug_info(struct binder_proc *proc,
> struct binder_node_debug_info *info)
> {
> @@ -4638,6 +4674,25 @@ static long binder_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
> }
> break;
> }
> + case BINDER_GET_NODE_INFO_FOR_REF: {
> + struct binder_node_info_for_ref info;
> +
> + if (copy_from_user(&info, ubuf, sizeof(info))) {
> + ret = -EFAULT;
> + goto err;
> + }
> +
> + ret = binder_ioctl_get_node_info_for_ref(proc, &info);
> + if (ret < 0)
> + goto err;
> +
> + if (copy_to_user(ubuf, &info, sizeof(info))) {
> + ret = -EFAULT;
> + goto err;
> + }
> +
> + break;
> + }
> case BINDER_GET_NODE_DEBUG_INFO: {
> struct binder_node_debug_info info;
>
> diff --git a/include/uapi/linux/android/binder.h b/include/uapi/linux/android/binder.h
> index bfaec6903b8bc..b9ba520f7e4bb 100644
> --- a/include/uapi/linux/android/binder.h
> +++ b/include/uapi/linux/android/binder.h
> @@ -200,6 +200,15 @@ struct binder_node_debug_info {
> __u32 has_weak_ref;
> };
>
> +struct binder_node_info_for_ref {
> + __u32 handle;
> + __u32 strong_count;
> + __u32 weak_count;
> + __u32 reserved1;
> + __u32 reserved2;
> + __u32 reserved3;
> +};
> +
> #define BINDER_WRITE_READ _IOWR('b', 1, struct binder_write_read)
> #define BINDER_SET_IDLE_TIMEOUT _IOW('b', 3, __s64)
> #define BINDER_SET_MAX_THREADS _IOW('b', 5, __u32)
> @@ -208,6 +217,7 @@ struct binder_node_debug_info {
> #define BINDER_THREAD_EXIT _IOW('b', 8, __s32)
> #define BINDER_VERSION _IOWR('b', 9, struct binder_version)
> #define BINDER_GET_NODE_DEBUG_INFO _IOWR('b', 11, struct binder_node_debug_info)
> +#define BINDER_GET_NODE_INFO_FOR_REF _IOWR('b', 12, struct binder_node_info_for_ref)
>
> /*
> * NOTE: Two special error codes you should check for when calling
> --
> 2.19.0.rc2.392.g5ba43deb5a-goog
>
prev parent reply other threads:[~2018-10-17 16:17 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-09-07 13:38 [PATCH v2] ANDROID: binder: Add BINDER_GET_NODE_INFO_FOR_REF ioctl Martijn Coenen
2018-10-17 16:17 ` Todd Kjos [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to='CAHRSSEx1vAMWBH3t0uS3CcrBi+zkVmcU0o_+QWP+vW_=+73anA@mail.gmail.com' \
--to=tkjos@google.com \
--cc=amit.pundir@linaro.org \
--cc=arve@android.com \
--cc=dan.carpenter@oracle.com \
--cc=devel@driverdev.osuosl.org \
--cc=gregkh@linuxfoundation.org \
--cc=john.stultz@linaro.org \
--cc=linux-kernel@vger.kernel.org \
--cc=maco@android.com \
--cc=maco@google.com \
--cc=peskal@google.com \
--cc=robenea@google.com \
--cc=smoreland@google.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).