From mboxrd@z Thu Jan 1 00:00:00 1970 From: Alexei Starovoitov Subject: Re: [PATCH 1/2] bpf: do not use KMALLOC_SHIFT_MAX Date: Fri, 16 Dec 2016 10:02:10 -0800 Message-ID: <20161216180209.GA77597@ast-mbp.thefacebook.com> References: <20161215164722.21586-1-mhocko@kernel.org> <20161215164722.21586-2-mhocko@kernel.org> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: linux-mm@kvack.org, Cristopher Lameter , Andrew Morton , Michal Hocko , Alexei Starovoitov , netdev@vger.kernel.org, Daniel Borkmann To: Michal Hocko Return-path: Content-Disposition: inline In-Reply-To: <20161215164722.21586-2-mhocko@kernel.org> Sender: owner-linux-mm@kvack.org List-Id: netdev.vger.kernel.org On Thu, Dec 15, 2016 at 05:47:21PM +0100, Michal Hocko wrote: > From: Michal Hocko > > 01b3f52157ff ("bpf: fix allocation warnings in bpf maps and integer > overflow") has added checks for the maximum allocateable size. It > (ab)used KMALLOC_SHIFT_MAX for that purpose. While this is not incorrect > it is not very clean because we already have KMALLOC_MAX_SIZE for this > very reason so let's change both checks to use KMALLOC_MAX_SIZE instead. > > Cc: Alexei Starovoitov > Signed-off-by: Michal Hocko Nack until the patches 1 and 2 are reversed. The bug that patch 2 fixes was the reason we used KMALLOC_SHIFT_MAX - 1 here instead of KMALLOC_MAX_SIZE, so you have to fix the kmalloc vs __alloc_pages_slowpath discrepancy first. > --- > kernel/bpf/arraymap.c | 2 +- > kernel/bpf/hashtab.c | 2 +- > 2 files changed, 2 insertions(+), 2 deletions(-) > > diff --git a/kernel/bpf/arraymap.c b/kernel/bpf/arraymap.c > index a2ac051c342f..229a5d5df977 100644 > --- a/kernel/bpf/arraymap.c > +++ b/kernel/bpf/arraymap.c > @@ -56,7 +56,7 @@ static struct bpf_map *array_map_alloc(union bpf_attr *attr) > attr->value_size == 0 || attr->map_flags) > return ERR_PTR(-EINVAL); > > - if (attr->value_size >= 1 << (KMALLOC_SHIFT_MAX - 1)) > + if (attr->value_size > KMALLOC_MAX_SIZE) > /* if value_size is bigger, the user space won't be able to > * access the elements. > */ > diff --git a/kernel/bpf/hashtab.c b/kernel/bpf/hashtab.c > index ad1bc67aff1b..c5ec7dc71c84 100644 > --- a/kernel/bpf/hashtab.c > +++ b/kernel/bpf/hashtab.c > @@ -181,7 +181,7 @@ static struct bpf_map *htab_map_alloc(union bpf_attr *attr) > */ > goto free_htab; > > - if (htab->map.value_size >= (1 << (KMALLOC_SHIFT_MAX - 1)) - > + if (htab->map.value_size >= KMALLOC_MAX_SIZE - > MAX_BPF_STACK - sizeof(struct htab_elem)) > /* if value_size is bigger, the user space won't be able to > * access the elements via bpf syscall. This check also makes > -- > 2.10.2 > -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org