1656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project/* apps/gendsa.c */
2656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
3656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * All rights reserved.
4656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
5656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * This package is an SSL implementation written
6656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * by Eric Young (eay@cryptsoft.com).
7656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * The implementation was written so as to conform with Netscapes SSL.
8656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
9656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * This library is free for commercial and non-commercial use as long as
10656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * the following conditions are aheared to.  The following conditions
11656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * apply to all code found in this distribution, be it the RC4, RSA,
12656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * lhash, DES, etc., code; not just the SSL code.  The SSL documentation
13656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * included with this distribution is covered by the same copyright terms
14656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * except that the holder is Tim Hudson (tjh@cryptsoft.com).
15656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
16656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * Copyright remains Eric Young's, and as such any Copyright notices in
17656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * the code are not to be removed.
18656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * If this package is used in a product, Eric Young should be given attribution
19656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * as the author of the parts of the library used.
20656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * This can be in the form of a textual message at program startup or
21656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * in documentation (online or textual) provided with the package.
22656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
23656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * Redistribution and use in source and binary forms, with or without
24656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * modification, are permitted provided that the following conditions
25656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * are met:
26656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 1. Redistributions of source code must retain the copyright
27656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    notice, this list of conditions and the following disclaimer.
28656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 2. Redistributions in binary form must reproduce the above copyright
29656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    notice, this list of conditions and the following disclaimer in the
30656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    documentation and/or other materials provided with the distribution.
31656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 3. All advertising materials mentioning features or use of this software
32656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    must display the following acknowledgement:
33656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    "This product includes cryptographic software written by
34656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *     Eric Young (eay@cryptsoft.com)"
35656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    The word 'cryptographic' can be left out if the rouines from the library
36656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    being used are not cryptographic related :-).
37656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 4. If you include any Windows specific code (or a derivative thereof) from
38656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    the apps directory (application code) you must include an acknowledgement:
39656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
40656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
41656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
42656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
43656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
44656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
45656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
46656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
47656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
48656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
49656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
50656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
51656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * SUCH DAMAGE.
52656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
53656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * The licence and distribution terms for any publically available version or
54656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * derivative of this code cannot be changed.  i.e. this code cannot simply be
55656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * copied and put under another distribution licence
56656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * [including the GNU Public Licence.]
57656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project */
58656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
59656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/opensslconf.h>	/* for OPENSSL_NO_DSA */
60656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_DSA
61656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <stdio.h>
62656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <string.h>
63656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <sys/types.h>
64656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <sys/stat.h>
65656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include "apps.h"
66656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/bio.h>
67656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/err.h>
68656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/bn.h>
69656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/dsa.h>
70656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/x509.h>
71656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/pem.h>
72656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
73656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#define DEFBITS	512
74656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#undef PROG
75656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#define PROG gendsa_main
76656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
77656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint MAIN(int, char **);
78656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
79656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint MAIN(int argc, char **argv)
80656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
81656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	DSA *dsa=NULL;
82656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int ret=1;
83656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	char *outfile=NULL;
84656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	char *inrand=NULL,*dsaparams=NULL;
85656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	char *passargout = NULL, *passout = NULL;
86656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	BIO *out=NULL,*in=NULL;
87656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	const EVP_CIPHER *enc=NULL;
88656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_ENGINE
89656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	char *engine=NULL;
90656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
91656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
92656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	apps_startup();
93656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
94656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (bio_err == NULL)
95656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if ((bio_err=BIO_new(BIO_s_file())) != NULL)
96656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			BIO_set_fp(bio_err,stderr,BIO_NOCLOSE|BIO_FP_TEXT);
97656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
98656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (!load_config(bio_err, NULL))
99656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		goto end;
100656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
101656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	argv++;
102656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	argc--;
103656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (;;)
104656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
105656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (argc <= 0) break;
106656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (strcmp(*argv,"-out") == 0)
107656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
108656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (--argc < 1) goto bad;
109656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			outfile= *(++argv);
110656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
111656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-passout") == 0)
112656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
113656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (--argc < 1) goto bad;
114656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			passargout= *(++argv);
115656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
116656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_ENGINE
117656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-engine") == 0)
118656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
119656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (--argc < 1) goto bad;
120656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			engine= *(++argv);
121656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
122656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
123656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-rand") == 0)
124656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
125656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (--argc < 1) goto bad;
126656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			inrand= *(++argv);
127656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
128656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-") == 0)
129656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto bad;
130656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_DES
131656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-des") == 0)
132656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			enc=EVP_des_cbc();
133656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-des3") == 0)
134656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			enc=EVP_des_ede3_cbc();
135656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
136656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_IDEA
137656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-idea") == 0)
138656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			enc=EVP_idea_cbc();
139656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
140656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_SEED
141656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-seed") == 0)
142656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			enc=EVP_seed_cbc();
143656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
144656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_AES
145656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-aes128") == 0)
146656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			enc=EVP_aes_128_cbc();
147656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-aes192") == 0)
148656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			enc=EVP_aes_192_cbc();
149656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-aes256") == 0)
150656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			enc=EVP_aes_256_cbc();
151656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
152656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_CAMELLIA
153656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-camellia128") == 0)
154656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			enc=EVP_camellia_128_cbc();
155656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-camellia192") == 0)
156656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			enc=EVP_camellia_192_cbc();
157656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (strcmp(*argv,"-camellia256") == 0)
158656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			enc=EVP_camellia_256_cbc();
159656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
160656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else if (**argv != '-' && dsaparams == NULL)
161656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
162656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			dsaparams = *argv;
163656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
164656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else
165656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto bad;
166656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		argv++;
167656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		argc--;
168656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
169656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
170656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (dsaparams == NULL)
171656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
172656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectbad:
173656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err,"usage: gendsa [args] dsaparam-file\n");
174656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err," -out file - output the key to 'file'\n");
175656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_DES
176656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err," -des      - encrypt the generated key with DES in cbc mode\n");
177656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err," -des3     - encrypt the generated key with DES in ede cbc mode (168 bit key)\n");
178656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
179656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_IDEA
180656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err," -idea     - encrypt the generated key with IDEA in cbc mode\n");
181656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
182656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_SEED
183656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err," -seed\n");
184656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err,"                 encrypt PEM output with cbc seed\n");
185656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
186656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_AES
187656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err," -aes128, -aes192, -aes256\n");
188656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err,"                 encrypt PEM output with cbc aes\n");
189656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
190656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_CAMELLIA
191656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err," -camellia128, -camellia192, -camellia256\n");
192656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err,"                 encrypt PEM output with cbc camellia\n");
193656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
194656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_ENGINE
195656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err," -engine e - use engine e, possibly a hardware device.\n");
196656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
197656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
198656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err,"           - load the file (or the files in the directory) into\n");
199656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err,"             the random number generator\n");
200656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err," dsaparam-file\n");
201656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err,"           - a DSA parameter file as generated by the dsaparam command\n");
202656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		goto end;
203656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
204656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
205656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_ENGINE
20643c12e3d4f9bbbbd4a8ba7b149686437514bc6b6Brian Carlstrom        setup_engine(bio_err, engine, 0);
207656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
208656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
209656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!app_passwd(bio_err, NULL, passargout, NULL, &passout)) {
210656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err, "Error getting password\n");
211656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		goto end;
212656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
213656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
214656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
215656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	in=BIO_new(BIO_s_file());
216656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (!(BIO_read_filename(in,dsaparams)))
217656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
218656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		perror(dsaparams);
219656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		goto end;
220656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
221656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
222656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if ((dsa=PEM_read_bio_DSAparams(in,NULL,NULL,NULL)) == NULL)
223656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
224656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err,"unable to load DSA parameter file\n");
225656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		goto end;
226656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
227656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	BIO_free(in);
228656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	in = NULL;
229656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
230656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	out=BIO_new(BIO_s_file());
231656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (out == NULL) goto end;
232656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
233656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (outfile == NULL)
234656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
235656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_set_fp(out,stdout,BIO_NOCLOSE);
236656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifdef OPENSSL_SYS_VMS
237656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
238656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO *tmpbio = BIO_new(BIO_f_linebuffer());
239656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		out = BIO_push(tmpbio, out);
240656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
241656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
242656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
243656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	else
244656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
245656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write_filename(out,outfile) <= 0)
246656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
247656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			perror(outfile);
248656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto end;
249656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
250656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
251656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
252656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (!app_RAND_load_file(NULL, bio_err, 1) && inrand == NULL)
253656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
254656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err,"warning, not much extra random data, consider using the -rand option\n");
255656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
256656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (inrand != NULL)
257656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		BIO_printf(bio_err,"%ld semi-random bytes loaded\n",
258656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			app_RAND_load_files(inrand));
259656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
260656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	BIO_printf(bio_err,"Generating DSA key, %d bits\n",
261656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project							BN_num_bits(dsa->p));
262656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (!DSA_generate_key(dsa)) goto end;
263656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
264656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	app_RAND_write_file(NULL, bio_err);
265656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
266656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (!PEM_write_bio_DSAPrivateKey(out,dsa,enc,NULL,0,NULL, passout))
267656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		goto end;
268656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	ret=0;
269656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectend:
270656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (ret != 0)
271656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		ERR_print_errors(bio_err);
272656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (in != NULL) BIO_free(in);
273656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (out != NULL) BIO_free_all(out);
274656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (dsa != NULL) DSA_free(dsa);
275656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(passout) OPENSSL_free(passout);
276656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	apps_shutdown();
277656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	OPENSSL_EXIT(ret);
278656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
27998d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom#else /* !OPENSSL_NO_DSA */
28098d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom
28198d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom# if PEDANTIC
28298d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstromstatic void *dummy=&dummy;
28398d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom# endif
28498d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom
285656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
286