| 
DSA_set_default_openssl_method(3DSA_set_default_openssl_method(3)
        DSA_set_method,            DSA_set_default_openssl_method,
       DSA_get_default_openssl_method,            DSA_new_method,
       DSA_OpenSSL - Select DSA method
       #include <openssl/dsa.h> #include <openssl/engine.h>
       void DSA_set_default_openssl_method(
               DSA_METHOD        *meth        );       DSA_METHOD
       *DSA_get_default_openssl_method(
               void ); int DSA_set_method(
               DSA *dsa, ENGINE *engine ); DSA *DSA_new_method(
               ENGINE *engine ); DSA_METHOD *DSA_OpenSSL(
               void );
       A DSA_METHOD specifies the functions that OpenSSL uses for
       DSA  operations.  By  modifying  the  method,  alternative
       implementations such as hardware accelerators can be used.
       Initially, the default is the OpenSSL internal implementation.
 The DSA_OpenSSL() function returns a pointer to that
       method.
       The  DSA_set_default_openssl_method()  function makes meth
       the default method for all DSA structures  created  later.
       This  is true only while the default engine for DSA operations
 remains as openssl.  ENGINEs provide  an  encapsulation
  for  implementations  of one or more algorithms at a
       time, and all the DSA  functions  mentioned  here  operate
       within the scope of the default openssl engine.
       The  DSA_get_default_openssl_method()  function  returns a
       pointer to the current  default  method  for  the  openssl
       engine.
       The  DSA_set_method()  selects  engine  for all operations
       using the structure dsa.
       The DSA_new_method() function allocates and initializes  a
       DSA  structure  so  that  engine  will be used for the DSA
       operations. If engine is NULL, the default engine for  DSA
       operations is used.
THE DSA_METHOD STRUCTURE    [Toc]    [Back]       struct    {        /*   name   of  the  implementation  */
       const char *name;
            /*   sign   */        DSA_SIG   *(*dsa_do_sign)(const
       unsigned char *dgst, int dlen,
                                        DSA *dsa);
            /*    pre-compute    k^-1    and    r   */        int
       (*dsa_sign_setup)(DSA   *dsa,   BN_CTX   *ctx_in,   BIGNUM
       **kinvp,
                                        BIGNUM **rp);
            /* verify */      int (*dsa_do_verify)(const unsigned
       char *dgst, int dgst_len,
                                        DSA_SIG *sig, DSA *dsa);
            /* compute rr = a1^p1 * a2^p2 mod m (May be NULL  for
       some
                                                 implementations)
       */      int (*dsa_mod_exp)(DSA *dsa,  BIGNUM  *rr,  BIGNUM
       *a1, BIGNUM *p1,
                                        BIGNUM  *a2,  BIGNUM *p2,
       BIGNUM *m,
                                        BN_CTX *ctx,  BN_MONT_CTX
       *in_mont);
            /*  compute  r  =  a  ^ p mod m (May be NULL for some
       implementations) */
               int (*bn_mod_exp)(DSA *dsa, BIGNUM *r, BIGNUM *a,
                                        const  BIGNUM  *p,  const
       BIGNUM *m,
                                        BN_CTX  *ctx, BN_MONT_CTX
       *m_ctx);
            /* called at DSA_new */
               int (*init)(DSA *DSA);
            /* called at DSA_free */
               int (*finish)(DSA *DSA);
               int flags;
               char *app_data; /* ?? */
        } DSA_METHOD;
       The  DSA_OpenSSL()  and   DSA_get_default_openssl_method()
       functions return pointers to the respective DSA_METHODs.
       The  DSA_set_default_openssl_method()  function returns no
       value.
       The DSA_set_method()  function  returns  non-zero  if  the
       ENGINE  associated  with  dsa  was successfully changed to
       engine.
       The DSA_new_method() function returns  NULL  and  sets  an
       error  code  that  can be obtained from ERR_get_error() if
       the allocation fails. Otherwise it returns  a  pointer  to
       the newly allocated structure.
       The   DSA_set_default_method(),  DSA_get_default_method(),
       DSA_set_method(),  DSA_new_method(),   and   DSA_OpenSSL()
       functions were added in OpenSSL 0.9.4.
       The          DSA_set_default_openssl_method()          and
       DSA_get_default_openssl_method()  functions  replaced  the
       DSA_set_default_method()    and   DSA_get_default_method()
       functions  respectively,  and  the  DSA_set_method()   and
       DSA_new_method()  functions  were  altered  to use ENGINEs
       rather than  DSA_METHODs  during  development  of  OpenSSL
       0.9.6.
       Functions: dsa(3), DSA_new(3)
                                DSA_set_default_openssl_method(3)
[ Back ] |