iPXE
Functions
elliptic_test.c File Reference

Elliptic curve self-tests. More...

#include <stdint.h>
#include <string.h>
#include <assert.h>
#include <ipxe/bigint.h>
#include <ipxe/crypto.h>
#include <ipxe/test.h>
#include "elliptic_test.h"

Go to the source code of this file.

Functions

 FILE_LICENCE (GPL2_OR_LATER_OR_UBDL)
 
void elliptic_curve_okx (struct elliptic_curve *curve, const char *file, unsigned int line)
 Report elliptic curve sanity test result. More...
 
void elliptic_multiply_okx (struct elliptic_multiply_test *test, const char *file, unsigned int line)
 Report elliptic curve point multiplication test result. More...
 
void elliptic_add_okx (struct elliptic_add_test *test, const char *file, unsigned int line)
 Report elliptic curve point addition test result. More...
 

Detailed Description

Elliptic curve self-tests.

Definition in file elliptic_test.c.

Function Documentation

◆ FILE_LICENCE()

FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL  )

◆ elliptic_curve_okx()

void elliptic_curve_okx ( struct elliptic_curve curve,
const char *  file,
unsigned int  line 
)

Report elliptic curve sanity test result.

Parameters
curveElliptic curve
fileTest code file
lineTest code line

Definition at line 50 of file elliptic_test.c.

51  {
52  static const uint8_t one[] = { 1 };
53  size_t pointsize = curve->pointsize;
54  size_t keysize = curve->keysize;
55  uint8_t point[pointsize];
56  uint8_t scalar[keysize];
57  struct {
58  bigint_t ( bigint_required_size ( keysize ) ) scalar;
60  } temp;
61 
62  /* Check that curve has the required properties */
63  okx ( curve->base != NULL, file, line );
64  okx ( curve->order != NULL, file, line );
65 
66  /* Test multiplying base point by group order. Result should
67  * be the point at infinity, which should not be representable
68  * as a point in affine coordinates (and so should fail).
69  */
70  okx ( elliptic_multiply ( curve, curve->base, curve->order,
71  point ) != 0, file, line );
72 
73  /* Test multiplying base point by group order plus one, to get
74  * back to the base point.
75  */
76  bigint_init ( &temp.scalar, curve->order, keysize );
77  bigint_init ( &temp.one, one, sizeof ( one ) );
78  bigint_add ( &temp.one, &temp.scalar );
79  bigint_done ( &temp.scalar, scalar, sizeof ( scalar ) );
80  okx ( elliptic_multiply ( curve, curve->base, scalar, point ) == 0,
81  file, line );
82  okx ( memcmp ( point, curve->base, pointsize ) == 0, file, line );
83 }
static int elliptic_multiply(struct elliptic_curve *curve, const void *base, const void *scalar, void *result)
Definition: crypto.h:311
const void * order
Order of the generator (if prime)
Definition: crypto.h:187
#define bigint_init(value, data, len)
Initialise big integer.
Definition: bigint.h:61
#define okx(success, file, line)
Report test result.
Definition: test.h:44
#define bigint_done(value, out, len)
Finalise big integer.
Definition: bigint.h:74
size_t keysize
Scalar (and private key) size.
Definition: crypto.h:183
#define bigint_required_size(len)
Determine number of elements required for a big-integer type.
Definition: bigint.h:30
unsigned char uint8_t
Definition: stdint.h:10
u16 keysize
Length of encryption key to be used, network byte order.
Definition: wpa.h:37
const void * base
Generator base point.
Definition: crypto.h:185
size_t pointsize
Point (and public key) size.
Definition: crypto.h:181
#define bigint_add(addend, value)
Add big integers.
Definition: bigint.h:86
int memcmp(const void *first, const void *second, size_t len)
Compare memory regions.
Definition: string.c:114
#define NULL
NULL pointer (VOID *)
Definition: Base.h:321
typedef bigint_t(X25519_SIZE) x25519_t
An X25519 unsigned big integer used in internal calculations.

References elliptic_curve::base, bigint_add, bigint_done, bigint_init, bigint_required_size, bigint_t(), elliptic_multiply(), keysize, elliptic_curve::keysize, memcmp(), NULL, okx, elliptic_curve::order, and elliptic_curve::pointsize.

