Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp469291ybl; Tue, 28 Jan 2020 06:27:27 -0800 (PST) X-Google-Smtp-Source: APXvYqzyPNESdqKVRH8aayKHXlmpjW2OpOIsejRWsEa20g8nO481Mx5BksB6kb9sMkbF9LgKv6Pc X-Received: by 2002:aca:190a:: with SMTP id l10mr3063829oii.56.1580221647670; Tue, 28 Jan 2020 06:27:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580221647; cv=none; d=google.com; s=arc-20160816; b=tufKbj2jqCh6LrhNfssmcJ0+CfuxKxYKQftuBdUlC3j0kdmGb0xB+z50NmvA5JcnjV eYWiaHY2hg9rz406oW+TVY3ywUqFetdgj2yDV3j8rT/jEchrou9lJY288bhogRW6cpXf mD2+XV6IAvi53I17t6NIcGME5eqruq6rv3ezDoJkdGqlwvm+C5ofjwDAl/Vu3sAsvFp/ oXS7zbpLn+Sb3DI41iDXd8mJZZbKv+1KcZvp695A+OvxhtlZtWl6SUOIx3Oj324HvbVe iDmDq0V5YNp3AI7fV/KGxUf4nTeaLC8sY4PH0J+trVQ2xUUzMDKwSTxND91Hdd6BTIBs eiSA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=xWYqdEgv9sImKhAkzGWHE1Nrcq8vkwb3p/jGsBQJXds=; b=u2tLXecAQQE9W5qciCML40G7U64+KBgZm96QLzd509jhpG0lkxre738vYFdUZytWTH 4zYPeI+AqmlCsaj5/b/Gx57uuPJGKfF0ucw8IeNqv2XS5PJC9/HJbm7i6U21iRvTSxbo j/C9JaFTbHssantlzsSVVuhPA0CV+lHxLgv2kmmpmmdnG8XPQ4CagmsuGFQgpM42aYFX rAFlNN4pLEfX/85l1G+E2GtxoXHgwKVAueZrooeb18SeyG2cMgSuV6YofrzOlNR4Drn4 J6PQwOm26F3zFuCpfncSc1lBqOtPMAnaXMUuvQHbkyiwHXLjsHn6/Mhq8+eGh3kcd7tV wMbw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Ao3ns2BR; 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 b10si4901519oic.153.2020.01.28.06.27.15; Tue, 28 Jan 2020 06:27:27 -0800 (PST) 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=@kernel.org header.s=default header.b=Ao3ns2BR; 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 S1733153AbgA1O0L (ORCPT + 99 others); Tue, 28 Jan 2020 09:26:11 -0500 Received: from mail.kernel.org ([198.145.29.99]:53438 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1733150AbgA1O0I (ORCPT ); Tue, 28 Jan 2020 09:26:08 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (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 9EA8224685; Tue, 28 Jan 2020 14:26:07 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1580221568; bh=UiVvcOxIJPdD8WM6VCX+s3qaxNYb/keReGTjo7C8E3A=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Ao3ns2BRSHbmdWfPhnmjVpHIsd2hcWKZLuoKNJVdQeYRU9M80IB0HKuAgvGuy+APA ZZ/MzIsOozc0VnX1JNWBWP8rOc5rs0CfJnQVtrVxNK5zRY8jrM5ku+riZDUwEE5SBv LWz+Hw+6qxQgmzebeI4aMzgp4K1Ao1cXnRZdUfGc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Andy Shevchenko , Dmitry Torokhov Subject: [PATCH 4.9 269/271] bitmap: Add bitmap_alloc(), bitmap_zalloc() and bitmap_free() Date: Tue, 28 Jan 2020 15:06:58 +0100 Message-Id: <20200128135912.620442094@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200128135852.449088278@linuxfoundation.org> References: <20200128135852.449088278@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Andy Shevchenko commit c42b65e363ce97a828f81b59033c3558f8fa7f70 upstream. A lot of code become ugly because of open coding allocations for bitmaps. Introduce three helpers to allow users be more clear of intention and keep their code neat. Note, due to multiple circular dependencies we may not provide the helpers as inliners. For now we keep them exported and, perhaps, at some point in the future we will sort out header inclusion and inheritance. Signed-off-by: Andy Shevchenko Signed-off-by: Dmitry Torokhov Signed-off-by: Greg Kroah-Hartman --- include/linux/bitmap.h | 8 ++++++++ lib/bitmap.c | 20 ++++++++++++++++++++ 2 files changed, 28 insertions(+) --- a/include/linux/bitmap.h +++ b/include/linux/bitmap.h @@ -86,6 +86,14 @@ */ /* + * Allocation and deallocation of bitmap. + * Provided in lib/bitmap.c to avoid circular dependency. + */ +extern unsigned long *bitmap_alloc(unsigned int nbits, gfp_t flags); +extern unsigned long *bitmap_zalloc(unsigned int nbits, gfp_t flags); +extern void bitmap_free(const unsigned long *bitmap); + +/* * lib/bitmap.c provides these functions: */ --- a/lib/bitmap.c +++ b/lib/bitmap.c @@ -13,6 +13,7 @@ #include #include #include +#include #include #include @@ -1212,3 +1213,22 @@ void bitmap_copy_le(unsigned long *dst, } EXPORT_SYMBOL(bitmap_copy_le); #endif + +unsigned long *bitmap_alloc(unsigned int nbits, gfp_t flags) +{ + return kmalloc_array(BITS_TO_LONGS(nbits), sizeof(unsigned long), + flags); +} +EXPORT_SYMBOL(bitmap_alloc); + +unsigned long *bitmap_zalloc(unsigned int nbits, gfp_t flags) +{ + return bitmap_alloc(nbits, flags | __GFP_ZERO); +} +EXPORT_SYMBOL(bitmap_zalloc); + +void bitmap_free(const unsigned long *bitmap) +{ + kfree(bitmap); +} +EXPORT_SYMBOL(bitmap_free);