Merge tag 'v6.10-p1' of git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6
[linux-2.6-block.git] / crypto / ecc_curve_defs.h
index 9719934c9428ef68325fd36e2653c337774b50ea..0ecade7d02f5d7845e3bc5591c6d990425cd06db 100644 (file)
@@ -17,6 +17,7 @@ static u64 nist_p192_b[] = { 0xFEB8DEECC146B9B1ull, 0x0FA7E9AB72243049ull,
                                0x64210519E59C80E7ull };
 static struct ecc_curve nist_p192 = {
        .name = "nist_192",
+       .nbits = 192,
        .g = {
                .x = nist_p192_g_x,
                .y = nist_p192_g_y,
@@ -43,6 +44,7 @@ static u64 nist_p256_b[] = { 0x3BCE3C3E27D2604Bull, 0x651D06B0CC53B0F6ull,
                                0xB3EBBD55769886BCull, 0x5AC635D8AA3A93E7ull };
 static struct ecc_curve nist_p256 = {
        .name = "nist_256",
+       .nbits = 256,
        .g = {
                .x = nist_p256_g_x,
                .y = nist_p256_g_y,
@@ -75,6 +77,7 @@ static u64 nist_p384_b[] = { 0x2a85c8edd3ec2aefull, 0xc656398d8a2ed19dull,
                                0x988e056be3f82d19ull, 0xb3312fa7e23ee7e4ull };
 static struct ecc_curve nist_p384 = {
        .name = "nist_384",
+       .nbits = 384,
        .g = {
                .x = nist_p384_g_x,
                .y = nist_p384_g_y,
@@ -86,6 +89,51 @@ static struct ecc_curve nist_p384 = {
        .b = nist_p384_b
 };
 
+/* NIST P-521 */
+static u64 nist_p521_g_x[] = { 0xf97e7e31c2e5bd66ull, 0x3348b3c1856a429bull,
+                               0xfe1dc127a2ffa8deull, 0xa14b5e77efe75928ull,
+                               0xf828af606b4d3dbaull, 0x9c648139053fb521ull,
+                               0x9e3ecb662395b442ull, 0x858e06b70404e9cdull,
+                               0xc6ull };
+static u64 nist_p521_g_y[] = { 0x88be94769fd16650ull, 0x353c7086a272c240ull,
+                               0xc550b9013fad0761ull, 0x97ee72995ef42640ull,
+                               0x17afbd17273e662cull, 0x98f54449579b4468ull,
+                               0x5c8a5fb42c7d1bd9ull, 0x39296a789a3bc004ull,
+                               0x118ull };
+static u64 nist_p521_p[] = { 0xffffffffffffffffull, 0xffffffffffffffffull,
+                               0xffffffffffffffffull, 0xffffffffffffffffull,
+                               0xffffffffffffffffull, 0xffffffffffffffffull,
+                               0xffffffffffffffffull, 0xffffffffffffffffull,
+                               0x1ffull };
+static u64 nist_p521_n[] = { 0xbb6fb71e91386409ull, 0x3bb5c9b8899c47aeull,
+                               0x7fcc0148f709a5d0ull, 0x51868783bf2f966bull,
+                               0xfffffffffffffffaull, 0xffffffffffffffffull,
+                               0xffffffffffffffffull, 0xffffffffffffffffull,
+                               0x1ffull };
+static u64 nist_p521_a[] = { 0xfffffffffffffffcull, 0xffffffffffffffffull,
+                               0xffffffffffffffffull, 0xffffffffffffffffull,
+                               0xffffffffffffffffull, 0xffffffffffffffffull,
+                               0xffffffffffffffffull, 0xffffffffffffffffull,
+                               0x1ffull };
+static u64 nist_p521_b[] = { 0xef451fd46b503f00ull, 0x3573df883d2c34f1ull,
+                               0x1652c0bd3bb1bf07ull, 0x56193951ec7e937bull,
+                               0xb8b489918ef109e1ull, 0xa2da725b99b315f3ull,
+                               0x929a21a0b68540eeull, 0x953eb9618e1c9a1full,
+                               0x051ull };
+static struct ecc_curve nist_p521 = {
+       .name = "nist_521",
+       .nbits = 521,
+       .g = {
+               .x = nist_p521_g_x,
+               .y = nist_p521_g_y,
+               .ndigits = 9,
+       },
+       .p = nist_p521_p,
+       .n = nist_p521_n,
+       .a = nist_p521_a,
+       .b = nist_p521_b
+};
+
 /* curve25519 */
 static u64 curve25519_g_x[] = { 0x0000000000000009, 0x0000000000000000,
                                0x0000000000000000, 0x0000000000000000 };
@@ -95,6 +143,7 @@ static u64 curve25519_a[] = { 0x000000000001DB41, 0x0000000000000000,
                                0x0000000000000000, 0x0000000000000000 };
 static const struct ecc_curve ecc_25519 = {
        .name = "curve25519",
+       .nbits = 255,
        .g = {
                .x = curve25519_g_x,
                .ndigits = 4,