1 files changed, 29 insertions, 0 deletions
diff --git a/crypto/src/math/raw/Bits.cs b/crypto/src/math/raw/Bits.cs
new file mode 100644
index 000000000..d344e1672
--- /dev/null
+++ b/crypto/src/math/raw/Bits.cs
@@ -0,0 +1,29 @@
+using System;
+
+namespace Org.BouncyCastle.Math.Raw
+{
+ internal abstract class Bits
+ {
+ internal static uint BitPermuteStep(uint x, uint m, int s)
+ {
+ uint t = (x ^ (x >> s)) & m;
+ return (t ^ (t << s)) ^ x;
+ }
+
+ internal static ulong BitPermuteStep(ulong x, ulong m, int s)
+ {
+ ulong t = (x ^ (x >> s)) & m;
+ return (t ^ (t << s)) ^ x;
+ }
+
+ internal static uint BitPermuteStepSimple(uint x, uint m, int s)
+ {
+ return ((x & m) << s) | ((x >> s) & m);
+ }
+
+ internal static ulong BitPermuteStepSimple(ulong x, ulong m, int s)
+ {
+ return ((x & m) << s) | ((x >> s) & m);
+ }
+ }
+}
|