Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3983823imu; Mon, 10 Dec 2018 11:02:22 -0800 (PST) X-Google-Smtp-Source: AFSGD/VwhI803Qu/6JZZtErzk04z/xUM2VwKyGqhCBt81lckN70FfEIJo1u7mdH9X3rypf0V3jjT X-Received: by 2002:a63:790e:: with SMTP id u14mr11815753pgc.452.1544468542724; Mon, 10 Dec 2018 11:02:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544468542; cv=none; d=google.com; s=arc-20160816; b=VUMkDbnj9T/4dx+o9T1dcpGU2rhVtVoy9SAlrAD0VgpfBD1VLMuGZ433LCJifCzUdM uCA3mw3ADQoOWNcpzdvNeZqXZ1xhHrBptU3t0dzlN++nkDt7MWLDavx85oBH0yXFs+nQ fDzPhdHgFQTm0mM+3ihd9/9naeRmRr79RkQMhDbzPd0iN0Sm7CHGycPKUCBEvNmj/AQg nXwlnh3hNpXB32Dk5lDax6jUihJaf8qb75M3kkUrD5clz94fcumsSjr9cESv0wtpL65F YVIgt4RPokwZv5Jn3PCk2MQ9BgOgrqW1weWJgnMFwrKuVSZcR7R1/tcHaEqJ5H+r87F8 nRBw== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:organization:from:references:to:subject:cc :dkim-signature; bh=jIu/NQdLrU30oMjYFo1Dv8/5GvUAOK5LaTrL/MaVmCg=; b=sT3erx52oBYPyOOcdIVYYR9kc2WJHPStapfiq0VyvljC48AUwMBpIJbJaiifdNwUm4 pow2scuMydyq18Wz77N+0RHj/wvVzvUSHxWwZeCtNhybXotvibS+ZGHU5qoDE1QBsbih sUGvtNigwj2lqkYCgTBIKWX6+auF8aMY3+bUmTHJU15fqUwFFu+gvcxA09vhn6G/N3R/ ym6Npsih5P2liNHMdRx0V/Zsgf5Pa3spSsVUUfS7hS76/GmPW2H6aEEpBx/jD0ZsO8ka D8pVNXalYOw89mUC5HU0y/gZedwrgdgV2KJQo6lqAMa84GgXFk/vA16qsE4qYJr01c2C g+fQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b="BBiCVq/u"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m8si10630746pls.400.2018.12.10.11.02.07; Mon, 10 Dec 2018 11:02:22 -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=@linaro.org header.s=google header.b="BBiCVq/u"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727479AbeLJQsk (ORCPT + 99 others); Mon, 10 Dec 2018 11:48:40 -0500 Received: from mail-qk1-f193.google.com ([209.85.222.193]:46865 "EHLO mail-qk1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727302AbeLJQsj (ORCPT ); Mon, 10 Dec 2018 11:48:39 -0500 Received: by mail-qk1-f193.google.com with SMTP id q1so6836576qkf.13 for ; Mon, 10 Dec 2018 08:48:37 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=cc:subject:to:references:from:organization:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=jIu/NQdLrU30oMjYFo1Dv8/5GvUAOK5LaTrL/MaVmCg=; b=BBiCVq/uyLE8Mcbj3/85rQLeTaF8vub5hoz5Kc5iSMv1QCR16Ef7AVjcegACWoNq2f b9FdakseRmRV12Sg5KE2z2Tgr+3eYXlQss/vCtI7sbVB6qPTTYbOmgUDuEDF3HntoBcd UQljs+6XDQ2PKvNkHy2raDh7Bhs4JA8gCN9E4= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:cc:subject:to:references:from:organization :message-id:date:user-agent:mime-version:in-reply-to :content-language:content-transfer-encoding; bh=jIu/NQdLrU30oMjYFo1Dv8/5GvUAOK5LaTrL/MaVmCg=; b=T+uT+4MxkGdnIbgMoPNj/SpCutfYimrKCvNZ7l6T9BdUDAtGcMwh7JyfsIGB6bZe88 daWOpI6YVgAMAG7tZN+ieqVCt0lGf/yeXA99B6xObRI9b/WXTuviyQKr+doHUdDr69lG N2Q5YTGFA0QnldyKf//mmQsLoarTnC1B4YQv2sRFhau02FgzE6VqwKudhja0hWwrtWgd ZcuhQd0t+f5qAyxRrRv43RMCeURsl4MDYa/yh5+3suY68TazHlcxHP5Ppfb4956I5lTg enA42Hg2uc1SxTngBVO2+2CyX3LB/pTJxbbEzaARf2XBpxIUqieBo+11/uDEh5hdowPs xnxg== X-Gm-Message-State: AA+aEWYZ4+STcV/vbq0VmgqU0Aqbdz9Dh/IcjJbblBnefh7X4tUrBljL n1CAtvQ5YRTiXnnXb9R41cvlDQ== X-Received: by 2002:a37:1f44:: with SMTP id f65mr11166603qkf.33.1544460517260; Mon, 10 Dec 2018 08:48:37 -0800 (PST) Received: from [192.168.49.18] ([138.204.25.7]) by smtp.gmail.com with ESMTPSA id l15sm6158986qtr.25.2018.12.10.08.48.27 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 10 Dec 2018 08:48:36 -0800 (PST) Cc: Rafael David Tinoco , Russell King , Catalin Marinas , Will Deacon , Tony Luck , Fenghua Yu , Ralf Baechle , Paul Burton , James Hogan , Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman , Martin Schwidefsky , Heiko Carstens , Yoshinori Sato , Rich Felker , "David S . Miller" , Thomas Gleixner , Ingo Molnar , Borislav Petkov , "H . Peter Anvin" , x86@kernel.org, Minchan Kim , Nitin Gupta , Sergey Senozhatsky , Christophe Leroy , "Aneesh Kumar K . V" , Ram Pai , Nicholas Piggin , Vasily Gorbik , Anthony Yznaga , Khalid Aziz , Joerg Roedel , Juergen Gross , "Kirill A . Shutemov" , Andy Lutomirski , Jiri Kosina , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-ia64@vger.kernel.org, linux-mips@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, linux-s390@vger.kernel.org, linux-sh@vger.kernel.org, sparclinux@vger.kernel.org, linux-mm@kvack.org Subject: Re: [PATCH] mm/zsmalloc.c: Fix zsmalloc 32-bit PAE support To: "Kirill A. Shutemov" References: <20181210142105.6750-1-rafael.tinoco@linaro.org> <20181210151506.phyjkfcg3skogtyh@kshutemo-mobl1> From: Rafael David Tinoco Organization: Linaro Message-ID: <32747ea1-7437-8055-a4f5-9f22378e57ae@linaro.org> Date: Mon, 10 Dec 2018 14:48:25 -0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.3.1 MIME-Version: 1.0 In-Reply-To: <20181210151506.phyjkfcg3skogtyh@kshutemo-mobl1> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 12/10/18 1:15 PM, Kirill A. Shutemov wrote: > On Mon, Dec 10, 2018 at 12:21:05PM -0200, Rafael David Tinoco wrote: >> diff --git a/arch/x86/include/asm/pgtable_64_types.h b/arch/x86/include/asm/pgtable_64_types.h >> index 84bd9bdc1987..d808cfde3d19 100644 >> --- a/arch/x86/include/asm/pgtable_64_types.h >> +++ b/arch/x86/include/asm/pgtable_64_types.h >> @@ -64,8 +64,6 @@ extern unsigned int ptrs_per_p4d; >> #define P4D_SIZE (_AC(1, UL) << P4D_SHIFT) >> #define P4D_MASK (~(P4D_SIZE - 1)) >> >> -#define MAX_POSSIBLE_PHYSMEM_BITS 52 >> - >> #else /* CONFIG_X86_5LEVEL */ >> >> /* >> @@ -154,4 +152,6 @@ extern unsigned int ptrs_per_p4d; >> >> #define PGD_KERNEL_START ((PAGE_SIZE / 2) / sizeof(pgd_t)) >> >> +#define MAX_POSSIBLE_PHYSMEM_BITS (pgtable_l5_enabled() ? 52 : 46) >> + > > ... > >> #endif /* _ASM_X86_PGTABLE_64_DEFS_H */ >> diff --git a/mm/zsmalloc.c b/mm/zsmalloc.c >> index 0787d33b80d8..132c20b6fd4f 100644 >> --- a/mm/zsmalloc.c >> +++ b/mm/zsmalloc.c > > ... > >> @@ -116,6 +100,25 @@ >> */ >> #define OBJ_ALLOCATED_TAG 1 >> #define OBJ_TAG_BITS 1 >> + >> +/* >> + * MAX_POSSIBLE_PHYSMEM_BITS should be defined by all archs using zsmalloc: >> + * Trying to guess it from MAX_PHYSMEM_BITS, or considering it BITS_PER_LONG, >> + * proved to be wrong by not considering PAE capabilities, or using SPARSEMEM >> + * only headers, leading to bad object encoding due to object index overflow. >> + */ >> +#ifndef MAX_POSSIBLE_PHYSMEM_BITS >> + #define MAX_POSSIBLE_PHYSMEM_BITS BITS_PER_LONG >> + #error "MAX_POSSIBLE_PHYSMEM_BITS HAS to be defined by arch using zsmalloc"; >> +#else >> + #ifndef CONFIG_64BIT >> + #if (MAX_POSSIBLE_PHYSMEM_BITS >= (BITS_PER_LONG + PAGE_SHIFT - OBJ_TAG_BITS)) >> + #error "MAX_POSSIBLE_PHYSMEM_BITS is wrong for this arch"; >> + #endif >> + #endif >> +#endif >> + >> +#define _PFN_BITS (MAX_POSSIBLE_PHYSMEM_BITS - PAGE_SHIFT) >> #define OBJ_INDEX_BITS (BITS_PER_LONG - _PFN_BITS - OBJ_TAG_BITS) >> #define OBJ_INDEX_MASK ((_AC(1, UL) << OBJ_INDEX_BITS) - 1) > > Have you tested it with CONFIG_X86_5LEVEL=y? > > ASAICS, the patch makes OBJ_INDEX_BITS and what depends from it dynamic -- > it depends what paging mode we are booting in. ZS_SIZE_CLASSES depends > indirectly on OBJ_INDEX_BITS and I don't see how struct zs_pool definition > can compile with dynamic ZS_SIZE_CLASSES. > > Hm? > You're right, terribly sorry. This was a last time change. mm/zsmalloc.c:256:21: error: variably modified ‘size_class’ at file scope I'll revisit the patch. Any other comments are welcome. Thank you