Hi Catanlin Thanks for the detailed explanation. Will send out v12 soon after testing
-- Cheers, Justin (Jia He) > -----Original Message----- > From: Catalin Marinas <catalin.mari...@arm.com> > Sent: Friday, October 11, 2019 6:39 PM > To: Justin He (Arm Technology China) <justin...@arm.com> > Cc: Will Deacon <w...@kernel.org>; Mark Rutland > <mark.rutl...@arm.com>; James Morse <james.mo...@arm.com>; Marc > Zyngier <m...@kernel.org>; Matthew Wilcox <wi...@infradead.org>; Kirill A. > Shutemov <kirill.shute...@linux.intel.com>; linux-arm- > ker...@lists.infradead.org; linux-kernel@vger.kernel.org; linux- > m...@kvack.org; Suzuki Poulose <suzuki.poul...@arm.com>; Borislav > Petkov <b...@alien8.de>; H. Peter Anvin <h...@zytor.com>; x...@kernel.org; > Thomas Gleixner <t...@linutronix.de>; Andrew Morton <akpm@linux- > foundation.org>; hejia...@gmail.com; Kaly Xin (Arm Technology China) > <kaly....@arm.com>; nd <n...@arm.com> > Subject: Re: [PATCH v11 1/4] arm64: cpufeature: introduce helper > cpu_has_hw_af() > > On Fri, Oct 11, 2019 at 01:16:36AM +0000, Justin He (Arm Technology China) > wrote: > > From: Catalin Marinas <catalin.mari...@arm.com> > > > On Wed, Oct 09, 2019 at 04:42:43PM +0800, Jia He wrote: > > > > + u64 mmfr1 = read_cpuid(ID_AA64MMFR1_EL1); > > > > + > > > > + return !!cpuid_feature_extract_unsigned_field(mmfr1, > > > > + > > > ID_AA64MMFR1_HADBS_SHIFT); > > > > > > No need for !!, the return type is a bool already. > > > > But cpuid_feature_extract_unsigned_field has the return type "unsigned > int" [1] > > > > [1] > https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch > /arm64/include/asm/cpufeature.h#n444 > > And the C language gives you the automatic conversion from unsigned int > to bool without the need for !!. The reason we use !! in some places is > for converting long to int (not bool) and losing the top 32-bit. See > commit 84fe6826c28f ("arm64: mm: Add double logical invert to pte > accessors") for an explanation. > > -- > Catalin