Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp652800imm; Mon, 9 Jul 2018 08:16:33 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdzZt12zRBk/iyrE3BD03BFWSpC/7EO9/03mI7XNTrs9G7xZ6K/WZv+31FugL6grWtWaC5g X-Received: by 2002:a65:4c02:: with SMTP id u2-v6mr19655386pgq.364.1531149393788; Mon, 09 Jul 2018 08:16:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531149393; cv=none; d=google.com; s=arc-20160816; b=md+Wc6OvflUrJ69ZCdB9yRkYAlU94hX6gSG/OLml9shHTiTTBGuTwHAbYnF4V72rPc GJlPcs2fq50k7QK0jBFEtCXjsuE5dk4JVNKmIPv7IyXLyKmmPLrFG8aIqeZ0zo5vYo8C IPJomEwr0kUAUiMh+4FXCuqdU4wzDf3V+wNWj6p0Qh0Svmx9DrY5pWvAek6U2RvjLNLh V/YeGB0xzzpcy63g2SACkoIWa2YVEJyElaKhd1PzJgVx4xRH6E33IfD1HKoU1zNEpVhG n2+znPFhHCVUYWRJJwofjEfGUOCEFJJdwLwgxST1XEcccV+IL9q2FrC7u7SXQOW2Kjgx RUXw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=oFHl/qb6kt+BdQRH7snwxI9/D15UmrVQxZQdfewdXGc=; b=0wOT77WC+0MI+TLY+6h6NKnaDMERhLT/uJ20knGuRz1WGkvwvZjDgreZhXWC3ut4L1 Z9Htr5rIEjHInuB2JeiQEIOiavBMcZrxBfI/ngsQEErqTapLFA3Xag/OY1KpoSV8KvNS IZVfzOFMJPizMknqNZsKayMEp0sItl5xWwv2gg20bT3IEN4ySPvYDTKxHiCll31MUYWi nWaYMwvzgvXSIUP2HAj6utdKm7f44WdRw6wHZpEMUaFjp+Gn6adsLkPqctShVzJFNf3D jyromwDKO6hq1srPbfigU2YCj5gaqnB+XSfeyEuXM7YqWSy7I1XIK7LLJOUFiGUUCQUc bQ7Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@colorfullife-com.20150623.gappssmtp.com header.s=20150623 header.b=MZmi7cIo; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d41-v6si14405902pla.162.2018.07.09.08.16.16; Mon, 09 Jul 2018 08:16:33 -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=@colorfullife-com.20150623.gappssmtp.com header.s=20150623 header.b=MZmi7cIo; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933555AbeGIPMY (ORCPT + 99 others); Mon, 9 Jul 2018 11:12:24 -0400 Received: from mail-wr1-f67.google.com ([209.85.221.67]:37358 "EHLO mail-wr1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933406AbeGIPKk (ORCPT ); Mon, 9 Jul 2018 11:10:40 -0400 Received: by mail-wr1-f67.google.com with SMTP id q10-v6so11375154wrd.4 for ; Mon, 09 Jul 2018 08:10:39 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=colorfullife-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=oFHl/qb6kt+BdQRH7snwxI9/D15UmrVQxZQdfewdXGc=; b=MZmi7cIoiodab3iisrWELPT8EII5FUalU7OXEvUVrWwHRufAJiQOxak5xZ07jv77OZ b/ogxpuQr+m7HrRhBVeMvqnUgPThl+Kyl/U5muK+otbbW1gmujVvJtigkKp6oI8Xr8cl Ge5f3BsTCyTamyjxqA5X9+1yWkPmmRjPWoZkvspANyzrR68e1lHDw/nJZW4TGCkE/AhG /WRm0isdYrDqdCeYXNGT8OVNRGRKdewrA7UBrGPg2CBCU2bnKc1RAu55HKJ8+NKFDrce Zdh6j65akWZq/ly0luTF582U8qTy+vJF854psYz06tap1GQT/nM5fhhJIyD3Ng5sXw5O JIuw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=oFHl/qb6kt+BdQRH7snwxI9/D15UmrVQxZQdfewdXGc=; b=eywOHrSRHrzZrMkzqGk1zBwmPDF41aKw73fbUPvrDwfaQGlLBx+iP6VlAoRih1w8ph b6ElBXKlRp6PqZZIUqPKBBui1mF7K3mRoqoJATv8TvY57gfrDvUgtGcbdH6idFLSfUSZ urL1OLdC2p3bxeU6ZWkO6tVWnOGt0+h74aQYnfJHey8ciUM5fC3rUd6VQZmQoXoT6bWW pejE//4vRgw8PGlliZU2onIBQKUz/b14BOrHKalCvod6j/52kemB6BLioCCd6J/7iWah sS9WwzylWH6ulA/fqNflsycc/y0cpHqVI02BSfsbcsWocOtf/pbFwMlgaftWSoZuYyEI ZxMA== X-Gm-Message-State: AOUpUlE9GFn0EMW3rVVCZuaHbQq+XJxYvHaW4kKDpt7N/zj9xadxqQ8D WUz816+xDRKQSaLXFm4n533/YA== X-Received: by 2002:adf:80c9:: with SMTP id 67-v6mr6210531wrl.95.1531149038792; Mon, 09 Jul 2018 08:10:38 -0700 (PDT) Received: from localhost.localdomain (p200300D993C227000209466FFA2F090C.dip0.t-ipconnect.de. [2003:d9:93c2:2700:209:466f:fa2f:90c]) by smtp.googlemail.com with ESMTPSA id u124-v6sm7817330wme.26.2018.07.09.08.10.37 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 09 Jul 2018 08:10:38 -0700 (PDT) From: Manfred Spraul To: Andrew Morton , Davidlohr Bueso , Dmitry Vyukov Cc: LKML , 1vier1@web.de, Kees Cook , Davidlohr Bueso , Manfred Spraul Subject: [PATCH 08/12] lib/rhashtable: simplify bucket_table_alloc() Date: Mon, 9 Jul 2018 17:10:15 +0200 Message-Id: <20180709151019.1336-9-manfred@colorfullife.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20180709151019.1336-1-manfred@colorfullife.com> References: <20180709151019.1336-1-manfred@colorfullife.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Davidlohr Bueso As of commit ce91f6ee5b3b ("mm: kvmalloc does not fallback to vmalloc for incompatible gfp flags") we can simplify the caller and trust kvzalloc() to just do the right thing. For the case of the GFP_ATOMIC context, we can drop the __GFP_NORETRY flag for obvious reasons, and for the __GFP_NOWARN case, however, it is changed such that the caller passes the flag instead of making bucket_table_alloc() handle it. This slightly changes the gfp flags passed on to nested_table_alloc() as it will now also use GFP_ATOMIC | __GFP_NOWARN. However, I consider this a positive consequence as for the same reasons we want nowarn semantics in bucket_table_alloc(). Signed-off-by: Davidlohr Bueso Acked-by: Michal Hocko (commit id extended to 12 digits, line wraps updated) Signed-off-by: Manfred Spraul --- lib/rhashtable.c | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/lib/rhashtable.c b/lib/rhashtable.c index 9427b5766134..083f871491a1 100644 --- a/lib/rhashtable.c +++ b/lib/rhashtable.c @@ -175,10 +175,7 @@ static struct bucket_table *bucket_table_alloc(struct rhashtable *ht, int i; size = sizeof(*tbl) + nbuckets * sizeof(tbl->buckets[0]); - if (gfp != GFP_KERNEL) - tbl = kzalloc(size, gfp | __GFP_NOWARN | __GFP_NORETRY); - else - tbl = kvzalloc(size, gfp); + tbl = kvzalloc(size, gfp); size = nbuckets; @@ -459,7 +456,7 @@ static int rhashtable_insert_rehash(struct rhashtable *ht, err = -ENOMEM; - new_tbl = bucket_table_alloc(ht, size, GFP_ATOMIC); + new_tbl = bucket_table_alloc(ht, size, GFP_ATOMIC | __GFP_NOWARN); if (new_tbl == NULL) goto fail; -- 2.17.1