diff options
author | Peter Dettman <peter.dettman@bouncycastle.org> | 2022-07-19 00:42:58 +0700 |
---|---|---|
committer | Peter Dettman <peter.dettman@bouncycastle.org> | 2022-07-19 00:42:58 +0700 |
commit | b966a4c7e871e8a1bdf50c29626ce40450c3db0c (patch) | |
tree | ec7ebe55384a5f92233977dc01e0c541a04af581 /crypto/src/math/BigInteger.cs | |
parent | Factor out Unshuffle methods (diff) | |
download | BouncyCastle.NET-ed25519-b966a4c7e871e8a1bdf50c29626ce40450c3db0c.tar.xz |
Use intrinsics in several places
Diffstat (limited to 'crypto/src/math/BigInteger.cs')
-rw-r--r-- | crypto/src/math/BigInteger.cs | 39 |
1 files changed, 18 insertions, 21 deletions
diff --git a/crypto/src/math/BigInteger.cs b/crypto/src/math/BigInteger.cs index 50229e2db..f915beafc 100644 --- a/crypto/src/math/BigInteger.cs +++ b/crypto/src/math/BigInteger.cs @@ -2,6 +2,9 @@ using System; using System.Collections.Generic; using System.Diagnostics; using System.Globalization; +#if NET5_0_OR_GREATER +using System.Runtime.Intrinsics.X86; +#endif using System.Runtime.Serialization; using System.Text; @@ -136,26 +139,6 @@ namespace Org.BouncyCastle.Math public static readonly BigInteger Four; public static readonly BigInteger Ten; - //private readonly static byte[] BitCountTable = - //{ - // 0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4, - // 1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5, - // 1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5, - // 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, - // 1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5, - // 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, - // 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, - // 3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7, - // 1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5, - // 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, - // 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, - // 3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7, - // 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, - // 3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7, - // 3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7, - // 4, 5, 5, 6, 5, 6, 6, 7, 5, 6, 6, 7, 6, 7, 7, 8 - //}; - private readonly static byte[] BitLengthTable = { 0, 1, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4, @@ -911,6 +894,13 @@ namespace Org.BouncyCastle.Math public static int BitCnt(int i) { +#if NET5_0_OR_GREATER + if (Popcnt.IsSupported) + { + return (int)Popcnt.PopCount((uint)i); + } +#endif + uint u = (uint)i; u = u - ((u >> 1) & 0x55555555); u = (u & 0x33333333) + ((u >> 2) & 0x33333333); @@ -976,8 +966,15 @@ namespace Org.BouncyCastle.Math // // BitLen(value) is the number of bits in value. // - internal static int BitLen(int w) + private static int BitLen(int w) { +#if NET5_0_OR_GREATER + if (Lzcnt.IsSupported) + { + return 32 - (int)Lzcnt.LeadingZeroCount((uint)w); + } +#endif + uint v = (uint)w; uint t = v >> 24; if (t != 0) |