Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp698747pxb; Fri, 16 Apr 2021 16:19:12 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwSGUyrn+5mwqdDamgLI7I20AUstzGbudef8JmuNTH3nGUAWkTevhUCN5lcT6lWiAmzNzWT X-Received: by 2002:a63:f542:: with SMTP id e2mr1219631pgk.338.1618615151802; Fri, 16 Apr 2021 16:19:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618615151; cv=none; d=google.com; s=arc-20160816; b=KOcwRG34iSCT45ADqjtlo97xv+Q7s2GzXgyvkiYLOO7GAFbS1qkIBRVdVwdo8IBCkO sf+7IJz4hpB0s/n9QJUPXt9/0LdYEMcacxpN0rJljNTpd8XI7aMWXQq54cyMj5Y5rnN3 ENBfNODJczsfmi8xX1ln7NXKTbjKvibX+2tzOZhgKXqcU5F1FfvY74oonxR+izLZynHr ok2VNMphytGHFJfr2RShJxzKf5Cs9RIOpQSo76VgiCc2TBZSbjU320HQ1HQokwbo0eX7 8LIw5+F3b4G2wLhnbUH2W3YAS3da5f2csAMPYOjTNagp3A10bP7R/vl9RMzIJqW36XtT MEVw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=/qqs9tp+kiyQL1m0mXkIuqlBljhf16wBFlxJh1VptKw=; b=RPe6ThNncyXKW8XfAg6TM1wyFAX7grL5F1uWYGx7MAXEtfYCOTDBsnkxwp6f73SedH vU1UE51iblZ83HX3ox+rcd3bMlEOuwyPKwlpnQEXBnBBxzim+Ekegg13q8ClDk9Bx8U8 rUULnzn8uexj7/9kP8o7+S68elL8iaSNa82A/ESTodNzkmIPIOkcsL/XLXgjs0IRG9e5 2FunjCalHXka7aAyhWom9coAmgryqlNeHMO5zKf4tdj3QH0qwVQ+jRahBmDT3l/rn2ta 5Cf95wApodQHu2qS65G+26c6XT7xViwaSEjvTBSLwccCikU7NrKtoQ/yvr7m5D0zLwC8 2HnA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=Z8EtYV1G; 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 j5si359075pji.167.2021.04.16.16.19.00; Fri, 16 Apr 2021 16:19:11 -0700 (PDT) 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=@infradead.org header.s=casper.20170209 header.b=Z8EtYV1G; 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 S234852AbhDPXRp (ORCPT + 99 others); Fri, 16 Apr 2021 19:17:45 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47802 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234922AbhDPXRn (ORCPT ); Fri, 16 Apr 2021 19:17:43 -0400 Received: from casper.infradead.org (casper.infradead.org [IPv6:2001:8b0:10b:1236::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2CF4BC061574 for ; Fri, 16 Apr 2021 16:17:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=casper.20170209; h=Content-Transfer-Encoding:MIME-Version: References:In-Reply-To:Message-Id:Date:Subject:Cc:To:From:Sender:Reply-To: Content-Type:Content-ID:Content-Description; bh=/qqs9tp+kiyQL1m0mXkIuqlBljhf16wBFlxJh1VptKw=; b=Z8EtYV1GqOIkMgD7iPf3L8u+Nw JnuFNauyEgqd9NsaDMbyVbkUcfMwd169BGAgIWsNBncjVuVFdBd8uEnj/JR/MwksytXhO5PPVtaTw mAFs/j2EulB4QzhHB/NcdcsJp6OqPoqgB5YlsOuW2zF0fyXYGUQ/Yx1tEvvZeYkda5iVghGSR3jBj y5sLZ6jLU4SRx9p/TMjXnfahlQD4k/eoQsgDSgEqfjjbUsasLCXppuIhViW6sVFaQfBW9x5hi3Qve TnUM3Y5lrYpyWZby6QeTr4boNPxI9Nb5HrKPyBtuJymhnfxQrIkSX1Y9UVmgaVZgPhqGoGkU7Hd5o Wt4kEXHA==; Received: from willy by casper.infradead.org with local (Exim 4.94 #2 (Red Hat Linux)) id 1lXXhL-00AZzb-4N; Fri, 16 Apr 2021 23:16:32 +0000 From: "Matthew Wilcox (Oracle)" To: linux-mm@kvack.org Cc: "Matthew Wilcox (Oracle)" , Andrew Morton , linux-kernel@vger.kernel.org Subject: [PATCH 4/6] mm: Make compound_head const-preserving Date: Sat, 17 Apr 2021 00:15:29 +0100 Message-Id: <20210416231531.2521383-5-willy@infradead.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20210416231531.2521383-1-willy@infradead.org> References: <20210416231531.2521383-1-willy@infradead.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If you pass a const pointer to compound_head(), you get a const pointer back; if you pass a mutable pointer, you get a mutable pointer back. Also remove an unnecessary forward definition of struct page; we're about to dereference page->compound_head, so it must already have been defined. Signed-off-by: Matthew Wilcox (Oracle) --- include/linux/page-flags.h | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/include/linux/page-flags.h b/include/linux/page-flags.h index 04a34c08e0a6..d8e26243db25 100644 --- a/include/linux/page-flags.h +++ b/include/linux/page-flags.h @@ -177,17 +177,17 @@ enum pageflags { #ifndef __GENERATING_BOUNDS_H -struct page; /* forward declaration */ - -static inline struct page *compound_head(struct page *page) +static inline unsigned long _compound_head(const struct page *page) { unsigned long head = READ_ONCE(page->compound_head); if (unlikely(head & 1)) - return (struct page *) (head - 1); - return page; + return head - 1; + return (unsigned long)page; } +#define compound_head(page) ((typeof(page))_compound_head(page)) + static __always_inline int PageTail(struct page *page) { return READ_ONCE(page->compound_head) & 1; -- 2.30.2