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