1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780 |
- #ifndef _GCRYPT_H
- #define _GCRYPT_H
- #include <stdlib.h>
- #include <stdarg.h>
- #include <string.h>
- #include <gpg-error.h>
- #include <sys/types.h>
- #if defined _WIN32 || defined __WIN32__
- # include <winsock2.h>
- # include <ws2tcpip.h>
- # include <time.h>
- # ifndef __GNUC__
- typedef long ssize_t;
- typedef int pid_t;
- # endif
- #else
- # include <sys/socket.h>
- # include <sys/time.h>
- # include <sys/select.h>
- #endif
- typedef socklen_t gcry_socklen_t;
- #define _GCRY_ERR_SOURCE_DEFAULT GPG_ERR_SOURCE_GCRYPT
- #ifdef __cplusplus
- extern "C" {
- #if 0
- }
- #endif
- #endif
- #define GCRYPT_VERSION "1.7.3"
- #define GCRYPT_VERSION_NUMBER 0x010703
- #ifdef _GCRYPT_IN_LIBGCRYPT
- #ifndef GCRYPT_NO_MPI_MACROS
- #define GCRYPT_NO_MPI_MACROS 1
- #endif
- #endif
- #ifdef __GNUC__
- #define _GCRY_GCC_VERSION (__GNUC__ * 10000 \
- + __GNUC_MINOR__ * 100 \
- + __GNUC_PATCHLEVEL__)
- #if _GCRY_GCC_VERSION >= 30100
- #define _GCRY_GCC_ATTR_DEPRECATED __attribute__ ((__deprecated__))
- #endif
- #if _GCRY_GCC_VERSION >= 29600
- #define _GCRY_GCC_ATTR_PURE __attribute__ ((__pure__))
- #endif
- #if _GCRY_GCC_VERSION >= 30200
- #define _GCRY_GCC_ATTR_MALLOC __attribute__ ((__malloc__))
- #endif
- #define _GCRY_GCC_ATTR_PRINTF(f,a) __attribute__ ((format (printf,f,a)))
- #if _GCRY_GCC_VERSION >= 40000
- #define _GCRY_GCC_ATTR_SENTINEL(a) __attribute__ ((sentinel(a)))
- #endif
- #endif
- #ifndef _GCRY_GCC_ATTR_DEPRECATED
- #define _GCRY_GCC_ATTR_DEPRECATED
- #endif
- #ifndef _GCRY_GCC_ATTR_PURE
- #define _GCRY_GCC_ATTR_PURE
- #endif
- #ifndef _GCRY_GCC_ATTR_MALLOC
- #define _GCRY_GCC_ATTR_MALLOC
- #endif
- #ifndef _GCRY_GCC_ATTR_PRINTF
- #define _GCRY_GCC_ATTR_PRINTF(f,a)
- #endif
- #ifndef _GCRY_GCC_ATTR_SENTINEL
- #define _GCRY_GCC_ATTR_SENTINEL(a)
- #endif
- #ifdef _GCRYPT_IN_LIBGCRYPT
- #define _GCRY_ATTR_INTERNAL
- #else
- #define _GCRY_ATTR_INTERNAL _GCRY_GCC_ATTR_DEPRECATED
- #endif
- typedef gpg_error_t gcry_error_t;
- typedef gpg_err_code_t gcry_err_code_t;
- typedef gpg_err_source_t gcry_err_source_t;
- static GPG_ERR_INLINE gcry_error_t
- gcry_err_make (gcry_err_source_t source, gcry_err_code_t code)
- {
- return gpg_err_make (source, code);
- }
- #ifndef GCRY_ERR_SOURCE_DEFAULT
- #define GCRY_ERR_SOURCE_DEFAULT GPG_ERR_SOURCE_USER_1
- #endif
- static GPG_ERR_INLINE gcry_error_t
- gcry_error (gcry_err_code_t code)
- {
- return gcry_err_make (GCRY_ERR_SOURCE_DEFAULT, code);
- }
- static GPG_ERR_INLINE gcry_err_code_t
- gcry_err_code (gcry_error_t err)
- {
- return gpg_err_code (err);
- }
- static GPG_ERR_INLINE gcry_err_source_t
- gcry_err_source (gcry_error_t err)
- {
- return gpg_err_source (err);
- }
- const char *gcry_strerror (gcry_error_t err);
- const char *gcry_strsource (gcry_error_t err);
- gcry_err_code_t gcry_err_code_from_errno (int err);
- int gcry_err_code_to_errno (gcry_err_code_t code);
- gcry_error_t gcry_err_make_from_errno (gcry_err_source_t source, int err);
- gcry_err_code_t gcry_error_from_errno (int err);
- #define GCRY_THREAD_OPTION_DEFAULT 0
- #define GCRY_THREAD_OPTION_USER 1
- #define GCRY_THREAD_OPTION_PTH 2
- #define GCRY_THREAD_OPTION_PTHREAD 3
- #define GCRY_THREAD_OPTION_VERSION 1
- struct gcry_thread_cbs
- {
-
- unsigned int option;
- } _GCRY_ATTR_INTERNAL;
- #define GCRY_THREAD_OPTION_PTH_IMPL \
- static struct gcry_thread_cbs gcry_threads_pth = { \
- (GCRY_THREAD_OPTION_PTH | (GCRY_THREAD_OPTION_VERSION << 8))}
- #define GCRY_THREAD_OPTION_PTHREAD_IMPL \
- static struct gcry_thread_cbs gcry_threads_pthread = { \
- (GCRY_THREAD_OPTION_PTHREAD | (GCRY_THREAD_OPTION_VERSION << 8))}
- struct gcry_context;
- typedef struct gcry_context *gcry_ctx_t;
- struct gcry_mpi;
- typedef struct gcry_mpi *gcry_mpi_t;
- struct gcry_mpi_point;
- typedef struct gcry_mpi_point *gcry_mpi_point_t;
- #ifndef GCRYPT_NO_DEPRECATED
- typedef struct gcry_mpi *GCRY_MPI _GCRY_GCC_ATTR_DEPRECATED;
- typedef struct gcry_mpi *GcryMPI _GCRY_GCC_ATTR_DEPRECATED;
- #endif
- typedef struct
- {
- size_t size;
- size_t off;
- size_t len;
- void *data;
- } gcry_buffer_t;
- const char *gcry_check_version (const char *req_version);
- enum gcry_ctl_cmds
- {
-
- GCRYCTL_CFB_SYNC = 3,
- GCRYCTL_RESET = 4,
- GCRYCTL_FINALIZE = 5,
- GCRYCTL_GET_KEYLEN = 6,
- GCRYCTL_GET_BLKLEN = 7,
- GCRYCTL_TEST_ALGO = 8,
- GCRYCTL_IS_SECURE = 9,
- GCRYCTL_GET_ASNOID = 10,
- GCRYCTL_ENABLE_ALGO = 11,
- GCRYCTL_DISABLE_ALGO = 12,
- GCRYCTL_DUMP_RANDOM_STATS = 13,
- GCRYCTL_DUMP_SECMEM_STATS = 14,
- GCRYCTL_GET_ALGO_NPKEY = 15,
- GCRYCTL_GET_ALGO_NSKEY = 16,
- GCRYCTL_GET_ALGO_NSIGN = 17,
- GCRYCTL_GET_ALGO_NENCR = 18,
- GCRYCTL_SET_VERBOSITY = 19,
- GCRYCTL_SET_DEBUG_FLAGS = 20,
- GCRYCTL_CLEAR_DEBUG_FLAGS = 21,
- GCRYCTL_USE_SECURE_RNDPOOL= 22,
- GCRYCTL_DUMP_MEMORY_STATS = 23,
- GCRYCTL_INIT_SECMEM = 24,
- GCRYCTL_TERM_SECMEM = 25,
- GCRYCTL_DISABLE_SECMEM_WARN = 27,
- GCRYCTL_SUSPEND_SECMEM_WARN = 28,
- GCRYCTL_RESUME_SECMEM_WARN = 29,
- GCRYCTL_DROP_PRIVS = 30,
- GCRYCTL_ENABLE_M_GUARD = 31,
- GCRYCTL_START_DUMP = 32,
- GCRYCTL_STOP_DUMP = 33,
- GCRYCTL_GET_ALGO_USAGE = 34,
- GCRYCTL_IS_ALGO_ENABLED = 35,
- GCRYCTL_DISABLE_INTERNAL_LOCKING = 36,
- GCRYCTL_DISABLE_SECMEM = 37,
- GCRYCTL_INITIALIZATION_FINISHED = 38,
- GCRYCTL_INITIALIZATION_FINISHED_P = 39,
- GCRYCTL_ANY_INITIALIZATION_P = 40,
- GCRYCTL_SET_CBC_CTS = 41,
- GCRYCTL_SET_CBC_MAC = 42,
-
- GCRYCTL_ENABLE_QUICK_RANDOM = 44,
- GCRYCTL_SET_RANDOM_SEED_FILE = 45,
- GCRYCTL_UPDATE_RANDOM_SEED_FILE = 46,
- GCRYCTL_SET_THREAD_CBS = 47,
- GCRYCTL_FAST_POLL = 48,
- GCRYCTL_SET_RANDOM_DAEMON_SOCKET = 49,
- GCRYCTL_USE_RANDOM_DAEMON = 50,
- GCRYCTL_FAKED_RANDOM_P = 51,
- GCRYCTL_SET_RNDEGD_SOCKET = 52,
- GCRYCTL_PRINT_CONFIG = 53,
- GCRYCTL_OPERATIONAL_P = 54,
- GCRYCTL_FIPS_MODE_P = 55,
- GCRYCTL_FORCE_FIPS_MODE = 56,
- GCRYCTL_SELFTEST = 57,
-
- GCRYCTL_DISABLE_HWF = 63,
- GCRYCTL_SET_ENFORCED_FIPS_FLAG = 64,
- GCRYCTL_SET_PREFERRED_RNG_TYPE = 65,
- GCRYCTL_GET_CURRENT_RNG_TYPE = 66,
- GCRYCTL_DISABLE_LOCKED_SECMEM = 67,
- GCRYCTL_DISABLE_PRIV_DROP = 68,
- GCRYCTL_SET_CCM_LENGTHS = 69,
- GCRYCTL_CLOSE_RANDOM_DEVICE = 70,
- GCRYCTL_INACTIVATE_FIPS_FLAG = 71,
- GCRYCTL_REACTIVATE_FIPS_FLAG = 72,
- GCRYCTL_SET_SBOX = 73,
- GCRYCTL_DRBG_REINIT = 74,
- GCRYCTL_SET_TAGLEN = 75,
- GCRYCTL_GET_TAGLEN = 76
- };
- gcry_error_t gcry_control (enum gcry_ctl_cmds CMD, ...);
- struct gcry_sexp;
- typedef struct gcry_sexp *gcry_sexp_t;
- #ifndef GCRYPT_NO_DEPRECATED
- typedef struct gcry_sexp *GCRY_SEXP _GCRY_GCC_ATTR_DEPRECATED;
- typedef struct gcry_sexp *GcrySexp _GCRY_GCC_ATTR_DEPRECATED;
- #endif
- enum gcry_sexp_format
- {
- GCRYSEXP_FMT_DEFAULT = 0,
- GCRYSEXP_FMT_CANON = 1,
- GCRYSEXP_FMT_BASE64 = 2,
- GCRYSEXP_FMT_ADVANCED = 3
- };
- gcry_error_t gcry_sexp_new (gcry_sexp_t *retsexp,
- const void *buffer, size_t length,
- int autodetect);
-
- gcry_error_t gcry_sexp_create (gcry_sexp_t *retsexp,
- void *buffer, size_t length,
- int autodetect, void (*freefnc) (void *));
- gcry_error_t gcry_sexp_sscan (gcry_sexp_t *retsexp, size_t *erroff,
- const char *buffer, size_t length);
- gcry_error_t gcry_sexp_build (gcry_sexp_t *retsexp, size_t *erroff,
- const char *format, ...);
- gcry_error_t gcry_sexp_build_array (gcry_sexp_t *retsexp, size_t *erroff,
- const char *format, void **arg_list);
- void gcry_sexp_release (gcry_sexp_t sexp);
- size_t gcry_sexp_canon_len (const unsigned char *buffer, size_t length,
- size_t *erroff, gcry_error_t *errcode);
- size_t gcry_sexp_sprint (gcry_sexp_t sexp, int mode, void *buffer,
- size_t maxlength);
- void gcry_sexp_dump (const gcry_sexp_t a);
- gcry_sexp_t gcry_sexp_cons (const gcry_sexp_t a, const gcry_sexp_t b);
- gcry_sexp_t gcry_sexp_alist (const gcry_sexp_t *array);
- gcry_sexp_t gcry_sexp_vlist (const gcry_sexp_t a, ...);
- gcry_sexp_t gcry_sexp_append (const gcry_sexp_t a, const gcry_sexp_t n);
- gcry_sexp_t gcry_sexp_prepend (const gcry_sexp_t a, const gcry_sexp_t n);
- gcry_sexp_t gcry_sexp_find_token (gcry_sexp_t list,
- const char *tok, size_t toklen);
- int gcry_sexp_length (const gcry_sexp_t list);
- gcry_sexp_t gcry_sexp_nth (const gcry_sexp_t list, int number);
- gcry_sexp_t gcry_sexp_car (const gcry_sexp_t list);
- gcry_sexp_t gcry_sexp_cdr (const gcry_sexp_t list);
- gcry_sexp_t gcry_sexp_cadr (const gcry_sexp_t list);
- const char *gcry_sexp_nth_data (const gcry_sexp_t list, int number,
- size_t *datalen);
- void *gcry_sexp_nth_buffer (const gcry_sexp_t list, int number,
- size_t *rlength);
- char *gcry_sexp_nth_string (gcry_sexp_t list, int number);
- gcry_mpi_t gcry_sexp_nth_mpi (gcry_sexp_t list, int number, int mpifmt);
- gpg_error_t gcry_sexp_extract_param (gcry_sexp_t sexp,
- const char *path,
- const char *list,
- ...) _GCRY_GCC_ATTR_SENTINEL(0);
- enum gcry_mpi_format
- {
- GCRYMPI_FMT_NONE= 0,
- GCRYMPI_FMT_STD = 1,
- GCRYMPI_FMT_PGP = 2,
- GCRYMPI_FMT_SSH = 3,
- GCRYMPI_FMT_HEX = 4,
- GCRYMPI_FMT_USG = 5,
- GCRYMPI_FMT_OPAQUE = 8
- };
- enum gcry_mpi_flag
- {
- GCRYMPI_FLAG_SECURE = 1,
- GCRYMPI_FLAG_OPAQUE = 2,
- GCRYMPI_FLAG_IMMUTABLE = 4,
- GCRYMPI_FLAG_CONST = 8,
- GCRYMPI_FLAG_USER1 = 0x0100,
- GCRYMPI_FLAG_USER2 = 0x0200,
- GCRYMPI_FLAG_USER3 = 0x0400,
- GCRYMPI_FLAG_USER4 = 0x0800
- };
- #define GCRYMPI_CONST_ONE (_gcry_mpi_get_const (1))
- #define GCRYMPI_CONST_TWO (_gcry_mpi_get_const (2))
- #define GCRYMPI_CONST_THREE (_gcry_mpi_get_const (3))
- #define GCRYMPI_CONST_FOUR (_gcry_mpi_get_const (4))
- #define GCRYMPI_CONST_EIGHT (_gcry_mpi_get_const (8))
- gcry_mpi_t gcry_mpi_new (unsigned int nbits);
- gcry_mpi_t gcry_mpi_snew (unsigned int nbits);
- void gcry_mpi_release (gcry_mpi_t a);
- gcry_mpi_t gcry_mpi_copy (const gcry_mpi_t a);
- void gcry_mpi_snatch (gcry_mpi_t w, gcry_mpi_t u);
- gcry_mpi_t gcry_mpi_set (gcry_mpi_t w, const gcry_mpi_t u);
- gcry_mpi_t gcry_mpi_set_ui (gcry_mpi_t w, unsigned long u);
- void gcry_mpi_swap (gcry_mpi_t a, gcry_mpi_t b);
- int gcry_mpi_is_neg (gcry_mpi_t a);
- void gcry_mpi_neg (gcry_mpi_t w, gcry_mpi_t u);
- void gcry_mpi_abs (gcry_mpi_t w);
- int gcry_mpi_cmp (const gcry_mpi_t u, const gcry_mpi_t v);
- int gcry_mpi_cmp_ui (const gcry_mpi_t u, unsigned long v);
- gcry_error_t gcry_mpi_scan (gcry_mpi_t *ret_mpi, enum gcry_mpi_format format,
- const void *buffer, size_t buflen,
- size_t *nscanned);
- gcry_error_t gcry_mpi_print (enum gcry_mpi_format format,
- unsigned char *buffer, size_t buflen,
- size_t *nwritten,
- const gcry_mpi_t a);
- gcry_error_t gcry_mpi_aprint (enum gcry_mpi_format format,
- unsigned char **buffer, size_t *nwritten,
- const gcry_mpi_t a);
- void gcry_mpi_dump (const gcry_mpi_t a);
- void gcry_mpi_add (gcry_mpi_t w, gcry_mpi_t u, gcry_mpi_t v);
- void gcry_mpi_add_ui (gcry_mpi_t w, gcry_mpi_t u, unsigned long v);
- void gcry_mpi_addm (gcry_mpi_t w, gcry_mpi_t u, gcry_mpi_t v, gcry_mpi_t m);
- void gcry_mpi_sub (gcry_mpi_t w, gcry_mpi_t u, gcry_mpi_t v);
- void gcry_mpi_sub_ui (gcry_mpi_t w, gcry_mpi_t u, unsigned long v );
- void gcry_mpi_subm (gcry_mpi_t w, gcry_mpi_t u, gcry_mpi_t v, gcry_mpi_t m);
- void gcry_mpi_mul (gcry_mpi_t w, gcry_mpi_t u, gcry_mpi_t v);
- void gcry_mpi_mul_ui (gcry_mpi_t w, gcry_mpi_t u, unsigned long v );
- void gcry_mpi_mulm (gcry_mpi_t w, gcry_mpi_t u, gcry_mpi_t v, gcry_mpi_t m);
- void gcry_mpi_mul_2exp (gcry_mpi_t w, gcry_mpi_t u, unsigned long cnt);
- void gcry_mpi_div (gcry_mpi_t q, gcry_mpi_t r,
- gcry_mpi_t dividend, gcry_mpi_t divisor, int round);
- void gcry_mpi_mod (gcry_mpi_t r, gcry_mpi_t dividend, gcry_mpi_t divisor);
- void gcry_mpi_powm (gcry_mpi_t w,
- const gcry_mpi_t b, const gcry_mpi_t e,
- const gcry_mpi_t m);
- int gcry_mpi_gcd (gcry_mpi_t g, gcry_mpi_t a, gcry_mpi_t b);
- int gcry_mpi_invm (gcry_mpi_t x, gcry_mpi_t a, gcry_mpi_t m);
- gcry_mpi_point_t gcry_mpi_point_new (unsigned int nbits);
- void gcry_mpi_point_release (gcry_mpi_point_t point);
- void gcry_mpi_point_get (gcry_mpi_t x, gcry_mpi_t y, gcry_mpi_t z,
- gcry_mpi_point_t point);
- void gcry_mpi_point_snatch_get (gcry_mpi_t x, gcry_mpi_t y, gcry_mpi_t z,
- gcry_mpi_point_t point);
- gcry_mpi_point_t gcry_mpi_point_set (gcry_mpi_point_t point,
- gcry_mpi_t x, gcry_mpi_t y, gcry_mpi_t z);
- gcry_mpi_point_t gcry_mpi_point_snatch_set (gcry_mpi_point_t point,
- gcry_mpi_t x, gcry_mpi_t y,
- gcry_mpi_t z);
- gpg_error_t gcry_mpi_ec_new (gcry_ctx_t *r_ctx,
- gcry_sexp_t keyparam, const char *curvename);
- gcry_mpi_t gcry_mpi_ec_get_mpi (const char *name, gcry_ctx_t ctx, int copy);
- gcry_mpi_point_t gcry_mpi_ec_get_point (const char *name,
- gcry_ctx_t ctx, int copy);
- gpg_error_t gcry_mpi_ec_set_mpi (const char *name, gcry_mpi_t newvalue,
- gcry_ctx_t ctx);
- gpg_error_t gcry_mpi_ec_set_point (const char *name, gcry_mpi_point_t newvalue,
- gcry_ctx_t ctx);
- gpg_error_t gcry_mpi_ec_decode_point (gcry_mpi_point_t result,
- gcry_mpi_t value, gcry_ctx_t ctx);
- int gcry_mpi_ec_get_affine (gcry_mpi_t x, gcry_mpi_t y, gcry_mpi_point_t point,
- gcry_ctx_t ctx);
- void gcry_mpi_ec_dup (gcry_mpi_point_t w, gcry_mpi_point_t u, gcry_ctx_t ctx);
- void gcry_mpi_ec_add (gcry_mpi_point_t w,
- gcry_mpi_point_t u, gcry_mpi_point_t v, gcry_ctx_t ctx);
- void gcry_mpi_ec_sub (gcry_mpi_point_t w,
- gcry_mpi_point_t u, gcry_mpi_point_t v, gcry_ctx_t ctx);
- void gcry_mpi_ec_mul (gcry_mpi_point_t w, gcry_mpi_t n, gcry_mpi_point_t u,
- gcry_ctx_t ctx);
- int gcry_mpi_ec_curve_point (gcry_mpi_point_t w, gcry_ctx_t ctx);
- unsigned int gcry_mpi_get_nbits (gcry_mpi_t a);
- int gcry_mpi_test_bit (gcry_mpi_t a, unsigned int n);
- void gcry_mpi_set_bit (gcry_mpi_t a, unsigned int n);
- void gcry_mpi_clear_bit (gcry_mpi_t a, unsigned int n);
- void gcry_mpi_set_highbit (gcry_mpi_t a, unsigned int n);
- void gcry_mpi_clear_highbit (gcry_mpi_t a, unsigned int n);
- void gcry_mpi_rshift (gcry_mpi_t x, gcry_mpi_t a, unsigned int n);
- void gcry_mpi_lshift (gcry_mpi_t x, gcry_mpi_t a, unsigned int n);
- gcry_mpi_t gcry_mpi_set_opaque (gcry_mpi_t a, void *p, unsigned int nbits);
- gcry_mpi_t gcry_mpi_set_opaque_copy (gcry_mpi_t a,
- const void *p, unsigned int nbits);
- void *gcry_mpi_get_opaque (gcry_mpi_t a, unsigned int *nbits);
- void gcry_mpi_set_flag (gcry_mpi_t a, enum gcry_mpi_flag flag);
- void gcry_mpi_clear_flag (gcry_mpi_t a, enum gcry_mpi_flag flag);
- int gcry_mpi_get_flag (gcry_mpi_t a, enum gcry_mpi_flag flag);
- gcry_mpi_t _gcry_mpi_get_const (int no);
- #ifndef GCRYPT_NO_MPI_MACROS
- #define mpi_new(n) gcry_mpi_new( (n) )
- #define mpi_secure_new( n ) gcry_mpi_snew( (n) )
- #define mpi_release(a) \
- do \
- { \
- gcry_mpi_release ((a)); \
- (a) = NULL; \
- } \
- while (0)
- #define mpi_copy( a ) gcry_mpi_copy( (a) )
- #define mpi_snatch( w, u) gcry_mpi_snatch( (w), (u) )
- #define mpi_set( w, u) gcry_mpi_set( (w), (u) )
- #define mpi_set_ui( w, u) gcry_mpi_set_ui( (w), (u) )
- #define mpi_abs( w ) gcry_mpi_abs( (w) )
- #define mpi_neg( w, u) gcry_mpi_neg( (w), (u) )
- #define mpi_cmp( u, v ) gcry_mpi_cmp( (u), (v) )
- #define mpi_cmp_ui( u, v ) gcry_mpi_cmp_ui( (u), (v) )
- #define mpi_is_neg( a ) gcry_mpi_is_neg ((a))
- #define mpi_add_ui(w,u,v) gcry_mpi_add_ui((w),(u),(v))
- #define mpi_add(w,u,v) gcry_mpi_add ((w),(u),(v))
- #define mpi_addm(w,u,v,m) gcry_mpi_addm ((w),(u),(v),(m))
- #define mpi_sub_ui(w,u,v) gcry_mpi_sub_ui ((w),(u),(v))
- #define mpi_sub(w,u,v) gcry_mpi_sub ((w),(u),(v))
- #define mpi_subm(w,u,v,m) gcry_mpi_subm ((w),(u),(v),(m))
- #define mpi_mul_ui(w,u,v) gcry_mpi_mul_ui ((w),(u),(v))
- #define mpi_mul_2exp(w,u,v) gcry_mpi_mul_2exp ((w),(u),(v))
- #define mpi_mul(w,u,v) gcry_mpi_mul ((w),(u),(v))
- #define mpi_mulm(w,u,v,m) gcry_mpi_mulm ((w),(u),(v),(m))
- #define mpi_powm(w,b,e,m) gcry_mpi_powm ( (w), (b), (e), (m) )
- #define mpi_tdiv(q,r,a,m) gcry_mpi_div ( (q), (r), (a), (m), 0)
- #define mpi_fdiv(q,r,a,m) gcry_mpi_div ( (q), (r), (a), (m), -1)
- #define mpi_mod(r,a,m) gcry_mpi_mod ((r), (a), (m))
- #define mpi_gcd(g,a,b) gcry_mpi_gcd ( (g), (a), (b) )
- #define mpi_invm(g,a,b) gcry_mpi_invm ( (g), (a), (b) )
- #define mpi_point_new(n) gcry_mpi_point_new((n))
- #define mpi_point_release(p) \
- do \
- { \
- gcry_mpi_point_release ((p)); \
- (p) = NULL; \
- } \
- while (0)
- #define mpi_point_get(x,y,z,p) gcry_mpi_point_get((x),(y),(z),(p))
- #define mpi_point_snatch_get(x,y,z,p) gcry_mpi_point_snatch_get((x),(y),(z),(p))
- #define mpi_point_set(p,x,y,z) gcry_mpi_point_set((p),(x),(y),(z))
- #define mpi_point_snatch_set(p,x,y,z) gcry_mpi_point_snatch_set((p),(x),(y),(z))
- #define mpi_get_nbits(a) gcry_mpi_get_nbits ((a))
- #define mpi_test_bit(a,b) gcry_mpi_test_bit ((a),(b))
- #define mpi_set_bit(a,b) gcry_mpi_set_bit ((a),(b))
- #define mpi_set_highbit(a,b) gcry_mpi_set_highbit ((a),(b))
- #define mpi_clear_bit(a,b) gcry_mpi_clear_bit ((a),(b))
- #define mpi_clear_highbit(a,b) gcry_mpi_clear_highbit ((a),(b))
- #define mpi_rshift(a,b,c) gcry_mpi_rshift ((a),(b),(c))
- #define mpi_lshift(a,b,c) gcry_mpi_lshift ((a),(b),(c))
- #define mpi_set_opaque(a,b,c) gcry_mpi_set_opaque( (a), (b), (c) )
- #define mpi_get_opaque(a,b) gcry_mpi_get_opaque( (a), (b) )
- #endif
- struct gcry_cipher_handle;
- typedef struct gcry_cipher_handle *gcry_cipher_hd_t;
- #ifndef GCRYPT_NO_DEPRECATED
- typedef struct gcry_cipher_handle *GCRY_CIPHER_HD _GCRY_GCC_ATTR_DEPRECATED;
- typedef struct gcry_cipher_handle *GcryCipherHd _GCRY_GCC_ATTR_DEPRECATED;
- #endif
- enum gcry_cipher_algos
- {
- GCRY_CIPHER_NONE = 0,
- GCRY_CIPHER_IDEA = 1,
- GCRY_CIPHER_3DES = 2,
- GCRY_CIPHER_CAST5 = 3,
- GCRY_CIPHER_BLOWFISH = 4,
- GCRY_CIPHER_SAFER_SK128 = 5,
- GCRY_CIPHER_DES_SK = 6,
- GCRY_CIPHER_AES = 7,
- GCRY_CIPHER_AES192 = 8,
- GCRY_CIPHER_AES256 = 9,
- GCRY_CIPHER_TWOFISH = 10,
-
- GCRY_CIPHER_ARCFOUR = 301,
- GCRY_CIPHER_DES = 302,
- GCRY_CIPHER_TWOFISH128 = 303,
- GCRY_CIPHER_SERPENT128 = 304,
- GCRY_CIPHER_SERPENT192 = 305,
- GCRY_CIPHER_SERPENT256 = 306,
- GCRY_CIPHER_RFC2268_40 = 307,
- GCRY_CIPHER_RFC2268_128 = 308,
- GCRY_CIPHER_SEED = 309,
- GCRY_CIPHER_CAMELLIA128 = 310,
- GCRY_CIPHER_CAMELLIA192 = 311,
- GCRY_CIPHER_CAMELLIA256 = 312,
- GCRY_CIPHER_SALSA20 = 313,
- GCRY_CIPHER_SALSA20R12 = 314,
- GCRY_CIPHER_GOST28147 = 315,
- GCRY_CIPHER_CHACHA20 = 316
- };
- #define GCRY_CIPHER_AES128 GCRY_CIPHER_AES
- #define GCRY_CIPHER_RIJNDAEL GCRY_CIPHER_AES
- #define GCRY_CIPHER_RIJNDAEL128 GCRY_CIPHER_AES128
- #define GCRY_CIPHER_RIJNDAEL192 GCRY_CIPHER_AES192
- #define GCRY_CIPHER_RIJNDAEL256 GCRY_CIPHER_AES256
- enum gcry_cipher_modes
- {
- GCRY_CIPHER_MODE_NONE = 0,
- GCRY_CIPHER_MODE_ECB = 1,
- GCRY_CIPHER_MODE_CFB = 2,
- GCRY_CIPHER_MODE_CBC = 3,
- GCRY_CIPHER_MODE_STREAM = 4,
- GCRY_CIPHER_MODE_OFB = 5,
- GCRY_CIPHER_MODE_CTR = 6,
- GCRY_CIPHER_MODE_AESWRAP = 7,
- GCRY_CIPHER_MODE_CCM = 8,
- GCRY_CIPHER_MODE_GCM = 9,
- GCRY_CIPHER_MODE_POLY1305 = 10,
- GCRY_CIPHER_MODE_OCB = 11,
- GCRY_CIPHER_MODE_CFB8 = 12
- };
- enum gcry_cipher_flags
- {
- GCRY_CIPHER_SECURE = 1,
- GCRY_CIPHER_ENABLE_SYNC = 2,
- GCRY_CIPHER_CBC_CTS = 4,
- GCRY_CIPHER_CBC_MAC = 8
- };
- #define GCRY_GCM_BLOCK_LEN (128 / 8)
- #define GCRY_CCM_BLOCK_LEN (128 / 8)
- #define GCRY_OCB_BLOCK_LEN (128 / 8)
- gcry_error_t gcry_cipher_open (gcry_cipher_hd_t *handle,
- int algo, int mode, unsigned int flags);
- void gcry_cipher_close (gcry_cipher_hd_t h);
- gcry_error_t gcry_cipher_ctl (gcry_cipher_hd_t h, int cmd, void *buffer,
- size_t buflen);
- gcry_error_t gcry_cipher_info (gcry_cipher_hd_t h, int what, void *buffer,
- size_t *nbytes);
- gcry_error_t gcry_cipher_algo_info (int algo, int what, void *buffer,
- size_t *nbytes);
- const char *gcry_cipher_algo_name (int algorithm) _GCRY_GCC_ATTR_PURE;
- int gcry_cipher_map_name (const char *name) _GCRY_GCC_ATTR_PURE;
- int gcry_cipher_mode_from_oid (const char *string) _GCRY_GCC_ATTR_PURE;
- gcry_error_t gcry_cipher_encrypt (gcry_cipher_hd_t h,
- void *out, size_t outsize,
- const void *in, size_t inlen);
- gcry_error_t gcry_cipher_decrypt (gcry_cipher_hd_t h,
- void *out, size_t outsize,
- const void *in, size_t inlen);
- gcry_error_t gcry_cipher_setkey (gcry_cipher_hd_t hd,
- const void *key, size_t keylen);
- gcry_error_t gcry_cipher_setiv (gcry_cipher_hd_t hd,
- const void *iv, size_t ivlen);
- gcry_error_t gcry_cipher_authenticate (gcry_cipher_hd_t hd, const void *abuf,
- size_t abuflen);
- gcry_error_t gcry_cipher_gettag (gcry_cipher_hd_t hd, void *outtag,
- size_t taglen);
- gcry_error_t gcry_cipher_checktag (gcry_cipher_hd_t hd, const void *intag,
- size_t taglen);
- #define gcry_cipher_reset(h) gcry_cipher_ctl ((h), GCRYCTL_RESET, NULL, 0)
- #define gcry_cipher_sync(h) gcry_cipher_ctl( (h), GCRYCTL_CFB_SYNC, NULL, 0)
- #define gcry_cipher_cts(h,on) gcry_cipher_ctl( (h), GCRYCTL_SET_CBC_CTS, \
- NULL, on )
- #define gcry_cipher_set_sbox(h,oid) gcry_cipher_ctl( (h), GCRYCTL_SET_SBOX, \
- (oid), 0);
- #define gcry_cipher_final(a) \
- gcry_cipher_ctl ((a), GCRYCTL_FINALIZE, NULL, 0)
- gpg_error_t gcry_cipher_setctr (gcry_cipher_hd_t hd,
- const void *ctr, size_t ctrlen);
- size_t gcry_cipher_get_algo_keylen (int algo);
- size_t gcry_cipher_get_algo_blklen (int algo);
- #define gcry_cipher_test_algo(a) \
- gcry_cipher_algo_info( (a), GCRYCTL_TEST_ALGO, NULL, NULL )
- enum gcry_pk_algos
- {
- GCRY_PK_RSA = 1,
- GCRY_PK_RSA_E = 2,
- GCRY_PK_RSA_S = 3,
- GCRY_PK_ELG_E = 16,
- GCRY_PK_DSA = 17,
- GCRY_PK_ECC = 18,
- GCRY_PK_ELG = 20,
- GCRY_PK_ECDSA = 301,
- GCRY_PK_ECDH = 302,
- GCRY_PK_EDDSA = 303
- };
- #define GCRY_PK_USAGE_SIGN 1
- #define GCRY_PK_USAGE_ENCR 2
- #define GCRY_PK_USAGE_CERT 4
- #define GCRY_PK_USAGE_AUTH 8
- #define GCRY_PK_USAGE_UNKN 128
- #define GCRY_PK_GET_PUBKEY 1
- #define GCRY_PK_GET_SECKEY 2
- gcry_error_t gcry_pk_encrypt (gcry_sexp_t *result,
- gcry_sexp_t data, gcry_sexp_t pkey);
- gcry_error_t gcry_pk_decrypt (gcry_sexp_t *result,
- gcry_sexp_t data, gcry_sexp_t skey);
- gcry_error_t gcry_pk_sign (gcry_sexp_t *result,
- gcry_sexp_t data, gcry_sexp_t skey);
- gcry_error_t gcry_pk_verify (gcry_sexp_t sigval,
- gcry_sexp_t data, gcry_sexp_t pkey);
- gcry_error_t gcry_pk_testkey (gcry_sexp_t key);
- gcry_error_t gcry_pk_genkey (gcry_sexp_t *r_key, gcry_sexp_t s_parms);
- gcry_error_t gcry_pk_ctl (int cmd, void *buffer, size_t buflen);
- gcry_error_t gcry_pk_algo_info (int algo, int what,
- void *buffer, size_t *nbytes);
- const char *gcry_pk_algo_name (int algorithm) _GCRY_GCC_ATTR_PURE;
- int gcry_pk_map_name (const char* name) _GCRY_GCC_ATTR_PURE;
- unsigned int gcry_pk_get_nbits (gcry_sexp_t key) _GCRY_GCC_ATTR_PURE;
- unsigned char *gcry_pk_get_keygrip (gcry_sexp_t key, unsigned char *array);
- const char *gcry_pk_get_curve (gcry_sexp_t key, int iterator,
- unsigned int *r_nbits);
- gcry_sexp_t gcry_pk_get_param (int algo, const char *name);
- #define gcry_pk_test_algo(a) \
- gcry_pk_algo_info( (a), GCRYCTL_TEST_ALGO, NULL, NULL )
- gcry_error_t gcry_pubkey_get_sexp (gcry_sexp_t *r_sexp,
- int mode, gcry_ctx_t ctx);
- enum gcry_md_algos
- {
- GCRY_MD_NONE = 0,
- GCRY_MD_MD5 = 1,
- GCRY_MD_SHA1 = 2,
- GCRY_MD_RMD160 = 3,
- GCRY_MD_MD2 = 5,
- GCRY_MD_TIGER = 6,
- GCRY_MD_HAVAL = 7,
- GCRY_MD_SHA256 = 8,
- GCRY_MD_SHA384 = 9,
- GCRY_MD_SHA512 = 10,
- GCRY_MD_SHA224 = 11,
- GCRY_MD_MD4 = 301,
- GCRY_MD_CRC32 = 302,
- GCRY_MD_CRC32_RFC1510 = 303,
- GCRY_MD_CRC24_RFC2440 = 304,
- GCRY_MD_WHIRLPOOL = 305,
- GCRY_MD_TIGER1 = 306,
- GCRY_MD_TIGER2 = 307,
- GCRY_MD_GOSTR3411_94 = 308,
- GCRY_MD_STRIBOG256 = 309,
- GCRY_MD_STRIBOG512 = 310,
- GCRY_MD_GOSTR3411_CP = 311,
- GCRY_MD_SHA3_224 = 312,
- GCRY_MD_SHA3_256 = 313,
- GCRY_MD_SHA3_384 = 314,
- GCRY_MD_SHA3_512 = 315,
- GCRY_MD_SHAKE128 = 316,
- GCRY_MD_SHAKE256 = 317
- };
- enum gcry_md_flags
- {
- GCRY_MD_FLAG_SECURE = 1,
- GCRY_MD_FLAG_HMAC = 2,
- GCRY_MD_FLAG_BUGEMU1 = 0x0100
- };
- struct gcry_md_context;
- typedef struct gcry_md_handle
- {
-
- struct gcry_md_context *ctx;
-
- int bufpos;
- int bufsize;
- unsigned char buf[1];
- } *gcry_md_hd_t;
- #ifndef GCRYPT_NO_DEPRECATED
- typedef struct gcry_md_handle *GCRY_MD_HD _GCRY_GCC_ATTR_DEPRECATED;
- typedef struct gcry_md_handle *GcryMDHd _GCRY_GCC_ATTR_DEPRECATED;
- #endif
- gcry_error_t gcry_md_open (gcry_md_hd_t *h, int algo, unsigned int flags);
- void gcry_md_close (gcry_md_hd_t hd);
- gcry_error_t gcry_md_enable (gcry_md_hd_t hd, int algo);
- gcry_error_t gcry_md_copy (gcry_md_hd_t *bhd, gcry_md_hd_t ahd);
- void gcry_md_reset (gcry_md_hd_t hd);
- gcry_error_t gcry_md_ctl (gcry_md_hd_t hd, int cmd,
- void *buffer, size_t buflen);
- void gcry_md_write (gcry_md_hd_t hd, const void *buffer, size_t length);
- unsigned char *gcry_md_read (gcry_md_hd_t hd, int algo);
- gpg_error_t gcry_md_extract (gcry_md_hd_t hd, int algo, void *buffer,
- size_t length);
- void gcry_md_hash_buffer (int algo, void *digest,
- const void *buffer, size_t length);
- gpg_error_t gcry_md_hash_buffers (int algo, unsigned int flags, void *digest,
- const gcry_buffer_t *iov, int iovcnt);
- int gcry_md_get_algo (gcry_md_hd_t hd);
- unsigned int gcry_md_get_algo_dlen (int algo);
- int gcry_md_is_enabled (gcry_md_hd_t a, int algo);
- int gcry_md_is_secure (gcry_md_hd_t a);
- gcry_error_t gcry_md_info (gcry_md_hd_t h, int what, void *buffer,
- size_t *nbytes);
- gcry_error_t gcry_md_algo_info (int algo, int what, void *buffer,
- size_t *nbytes);
- const char *gcry_md_algo_name (int algo) _GCRY_GCC_ATTR_PURE;
- int gcry_md_map_name (const char* name) _GCRY_GCC_ATTR_PURE;
- gcry_error_t gcry_md_setkey (gcry_md_hd_t hd, const void *key, size_t keylen);
- void gcry_md_debug (gcry_md_hd_t hd, const char *suffix);
- #define gcry_md_putc(h,c) \
- do { \
- gcry_md_hd_t h__ = (h); \
- if( (h__)->bufpos == (h__)->bufsize ) \
- gcry_md_write( (h__), NULL, 0 ); \
- (h__)->buf[(h__)->bufpos++] = (c) & 0xff; \
- } while(0)
- #define gcry_md_final(a) \
- gcry_md_ctl ((a), GCRYCTL_FINALIZE, NULL, 0)
- #define gcry_md_test_algo(a) \
- gcry_md_algo_info( (a), GCRYCTL_TEST_ALGO, NULL, NULL )
- #define gcry_md_get_asnoid(a,b,n) \
- gcry_md_algo_info((a), GCRYCTL_GET_ASNOID, (b), (n))
- struct gcry_mac_handle;
- typedef struct gcry_mac_handle *gcry_mac_hd_t;
- enum gcry_mac_algos
- {
- GCRY_MAC_NONE = 0,
- GCRY_MAC_HMAC_SHA256 = 101,
- GCRY_MAC_HMAC_SHA224 = 102,
- GCRY_MAC_HMAC_SHA512 = 103,
- GCRY_MAC_HMAC_SHA384 = 104,
- GCRY_MAC_HMAC_SHA1 = 105,
- GCRY_MAC_HMAC_MD5 = 106,
- GCRY_MAC_HMAC_MD4 = 107,
- GCRY_MAC_HMAC_RMD160 = 108,
- GCRY_MAC_HMAC_TIGER1 = 109,
- GCRY_MAC_HMAC_WHIRLPOOL = 110,
- GCRY_MAC_HMAC_GOSTR3411_94 = 111,
- GCRY_MAC_HMAC_STRIBOG256 = 112,
- GCRY_MAC_HMAC_STRIBOG512 = 113,
- GCRY_MAC_HMAC_MD2 = 114,
- GCRY_MAC_HMAC_SHA3_224 = 115,
- GCRY_MAC_HMAC_SHA3_256 = 116,
- GCRY_MAC_HMAC_SHA3_384 = 117,
- GCRY_MAC_HMAC_SHA3_512 = 118,
- GCRY_MAC_CMAC_AES = 201,
- GCRY_MAC_CMAC_3DES = 202,
- GCRY_MAC_CMAC_CAMELLIA = 203,
- GCRY_MAC_CMAC_CAST5 = 204,
- GCRY_MAC_CMAC_BLOWFISH = 205,
- GCRY_MAC_CMAC_TWOFISH = 206,
- GCRY_MAC_CMAC_SERPENT = 207,
- GCRY_MAC_CMAC_SEED = 208,
- GCRY_MAC_CMAC_RFC2268 = 209,
- GCRY_MAC_CMAC_IDEA = 210,
- GCRY_MAC_CMAC_GOST28147 = 211,
- GCRY_MAC_GMAC_AES = 401,
- GCRY_MAC_GMAC_CAMELLIA = 402,
- GCRY_MAC_GMAC_TWOFISH = 403,
- GCRY_MAC_GMAC_SERPENT = 404,
- GCRY_MAC_GMAC_SEED = 405,
- GCRY_MAC_POLY1305 = 501,
- GCRY_MAC_POLY1305_AES = 502,
- GCRY_MAC_POLY1305_CAMELLIA = 503,
- GCRY_MAC_POLY1305_TWOFISH = 504,
- GCRY_MAC_POLY1305_SERPENT = 505,
- GCRY_MAC_POLY1305_SEED = 506
- };
- enum gcry_mac_flags
- {
- GCRY_MAC_FLAG_SECURE = 1
- };
- gcry_error_t gcry_mac_open (gcry_mac_hd_t *handle, int algo,
- unsigned int flags, gcry_ctx_t ctx);
- void gcry_mac_close (gcry_mac_hd_t h);
- gcry_error_t gcry_mac_ctl (gcry_mac_hd_t h, int cmd, void *buffer,
- size_t buflen);
- gcry_error_t gcry_mac_algo_info (int algo, int what, void *buffer,
- size_t *nbytes);
- gcry_error_t gcry_mac_setkey (gcry_mac_hd_t hd, const void *key,
- size_t keylen);
- gcry_error_t gcry_mac_setiv (gcry_mac_hd_t hd, const void *iv,
- size_t ivlen);
- gcry_error_t gcry_mac_write (gcry_mac_hd_t hd, const void *buffer,
- size_t length);
- gcry_error_t gcry_mac_read (gcry_mac_hd_t hd, void *buffer, size_t *buflen);
- gcry_error_t gcry_mac_verify (gcry_mac_hd_t hd, const void *buffer,
- size_t buflen);
- int gcry_mac_get_algo (gcry_mac_hd_t hd);
- unsigned int gcry_mac_get_algo_maclen (int algo);
- unsigned int gcry_mac_get_algo_keylen (int algo);
- const char *gcry_mac_algo_name (int algorithm) _GCRY_GCC_ATTR_PURE;
- int gcry_mac_map_name (const char *name) _GCRY_GCC_ATTR_PURE;
- #define gcry_mac_reset(h) gcry_mac_ctl ((h), GCRYCTL_RESET, NULL, 0)
- #define gcry_mac_test_algo(a) \
- gcry_mac_algo_info( (a), GCRYCTL_TEST_ALGO, NULL, NULL )
- enum gcry_kdf_algos
- {
- GCRY_KDF_NONE = 0,
- GCRY_KDF_SIMPLE_S2K = 16,
- GCRY_KDF_SALTED_S2K = 17,
- GCRY_KDF_ITERSALTED_S2K = 19,
- GCRY_KDF_PBKDF1 = 33,
- GCRY_KDF_PBKDF2 = 34,
- GCRY_KDF_SCRYPT = 48
- };
- gpg_error_t gcry_kdf_derive (const void *passphrase, size_t passphraselen,
- int algo, int subalgo,
- const void *salt, size_t saltlen,
- unsigned long iterations,
- size_t keysize, void *keybuffer);
- enum gcry_rng_types
- {
- GCRY_RNG_TYPE_STANDARD = 1,
- GCRY_RNG_TYPE_FIPS = 2,
- GCRY_RNG_TYPE_SYSTEM = 3
- };
- typedef enum gcry_random_level
- {
- GCRY_WEAK_RANDOM = 0,
- GCRY_STRONG_RANDOM = 1,
- GCRY_VERY_STRONG_RANDOM = 2
- }
- gcry_random_level_t;
- void gcry_randomize (void *buffer, size_t length,
- enum gcry_random_level level);
- gcry_error_t gcry_random_add_bytes (const void *buffer, size_t length,
- int quality);
- #define gcry_fast_random_poll() gcry_control (GCRYCTL_FAST_POLL, NULL)
- void *gcry_random_bytes (size_t nbytes, enum gcry_random_level level)
- _GCRY_GCC_ATTR_MALLOC;
- void *gcry_random_bytes_secure (size_t nbytes, enum gcry_random_level level)
- _GCRY_GCC_ATTR_MALLOC;
- void gcry_mpi_randomize (gcry_mpi_t w,
- unsigned int nbits, enum gcry_random_level level);
- void gcry_create_nonce (void *buffer, size_t length);
- #define GCRY_PRIME_CHECK_AT_FINISH 0
- #define GCRY_PRIME_CHECK_AT_GOT_PRIME 1
- #define GCRY_PRIME_CHECK_AT_MAYBE_PRIME 2
- typedef int (*gcry_prime_check_func_t) (void *arg, int mode,
- gcry_mpi_t candidate);
- #define GCRY_PRIME_FLAG_SECRET (1 << 0)
- #define GCRY_PRIME_FLAG_SPECIAL_FACTOR (1 << 1)
- gcry_error_t gcry_prime_generate (gcry_mpi_t *prime,
- unsigned int prime_bits,
- unsigned int factor_bits,
- gcry_mpi_t **factors,
- gcry_prime_check_func_t cb_func,
- void *cb_arg,
- gcry_random_level_t random_level,
- unsigned int flags);
- gcry_error_t gcry_prime_group_generator (gcry_mpi_t *r_g,
- gcry_mpi_t prime,
- gcry_mpi_t *factors,
- gcry_mpi_t start_g);
- void gcry_prime_release_factors (gcry_mpi_t *factors);
- gcry_error_t gcry_prime_check (gcry_mpi_t x, unsigned int flags);
- void gcry_ctx_release (gcry_ctx_t ctx);
- void gcry_log_debug (const char *fmt, ...) _GCRY_GCC_ATTR_PRINTF(1,2);
- void gcry_log_debughex (const char *text, const void *buffer, size_t length);
- void gcry_log_debugmpi (const char *text, gcry_mpi_t mpi);
- void gcry_log_debugpnt (const char *text,
- gcry_mpi_point_t point, gcry_ctx_t ctx);
- void gcry_log_debugsxp (const char *text, gcry_sexp_t sexp);
- enum gcry_log_levels
- {
- GCRY_LOG_CONT = 0,
- GCRY_LOG_INFO = 10,
- GCRY_LOG_WARN = 20,
- GCRY_LOG_ERROR = 30,
- GCRY_LOG_FATAL = 40,
- GCRY_LOG_BUG = 50,
- GCRY_LOG_DEBUG = 100
- };
- typedef void (*gcry_handler_progress_t) (void *, const char *, int, int, int);
- typedef void *(*gcry_handler_alloc_t) (size_t n);
- typedef int (*gcry_handler_secure_check_t) (const void *);
- typedef void *(*gcry_handler_realloc_t) (void *p, size_t n);
- typedef void (*gcry_handler_free_t) (void *);
- typedef int (*gcry_handler_no_mem_t) (void *, size_t, unsigned int);
- typedef void (*gcry_handler_error_t) (void *, int, const char *);
- typedef void (*gcry_handler_log_t) (void *, int, const char *, va_list);
- void gcry_set_progress_handler (gcry_handler_progress_t cb, void *cb_data);
- void gcry_set_allocation_handler (
- gcry_handler_alloc_t func_alloc,
- gcry_handler_alloc_t func_alloc_secure,
- gcry_handler_secure_check_t func_secure_check,
- gcry_handler_realloc_t func_realloc,
- gcry_handler_free_t func_free);
- void gcry_set_outofcore_handler (gcry_handler_no_mem_t h, void *opaque);
- void gcry_set_fatalerror_handler (gcry_handler_error_t fnc, void *opaque);
- void gcry_set_log_handler (gcry_handler_log_t f, void *opaque);
- void gcry_set_gettext_handler (const char *(*f)(const char*));
- void *gcry_malloc (size_t n) _GCRY_GCC_ATTR_MALLOC;
- void *gcry_calloc (size_t n, size_t m) _GCRY_GCC_ATTR_MALLOC;
- void *gcry_malloc_secure (size_t n) _GCRY_GCC_ATTR_MALLOC;
- void *gcry_calloc_secure (size_t n, size_t m) _GCRY_GCC_ATTR_MALLOC;
- void *gcry_realloc (void *a, size_t n);
- char *gcry_strdup (const char *string) _GCRY_GCC_ATTR_MALLOC;
- void *gcry_xmalloc (size_t n) _GCRY_GCC_ATTR_MALLOC;
- void *gcry_xcalloc (size_t n, size_t m) _GCRY_GCC_ATTR_MALLOC;
- void *gcry_xmalloc_secure (size_t n) _GCRY_GCC_ATTR_MALLOC;
- void *gcry_xcalloc_secure (size_t n, size_t m) _GCRY_GCC_ATTR_MALLOC;
- void *gcry_xrealloc (void *a, size_t n);
- char *gcry_xstrdup (const char * a) _GCRY_GCC_ATTR_MALLOC;
- void gcry_free (void *a);
- int gcry_is_secure (const void *a) _GCRY_GCC_ATTR_PURE;
- #define gcry_fips_mode_active() !!gcry_control (GCRYCTL_FIPS_MODE_P, 0)
- #if 0
- {
- #endif
- #ifdef __cplusplus
- }
- #endif
- #endif
|