Add gcry_pk_get_curve.
[libgcrypt.git] / src / visibility.c
1 /* visibility.c - Wrapper for all public functions.
2  * Copyright (C) 2007, 2008, 2011  Free Software Foundation, Inc.
3  *
4  * This file is part of Libgcrypt.
5  *
6  * Libgcrypt is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU Lesser General Public License as
8  * published by the Free Software Foundation; either version 2.1 of
9  * the License, or (at your option) any later version.
10  *
11  * Libgcrypt is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this program; if not, see <http://www.gnu.org/licenses/>.
18  */
19
20 #include <config.h>
21 #include <stdarg.h>
22
23 #define _GCRY_INCLUDED_BY_VISIBILITY_C 
24 #include "g10lib.h"
25 #include "cipher-proto.h"
26
27
28
29 const char *
30 gcry_strerror (gcry_error_t err)
31 {
32   return _gcry_strerror (err);
33 }
34
35 const char *
36 gcry_strsource (gcry_error_t err)
37 {
38   return _gcry_strsource (err);
39 }
40
41 gcry_err_code_t 
42 gcry_err_code_from_errno (int err)
43 {
44   return _gcry_err_code_from_errno (err);
45 }
46
47 int
48 gcry_err_code_to_errno (gcry_err_code_t code)
49 {
50   return _gcry_err_code_to_errno (code);
51 }
52
53 gcry_error_t 
54 gcry_err_make_from_errno (gcry_err_source_t source, int err)
55 {
56   return _gcry_err_make_from_errno (source, err);
57 }
58
59 gcry_err_code_t 
60 gcry_error_from_errno (int err)
61 {
62   return _gcry_error_from_errno (err);
63 }
64
65 const char *
66 gcry_check_version (const char *req_version)
67 {
68   return _gcry_check_version (req_version);
69 }
70
71 gcry_error_t 
72 gcry_control (enum gcry_ctl_cmds cmd, ...)
73 {
74   gcry_error_t err;
75   va_list arg_ptr;
76   
77   va_start (arg_ptr, cmd);
78   err = _gcry_vcontrol (cmd, arg_ptr);
79   va_end(arg_ptr);
80   return err;
81 }
82
83 gcry_error_t 
84 gcry_sexp_new (gcry_sexp_t *retsexp,
85                const void *buffer, size_t length,
86                int autodetect)
87 {
88   return _gcry_sexp_new (retsexp, buffer, length, autodetect);
89 }
90
91 gcry_error_t 
92 gcry_sexp_create (gcry_sexp_t *retsexp,
93                   void *buffer, size_t length,
94                   int autodetect, void (*freefnc) (void *))
95 {
96   return _gcry_sexp_create (retsexp, buffer, length,
97                             autodetect, freefnc);
98 }
99
100 gcry_error_t 
101 gcry_sexp_sscan (gcry_sexp_t *retsexp, size_t *erroff,
102                  const char *buffer, size_t length)
103 {
104   return _gcry_sexp_sscan (retsexp, erroff, buffer, length);
105 }
106
107 gcry_error_t 
108 gcry_sexp_build (gcry_sexp_t *retsexp, size_t *erroff,
109                  const char *format, ...)
110 {
111   gcry_error_t err;
112   va_list arg_ptr;
113   
114   va_start (arg_ptr, format);
115   err = _gcry_sexp_vbuild (retsexp, erroff, format, arg_ptr);
116   va_end (arg_ptr);
117   return err;
118 }
119
120 gcry_error_t 
121 gcry_sexp_build_array (gcry_sexp_t *retsexp, size_t *erroff,
122                        const char *format, void **arg_list)
123 {
124   return _gcry_sexp_build_array (retsexp, erroff, format, arg_list);
125 }
126
127 void 
128 gcry_sexp_release (gcry_sexp_t sexp)
129 {
130   _gcry_sexp_release (sexp);
131 }
132
133 size_t 
134 gcry_sexp_canon_len (const unsigned char *buffer, size_t length, 
135                      size_t *erroff, gcry_error_t *errcode)
136 {
137   return _gcry_sexp_canon_len (buffer, length, erroff, errcode);
138 }
139
140 size_t 
141 gcry_sexp_sprint (gcry_sexp_t sexp, int mode, void *buffer, size_t maxlength)
142 {
143   return _gcry_sexp_sprint (sexp, mode, buffer, maxlength);
144 }
145
146 void 
147 gcry_sexp_dump (const gcry_sexp_t a)
148 {
149   _gcry_sexp_dump (a);
150 }
151
152 gcry_sexp_t
153 gcry_sexp_cons (const gcry_sexp_t a, const gcry_sexp_t b)
154 {
155   return _gcry_sexp_cons (a, b);
156 }
157
158 gcry_sexp_t
159 gcry_sexp_alist (const gcry_sexp_t *array)
160 {
161   return _gcry_sexp_alist (array);
162 }
163
164 gcry_sexp_t
165 gcry_sexp_vlist (const gcry_sexp_t a, ...)
166 {
167   /* This is not yet implemented in sexp.c.  */
168   (void)a;
169   BUG ();
170   return NULL;
171 }
172
173 gcry_sexp_t
174 gcry_sexp_append (const gcry_sexp_t a, const gcry_sexp_t n)
175 {
176   return _gcry_sexp_append (a, n);
177 }
178
179 gcry_sexp_t
180 gcry_sexp_prepend (const gcry_sexp_t a, const gcry_sexp_t n)
181 {
182   return _gcry_sexp_prepend (a, n);
183 }
184
185
186 gcry_sexp_t
187 gcry_sexp_find_token (gcry_sexp_t list, const char *tok, size_t toklen)
188 {
189   return _gcry_sexp_find_token (list, tok, toklen);
190 }
191
192 int
193 gcry_sexp_length (const gcry_sexp_t list)
194 {
195   return _gcry_sexp_length (list);
196 }
197
198 gcry_sexp_t
199 gcry_sexp_nth (const gcry_sexp_t list, int number)
200 {
201   return _gcry_sexp_nth (list, number);
202 }
203
204 gcry_sexp_t
205 gcry_sexp_car (const gcry_sexp_t list)
206 {
207   return _gcry_sexp_car (list);
208 }
209
210 gcry_sexp_t
211 gcry_sexp_cdr (const gcry_sexp_t list)
212 {
213   return _gcry_sexp_cdr (list);
214 }
215
216 gcry_sexp_t
217 gcry_sexp_cadr (const gcry_sexp_t list)
218 {
219   return _gcry_sexp_cadr (list);
220 }
221
222 const char *
223 gcry_sexp_nth_data (const gcry_sexp_t list, int number, size_t *datalen)
224 {
225   return _gcry_sexp_nth_data (list, number, datalen);
226 }
227
228 char *
229 gcry_sexp_nth_string (gcry_sexp_t list, int number)
230 {
231   return _gcry_sexp_nth_string (list, number);
232 }
233
234 gcry_mpi_t
235 gcry_sexp_nth_mpi (gcry_sexp_t list, int number, int mpifmt)
236 {
237   return _gcry_sexp_nth_mpi (list, number, mpifmt);
238 }
239
240 gcry_mpi_t
241 gcry_mpi_new (unsigned int nbits)
242 {
243   return _gcry_mpi_new (nbits);
244 }
245
246 gcry_mpi_t
247 gcry_mpi_snew (unsigned int nbits)
248 {
249   return _gcry_mpi_snew (nbits);
250 }
251
252 void 
253 gcry_mpi_release (gcry_mpi_t a)
254 {
255   _gcry_mpi_release (a);
256 }
257
258 gcry_mpi_t
259 gcry_mpi_copy (const gcry_mpi_t a)
260 {
261   return _gcry_mpi_copy (a);
262 }
263
264 gcry_mpi_t
265 gcry_mpi_set (gcry_mpi_t w, const gcry_mpi_t u)
266 {
267   return _gcry_mpi_set (w, u);
268 }
269
270 gcry_mpi_t
271 gcry_mpi_set_ui (gcry_mpi_t w, unsigned long u)
272 {
273   return _gcry_mpi_set_ui (w, u);
274 }
275
276 void
277 gcry_mpi_swap (gcry_mpi_t a, gcry_mpi_t b)
278 {
279   _gcry_mpi_swap (a, b);
280 }
281
282 int
283 gcry_mpi_cmp (const gcry_mpi_t u, const gcry_mpi_t v)
284 {
285   return _gcry_mpi_cmp (u, v);
286 }
287
288 int
289 gcry_mpi_cmp_ui (const gcry_mpi_t u, unsigned long v)
290 {
291   return _gcry_mpi_cmp_ui (u, v);
292 }
293
294 gcry_error_t
295 gcry_mpi_scan (gcry_mpi_t *ret_mpi, enum gcry_mpi_format format,
296                const void *buffer, size_t buflen, 
297                size_t *nscanned)
298 {
299   return _gcry_mpi_scan (ret_mpi, format, buffer, buflen, nscanned);
300 }
301
302 gcry_error_t
303 gcry_mpi_print (enum gcry_mpi_format format,
304                 unsigned char *buffer, size_t buflen,
305                 size_t *nwritten,
306                 const gcry_mpi_t a)
307 {
308   return _gcry_mpi_print (format, buffer, buflen, nwritten, a);
309 }
310
311 gcry_error_t
312 gcry_mpi_aprint (enum gcry_mpi_format format,
313                  unsigned char **buffer, size_t *nwritten,
314                  const gcry_mpi_t a)
315 {
316   return _gcry_mpi_aprint (format, buffer, nwritten, a);
317 }
318
319 void
320 gcry_mpi_dump (const gcry_mpi_t a)
321 {
322   _gcry_mpi_dump (a);
323 }
324
325 void
326 gcry_mpi_add (gcry_mpi_t w, gcry_mpi_t u, gcry_mpi_t v)
327 {
328   _gcry_mpi_add (w, u, v);
329 }
330
331 void
332 gcry_mpi_add_ui (gcry_mpi_t w, gcry_mpi_t u, unsigned long v)
333 {
334   _gcry_mpi_add_ui (w, u, v);
335 }
336
337 void
338 gcry_mpi_addm (gcry_mpi_t w, gcry_mpi_t u, gcry_mpi_t v, gcry_mpi_t m)
339 {
340   _gcry_mpi_addm (w, u, v, m);
341 }
342
343 void
344 gcry_mpi_sub (gcry_mpi_t w, gcry_mpi_t u, gcry_mpi_t v)
345 {
346   _gcry_mpi_sub (w, u, v);
347 }
348
349 void
350 gcry_mpi_sub_ui (gcry_mpi_t w, gcry_mpi_t u, unsigned long v )
351 {
352   _gcry_mpi_sub_ui (w, u, v);
353 }
354
355 void
356 gcry_mpi_subm (gcry_mpi_t w, gcry_mpi_t u, gcry_mpi_t v, gcry_mpi_t m)
357 {
358   _gcry_mpi_subm (w, u, v, m);
359 }
360
361 void
362 gcry_mpi_mul (gcry_mpi_t w, gcry_mpi_t u, gcry_mpi_t v)
363 {
364   _gcry_mpi_mul (w, u, v);
365 }
366
367 void
368 gcry_mpi_mul_ui (gcry_mpi_t w, gcry_mpi_t u, unsigned long v )
369 {
370   _gcry_mpi_mul_ui (w, u, v);
371 }
372
373 void
374 gcry_mpi_mulm (gcry_mpi_t w, gcry_mpi_t u, gcry_mpi_t v, gcry_mpi_t m)
375 {
376   _gcry_mpi_mulm (w, u, v, m);
377 }
378
379 void
380 gcry_mpi_mul_2exp (gcry_mpi_t w, gcry_mpi_t u, unsigned long cnt)
381 {
382   _gcry_mpi_mul_2exp (w, u, cnt);
383 }
384
385 void
386 gcry_mpi_div (gcry_mpi_t q, gcry_mpi_t r,
387               gcry_mpi_t dividend, gcry_mpi_t divisor, int round)
388 {
389   _gcry_mpi_div (q, r, dividend, divisor, round);
390 }
391
392 void
393 gcry_mpi_mod (gcry_mpi_t r, gcry_mpi_t dividend, gcry_mpi_t divisor)
394 {
395   _gcry_mpi_mod (r, dividend, divisor);
396 }
397
398 void
399 gcry_mpi_powm (gcry_mpi_t w, const gcry_mpi_t b, const gcry_mpi_t e,
400                const gcry_mpi_t m)
401 {
402   _gcry_mpi_powm (w, b, e, m);
403 }
404
405 int
406 gcry_mpi_gcd (gcry_mpi_t g, gcry_mpi_t a, gcry_mpi_t b)
407 {
408   return _gcry_mpi_gcd (g, a, b);
409 }
410
411 int
412 gcry_mpi_invm (gcry_mpi_t x, gcry_mpi_t a, gcry_mpi_t m)
413 {
414   return _gcry_mpi_invm (x, a, m);
415 }
416
417
418 unsigned int
419 gcry_mpi_get_nbits (gcry_mpi_t a)
420 {
421   return _gcry_mpi_get_nbits (a);
422 }
423
424 int
425 gcry_mpi_test_bit (gcry_mpi_t a, unsigned int n)
426 {
427   return _gcry_mpi_test_bit (a, n);
428 }
429
430 void
431 gcry_mpi_set_bit (gcry_mpi_t a, unsigned int n)
432 {
433   _gcry_mpi_set_bit (a, n);
434 }
435
436 void
437 gcry_mpi_clear_bit (gcry_mpi_t a, unsigned int n)
438 {
439   _gcry_mpi_clear_bit (a, n);
440 }
441
442 void
443 gcry_mpi_set_highbit (gcry_mpi_t a, unsigned int n)
444 {
445   _gcry_mpi_set_highbit (a, n);
446 }
447
448 void
449 gcry_mpi_clear_highbit (gcry_mpi_t a, unsigned int n)
450 {
451   _gcry_mpi_clear_highbit (a, n);
452 }
453
454 void
455 gcry_mpi_rshift (gcry_mpi_t x, gcry_mpi_t a, unsigned int n)
456 {
457   _gcry_mpi_rshift (x, a, n);
458 }
459
460 void
461 gcry_mpi_lshift (gcry_mpi_t x, gcry_mpi_t a, unsigned int n)
462 {
463   _gcry_mpi_lshift (x, a, n);
464 }
465
466 gcry_mpi_t
467 gcry_mpi_set_opaque (gcry_mpi_t a, void *p, unsigned int nbits)
468 {
469   return _gcry_mpi_set_opaque (a, p, nbits);
470 }
471
472 void *
473 gcry_mpi_get_opaque (gcry_mpi_t a, unsigned int *nbits)
474 {
475   return _gcry_mpi_get_opaque (a, nbits);
476 }
477
478 void
479 gcry_mpi_set_flag (gcry_mpi_t a, enum gcry_mpi_flag flag)
480 {
481   _gcry_mpi_set_flag (a, flag);
482 }
483
484 void
485 gcry_mpi_clear_flag (gcry_mpi_t a, enum gcry_mpi_flag flag)
486 {
487   _gcry_mpi_clear_flag (a, flag);
488 }
489
490 int
491 gcry_mpi_get_flag (gcry_mpi_t a, enum gcry_mpi_flag flag)
492 {
493   return _gcry_mpi_get_flag (a, flag);
494 }
495
496 gcry_error_t
497 gcry_cipher_open (gcry_cipher_hd_t *handle,
498                   int algo, int mode, unsigned int flags)
499 {
500   if (!fips_is_operational ())
501     {
502       *handle = NULL;
503       return gpg_error (fips_not_operational ());
504     }
505
506   return _gcry_cipher_open (handle, algo, mode, flags);
507 }
508
509 void
510 gcry_cipher_close (gcry_cipher_hd_t h)
511 {
512   _gcry_cipher_close (h);
513 }
514
515 gcry_error_t
516 gcry_cipher_setkey (gcry_cipher_hd_t hd, const void *key, size_t keylen)
517 {
518   if (!fips_is_operational ())
519     return gpg_error (fips_not_operational ());
520
521   return _gcry_cipher_setkey (hd, key, keylen);
522 }
523
524 gcry_error_t
525 gcry_cipher_setiv (gcry_cipher_hd_t hd, const void *iv, size_t ivlen)
526 {
527   if (!fips_is_operational ())
528     return gpg_error (fips_not_operational ());
529
530   return _gcry_cipher_setiv (hd, iv, ivlen);
531 }
532
533 gpg_error_t
534 gcry_cipher_setctr (gcry_cipher_hd_t hd, const void *ctr, size_t ctrlen)
535 {
536   if (!fips_is_operational ())
537     return gpg_error (fips_not_operational ());
538
539   return _gcry_cipher_setctr (hd, ctr, ctrlen);
540 }
541
542
543 gcry_error_t
544 gcry_cipher_ctl (gcry_cipher_hd_t h, int cmd, void *buffer, size_t buflen)
545 {
546   if (!fips_is_operational ())
547     return gpg_error (fips_not_operational ());
548
549   return _gcry_cipher_ctl (h, cmd, buffer, buflen);
550 }
551
552 gcry_error_t
553 gcry_cipher_info (gcry_cipher_hd_t h, int what, void *buffer, size_t *nbytes)
554 {
555   return _gcry_cipher_info (h, what, buffer, nbytes);
556 }
557
558 gcry_error_t
559 gcry_cipher_algo_info (int algo, int what, void *buffer, size_t *nbytes)
560 {
561   if (!fips_is_operational ())
562     return gpg_error (fips_not_operational ());
563
564   return _gcry_cipher_algo_info (algo, what, buffer, nbytes);
565 }
566
567 const char *
568 gcry_cipher_algo_name (int algorithm)
569 {
570   return _gcry_cipher_algo_name (algorithm);
571 }
572
573 int
574 gcry_cipher_map_name (const char *name)
575 {
576   return _gcry_cipher_map_name (name);
577 }
578
579 int
580 gcry_cipher_mode_from_oid (const char *string)
581 {
582   return _gcry_cipher_mode_from_oid (string);
583 }
584
585 gcry_error_t
586 gcry_cipher_encrypt (gcry_cipher_hd_t h,
587                      void *out, size_t outsize,
588                      const void *in, size_t inlen)
589 {
590   if (!fips_is_operational ())
591     {
592       /* Make sure that the plaintext will never make it to OUT. */
593       if (out)
594         memset (out, 0x42, outsize); 
595       return gpg_error (fips_not_operational ());
596     }
597
598   return _gcry_cipher_encrypt (h, out, outsize, in, inlen);
599 }
600
601 gcry_error_t
602 gcry_cipher_decrypt (gcry_cipher_hd_t h,
603                      void *out, size_t outsize,
604                      const void *in, size_t inlen)
605 {
606   if (!fips_is_operational ())
607     return gpg_error (fips_not_operational ());
608
609   return _gcry_cipher_decrypt (h, out, outsize, in, inlen);
610 }
611
612 size_t
613 gcry_cipher_get_algo_keylen (int algo)
614 {
615   return _gcry_cipher_get_algo_keylen (algo);
616 }
617
618 size_t
619 gcry_cipher_get_algo_blklen (int algo)
620 {
621   return _gcry_cipher_get_algo_blklen (algo);
622 }
623
624 gcry_error_t
625 gcry_cipher_list (int *list, int *list_length)
626 {
627   return _gcry_cipher_list (list, list_length);
628 }
629
630 gcry_error_t
631 gcry_pk_encrypt (gcry_sexp_t *result, gcry_sexp_t data, gcry_sexp_t pkey)
632 {
633   if (!fips_is_operational ())
634     {
635       *result = NULL;
636       return gpg_error (fips_not_operational ());
637     }
638   return _gcry_pk_encrypt (result, data, pkey);
639 }
640
641 gcry_error_t
642 gcry_pk_decrypt (gcry_sexp_t *result, gcry_sexp_t data, gcry_sexp_t skey)
643 {
644   if (!fips_is_operational ())
645     {
646       *result = NULL;
647       return gpg_error (fips_not_operational ());
648     }
649   return _gcry_pk_decrypt (result, data, skey);
650 }
651
652 gcry_error_t
653 gcry_pk_sign (gcry_sexp_t *result, gcry_sexp_t data, gcry_sexp_t skey)
654 {
655   if (!fips_is_operational ())
656     {
657       *result = NULL;
658       return gpg_error (fips_not_operational ());
659     }
660   return _gcry_pk_sign (result, data, skey);
661 }
662
663 gcry_error_t
664 gcry_pk_verify (gcry_sexp_t sigval, gcry_sexp_t data, gcry_sexp_t pkey)
665 {
666   if (!fips_is_operational ())
667     return gpg_error (fips_not_operational ());
668   return _gcry_pk_verify (sigval, data, pkey);
669 }
670
671 gcry_error_t
672 gcry_pk_testkey (gcry_sexp_t key)
673 {
674   if (!fips_is_operational ())
675     return gpg_error (fips_not_operational ());
676   return _gcry_pk_testkey (key);
677 }
678
679 gcry_error_t
680 gcry_pk_genkey (gcry_sexp_t *r_key, gcry_sexp_t s_parms)
681 {
682   if (!fips_is_operational ())
683     {
684       *r_key = NULL;
685       return gpg_error (fips_not_operational ());
686     }
687   return _gcry_pk_genkey (r_key, s_parms);
688 }
689
690 gcry_error_t
691 gcry_pk_ctl (int cmd, void *buffer, size_t buflen)
692 {
693   return _gcry_pk_ctl (cmd, buffer, buflen);
694 }
695
696 gcry_error_t
697 gcry_pk_algo_info (int algo, int what, void *buffer, size_t *nbytes)
698 {
699   if (!fips_is_operational ())
700     return gpg_error (fips_not_operational ());
701
702   return _gcry_pk_algo_info (algo, what, buffer, nbytes);
703 }
704
705 const char *
706 gcry_pk_algo_name (int algorithm)
707 {
708   return _gcry_pk_algo_name (algorithm);
709 }
710
711 int
712 gcry_pk_map_name (const char *name)
713 {
714   return _gcry_pk_map_name (name);
715 }
716
717 unsigned int
718 gcry_pk_get_nbits (gcry_sexp_t key)
719 {
720   if (!fips_is_operational ())
721     {
722       (void)fips_not_operational ();
723       return 0;
724     }
725
726   return _gcry_pk_get_nbits (key);
727 }
728
729 unsigned char *
730 gcry_pk_get_keygrip (gcry_sexp_t key, unsigned char *array)
731 {
732   if (!fips_is_operational ())
733     {
734       (void)fips_not_operational ();
735       return NULL;
736     }
737   return _gcry_pk_get_keygrip (key, array);
738 }
739
740 const char *
741 gcry_pk_get_curve (gcry_sexp_t key, int iterator, unsigned int *r_nbits)
742 {
743   if (!fips_is_operational ())
744     {
745       (void)fips_not_operational ();
746       return NULL;
747     }
748   return _gcry_pk_get_curve (key, iterator, r_nbits);
749 }
750
751 gcry_error_t
752 gcry_pk_list (int *list, int *list_length)
753 {
754   return _gcry_pk_list (list, list_length);
755 }
756
757 gcry_error_t
758 gcry_md_open (gcry_md_hd_t *h, int algo, unsigned int flags)
759 {
760   if (!fips_is_operational ())
761     {
762       *h = NULL;
763       return gpg_error (fips_not_operational ());
764     }
765
766   return _gcry_md_open (h, algo, flags);
767 }
768
769 void 
770 gcry_md_close (gcry_md_hd_t hd)
771 {
772   _gcry_md_close (hd);
773 }
774
775 gcry_error_t
776 gcry_md_enable (gcry_md_hd_t hd, int algo)
777 {
778   if (!fips_is_operational ())
779     return gpg_error (fips_not_operational ());
780   return _gcry_md_enable (hd, algo);
781 }
782
783 gcry_error_t
784 gcry_md_copy (gcry_md_hd_t *bhd, gcry_md_hd_t ahd)
785 {
786   if (!fips_is_operational ())
787     {
788       *bhd = NULL;
789       return gpg_error (fips_not_operational ());
790     }
791   return _gcry_md_copy (bhd, ahd);
792 }
793
794 void
795 gcry_md_reset (gcry_md_hd_t hd)
796 {
797   _gcry_md_reset (hd);
798 }
799
800 gcry_error_t
801 gcry_md_ctl (gcry_md_hd_t hd, int cmd, void *buffer, size_t buflen)
802 {
803   if (!fips_is_operational ())
804     return gpg_error (fips_not_operational ());
805   return _gcry_md_ctl (hd, cmd, buffer, buflen);
806 }
807
808 void
809 gcry_md_write (gcry_md_hd_t hd, const void *buffer, size_t length)
810 {
811   if (!fips_is_operational ())
812     {
813       (void)fips_not_operational ();
814       return;
815     }
816   _gcry_md_write (hd, buffer, length);
817 }
818
819 unsigned char *
820 gcry_md_read (gcry_md_hd_t hd, int algo)
821 {
822   return _gcry_md_read (hd, algo);
823 }
824
825 void 
826 gcry_md_hash_buffer (int algo, void *digest,
827                      const void *buffer, size_t length)
828 {
829   if (!fips_is_operational ())
830     {
831       (void)fips_not_operational ();
832       fips_signal_error ("called in non-operational state");
833     }
834   _gcry_md_hash_buffer (algo, digest, buffer, length);
835 }
836
837 int
838 gcry_md_get_algo (gcry_md_hd_t hd)
839 {
840   if (!fips_is_operational ())
841     {
842       (void)fips_not_operational ();
843       fips_signal_error ("used in non-operational state");
844       return 0;
845     }
846   return _gcry_md_get_algo (hd);
847 }
848
849 unsigned int
850 gcry_md_get_algo_dlen (int algo)
851 {
852   return _gcry_md_get_algo_dlen (algo);
853 }
854
855 int
856 gcry_md_is_enabled (gcry_md_hd_t a, int algo)
857 {
858   if (!fips_is_operational ())
859     {
860       (void)fips_not_operational ();
861       return 0;
862     }
863
864   return _gcry_md_is_enabled (a, algo);
865 }
866
867 int
868 gcry_md_is_secure (gcry_md_hd_t a)
869 {
870   return _gcry_md_is_secure (a);
871 }
872
873 gcry_error_t
874 gcry_md_info (gcry_md_hd_t h, int what, void *buffer, size_t *nbytes)
875 {
876   if (!fips_is_operational ())
877     return gpg_error (fips_not_operational ());
878
879   return _gcry_md_info (h, what, buffer, nbytes);
880 }
881
882 gcry_error_t
883 gcry_md_algo_info (int algo, int what, void *buffer, size_t *nbytes)
884 {
885   return _gcry_md_algo_info (algo, what, buffer, nbytes);
886 }
887
888 const char *
889 gcry_md_algo_name (int algo)
890 {
891   return _gcry_md_algo_name (algo);
892 }
893
894 int
895 gcry_md_map_name (const char* name)
896 {
897   return _gcry_md_map_name (name);
898 }
899
900 gcry_error_t
901 gcry_md_setkey (gcry_md_hd_t hd, const void *key, size_t keylen)
902 {
903   if (!fips_is_operational ())
904     return gpg_error (fips_not_operational ());
905   return _gcry_md_setkey (hd, key, keylen);
906 }
907
908 void
909 gcry_md_debug (gcry_md_hd_t hd, const char *suffix)
910 {
911   _gcry_md_debug (hd, suffix);
912 }
913
914 gcry_error_t
915 gcry_md_list (int *list, int *list_length)
916 {
917   return _gcry_md_list (list, list_length);
918 }
919
920 gcry_error_t
921 gcry_ac_data_new (gcry_ac_data_t *data)
922 {
923   return _gcry_ac_data_new (data);
924 }
925
926 void
927 gcry_ac_data_destroy (gcry_ac_data_t data)
928 {
929   _gcry_ac_data_destroy (data);
930 }
931
932 gcry_error_t
933 gcry_ac_data_copy (gcry_ac_data_t *data_cp, gcry_ac_data_t data)
934 {
935   return _gcry_ac_data_copy (data_cp, data);
936 }
937
938 unsigned int
939 gcry_ac_data_length (gcry_ac_data_t data)
940 {
941   return _gcry_ac_data_length (data);
942 }
943
944 void
945 gcry_ac_data_clear (gcry_ac_data_t data)
946 {
947   _gcry_ac_data_clear (data);
948 }
949
950 gcry_error_t
951 gcry_ac_data_set (gcry_ac_data_t data, unsigned int flags,
952                   const char *name, gcry_mpi_t mpi)
953 {
954   return _gcry_ac_data_set (data, flags, name, mpi);
955 }
956
957 gcry_error_t
958 gcry_ac_data_get_name (gcry_ac_data_t data, unsigned int flags,
959                        const char *name, gcry_mpi_t *mpi)
960 {
961   return _gcry_ac_data_get_name (data, flags, name, mpi);
962 }
963
964 gcry_error_t
965 gcry_ac_data_get_index (gcry_ac_data_t data, unsigned int flags,
966                         unsigned int idx, const char **name, gcry_mpi_t *mpi)
967 {
968   return _gcry_ac_data_get_index (data, flags, idx, name, mpi);
969 }
970
971 gcry_error_t
972 gcry_ac_data_to_sexp (gcry_ac_data_t data, gcry_sexp_t *sexp,
973                       const char **identifiers)
974 {
975   return _gcry_ac_data_to_sexp (data, sexp, identifiers);
976 }
977
978 gcry_error_t
979 gcry_ac_data_from_sexp (gcry_ac_data_t *data, gcry_sexp_t sexp,
980                         const char **identifiers)
981 {
982   return _gcry_ac_data_from_sexp (data, sexp, identifiers);
983 }
984
985 void
986 gcry_ac_io_init (gcry_ac_io_t *ac_io, gcry_ac_io_mode_t mode,
987                  gcry_ac_io_type_t type, ...)
988 {
989   va_list arg_ptr;
990
991   va_start (arg_ptr, type);
992   _gcry_ac_io_init_va (ac_io, mode, type, arg_ptr);
993   va_end (arg_ptr);
994 }
995
996 void
997 gcry_ac_io_init_va (gcry_ac_io_t *ac_io, gcry_ac_io_mode_t mode,
998                     gcry_ac_io_type_t type, va_list ap)
999 {
1000   _gcry_ac_io_init_va (ac_io, mode, type, ap);
1001 }
1002
1003 gcry_error_t
1004 gcry_ac_open (gcry_ac_handle_t *handle,
1005               gcry_ac_id_t algorithm, unsigned int flags)
1006 {
1007   return _gcry_ac_open (handle, algorithm, flags);
1008 }
1009
1010 void
1011 gcry_ac_close (gcry_ac_handle_t handle)
1012 {
1013   _gcry_ac_close (handle);
1014 }
1015
1016 gcry_error_t
1017 gcry_ac_key_init (gcry_ac_key_t *key, gcry_ac_handle_t handle,
1018                   gcry_ac_key_type_t type, gcry_ac_data_t data)
1019 {
1020   return _gcry_ac_key_init (key, handle, type, data);
1021 }
1022
1023 gcry_error_t
1024 gcry_ac_key_pair_generate (gcry_ac_handle_t handle,
1025                            unsigned int nbits, void *spec,
1026                            gcry_ac_key_pair_t *key_pair,
1027                            gcry_mpi_t **miscdata)
1028 {
1029   return _gcry_ac_key_pair_generate ( handle, nbits, spec, key_pair, miscdata);
1030 }
1031
1032 gcry_ac_key_t
1033 gcry_ac_key_pair_extract (gcry_ac_key_pair_t keypair, gcry_ac_key_type_t which)
1034 {
1035   return _gcry_ac_key_pair_extract (keypair, which);
1036 }
1037
1038 gcry_ac_data_t
1039 gcry_ac_key_data_get (gcry_ac_key_t key)
1040 {
1041   return _gcry_ac_key_data_get (key);
1042 }
1043
1044 gcry_error_t
1045 gcry_ac_key_test (gcry_ac_handle_t handle, gcry_ac_key_t key)
1046 {
1047   return _gcry_ac_key_test (handle, key);
1048 }
1049
1050 gcry_error_t
1051 gcry_ac_key_get_nbits (gcry_ac_handle_t handle,
1052                        gcry_ac_key_t key, unsigned int *nbits)
1053 {
1054   return _gcry_ac_key_get_nbits (handle, key, nbits);
1055 }
1056
1057 gcry_error_t
1058 gcry_ac_key_get_grip (gcry_ac_handle_t handle, gcry_ac_key_t key,
1059                       unsigned char *key_grip)
1060 {
1061   return _gcry_ac_key_get_grip (handle, key, key_grip);
1062 }
1063
1064 void
1065 gcry_ac_key_destroy (gcry_ac_key_t key)
1066 {
1067   _gcry_ac_key_destroy (key);
1068 }
1069
1070 void
1071 gcry_ac_key_pair_destroy (gcry_ac_key_pair_t key_pair)
1072 {
1073   _gcry_ac_key_pair_destroy (key_pair);
1074 }
1075
1076 gcry_error_t
1077 gcry_ac_data_encode (gcry_ac_em_t method, unsigned int flags, void *options,
1078                      gcry_ac_io_t *io_read, gcry_ac_io_t *io_write)
1079 {
1080   return _gcry_ac_data_encode (method, flags, options, io_read, io_write);
1081 }
1082
1083 gcry_error_t
1084 gcry_ac_data_decode (gcry_ac_em_t method, unsigned int flags, void *options,
1085                      gcry_ac_io_t *io_read, gcry_ac_io_t *io_write)
1086 {
1087   return _gcry_ac_data_decode (method, flags, options, io_read,  io_write);
1088 }
1089
1090 gcry_error_t
1091 gcry_ac_data_encrypt (gcry_ac_handle_t handle,
1092                       unsigned int flags,
1093                       gcry_ac_key_t key,
1094                       gcry_mpi_t data_plain,
1095                       gcry_ac_data_t *data_encrypted)
1096 {
1097   return _gcry_ac_data_encrypt (handle, flags, key, 
1098                                 data_plain, data_encrypted);
1099 }
1100
1101 gcry_error_t
1102 gcry_ac_data_decrypt (gcry_ac_handle_t handle,
1103                       unsigned int flags,
1104                       gcry_ac_key_t key,
1105                       gcry_mpi_t *data_plain,
1106                       gcry_ac_data_t data_encrypted)
1107 {
1108   return _gcry_ac_data_decrypt (handle, flags, key,
1109                                 data_plain, data_encrypted);
1110 }
1111
1112 gcry_error_t
1113 gcry_ac_data_sign (gcry_ac_handle_t handle,
1114                    gcry_ac_key_t key,
1115                    gcry_mpi_t data,
1116                    gcry_ac_data_t *data_signature)
1117 {
1118   return _gcry_ac_data_sign (handle, key, data, data_signature);
1119 }
1120
1121 gcry_error_t
1122 gcry_ac_data_verify (gcry_ac_handle_t handle,
1123                      gcry_ac_key_t key,
1124                      gcry_mpi_t data,
1125                      gcry_ac_data_t data_signature)
1126 {
1127   return _gcry_ac_data_verify (handle, key, data, data_signature);
1128 }
1129
1130 gcry_error_t
1131 gcry_ac_data_encrypt_scheme (gcry_ac_handle_t handle,
1132                              gcry_ac_scheme_t scheme,
1133                              unsigned int flags, void *opts,
1134                              gcry_ac_key_t key,
1135                              gcry_ac_io_t *io_message,
1136                              gcry_ac_io_t *io_cipher)
1137 {
1138   return _gcry_ac_data_encrypt_scheme (handle, scheme, flags, opts, key,
1139                                        io_message, io_cipher);
1140 }
1141
1142 gcry_error_t
1143 gcry_ac_data_decrypt_scheme (gcry_ac_handle_t handle,
1144                              gcry_ac_scheme_t scheme,
1145                              unsigned int flags, void *opts,
1146                              gcry_ac_key_t key,
1147                              gcry_ac_io_t *io_cipher,
1148                              gcry_ac_io_t *io_message)
1149 {
1150   return _gcry_ac_data_decrypt_scheme (handle, scheme, flags, opts, key,
1151                                        io_cipher, io_message);
1152 }
1153
1154 gcry_error_t
1155 gcry_ac_data_sign_scheme (gcry_ac_handle_t handle,
1156                           gcry_ac_scheme_t scheme,
1157                           unsigned int flags, void *opts,
1158                           gcry_ac_key_t key,
1159                           gcry_ac_io_t *io_message,
1160                           gcry_ac_io_t *io_signature)
1161 {
1162   return _gcry_ac_data_sign_scheme (handle, scheme, flags, opts, key,
1163                                     io_message, io_signature);
1164 }
1165
1166 gcry_error_t
1167 gcry_ac_data_verify_scheme (gcry_ac_handle_t handle,
1168                             gcry_ac_scheme_t scheme,
1169                             unsigned int flags, void *opts,
1170                             gcry_ac_key_t key,
1171                             gcry_ac_io_t *io_message,
1172                             gcry_ac_io_t *io_signature)
1173 {
1174   return _gcry_ac_data_verify_scheme (handle, scheme, flags, opts, key,
1175                                       io_message, io_signature);
1176 }
1177
1178 gcry_error_t
1179 gcry_ac_id_to_name (gcry_ac_id_t algorithm, const char **name) 
1180 {
1181   /* This function is deprecated.  We implement it in terms of the
1182      suggested replacement.  */
1183   const char *tmp = _gcry_pk_algo_name (algorithm);
1184   if (!*tmp)
1185     return gcry_error (GPG_ERR_PUBKEY_ALGO);
1186   *name = tmp;
1187   return 0;
1188 }
1189
1190 gcry_error_t
1191 gcry_ac_name_to_id (const char *name, gcry_ac_id_t *algorithm)
1192 {
1193   /* This function is deprecated.  We implement it in terms of the
1194      suggested replacement.  */
1195   int algo = _gcry_pk_map_name (name);
1196   if (!algo)
1197     return gcry_error (GPG_ERR_PUBKEY_ALGO);
1198   *algorithm = algo;
1199   return 0;
1200 }
1201
1202 void
1203 gcry_randomize (void *buffer, size_t length, enum gcry_random_level level)
1204 {
1205   if (!fips_is_operational ())
1206     {
1207       (void)fips_not_operational ();
1208       fips_signal_fatal_error ("called in non-operational state");
1209       fips_noreturn (); 
1210     }
1211   _gcry_randomize (buffer, length, level);
1212 }
1213
1214 gcry_error_t
1215 gcry_random_add_bytes (const void *buffer, size_t length, int quality)
1216 {
1217   if (!fips_is_operational ())
1218     return gpg_error (fips_not_operational ());
1219   return _gcry_random_add_bytes (buffer, length, quality);
1220 }
1221
1222 void *
1223 gcry_random_bytes (size_t nbytes, enum gcry_random_level level)
1224 {
1225   if (!fips_is_operational ())
1226     {
1227       (void)fips_not_operational ();
1228       fips_signal_fatal_error ("called in non-operational state");
1229       fips_noreturn (); 
1230     }
1231
1232   return _gcry_random_bytes (nbytes,level);
1233 }
1234
1235 void *
1236 gcry_random_bytes_secure (size_t nbytes, enum gcry_random_level level)
1237 {
1238   if (!fips_is_operational ())
1239     {
1240       (void)fips_not_operational ();
1241       fips_signal_fatal_error ("called in non-operational state");
1242       fips_noreturn (); 
1243     }
1244
1245   return _gcry_random_bytes_secure (nbytes, level);
1246 }
1247
1248 void
1249 gcry_mpi_randomize (gcry_mpi_t w,
1250                     unsigned int nbits, enum gcry_random_level level)
1251 {
1252   _gcry_mpi_randomize (w, nbits, level);
1253 }
1254
1255 void
1256 gcry_create_nonce (void *buffer, size_t length)
1257 {
1258   if (!fips_is_operational ())
1259     {
1260       (void)fips_not_operational ();
1261       fips_signal_fatal_error ("called in non-operational state");
1262       fips_noreturn (); 
1263     }
1264   _gcry_create_nonce (buffer, length);
1265 }
1266
1267 gcry_error_t
1268 gcry_prime_generate (gcry_mpi_t *prime,
1269                      unsigned int prime_bits,
1270                      unsigned int factor_bits,
1271                      gcry_mpi_t **factors,
1272                      gcry_prime_check_func_t cb_func,
1273                      void *cb_arg,
1274                      gcry_random_level_t random_level,
1275                      unsigned int flags)
1276 {
1277   return _gcry_prime_generate (prime, prime_bits, factor_bits, factors,
1278                                cb_func, cb_arg, random_level, flags);
1279 }
1280
1281 gcry_error_t
1282 gcry_prime_group_generator (gcry_mpi_t *r_g,
1283                             gcry_mpi_t prime, gcry_mpi_t *factors,
1284                             gcry_mpi_t start_g)
1285 {
1286   return _gcry_prime_group_generator (r_g, prime, factors, start_g);
1287 }
1288
1289 void
1290 gcry_prime_release_factors (gcry_mpi_t *factors)
1291 {
1292   _gcry_prime_release_factors (factors);
1293 }
1294
1295 gcry_error_t
1296 gcry_prime_check (gcry_mpi_t x, unsigned int flags)
1297 {
1298   return _gcry_prime_check (x, flags);
1299 }
1300
1301 void
1302 gcry_set_progress_handler (gcry_handler_progress_t cb, void *cb_data)
1303 {
1304   _gcry_set_progress_handler (cb, cb_data);
1305 }
1306
1307 void
1308 gcry_set_allocation_handler (gcry_handler_alloc_t func_alloc,
1309                              gcry_handler_alloc_t func_alloc_secure,
1310                              gcry_handler_secure_check_t func_secure_check,
1311                              gcry_handler_realloc_t func_realloc,
1312                              gcry_handler_free_t func_free)
1313 {
1314   _gcry_set_allocation_handler (func_alloc, func_alloc_secure,
1315                                 func_secure_check, func_realloc, func_free);
1316 }
1317
1318 void
1319 gcry_set_outofcore_handler (gcry_handler_no_mem_t h, void *opaque)
1320 {
1321   _gcry_set_outofcore_handler (h, opaque);
1322 }
1323
1324 void
1325 gcry_set_fatalerror_handler (gcry_handler_error_t fnc, void *opaque)
1326 {
1327   _gcry_set_fatalerror_handler (fnc, opaque);
1328 }
1329
1330 void
1331 gcry_set_log_handler (gcry_handler_log_t f, void *opaque)
1332 {
1333   _gcry_set_log_handler (f, opaque);
1334 }
1335
1336 void
1337 gcry_set_gettext_handler (const char *(*f)(const char*))
1338 {
1339   _gcry_set_gettext_handler (f);
1340 }
1341
1342 void *
1343 gcry_malloc (size_t n)
1344 {
1345   return _gcry_malloc (n);
1346 }
1347
1348 void *
1349 gcry_calloc (size_t n, size_t m)
1350 {
1351   return _gcry_calloc (n, m);
1352 }
1353
1354 void *
1355 gcry_malloc_secure (size_t n)
1356 {
1357   return _gcry_malloc_secure (n);
1358 }
1359
1360 void *
1361 gcry_calloc_secure (size_t n, size_t m)
1362 {
1363   return _gcry_calloc_secure (n,m);
1364 }
1365
1366 void *
1367 gcry_realloc (void *a, size_t n)
1368 {
1369   return _gcry_realloc (a, n);
1370 }
1371
1372 char *
1373 gcry_strdup (const char *string)
1374 {
1375   return _gcry_strdup (string);
1376 }
1377
1378 void *
1379 gcry_xmalloc (size_t n)
1380 {
1381   return _gcry_xmalloc (n);
1382 }
1383
1384 void *
1385 gcry_xcalloc (size_t n, size_t m)
1386 {
1387   return _gcry_xcalloc (n, m);
1388 }
1389
1390 void *
1391 gcry_xmalloc_secure (size_t n)
1392 {
1393   return _gcry_xmalloc_secure (n);
1394 }
1395
1396 void *
1397 gcry_xcalloc_secure (size_t n, size_t m)
1398 {
1399   return _gcry_xcalloc_secure (n, m);
1400 }
1401
1402 void *
1403 gcry_xrealloc (void *a, size_t n)
1404 {
1405   return _gcry_xrealloc (a, n);
1406 }
1407
1408 char *
1409 gcry_xstrdup (const char *a)
1410 {
1411   return _gcry_xstrdup (a);
1412 }
1413
1414 void
1415 gcry_free (void *a)
1416 {
1417   _gcry_free (a);
1418 }
1419
1420 int
1421 gcry_is_secure (const void *a)
1422 {
1423   return _gcry_is_secure (a);
1424 }
1425
1426
1427 gcry_error_t
1428 gcry_cipher_register (gcry_cipher_spec_t *cipher, int *algorithm_id,
1429                       gcry_module_t *module)
1430 {
1431   return _gcry_cipher_register (cipher, NULL, algorithm_id, module);
1432 }
1433
1434 void
1435 gcry_cipher_unregister (gcry_module_t module)
1436 {
1437   _gcry_cipher_unregister (module);
1438 }
1439
1440 gcry_error_t
1441 gcry_pk_register (gcry_pk_spec_t *pubkey, unsigned int *algorithm_id,
1442                   gcry_module_t *module)
1443 {
1444   return _gcry_pk_register (pubkey, NULL, algorithm_id, module);
1445 }
1446
1447 void
1448 gcry_pk_unregister (gcry_module_t module)
1449 {
1450   _gcry_pk_unregister (module);
1451 }
1452
1453 gcry_error_t
1454 gcry_md_register (gcry_md_spec_t *digest, unsigned int *algorithm_id,
1455                   gcry_module_t *module)
1456 {
1457   return _gcry_md_register (digest, NULL, algorithm_id, module);
1458 }
1459
1460 void
1461 gcry_md_unregister (gcry_module_t module)
1462 {
1463   _gcry_md_unregister (module);
1464 }