Message ID | 20250325121624.523258-9-guoren@kernel.org (mailing list archive) |
---|---|
State | New |
Headers | show
Return-Path: <owner-linux-mm@kvack.org> X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id DD47DC35FFC for <linux-mm@archiver.kernel.org>; Tue, 25 Mar 2025 12:18:46 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 6F75328000A; Tue, 25 Mar 2025 08:18:44 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 6A73F280001; Tue, 25 Mar 2025 08:18:44 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 548F928000A; Tue, 25 Mar 2025 08:18:44 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0015.hostedemail.com [216.40.44.15]) by kanga.kvack.org (Postfix) with ESMTP id 37587280001 for <linux-mm@kvack.org>; Tue, 25 Mar 2025 08:18:44 -0400 (EDT) Received: from smtpin25.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay03.hostedemail.com (Postfix) with ESMTP id E2C5DAD566 for <linux-mm@kvack.org>; Tue, 25 Mar 2025 12:18:45 +0000 (UTC) X-FDA: 83259977010.25.08071F4 Received: from sea.source.kernel.org (sea.source.kernel.org [172.234.252.31]) by imf21.hostedemail.com (Postfix) with ESMTP id 2D22B1C001C for <linux-mm@kvack.org>; Tue, 25 Mar 2025 12:18:43 +0000 (UTC) Authentication-Results: imf21.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=lucl4scH; spf=pass (imf21.hostedemail.com: domain of guoren@kernel.org designates 172.234.252.31 as permitted sender) smtp.mailfrom=guoren@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1742905124; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=m4LWBWRzcm1QTP7VTR8DNLgeXM+JgvAKkiStqH/lulU=; b=YnD11RVvZ5ypNBkbuJqkeXe76umxlLaOCxbur//NHX2KaNxQCX0nn/qXHm0mFv9zwJaj0N g8fj4zGjW0MpwIZq08GnsmKaP3oqBg9WF7/2cCvAFfSr735rRWbMjTTQYULWWPLl1pdn4H idSdEHfgxMRl+Ph57Iuwjr+mxSZ3lBI= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1742905124; a=rsa-sha256; cv=none; b=kp+/ANOSIaztCC02d5axOsiZXC7HILOr8Wh2fzaAWoxt1HYKcZVwHiD1azPXbAXw6X29rQ e2ufHWuntWlgkKB8uAmD2bQbjN3oIeC8+P1NGJ4i6XSyp/nURsPPD7VUJeEO5VesRlrRfn LvrJLXHksWkavUf3BITsxhnd35HENI0= ARC-Authentication-Results: i=1; imf21.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=lucl4scH; spf=pass (imf21.hostedemail.com: domain of guoren@kernel.org designates 172.234.252.31 as permitted sender) smtp.mailfrom=guoren@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by sea.source.kernel.org (Postfix) with ESMTP id E1EE743C2A; Tue, 25 Mar 2025 12:18:42 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id D2D25C4CEED; Tue, 25 Mar 2025 12:18:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1742905123; bh=IoEFeh+m75KDxz7bIm+5+JPKqFD60PyKrITdPvnkO1Y=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=lucl4scHiNV8o0GAc3IKkqwvULaoWzPmEp5Cf3HWn54r4yb4FO0Wcun579c2vfuZz J8cjJa3GTTzkMWx5VdBC4BoSRe3Rj4eXqqI4hKBSbaoTMZ+l2q1jnuJGFbX5wp6j2P m4aeZBNLUPltdt6Ih13MGR6Div/iKVhSIZIxo4dWkQp8ORKrVGeC8JOoffP8TQadpr bZFHGx2/54BhY+aa5gsFpFKEFifG6AH1a8qy5WxVap/Iz20XwOxa0fOKpKS0lOBu99 ve/Glkh5gV2+3Jeg8PA+Vog5uAShqNQ+riLO4RMDzBggckY3glJExTgraHapieY6+k 4nOhr50cYNVQA== From: guoren@kernel.org To: arnd@arndb.de, gregkh@linuxfoundation.org, torvalds@linux-foundation.org, paul.walmsley@sifive.com, palmer@dabbelt.com, anup@brainfault.org, atishp@atishpatra.org, oleg@redhat.com, kees@kernel.org, tglx@linutronix.de, will@kernel.org, mark.rutland@arm.com, brauner@kernel.org, akpm@linux-foundation.org, rostedt@goodmis.org, edumazet@google.com, unicorn_wang@outlook.com, inochiama@outlook.com, gaohan@iscas.ac.cn, shihua@iscas.ac.cn, jiawei@iscas.ac.cn, wuwei2016@iscas.ac.cn, drew@pdp7.com, prabhakar.mahadev-lad.rj@bp.renesas.com, ctsai390@andestech.com, wefu@redhat.com, kuba@kernel.org, pabeni@redhat.com, josef@toxicpanda.com, dsterba@suse.com, mingo@redhat.com, peterz@infradead.org, boqun.feng@gmail.com, guoren@kernel.org, xiao.w.wang@intel.com, qingfang.deng@siflower.com.cn, leobras@redhat.com, jszhang@kernel.org, conor.dooley@microchip.com, samuel.holland@sifive.com, yongxuan.wang@sifive.com, luxu.kernel@bytedance.com, david@redhat.com, ruanjinjie@huawei.com, cuiyunhui@bytedance.com, wangkefeng.wang@huawei.com, qiaozhe@iscas.ac.cn Cc: ardb@kernel.org, ast@kernel.org, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, kvm@vger.kernel.org, kvm-riscv@lists.infradead.org, linux-mm@kvack.org, linux-crypto@vger.kernel.org, bpf@vger.kernel.org, linux-input@vger.kernel.org, linux-perf-users@vger.kernel.org, linux-serial@vger.kernel.org, linux-fsdevel@vger.kernel.org, linux-arch@vger.kernel.org, maple-tree@lists.infradead.org, linux-trace-kernel@vger.kernel.org, netdev@vger.kernel.org, linux-atm-general@lists.sourceforge.net, linux-btrfs@vger.kernel.org, netfilter-devel@vger.kernel.org, coreteam@netfilter.org, linux-nfs@vger.kernel.org, linux-sctp@vger.kernel.org, linux-usb@vger.kernel.org, linux-media@vger.kernel.org Subject: [RFC PATCH V3 08/43] rv64ilp32_abi: riscv: bitops: Adapt ctzw & clzw of zbb extension Date: Tue, 25 Mar 2025 08:15:49 -0400 Message-Id: <20250325121624.523258-9-guoren@kernel.org> X-Mailer: git-send-email 2.40.1 In-Reply-To: <20250325121624.523258-1-guoren@kernel.org> References: <20250325121624.523258-1-guoren@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Rspam-User: X-Rspamd-Server: rspam10 X-Rspamd-Queue-Id: 2D22B1C001C X-Stat-Signature: ihordh5uxt96uxs46ii9jg9mzeibczu9 X-HE-Tag: 1742905123-866560 X-HE-Meta: U2FsdGVkX1+Td94IJ+mSWO/yPco4Mkeijn408ECE/fShg5A6n105jTrnjpAdD152uhn5tAcGS14ww17hNinxcc3tRYEFN73aSfkDca2YTXsyr4YjkylEFcdTkDnSjX5C+HahMJWD6i+DuMDGfcswPLjKoSdruO6GR5nC/bPVRbECki3mQ13AknUVdfAVCwO7+fzyH88hJy4i3Nf6ebl0XPTeO1+FYA7NfK3VKgbe0d8ntj5enuXmdxD63WBAw1WbPv+PJDR5OGsfqa24y0ArinU/pD/0eMUyA2LmUcgaOmKWuxTKwIz9hs0BKTRTNsQfQdnVIvDZELHbHPUwEfA8zX33GayHV4HR3kdk+zqAtZR6OkEyX7ff8P6c5EL6ICiHIFMk55MhVo02qBMsV7T1fmd/YQHojMsRBytvfXCjAd/G25GF1iGzc8blpnyQojGWav5k9Q1vO6NmTsZssUSdLkeHl+vbEVYVVQj/XEljbWRQIZXzRrsVSOLDE51tvAQ5zgBIomgeT3VUrqs0yRc4JgvXtZWc/LGe/gyyy8HJVcpUFl7CVGuhHZsiYRhQOGuXcQPYm1Ez6p9Ce97POdAnX8moMF51mEfcyDSBkd5Lifk+yU8nGJXPhzn4d/LMBHmzDbUVAYF1C6fxoTk+dZMnshPdSB4fNr/4V+B3/agdLCwKdEWCikd3CvonIie5Sq0Z1sFR5Vyho/LNCYTTGqUEtpwUHGch1X0q+jrA9dPm3QIQoy6LrcTmKhsxOWOWKjqTc/xn0OhSGONe9HAJ8MalhAar0INZ3pMoRp24CKUb9xRsSTaIJVCprnFZGJxMIYh89XbYzGya8erH5Kpf5ZhgaphbYFwe9lC6QdRUKvvAN2lcQefB2zu2CSJbChiQBm8VJRC6Z+ytKESNLX2WKBSkZbpaHhTxP6llnF+lVQXwzo92g1d+8aZgpboQhpzyQRzB3Ys7sB708uMOrhQUtMt 1pLg4oKz L144+aOta36rXb4vhlkJzxAJA1V7XxipPn6kPpMKJH28+dwKGZdSYkdC5RhY+DJTyezpIANhCQmrwRAq6gsAqlzCpiscAtVSoOuwijHGSOIRiVegB9migToQqUVNpAhvPj4TMUJiqojr9rTUR28ioNKk75JkUrbbfdoL75xBV07DjaPW2pQLCHk3tdOZAc8URpVT0aV8u8IIXOnnLzaBL6AUxLnlAMcoDVBgl47aTn3gn76ESsFckRy1HEzpS/eQbPEUx6K9yAI/8btCcNhIF4SGfL1SKoYR9xbNlYhvOGEnWbbNQsjiQHcmiy0fmTenbQU8QXYscHDlTmilg/WfVpzbr1o2PE3qJlZvDGCrgC1Vb2gew6kA6HZbqaJ3ao8r2Cs8g X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: <linux-mm.kvack.org> List-Subscribe: <mailto:majordomo@kvack.org> List-Unsubscribe: <mailto:majordomo@kvack.org> |
Series |
rv64ilp32_abi: Build CONFIG_64BIT kernel-self with ILP32 ABI
|
expand
|
diff --git a/arch/riscv/include/asm/bitops.h b/arch/riscv/include/asm/bitops.h index c6bd3d8354a9..d041b9e3ba84 100644 --- a/arch/riscv/include/asm/bitops.h +++ b/arch/riscv/include/asm/bitops.h @@ -35,14 +35,27 @@ #include <asm/alternative-macros.h> #include <asm/hwcap.h> -#if (BITS_PER_LONG == 64) +#if (__riscv_xlen == 64) #define CTZW "ctzw " #define CLZW "clzw " + +#if (BITS_PER_LONG == 64) +#define CTZ "ctz " +#define CLZ "clz " #elif (BITS_PER_LONG == 32) +#define CTZ "ctzw " +#define CLZ "clzw " +#else +#error "Unexpected BITS_PER_LONG" +#endif + +#elif (__riscv_xlen == 32) #define CTZW "ctz " #define CLZW "clz " +#define CTZ "ctz " +#define CLZ "clz " #else -#error "Unexpected BITS_PER_LONG" +#error "Unexpected __riscv_xlen" #endif static __always_inline unsigned long variable__ffs(unsigned long word) @@ -53,7 +66,7 @@ static __always_inline unsigned long variable__ffs(unsigned long word) asm volatile (".option push\n" ".option arch,+zbb\n" - "ctz %0, %1\n" + CTZ "%0, %1\n" ".option pop\n" : "=r" (word) : "r" (word) :); @@ -82,7 +95,7 @@ static __always_inline unsigned long variable__fls(unsigned long word) asm volatile (".option push\n" ".option arch,+zbb\n" - "clz %0, %1\n" + CLZ "%0, %1\n" ".option pop\n" : "=r" (word) : "r" (word) :);