Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp864826ybt; Wed, 1 Jul 2020 11:55:37 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyY2u/ixibVrGp/5pi2CmevhEaB9n/H2NaDbOSOTZykDVZY+8mV36UINNqDc2t1tzn3X3+f X-Received: by 2002:a17:906:1254:: with SMTP id u20mr3989313eja.540.1593629737618; Wed, 01 Jul 2020 11:55:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593629737; cv=none; d=google.com; s=arc-20160816; b=oNIAHhmeXJ2WIf/la/31n3u5sHLA7iseN9XkhcDxyR1lzw8vllSnC9cIJHR0ydQRHL K4KsO7HphRQNkIZXU3bUPuU2+bb0DQOkjMe+a44AnmEQ9At43pKXfJTnrG1sgJL1A9Dk CdFjjttx8nQaWu7LBmtfmJ85qzLz3szDZ9w4QHEoDgz6w4bP1shNYhtN4C40uUFFLk2r wbDJIWSlf0uJ9SJNUsZ1PgRP7cQLKdSRWJlYrNH2YeXVWrNHA2Et8MIXF+l/gw5vqp2R wjnArYZr9sVTvju5U+XSFfNU+Gi36PzvR+mCW2w5afE5UrTG+E2apONHHwSdASiGpyIG vT1A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :message-id:in-reply-to:subject:cc:to:from:date:dkim-signature; bh=+/n+6AxpUg9QzHb5YBIhMhs6/emUx+VgYGqTlwi4IMw=; b=cvdR2N570qq+fdNEtlqqde8e8HbzFzM2me2+9fyZzRHPCPUecMmRAsVGnwQHW7sLg/ O3EHMZJiYPJTvNlAb3+sjOCvfu1eokPgspiG9l6Ih6WIp6ktyEplMM5CPuaL8zvnOphn uhVfJruaxhuS3HZtu2YKpc7alAyxDNbEJ45Iscl+T39Peyj3sdHq9Ulks9vAkXG4hVJ3 VLf4SvRPJUUPjpd2mWZDeCqD3aCGvESgNiV5IDktm5x1zcgew67l0bRA3hRZHJfJXK3+ lxSh7Cdi2av2imsdokKRgmiLkUvMdz4uRV6QKmgih3exIXi4Bt5ueIiPjfnPmdSa8Nhe AYSA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=tKw3y28u; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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. [23.128.96.18]) by mx.google.com with ESMTP id g12si4435409edu.151.2020.07.01.11.55.13; Wed, 01 Jul 2020 11:55:37 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=tKw3y28u; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S1726129AbgGASwl (ORCPT + 99 others); Wed, 1 Jul 2020 14:52:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35312 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725812AbgGASwk (ORCPT ); Wed, 1 Jul 2020 14:52:40 -0400 Received: from mail-pf1-x444.google.com (mail-pf1-x444.google.com [IPv6:2607:f8b0:4864:20::444]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7D448C08C5C1 for ; Wed, 1 Jul 2020 11:52:40 -0700 (PDT) Received: by mail-pf1-x444.google.com with SMTP id u5so11387270pfn.7 for ; Wed, 01 Jul 2020 11:52:40 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:from:to:cc:subject:in-reply-to:message-id:references :user-agent:mime-version; bh=+/n+6AxpUg9QzHb5YBIhMhs6/emUx+VgYGqTlwi4IMw=; b=tKw3y28uTOBX9axPwIKFUPPmh0R0UNimy9v+qXphx9OQ+8fNirGczQwtCOYzkSUsDy XfzLwndgIx1YzhgqrfZPK9CvKHaLYAi7VQ3391n5HfRKx4FHEVrnIt1yL2HuBCa19s/N AeJA3vKm+9VAn/8DZ51lc7rNYGWTjrc6I16ml/wl8mJ2Sm5FHOdk4vyBoylbAm8tK12N 4CXJ3//34hdOlLKx1qhUOqxZjYwGv1X4is1X51aZzRRFO/XsitFrxVDcDATtCxHD65lE 9wczxCZw5jN9/ZRKYgD0SMLsCQhe9//H5HzOpmP3WjedI/z5/gwI8wlfL+7AowIKcUUy Hoog== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:in-reply-to:message-id :references:user-agent:mime-version; bh=+/n+6AxpUg9QzHb5YBIhMhs6/emUx+VgYGqTlwi4IMw=; b=Z7IYLcHzRvFALjbGku2f6+Na+xAbQlwKe47qx4v6Ql4Lfaaq7Hq4GL/omTnD18UUZ7 jrZqlBOOEYquwO6hpUXyt4iDheH63VWA19B2PVB5yt1XlIeKvxEOlHnFN1S2jF44g1h4 gJ9x60Y7DPWEpibAssad+XCcAFcY0NhNWj6huA24mGiufJ36cZ4nrEVLrYNKSlSXaIK6 hoNIn0kJqboG6IhzE3P+l2RRVhBY1yyhU5i5XATsQGIZOcSmNLZEW3Bwh/VflvkW9YJ2 uVqNGD3lK3MK0sHPL+Z98FpAGmzjpEI7m9niMKthINYI0msf0pvLS23QUJikvR09PDDF /I/g== X-Gm-Message-State: AOAM533xGthW9xmogUPvg4RPEcPf8EKF9SWsHUiEYZQxnQS0S9dqQUQU 9XPKrR0rrrbF0mJYIjJq22GEhw== X-Received: by 2002:a65:4908:: with SMTP id p8mr20783609pgs.214.1593629559668; Wed, 01 Jul 2020 11:52:39 -0700 (PDT) Received: from [2620:15c:17:3:4a0f:cfff:fe51:6667] ([2620:15c:17:3:4a0f:cfff:fe51:6667]) by smtp.gmail.com with ESMTPSA id u20sm6359360pfm.152.2020.07.01.11.52.38 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 01 Jul 2020 11:52:39 -0700 (PDT) Date: Wed, 1 Jul 2020 11:52:38 -0700 (PDT) From: David Rientjes X-X-Sender: rientjes@chino.kir.corp.google.com To: Long Li cc: willy@infradead.org, cl@linux.com, penberg@kernel.org, iamjoonsoo.kim@lge.com, akpm@linux-foundation.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v3] mm, slab: Check GFP_SLAB_BUG_MASK before alloc_pages in kmalloc_order In-Reply-To: <20200701151645.GA26223@lilong> Message-ID: References: <20200701151645.GA26223@lilong> User-Agent: Alpine 2.23 (DEB 453 2020-06-18) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 1 Jul 2020, Long Li wrote: > diff --git a/mm/slab.c b/mm/slab.c > index ac7a223d9ac3..2850fe3c5fb8 100644 > --- a/mm/slab.c > +++ b/mm/slab.c > @@ -2573,13 +2573,9 @@ static struct page *cache_grow_begin(struct kmem_cache *cachep, > * Be lazy and only check for valid flags here, keeping it out of the > * critical path in kmem_cache_alloc(). > */ > - if (unlikely(flags & GFP_SLAB_BUG_MASK)) { > - gfp_t invalid_mask = flags & GFP_SLAB_BUG_MASK; > - flags &= ~GFP_SLAB_BUG_MASK; > - pr_warn("Unexpected gfp: %#x (%pGg). Fixing up to gfp: %#x (%pGg). Fix your code!\n", > - invalid_mask, &invalid_mask, flags, &flags); > - dump_stack(); > - } > + if (unlikely(flags & GFP_SLAB_BUG_MASK)) > + flags = kmalloc_invalid_flags(flags); > + > WARN_ON_ONCE(cachep->ctor && (flags & __GFP_ZERO)); > local_flags = flags & (GFP_CONSTRAINT_MASK|GFP_RECLAIM_MASK); > Is this name correct? kmalloc_invalid_flags() masks off the invalid flags and returns the valid flags :) Maybe kmalloc_check_flags()?