Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp2298453pxb; Sat, 7 Nov 2020 17:21:07 -0800 (PST) X-Google-Smtp-Source: ABdhPJzlR7AhrZxkWOEFqmuavBmVHIx5ODDWlDtXGBWpTIcwen+oYz5OIAQ0BWu0iuFJKZ4XFHc9 X-Received: by 2002:a17:906:edd9:: with SMTP id sb25mr8858235ejb.430.1604798467180; Sat, 07 Nov 2020 17:21:07 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604798467; cv=none; d=google.com; s=arc-20160816; b=BvuCbMTKizBjODE6XCDu9YtIhiqMWVNTM6cH55wr8aBUbk6YuUqzJGZRI3vgj15QEQ GEROE/XfKGkF+7q6b49YGooWOFXNtbwWeidIst6ZnofRbe6g8GJzmeZBBMdp1c7OK8Ct eFHtuf8m4bkWfkUSWpyN9ErVWA9bkKA/R9FjWxWu+qYx7ZE0ouD1bHfZDBBaUp2VYQzB mv1xQaItqWUbejBm+2xpo4krDrcuiPu6+jZsBRcHK3zUSJtmgH1M1p1FT8LqYQT1JGut mXPzQgu3w2yt9sYMbPI5Kf+j4F0g0pvd0QBWO0TXNzyfjyo2Fx6uwhNvCCeGYYijtC8p +cbQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:message-id:user-agent :references:in-reply-to:subject:cc:to:from:date:mime-version :dkim-signature; bh=dLE43ZLA8hp6UktmPV/LfyXxESj/KMWUrBP1RF1ENVY=; b=MH65IBT5ejE7niKT0lCuJBJygAEd5AviqCc9wW3lN2/iLFMSREs8FjvRmD9/Hk83zT jL2Df8lnfVB4m9pG3J0U4zmIjCNyxp7vB5MRCPfWf4I9JZnwOeix5HaSgL5z3kQbhTvd 0GNZEMsFCVnpUabgv4LaeekngAyphSfupqQyAuzRkz3Bkt5TdmPMOUyiDIcPLCGU4wVr 2M0YQrHnDiklk52Vf6HuVjd/XRJdK+puUQGUpl2E5EvY1+RXcR2qnAGAiOBaRezziVcw mL2SKaB1QyMQE9K1bcWXFblsSaGdua1IGpDNWw8ntdl1ayyN9ue5d5I5pHDBVwOuQq2J k4lQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@agner.ch header.s=dkim header.b="DsC/Mq/X"; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t13si4570606edj.45.2020.11.07.17.20.42; Sat, 07 Nov 2020 17:21:07 -0800 (PST) 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=@agner.ch header.s=dkim header.b="DsC/Mq/X"; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728276AbgKHBQm (ORCPT + 99 others); Sat, 7 Nov 2020 20:16:42 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56854 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725838AbgKHBQm (ORCPT ); Sat, 7 Nov 2020 20:16:42 -0500 Received: from mail.kmu-office.ch (mail.kmu-office.ch [IPv6:2a02:418:6a02::a2]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9360AC0613CF for ; Sat, 7 Nov 2020 17:16:42 -0800 (PST) Received: from webmail.kmu-office.ch (unknown [IPv6:2a02:418:6a02::a3]) by mail.kmu-office.ch (Postfix) with ESMTPSA id 44BBE5C0578; Sun, 8 Nov 2020 02:16:38 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=agner.ch; s=dkim; t=1604798198; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=dLE43ZLA8hp6UktmPV/LfyXxESj/KMWUrBP1RF1ENVY=; b=DsC/Mq/XXB7fYqz/csDP6ii7P2ZroqESQeOI2mC9ux6+0qR/orbNMOgN1vhjTJA+VtOB9C bFCraFNMPo/XNjKrub1zkWK/TaphtteLuzCx5zQy3p6w16pMDvDWVUIIJrbRiMsDE4s+px ijemFdXgotntVsYjiqoCT0X9Zs6/0D4= MIME-Version: 1.0 Date: Sun, 08 Nov 2020 02:16:37 +0100 From: Stefan Agner To: Andrew Morton Cc: minchan@kernel.org, ngupta@vflare.org, sergey.senozhatsky.work@gmail.com, sjenning@linux.vnet.ibm.com, gregkh@linuxfoundation.org, arnd@arndb.de, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] mm/zsmalloc: include sparsemem.h for MAX_PHYSMEM_BITS In-Reply-To: <20201107165645.1b139b595b6b64feaca61bcb@linux-foundation.org> References: <20201107165645.1b139b595b6b64feaca61bcb@linux-foundation.org> User-Agent: Roundcube Webmail/1.4.9 Message-ID: X-Sender: stefan@agner.ch Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2020-11-08 01:56, Andrew Morton wrote: > On Sat, 7 Nov 2020 16:22:06 +0100 Stefan Agner wrote: > >> Most architectures define MAX_PHYSMEM_BITS in asm/sparsemem.h and don't >> include it in asm/pgtable.h. Include asm/sparsemem.h directly to get >> the MAX_PHYSMEM_BITS define on all architectures. >> >> This fixes a crash when accessing zram on 32-bit ARM platform with LPAE and >> more than 4GB of memory: >> Unable to handle kernel NULL pointer dereference at virtual address 00000000 > > Mysterious. Presumably without this include, some compilation unit is > picking up the wrong value of MAX_PHYSMEM_BITS? But I couldn't > actually see where/how this occurs. Can you please explain further? Not sure if I got that right, but from what I understand if MAX_PHYSMEM_BITS is not set in mm/zsmalloc.c it will set MAX_PHYSMEM_BITS to BITS_PER_LONG. And this is 32-bit, too short when LPAE is in use... -- Stefan