new function to lookup FIPS supported ciphers by NID
authorDr. Stephen Henson <steve@openssl.org>
Wed, 14 Sep 2011 13:25:48 +0000 (13:25 +0000)
committerDr. Stephen Henson <steve@openssl.org>
Wed, 14 Sep 2011 13:25:48 +0000 (13:25 +0000)
CHANGES
fips/fips.h
fips/utl/fips_enc.c

diff --git a/CHANGES b/CHANGES
index 8fa3e54..c4e8639 100644 (file)
--- a/CHANGES
+++ b/CHANGES
@@ -4,6 +4,10 @@
 
  Changes between 1.0.1 and 1.1.0  [xx XXX xxxx]
 
+  *) New function FIPS_get_cipherbynid() to lookup FIPS supported ciphers
+     based on NID.
+     [Steve Henson]
+
   *) More extensive health check for DRBG checking many more failure modes.
      New function FIPS_selftest_drbg_all() to handle every possible DRBG
      combination: call this in fips_test_suite.
index 17dd066..27242f1 100644 (file)
@@ -193,6 +193,8 @@ int fips_cipher_test(int id, struct evp_cipher_ctx_st *ctx,
 
 const struct env_md_st *FIPS_get_digestbynid(int nid);
 
+const struct evp_cipher_st *FIPS_get_cipherbynid(int nid);
+
 struct rsa_st *FIPS_rsa_new(void);
 void FIPS_rsa_free(struct rsa_st *r);
 int FIPS_rsa_sign_ctx(struct rsa_st *rsa, struct env_md_ctx_st *ctx,
index fcff5ec..9ed9dbf 100644 (file)
@@ -338,3 +338,131 @@ int FIPS_cipher(EVP_CIPHER_CTX *ctx, unsigned char *out,
                }
        return ctx->cipher->do_cipher(ctx,out,in,inl);
        }
+
+const EVP_CIPHER *FIPS_get_cipherbynid(int nid)
+       {
+       switch (nid)
+               {
+               case NID_aes_128_cbc:
+               return FIPS_evp_aes_128_cbc();
+
+               case NID_aes_128_ccm:
+               return FIPS_evp_aes_128_ccm();
+
+               case NID_aes_128_cfb1:
+               return FIPS_evp_aes_128_cfb1();
+
+               case NID_aes_128_cfb128:
+               return FIPS_evp_aes_128_cfb128();
+
+               case NID_aes_128_cfb8:
+               return FIPS_evp_aes_128_cfb8();
+
+               case NID_aes_128_ctr:
+               return FIPS_evp_aes_128_ctr();
+
+               case NID_aes_128_ecb:
+               return FIPS_evp_aes_128_ecb();
+
+               case NID_aes_128_gcm:
+               return FIPS_evp_aes_128_gcm();
+
+               case NID_aes_128_ofb128:
+               return FIPS_evp_aes_128_ofb();
+
+               case NID_aes_128_xts:
+               return FIPS_evp_aes_128_xts();
+
+               case NID_aes_192_cbc:
+               return FIPS_evp_aes_192_cbc();
+
+               case NID_aes_192_ccm:
+               return FIPS_evp_aes_192_ccm();
+
+               case NID_aes_192_cfb1:
+               return FIPS_evp_aes_192_cfb1();
+
+               case NID_aes_192_cfb128:
+               return FIPS_evp_aes_192_cfb128();
+
+               case NID_aes_192_cfb8:
+               return FIPS_evp_aes_192_cfb8();
+
+               case NID_aes_192_ctr:
+               return FIPS_evp_aes_192_ctr();
+
+               case NID_aes_192_ecb:
+               return FIPS_evp_aes_192_ecb();
+
+               case NID_aes_192_gcm:
+               return FIPS_evp_aes_192_gcm();
+
+               case NID_aes_192_ofb128:
+               return FIPS_evp_aes_192_ofb();
+
+               case NID_aes_256_cbc:
+               return FIPS_evp_aes_256_cbc();
+
+               case NID_aes_256_ccm:
+               return FIPS_evp_aes_256_ccm();
+
+               case NID_aes_256_cfb1:
+               return FIPS_evp_aes_256_cfb1();
+
+               case NID_aes_256_cfb128:
+               return FIPS_evp_aes_256_cfb128();
+
+               case NID_aes_256_cfb8:
+               return FIPS_evp_aes_256_cfb8();
+
+               case NID_aes_256_ctr:
+               return FIPS_evp_aes_256_ctr();
+
+               case NID_aes_256_ecb:
+               return FIPS_evp_aes_256_ecb();
+
+               case NID_aes_256_gcm:
+               return FIPS_evp_aes_256_gcm();
+
+               case NID_aes_256_ofb128:
+               return FIPS_evp_aes_256_ofb();
+
+               case NID_aes_256_xts:
+               return FIPS_evp_aes_256_xts();
+
+               case NID_des_ede_ecb:
+               return FIPS_evp_des_ede();
+
+               case NID_des_ede3_ecb:
+               return FIPS_evp_des_ede3();
+
+               case NID_des_ede3_cbc:
+               return FIPS_evp_des_ede3_cbc();
+
+               case NID_des_ede3_cfb1:
+               return FIPS_evp_des_ede3_cfb1();
+
+               case NID_des_ede3_cfb64:
+               return FIPS_evp_des_ede3_cfb64();
+
+               case NID_des_ede3_cfb8:
+               return FIPS_evp_des_ede3_cfb8();
+
+               case NID_des_ede3_ofb64:
+               return FIPS_evp_des_ede3_ofb();
+
+               case NID_des_ede_cbc:
+               return FIPS_evp_des_ede_cbc();
+
+               case NID_des_ede_cfb64:
+               return FIPS_evp_des_ede_cfb64();
+
+               case NID_des_ede_ofb64:
+               return FIPS_evp_des_ede_ofb();
+
+               default:
+               return NULL;
+
+               }
+       }
+