From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-10.2 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS,URIBL_BLOCKED,USER_AGENT_SANE_2 autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 91DE7C433ED for ; Thu, 1 Apr 2021 20:53:59 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 5B9FA60BBB for ; Thu, 1 Apr 2021 20:53:59 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234410AbhDAUx4 (ORCPT ); Thu, 1 Apr 2021 16:53:56 -0400 Received: from mail.kernel.org ([198.145.29.99]:37858 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235073AbhDAUxG (ORCPT ); Thu, 1 Apr 2021 16:53:06 -0400 Received: from gandalf.local.home (cpe-66-24-58-225.stny.res.rr.com [66.24.58.225]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 57B0A60BBB; Thu, 1 Apr 2021 20:53:06 +0000 (UTC) Date: Thu, 1 Apr 2021 16:53:04 -0400 From: Steven Rostedt To: Linus Torvalds Cc: LKML , Ingo Molnar , Andrew Morton Subject: Re: [GIT PULL] ftrace: Check if pages were allocated before calling free_pages() Message-ID: <20210401165304.187c7f7e@gandalf.local.home> In-Reply-To: References: <20210331092711.2b23fcff@gandalf.local.home> <20210401160710.45a7a9b8@gandalf.local.home> X-Mailer: Claws Mail 3.17.8 (GTK+ 2.24.33; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 1 Apr 2021 13:18:59 -0700 Linus Torvalds wrote: > On Thu, Apr 1, 2021 at 1:07 PM Steven Rostedt wrote: > > > > On Wed, 31 Mar 2021 11:03:21 -0700 > > Linus Torvalds wrote: > > > > > @@ -6231,7 +6231,8 @@ static int ftrace_process_locs(struct module *mod, > > > if (!addr) > > > continue; > > > > > > - if (pg->index == pg->size) { > > > + end_offset = (pg->index+1) * sizeof(pg->records[0]); > > > + if (end_offset < PAGE_SIZE << pg->order) { > > > > I believe that needs to be: > > > > if (end_offset >= PAGE_SIZE << pg->order) { > [..] > which will be > > end_offset = (3+1) * 1024; > > ie 4096. That just means that the struct fill fill things _up_to_ the > end of the page. > > So only when the end_offset is strictly larger than the page would it > have overflowed the allocation. Ah, I forgot about the "+1" you added to the pg->index, which would make it equivalent to replacing: if (pg->index + 1 > pg->size) { Will update and add your SOB. Thanks, -- Steve