From: Martin Kepplinger <martink@posteo.de>
To: zengzhaoxiu@163.com, linux-kernel@vger.kernel.org,
linux@horizon.com, ulrik.debie-os@e2big.org
Cc: Zhaoxiu Zeng <zhaoxiu.zeng@gmail.com>,
Arnd Bergmann <arnd@arndb.de>,
Andrew Morton <akpm@linux-foundation.org>,
Sasha Levin <sasha.levin@oracle.com>,
Ingo Molnar <mingo@kernel.org>,
Denys Vlasenko <dvlasenk@redhat.com>,
linux-arch@vger.kernel.org
Subject: Re: [patch V4 01/31] bitops: add parity functions
Date: Wed, 11 May 2016 16:32:39 +0200 [thread overview]
Message-ID: <57334287.6040208@posteo.de> (raw)
In-Reply-To: <1462956486-29349-1-git-send-email-zengzhaoxiu@163.com>
Am 2016-05-11 um 10:47 schrieb zengzhaoxiu@163.com:
> From: Zhaoxiu Zeng <zhaoxiu.zeng@gmail.com>
>
> Add generic parity functions, adapted from
> "https://graphics.stanford.edu/~seander/bithacks.html#ParityParallel".
>
> The function parityN returns whether an odd or even number of bits are on
> in a N-bit word.
>
> Signed-off-by: Zhaoxiu Zeng <zhaoxiu.zeng@gmail.com>
> ---
This won't be up to me, but I'd appreciate to see all 31 patches
together without having to look for them; I guess I'm not alone.
thanks
martin
> include/asm-generic/bitops.h | 1 +
> include/asm-generic/bitops/arch_parity.h | 39 +++++++++++++++++++++++++++++++
> include/asm-generic/bitops/const_parity.h | 36 ++++++++++++++++++++++++++++
> include/asm-generic/bitops/parity.h | 7 ++++++
> include/asm-generic/bitops/popc-parity.h | 32 +++++++++++++++++++++++++
> include/linux/bitops.h | 10 ++++++++
> 6 files changed, 125 insertions(+)
> create mode 100644 include/asm-generic/bitops/arch_parity.h
> create mode 100644 include/asm-generic/bitops/const_parity.h
> create mode 100644 include/asm-generic/bitops/parity.h
> create mode 100644 include/asm-generic/bitops/popc-parity.h
>
> diff --git a/include/asm-generic/bitops.h b/include/asm-generic/bitops.h
> index dcdcacf..d85722f 100644
> --- a/include/asm-generic/bitops.h
> +++ b/include/asm-generic/bitops.h
> @@ -27,6 +27,7 @@
> #include <asm-generic/bitops/sched.h>
> #include <asm-generic/bitops/ffs.h>
> #include <asm-generic/bitops/hweight.h>
> +#include <asm-generic/bitops/parity.h>
> #include <asm-generic/bitops/lock.h>
>
> #include <asm-generic/bitops/atomic.h>
> diff --git a/include/asm-generic/bitops/arch_parity.h b/include/asm-generic/bitops/arch_parity.h
> new file mode 100644
> index 0000000..813e152
> --- /dev/null
> +++ b/include/asm-generic/bitops/arch_parity.h
> @@ -0,0 +1,39 @@
> +#ifndef _ASM_GENERIC_BITOPS_ARCH_PARITY_H_
> +#define _ASM_GENERIC_BITOPS_ARCH_PARITY_H_
> +
> +#include <asm/types.h>
> +
> +/*
> + * Refrence to 'https://graphics.stanford.edu/~seander/bithacks.html#ParityParallel'.
> + */
> +
> +static inline unsigned int __arch_parity4(unsigned int w)
> +{
> + w &= 0xf;
> + return ((PARITY_MAGIC) >> w) & 1;
> +}
> +
> +static inline unsigned int __arch_parity8(unsigned int w)
> +{
> + w ^= w >> 4;
> + return __arch_parity4(w);
> +}
> +
> +static inline unsigned int __arch_parity16(unsigned int w)
> +{
> + w ^= w >> 8;
> + return __arch_parity8(w);
> +}
> +
> +static inline unsigned int __arch_parity32(unsigned int w)
> +{
> + w ^= w >> 16;
> + return __arch_parity16(w);
> +}
> +
> +static inline unsigned int __arch_parity64(__u64 w)
> +{
> + return __arch_parity32((unsigned int)(w >> 32) ^ (unsigned int)w);
> +}
> +
> +#endif /* _ASM_GENERIC_BITOPS_ARCH_PARITY_H_ */
> diff --git a/include/asm-generic/bitops/const_parity.h b/include/asm-generic/bitops/const_parity.h
> new file mode 100644
> index 0000000..3970546
> --- /dev/null
> +++ b/include/asm-generic/bitops/const_parity.h
> @@ -0,0 +1,36 @@
> +#ifndef _ASM_GENERIC_BITOPS_CONST_PARITY_H_
> +#define _ASM_GENERIC_BITOPS_CONST_PARITY_H_
> +
> +/*
> + * Compile time versions of __arch_parityN()
> + */
> +#define __const_parity4(w) (((PARITY_MAGIC) >> ((w) & 0xf)) & 1)
> +#define __const_parity8(w) (__const_parity4((w) ^ ((w) >> 4)))
> +#define __const_parity16(w) (__const_parity8((w) ^ ((w) >> 8)))
> +#define __const_parity32(w) (__const_parity16((w) ^ ((w) >> 16)))
> +#define __const_parity64(w) (__const_parity32((w) ^ ((w) >> 32)))
> +
> +/*
> + * Generic interface.
> + */
> +#define parity4(w) (__builtin_constant_p(w) ? __const_parity4(w) : __arch_parity4(w))
> +#define parity8(w) (__builtin_constant_p(w) ? __const_parity8(w) : __arch_parity8(w))
> +#define parity16(w) (__builtin_constant_p(w) ? __const_parity16(w) : __arch_parity16(w))
> +#define parity32(w) (__builtin_constant_p(w) ? __const_parity32(w) : __arch_parity32(w))
> +#define parity64(w) (__builtin_constant_p(w) ? __const_parity64(w) : __arch_parity64(w))
> +
> +/*
> + * Interface for known constant arguments
> + */
> +#define PARITY4(w) (BUILD_BUG_ON_ZERO(!__builtin_constant_p(w)) + __const_parity4(w))
> +#define PARITY8(w) (BUILD_BUG_ON_ZERO(!__builtin_constant_p(w)) + __const_parity8(w))
> +#define PARITY16(w) (BUILD_BUG_ON_ZERO(!__builtin_constant_p(w)) + __const_parity16(w))
> +#define PARITY32(w) (BUILD_BUG_ON_ZERO(!__builtin_constant_p(w)) + __const_parity32(w))
> +#define PARITY64(w) (BUILD_BUG_ON_ZERO(!__builtin_constant_p(w)) + __const_parity64(w))
> +
> +/*
> + * Type invariant interface to the compile time constant parity functions.
> + */
> +#define PARITY(w) PARITY64((u64)(w))
> +
> +#endif /* _ASM_GENERIC_BITOPS_CONST_PARITY_H_ */
> diff --git a/include/asm-generic/bitops/parity.h b/include/asm-generic/bitops/parity.h
> new file mode 100644
> index 0000000..a91dce7
> --- /dev/null
> +++ b/include/asm-generic/bitops/parity.h
> @@ -0,0 +1,7 @@
> +#ifndef _ASM_GENERIC_BITOPS_PARITY_H_
> +#define _ASM_GENERIC_BITOPS_PARITY_H_
> +
> +#include <asm-generic/bitops/arch_parity.h>
> +#include <asm-generic/bitops/const_parity.h>
> +
> +#endif /* _ASM_GENERIC_BITOPS_PARITY_H_ */
> diff --git a/include/asm-generic/bitops/popc-parity.h b/include/asm-generic/bitops/popc-parity.h
> new file mode 100644
> index 0000000..bf05999
> --- /dev/null
> +++ b/include/asm-generic/bitops/popc-parity.h
> @@ -0,0 +1,32 @@
> +#ifndef _ASM_GENERIC_BITOPS_POPC_PARITY_H_
> +#define _ASM_GENERIC_BITOPS_POPC_PARITY_H_
> +
> +#include <asm/types.h>
> +
> +static inline unsigned int __arch_parity32(unsigned int w)
> +{
> + return __builtin_popcount(w) & 1;
> +}
> +
> +static inline unsigned int __arch_parity16(unsigned int w)
> +{
> + return __arch_parity32(w & 0xffff);
> +}
> +
> +static inline unsigned int __arch_parity8(unsigned int w)
> +{
> + return __arch_parity32(w & 0xff);
> +}
> +
> +static inline unsigned int __arch_parity4(unsigned int w)
> +{
> + return __arch_parity32(w & 0xf);
> +}
> +
> +static inline unsigned int __arch_parity64(__u64 w)
> +{
> + return (unsigned int)__builtin_popcountll(w) & 1;
> +}
> +
> +#endif
> +
> diff --git a/include/linux/bitops.h b/include/linux/bitops.h
> index defeaac..c3ea19e 100644
> --- a/include/linux/bitops.h
> +++ b/include/linux/bitops.h
> @@ -30,6 +30,11 @@ extern unsigned int __sw_hweight32(unsigned int w);
> extern unsigned long __sw_hweight64(__u64 w);
>
> /*
> + * a miniature 16-bit parity-table of 4-bits number
> + */
> +#define PARITY_MAGIC 0x6996
> +
> +/*
> * Include this here because some architectures need generic_ffs/fls in
> * scope
> */
> @@ -80,6 +85,11 @@ static __always_inline unsigned long hweight_long(unsigned long w)
> return sizeof(w) == 4 ? hweight32(w) : hweight64(w);
> }
>
> +static __always_inline unsigned int parity_long(unsigned long w)
> +{
> + return sizeof(w) == 4 ? parity32(w) : parity64(w);
> +}
> +
> /**
> * rol64 - rotate a 64-bit value left
> * @word: value to rotate
>
next prev parent reply other threads:[~2016-05-11 14:32 UTC|newest]
Thread overview: 85+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-05-11 8:25 [patch V4 00/31] bitops: add parity functions zengzhaoxiu
2016-05-11 8:25 ` zengzhaoxiu
2016-05-11 8:47 ` [patch V4 01/31] " zengzhaoxiu
2016-05-11 14:32 ` Martin Kepplinger [this message]
2016-05-11 9:06 ` [patch V4 02/31] bitops: Include generic parity.h in some architectures' bitops.h zengzhaoxiu
2016-05-11 9:06 ` zengzhaoxiu
2016-05-11 9:06 ` zengzhaoxiu at 163.com
2016-05-11 9:06 ` zengzhaoxiu
2016-05-11 9:06 ` zengzhaoxiu
2016-05-11 9:06 ` zengzhaoxiu
2016-05-11 10:06 ` Jesper Nilsson
2016-05-11 10:06 ` Jesper Nilsson
2016-05-11 10:06 ` Jesper Nilsson
2016-05-11 10:06 ` Jesper Nilsson
2016-05-11 10:06 ` Jesper Nilsson
2016-05-11 10:06 ` Jesper Nilsson
2016-05-11 10:06 ` Jesper Nilsson
2016-05-11 10:42 ` Catalin Marinas
2016-05-11 10:42 ` Catalin Marinas
2016-05-11 10:42 ` Catalin Marinas
2016-05-11 10:42 ` Catalin Marinas
2016-05-11 10:42 ` Catalin Marinas
2016-05-11 10:42 ` Catalin Marinas
2016-05-11 13:52 ` Vineet Gupta
2016-05-11 13:57 ` Vineet Gupta
2016-05-11 13:52 ` Vineet Gupta
2016-05-11 13:52 ` Vineet Gupta
2016-05-11 15:24 ` Mark Salter
2016-05-11 15:24 ` Mark Salter
2016-05-11 15:24 ` Mark Salter
2016-05-11 15:24 ` Mark Salter
2016-05-11 15:24 ` Mark Salter
2016-05-11 15:24 ` Mark Salter
2016-05-11 9:06 ` zengzhaoxiu
2016-05-11 9:09 ` [patch V4 03/31] bitops: Add alpha-specific parity functions zengzhaoxiu
2016-05-11 9:09 ` [patch V4 04/31] bitops: Add blackfin-specific " zengzhaoxiu
2016-05-11 9:10 ` [patch V4 05/31] bitops: Add ia-specific " zengzhaoxiu
2016-05-11 9:10 ` zengzhaoxiu
2016-06-29 15:15 ` [patch V4 05/31] bitops: Add ia64-specific " zengzhaoxiu
2016-06-29 15:15 ` zengzhaoxiu
2016-05-11 9:10 ` [patch V4 06/31] bitops: Tile and MIPS (if has usable __builtin_popcount) use popcount " zengzhaoxiu
2016-05-11 9:11 ` [patch V4 07/31] bitops: Add powerpc-specific " zengzhaoxiu
2016-05-11 9:13 ` [patch V4 08/31] bitops: Add sparc-specific " zengzhaoxiu
2016-05-11 9:13 ` zengzhaoxiu
2016-05-11 23:59 ` David Miller
2016-05-11 23:59 ` David Miller
2016-05-11 9:16 ` [patch V4 09/31] bitops: Add x86-specific " zengzhaoxiu
2016-05-11 9:31 ` Peter Zijlstra
2016-05-11 9:52 ` Borislav Petkov
2016-05-16 15:49 ` Zhaoxiu Zeng
2016-05-16 17:06 ` Peter Zijlstra
2016-05-16 19:22 ` H. Peter Anvin
2016-05-17 11:22 ` Peter Zijlstra
2016-05-16 19:19 ` H. Peter Anvin
2016-06-29 15:04 ` zengzhaoxiu
2016-05-11 9:17 ` [patch V4 10/31] sunrpc: use parity8 zengzhaoxiu
2016-05-11 9:17 ` [patch V4 11/31] mips: use parity functions in cerr-sb1.c zengzhaoxiu
2016-05-11 9:18 ` [patch V4 12/31] lib: bch: use parity32 zengzhaoxiu
2016-05-11 9:18 ` [patch V4 13/31] media: use parity8 in vivid-vbi-gen.c zengzhaoxiu
2016-05-11 9:19 ` [patch V4 14/31] media: use parity functions in saa7115 zengzhaoxiu
2016-07-01 11:53 ` Hans Verkuil
2016-05-11 9:19 ` [patch V4 15/31] input: use parity32 in grip_mp zengzhaoxiu
2016-05-11 9:19 ` [patch V4 16/31] input: use parity64 in sidewinder zengzhaoxiu
2016-05-11 9:19 ` [patch V4 17/31] input: use parity16 in ams_delta_serio zengzhaoxiu
2016-05-11 9:19 ` [patch V4 18/31] scsi: use parity32 in isci's phy zengzhaoxiu
2016-05-11 9:20 ` [patch V4 19/31] mtd: use parity16 in ssfdc zengzhaoxiu
2016-05-11 9:21 ` [patch V4 20/31] mtd: use parity functions in inftlcore zengzhaoxiu
2016-05-11 9:21 ` [patch V4 21/31] crypto: use parity functions in qat_hal zengzhaoxiu
2016-05-11 9:22 ` [patch V4 22/31] mtd: use parity16 in sm_ftl zengzhaoxiu
2016-05-11 9:22 ` [patch V4 23/31] ethernet: use parity8 in sun/niu.c zengzhaoxiu
2016-05-11 23:59 ` David Miller
2016-05-11 9:22 ` [patch V4 24/31] input: use parity8 in pcips2 zengzhaoxiu
2016-05-11 9:22 ` [patch V4 25/31] input: use parity8 in sa1111ps2 zengzhaoxiu
2016-05-11 9:22 ` [patch V4 26/31] iio: use parity32 in adxrs450 zengzhaoxiu
2016-05-11 9:23 ` [patch V4 27/31] serial: use parity32 in max3100 zengzhaoxiu
2016-06-25 17:25 ` Greg Kroah-Hartman
2016-06-29 14:57 ` [patch V4 27/31] serial: use parity8 " zengzhaoxiu
2016-06-29 16:43 ` Greg KH
2016-06-29 17:25 ` zengzhaoxiu
2016-05-11 9:24 ` [patch V4 28/31] input: use parity8 in elantech zengzhaoxiu
2016-05-11 9:24 ` [patch V4 29/31] ethernet: use parity8 in broadcom/tg3.c zengzhaoxiu
2016-05-11 23:59 ` David Miller
2016-05-11 9:24 ` [patch V4 30/31] crypto: use parity_long is sahara.c zengzhaoxiu
2016-06-29 15:18 ` [patch V4 30/31] crypto: use parity_long in sahara.c zengzhaoxiu
2016-05-11 9:24 ` [patch V4 31/31] edac: use parity8 in amd64_edac.c zengzhaoxiu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=57334287.6040208@posteo.de \
--to=martink@posteo.de \
--cc=akpm@linux-foundation.org \
--cc=arnd@arndb.de \
--cc=dvlasenk@redhat.com \
--cc=linux-arch@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux@horizon.com \
--cc=mingo@kernel.org \
--cc=sasha.levin@oracle.com \
--cc=ulrik.debie-os@e2big.org \
--cc=zengzhaoxiu@163.com \
--cc=zhaoxiu.zeng@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.