summaryrefslogtreecommitdiff
path: root/board/cr50/dcrypto/p256.c
blob: f75329d5bf0dcc2470c93bf2c3438ca5aaa842f3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
/* Copyright 2015 The Chromium OS Authors. All rights reserved.
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */

#include "dcrypto.h"

#include "cryptoc/p256.h"

static const p256_int p256_one = P256_ONE;

/*
 * Key selection based on FIPS-186-4, section B.4.2 (Key Pair
 * Generation by Testing Candidates).
 */
int DCRYPTO_p256_key_from_bytes(p256_int *x, p256_int *y, p256_int *d,
				const uint8_t key_bytes[P256_NBYTES])
{
	p256_int key;

	p256_from_bin(key_bytes, &key);
	if (p256_cmp(&SECP256r1_nMin2, &key) < 0)
		return 0;
	p256_add(&key, &p256_one, d);
	always_memset(&key, 0, sizeof(key));
	if (x == NULL || y == NULL)
		return 1;
	return dcrypto_p256_base_point_mul(d, x, y);
}