Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754655AbbG0VU4 (ORCPT ); Mon, 27 Jul 2015 17:20:56 -0400 Received: from mail-bl2on0145.outbound.protection.outlook.com ([65.55.169.145]:50780 "EHLO na01-bl2-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751587AbbG0VUx (ORCPT ); Mon, 27 Jul 2015 17:20:53 -0400 Authentication-Results: freescale.com; dkim=none (message not signed) header.d=none; Message-ID: <1438032043.2993.311.camel@freescale.com> Subject: Re: [RFC v2] genalloc:add an gen_pool_first_fit_align algo to genalloc From: Scott Wood To: Zhao Qiang CC: , , , , , , Date: Mon, 27 Jul 2015 16:20:43 -0500 In-Reply-To: <1437991074-35377-1-git-send-email-qiang.zhao@freescale.com> References: <1437991074-35377-1-git-send-email-qiang.zhao@freescale.com> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.16.0-fta1 MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Originating-IP: [2601:448:8100:f9f:12bf:48ff:fe84:c9a0] X-ClientProxiedBy: BY2PR02CA0112.namprd02.prod.outlook.com (25.163.44.166) To BN3PR03MB1479.namprd03.prod.outlook.com (25.163.35.142) X-Microsoft-Exchange-Diagnostics: 1;BN3PR03MB1479;2:WWWCx5j7m1qYAapraFWoqf6H9mHe6uhulgKDDsN70/9Ux4c6qUcY+2P7b+oznQxqzcR+axdAE/MTcTInoGM9h5VPF1QhWNE2upgVgHFmiAAxIftHqwmdcHXGnj9gCowC0JbVBhBNk4rvNj96dVM2H8wLLp//bf1/UiVKSUKrLV8=;3:YxLl0VjP8AWLibWKbXrlxdI6cM9ypcMGm8Egaa2DJGiX7VQ55BsjvEODKPpppaisnsk9E9TBVS1V1opH1w6mnkZ5RjCVjN/CkbwK14lQr8iAD4HtQbXs0ZQhxIBxIB4ei61tPgrsLM5eVeZtEHhb1w==;25:r2fk/FpLlCm3ve4d0Vqu8G0AU2MvaHaRjQ9wkDTqmtdddklX/+Fcz/N6ecNlAhHaHfQHAjCRLFXZkW8bA2FDgFF3AuXpiCHefJu3keGwI0QVPl7vCHWJ+Yew4kOf6WDdk1W3bHRrIEY8rDWGa0vRsV7RjjkYbx9+2GTIC0ttIYnLENTvMe4gx6ncaUNb2xvRYA1DaCnkao+/QX91IGlnfU4+bWH16ThoLUww4RzGpMn9qx8WHrz/ZL+0mqZn/I9VKrpJShLFidog8peas/o8Fg== X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:BN3PR03MB1479; X-Microsoft-Exchange-Diagnostics: 1;BN3PR03MB1479;20:q83ORBqXJxyrIWJ2F8BYqX2HxeRwPsEgySkYGU0DsrIfPgJoyblK6EmUlspjUOlp3+b3XGSAwNu/LPrtSfNeBkNQSOQuFQsnBoVcLJjw9w1D5q3Sa8zxpLNovWQgGOsHLTIKmgvg6RA5FEO9uyFH48r3NnlrsI55D9Tx4W7MCMi6RXYu7ZwzybhQ5ifR1rtYm76/wKOnuq9cwBWb/oCovtKXKclLTA8aWjQ5Ypm+a5eL1FJfcQ6u1jOjRtffmkZwcORYg0+ALgXGztNJu3/SL+mxJ6OEBmX4izMrQObfKwhdY97rA3LrTxrM/k0sIBDj3x+AAFGILhJpyc7KRe9wSpHPk/Mkqfs/7oiynFDNlTSQhUpDjUnTEr7Bssnnfe+cGJafhXLYndwqvcOLyCsji49Yx3r6qPIVXBJ3AW+FodkyeUFBIQEizN6PsQFZVx5b4xohZO79cnwMFSjAiK/8vGKhQ3Ev1GaEGY9mYSjxA+v/ZO6xvZC9iCIvyVyl/DOC;4:OPoz3oKg65C4d/1U/buRaOtwvtlJvkvSxtmKi/B1IpYKoI/QRPbE4FC+jEJeZJHxauVAHt1c3S0Lmt6CSvzxBu/x3RTgMKD4ubBxzkx7uUg43ubVg3YrilS08h+FcMolKR0gLl4fKeH6frx0zTKKqFxSyHCDSkamriQCDjUBGTxCcQhsU/BD3Q6fCSHag8r0Cjny2mHSuNtMVmY4gBOEhqJMRrRYblvKlEBZ0amGy1I8i5vdXEWvDV52+POvAOMOtI2QN24Lw6C+6w7u++HfVdBsWcBDTu82X3AmKXsFwXE= BN3PR03MB1479: X-MS-Exchange-Organization-RulesExecuted X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(601004)(5005006)(3002001);SRVR:BN3PR03MB1479;BCL:0;PCL:0;RULEID:;SRVR:BN3PR03MB1479; X-Forefront-PRVS: 0650714AAA X-Forefront-Antispam-Report: SFV:NSPM;SFS:(10019020)(6009001)(377424004)(24454002)(36756003)(76176999)(110136002)(87976001)(50226001)(33646002)(62966003)(47776003)(86362001)(50986999)(77096005)(189998001)(23676002)(5001960100002)(2950100001)(42186005)(103116003)(107886002)(77156002)(40100003)(4001450100002)(92566002)(5820100001)(50466002)(46102003)(122386002)(3826002)(4001430100001);DIR:OUT;SFP:1102;SCL:1;SRVR:BN3PR03MB1479;H:[IPv6:2601:448:8100:f9f:12bf:48ff:fe84:c9a0];FPR:;SPF:None;MLV:sfv;LANG:en; X-Microsoft-Exchange-Diagnostics: 1;BN3PR03MB1479;23:mziSt6OTndIl0Q5H71LnVenuCQrlvANyKKHGcn5fOjCllEi/LENZqVh9dTDvllAZWjVxaz3sqaBKixbKu5A4ivYAamKrxPKbFt72rhh3dbl5+gMNyhUELtfefTGO8m1zA8DOw94mMoKLIYIwZ5pi8GovhWTycgkC12Qi2QmQgBkKSZNkTUeCGhxnBKmg4T9BhmHEldjJfVaKYwzpC9+GdZIdbEcX4b1cesv2ug2CiQhrduYmS/mrsuh7argsujE2kJc7JMiW2bYav8SsSunDl3s7NhbCe0OBN5qW5s2SuSIZEiVA9kBYciJhY2TEvirgukviKKsPqEaq+STf5QrchV0G44sIx4ttOdfnSCBkhatqeBgcyg3xW0LqlSPVxc9K26KjUYjLAHBRVvTv0OBHudJbk7Ysx8JGCcQpcaT6VK5ONzsTPr840sSCnWIUwZ/LyXhKk6rG3G3OCyj9TUEc/vEuQHfG4alneSQ3V2542RP/N0rWwSthAhQHTcrMmfPYYXCbDIblzIGKtxoMYE/SqFPork/K9LqE9SwIwzFAfPcsvBQ3H9hpc7d4e4WI4mpVgnrkXRD503CCNwAgtcIk8gPssyY7zgSjtKThJgNQE4CRV1mJtIGR9cZ4opQaWiHGMNHoD3cCyaMaOXSrgEKK3yJ4Z0APogS1IIFU/N9+F7EyMjp5j+yXGVeRlGA3dib8bDzFuF47nnMZLtcSvTnoXusCN4w93Mp8kHeE9oyrvBWXp1vGnC3lTKIy36HCkW9z4EUewVruJNGMauNRvgbPT3lIlscj2TJ0zDYowgP3DKKV5VtpUO5mCmy8lD2aIsr1oC5NeYbrlci/2LpSJsJ9Fqucv9nCcPJ9MxndN/pd8nA= X-Microsoft-Exchange-Diagnostics: 1;BN3PR03MB1479;5:VzYC4o/7UV/e6gScrJmSpUCJ+EHBXHsHwuNHNcpc3q490R5m6epronIkcN0RrgoMU9oxsh/f/XkF/OaevT8zeqg9qmQ2SKU2wLOuT3LOs8iq8vPTzX/wXa3ZBZnUqglNM7WSCylJvjdAeOxXooCIrA==;24:NS5N2s6iMmfX35mGPfmHKu1YJTVyeD8WZfKbXND3MRaAbWtLQX3xDmgjWeuqXNmvvE1W5KQFxZTy0olWy2p3Y91UDW2oWmBLgx0JDjFAjRQ=;20:1nnvmUXountflPQiHEPYZji6lUMFkx5E4G9OI8j2NuRkb6gn+bdxP2pM7jdfbbd7BAJuGXwFDAqCq4d+JKbNAA== X-OriginatorOrg: freescale.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 27 Jul 2015 21:20:50.0386 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-Transport-CrossTenantHeadersStamped: BN3PR03MB1479 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2021 Lines: 55 On Mon, 2015-07-27 at 17:57 +0800, Zhao Qiang wrote: > diff --git a/lib/genalloc.c b/lib/genalloc.c > index d214866..e6608cd 100644 > --- a/lib/genalloc.c > +++ b/lib/genalloc.c > @@ -509,6 +509,31 @@ unsigned long gen_pool_first_fit(unsigned long *map, > unsigned long size, > EXPORT_SYMBOL(gen_pool_first_fit); > > /** > + * gen_pool_first_fit_align - find the first available region > + * of memory matching the size requirement (no alignment constraint) > + * @map: The address to base the search on > + * @size: The bitmap size in bits > + * @start: The bitnumber to start searching at > + * @nr: The number of zeroed bits we're looking for > + * @data: additional data - unused > + */ > +unsigned long gen_pool_first_fit_align(unsigned long *map, unsigned long > size, > + unsigned long start, unsigned int nr, void *data) > +{ > + unsigned long align_mask; > + int order; > + > + if (data && data->pool) { There is no way that this compiles. You can't dereference a void pointer. Please test your code before submitting, even for an RFC. > + order = data->pool->min_alloc_order; I don't think pool belongs in data. It's fundamental enough that, if a pointer to pool is needed, it should be an argument to the algorithm. > + align_mask = ((data->align + (1UL << order) - 1) >> order) - 1; > + } else { > + pr_err("no data or data->pool\n"); > + } This is way too vague and unobtrusive of an error message, and also not rate- limited, etc. I wouldn't bother checking at all. Just let it crash on the developer's machine if they use this without passing in data. Where's the part that adds the ability to pass in data to each allocation call, as per the previous discussion? -Scott -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/