crypto: gf128mul - The x8_ble multiplication functions
authorHarsh Jain <harsh@chelsio.com>
Sun, 8 Oct 2017 08:07:20 +0000 (13:37 +0530)
committerHerbert Xu <herbert@gondor.apana.org.au>
Fri, 3 Nov 2017 13:50:43 +0000 (21:50 +0800)
It multiply GF(2^128) elements in the ble format.
It will be used by chelsio driver to speed up gf multiplication.

Signed-off-by: Harsh Jain <harsh@chelsio.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
crypto/gf128mul.c
include/crypto/gf128mul.h

index dc012129c0631ab11a9d8afa69d8c57b06dc3ead..24e601954c7a405c12d30fbfdb683430edff1f07 100644 (file)
@@ -156,6 +156,19 @@ static void gf128mul_x8_bbe(be128 *x)
        x->b = cpu_to_be64((b << 8) ^ _tt);
 }
 
+void gf128mul_x8_ble(le128 *r, const le128 *x)
+{
+       u64 a = le64_to_cpu(x->a);
+       u64 b = le64_to_cpu(x->b);
+
+       /* equivalent to gf128mul_table_be[b >> 63] (see crypto/gf128mul.c): */
+       u64 _tt = gf128mul_table_be[a >> 56];
+
+       r->a = cpu_to_le64((a << 8) | (b >> 56));
+       r->b = cpu_to_le64((b << 8) ^ _tt);
+}
+EXPORT_SYMBOL(gf128mul_x8_ble);
+
 void gf128mul_lle(be128 *r, const be128 *b)
 {
        be128 p[8];
index 0977fb18ff68c63ad66eccbb34cc4bff8c514af0..fa0a63d298dc4866a01e78d623e6cbe33e4953aa 100644 (file)
@@ -227,7 +227,7 @@ struct gf128mul_4k *gf128mul_init_4k_lle(const be128 *g);
 struct gf128mul_4k *gf128mul_init_4k_bbe(const be128 *g);
 void gf128mul_4k_lle(be128 *a, const struct gf128mul_4k *t);
 void gf128mul_4k_bbe(be128 *a, const struct gf128mul_4k *t);
-
+void gf128mul_x8_ble(le128 *r, const le128 *x);
 static inline void gf128mul_free_4k(struct gf128mul_4k *t)
 {
        kzfree(t);