◆ elliptic_multiply_okx()

void elliptic_multiply_okx ( struct elliptic_multiply_test test,
const char *  file,
unsigned int  line 
)

Report elliptic curve point multiplication test result.

Parameters
testElliptic curve point multiplication test
fileTest code file
lineTest code line

Definition at line 92 of file elliptic_test.c.

93  {
94  struct elliptic_curve *curve = test->curve;
95  size_t pointsize = curve->pointsize;
96  size_t keysize = curve->keysize;
97  uint8_t actual[pointsize];
98  const void *base;
99  int rc;
100 
101  /* Sanity checks */
102  okx ( ( test->base_len == pointsize ) || ( ! test->base_len ),
103  file, line );
104  okx ( test->scalar_len == keysize, file, line );
105  okx ( ( test->expected_len == pointsize ) || ( ! test->expected_len ),
106  file, line );
107 
108  /* Perform point multiplication */
109  base = ( test->base_len ? test->base : curve->base );
110  rc = elliptic_multiply ( curve, base, test->scalar, actual );
111  if ( test->expected_len ) {
112  okx ( rc == 0, file, line );
113  } else {
114  okx ( rc != 0, file, line );
115  }
116 
117  /* Check expected result */
118  okx ( memcmp ( actual, test->expected, test->expected_len ) == 0,
119  file, line );
120 }
uint32_t base
Base.
Definition: librm.h:138
struct arbelprm_rc_send_wqe rc
Definition: arbel.h:14
static int elliptic_multiply(struct elliptic_curve *curve, const void *base, const void *scalar, void *result)
Definition: crypto.h:311
#define okx(success, file, line)
Report test result.
Definition: test.h:44
size_t keysize
Scalar (and private key) size.
Definition: crypto.h:183
unsigned char uint8_t
Definition: stdint.h:10
u16 keysize
Length of encryption key to be used, network byte order.
Definition: wpa.h:37
An elliptic curve.
Definition: crypto.h:177
const void * base
Generator base point.
Definition: crypto.h:185
size_t pointsize
Point (and public key) size.
Definition: crypto.h:181
int memcmp(const void *first, const void *second, size_t len)
Compare memory regions.
Definition: string.c:114
static int test
Definition: epic100.c:73

References base, elliptic_curve::base, elliptic_multiply(), keysize, elliptic_curve::keysize, memcmp(), okx, elliptic_curve::pointsize, rc, and test.

◆ elliptic_add_okx()

void elliptic_add_okx ( struct elliptic_add_test test,
const char *  file,
unsigned int  line 
)

Report elliptic curve point addition test result.

Parameters
testElliptic curve point addition test
fileTest code file
lineTest code line

Definition at line 129 of file elliptic_test.c.

130  {
131  struct elliptic_curve *curve = test->curve;
132  size_t pointsize = curve->pointsize;
133  uint8_t actual[pointsize];
134  int rc;
135 
136  /* Sanity checks */
137  okx ( test->addend_len == pointsize, file, line );
138  okx ( test->augend_len == pointsize, file, line );
139  okx ( ( test->expected_len == pointsize ) || ( ! test->expected_len ),
140  file, line );
141 
142  /* Perform point addition */
143  rc = elliptic_add ( curve, test->addend, test->augend, actual );
144  if ( test->expected_len ) {
145  okx ( rc == 0, file, line );
146  } else {
147  okx ( rc != 0, file, line );
148  }
149 
150  /* Check expected result */
151  okx ( memcmp ( actual, test->expected, test->expected_len ) == 0,
152  file, line );
153 }
struct arbelprm_rc_send_wqe rc
Definition: arbel.h:14
#define okx(success, file, line)
Report test result.
Definition: test.h:44
unsigned char uint8_t
Definition: stdint.h:10
static int elliptic_add(struct elliptic_curve *curve, const void *addend, const void *augend, void *result)
Definition: crypto.h:317
An elliptic curve.
Definition: crypto.h:177
size_t pointsize
Point (and public key) size.
Definition: crypto.h:181
int memcmp(const void *first, const void *second, size_t len)
Compare memory regions.
Definition: string.c:114
static int test
Definition: epic100.c:73

References elliptic_add(), memcmp(), okx, elliptic_curve::pointsize, rc, and test.