1656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project/* crypto/ecdsa/ecdsa_sign.c */
2656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project/* ====================================================================
3656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * Copyright (c) 1998-2002 The OpenSSL Project.  All rights reserved.
4656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
5656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * Redistribution and use in source and binary forms, with or without
6656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * modification, are permitted provided that the following conditions
7656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * are met:
8656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
9656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 1. Redistributions of source code must retain the above copyright
10656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    notice, this list of conditions and the following disclaimer.
11656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
12656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 2. Redistributions in binary form must reproduce the above copyright
13656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    notice, this list of conditions and the following disclaimer in
14656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    the documentation and/or other materials provided with the
15656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    distribution.
16656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
17656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 3. All advertising materials mentioning features or use of this
18656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    software must display the following acknowledgment:
19656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    "This product includes software developed by the OpenSSL Project
20656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)"
21656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
22656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
23656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    endorse or promote products derived from this software without
24656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    prior written permission. For written permission, please contact
25656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    openssl-core@OpenSSL.org.
26656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
27656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 5. Products derived from this software may not be called "OpenSSL"
28656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    nor may "OpenSSL" appear in their names without prior written
29656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    permission of the OpenSSL Project.
30656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
31656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 6. Redistributions of any form whatsoever must retain the following
32656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    acknowledgment:
33656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    "This product includes software developed by the OpenSSL Project
34656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"
35656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
36656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
37656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
38656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
39656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR
40656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
41656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
42656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
43656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
44656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
45656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
46656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
47656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * OF THE POSSIBILITY OF SUCH DAMAGE.
48656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * ====================================================================
49656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
50656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * This product includes cryptographic software written by Eric Young
51656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * (eay@cryptsoft.com).  This product includes software written by Tim
52656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * Hudson (tjh@cryptsoft.com).
53656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
54656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project */
55656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
56656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include "ecs_locl.h"
57656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_ENGINE
58656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/engine.h>
59656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
6098d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom#include <openssl/rand.h>
6123b9568fd705172c870175f42556ae21861da399Adam Langley#include <openssl/err.h>
62656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
63656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source ProjectECDSA_SIG *ECDSA_do_sign(const unsigned char *dgst, int dlen, EC_KEY *eckey)
64656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project{
65656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return ECDSA_do_sign_ex(dgst, dlen, NULL, NULL, eckey);
66656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project}
67656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
68656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source ProjectECDSA_SIG *ECDSA_do_sign_ex(const unsigned char *dgst, int dlen,
69656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	const BIGNUM *kinv, const BIGNUM *rp, EC_KEY *eckey)
70656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project{
71656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	ECDSA_DATA *ecdsa = ecdsa_check(eckey);
72656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (ecdsa == NULL)
73656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		return NULL;
74656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return ecdsa->meth->ecdsa_do_sign(dgst, dlen, kinv, rp, eckey);
75656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project}
76656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
77656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint ECDSA_sign(int type, const unsigned char *dgst, int dlen, unsigned char
78656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		*sig, unsigned int *siglen, EC_KEY *eckey)
79656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project{
80656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return ECDSA_sign_ex(type, dgst, dlen, sig, siglen, NULL, NULL, eckey);
81656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project}
82656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
83656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint ECDSA_sign_ex(int type, const unsigned char *dgst, int dlen, unsigned char
84656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	*sig, unsigned int *siglen, const BIGNUM *kinv, const BIGNUM *r,
85656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	EC_KEY *eckey)
86656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project{
87656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	ECDSA_SIG *s;
8898d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom	RAND_seed(dgst, dlen);
89656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	s = ECDSA_do_sign_ex(dgst, dlen, kinv, r, eckey);
90656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (s == NULL)
91656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
92656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		*siglen=0;
93656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		return 0;
94656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
95656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	*siglen = i2d_ECDSA_SIG(s, &sig);
96656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	ECDSA_SIG_free(s);
97656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return 1;
98656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project}
99656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
100656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint ECDSA_sign_setup(EC_KEY *eckey, BN_CTX *ctx_in, BIGNUM **kinvp,
101656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIGNUM **rp)
102656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project{
103656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	ECDSA_DATA *ecdsa = ecdsa_check(eckey);
104656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (ecdsa == NULL)
105656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		return 0;
10623b9568fd705172c870175f42556ae21861da399Adam Langley	if (EC_KEY_get_nonce_from_hash(eckey))
10723b9568fd705172c870175f42556ae21861da399Adam Langley		{
10823b9568fd705172c870175f42556ae21861da399Adam Langley		/* You cannot precompute the ECDSA nonce if it is required to
10923b9568fd705172c870175f42556ae21861da399Adam Langley		 * depend on the message. */
11023b9568fd705172c870175f42556ae21861da399Adam Langley		ECDSAerr(ECDSA_F_ECDSA_SIGN_SETUP, ECDSA_R_NONCE_CANNOT_BE_PRECOMPUTED);
11123b9568fd705172c870175f42556ae21861da399Adam Langley		return 0;
11223b9568fd705172c870175f42556ae21861da399Adam Langley		}
11323b9568fd705172c870175f42556ae21861da399Adam Langley	return ecdsa->meth->ecdsa_sign_setup(eckey, ctx_in, kinvp, rp, NULL, 0);
114656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project}
115