BEGIN_ENUM_TYPE(hashalg)
    ENUM_VALUE("md5", &ssh_md5)
    ENUM_VALUE("sha1", &ssh_sha1)
    ENUM_VALUE("sha1_sw", &ssh_sha1_sw)
    ENUM_VALUE("sha256", &ssh_sha256)
    ENUM_VALUE("sha384", &ssh_sha384)
    ENUM_VALUE("sha512", &ssh_sha512)
    ENUM_VALUE("sha256_sw", &ssh_sha256_sw)
    ENUM_VALUE("sha384_sw", &ssh_sha384_sw)
    ENUM_VALUE("sha512_sw", &ssh_sha512_sw)
#if HAVE_SHA_NI
    ENUM_VALUE("sha1_ni", &ssh_sha1_ni)
    ENUM_VALUE("sha256_ni", &ssh_sha256_ni)
#endif
#if HAVE_NEON_CRYPTO
    ENUM_VALUE("sha1_neon", &ssh_sha1_neon)
    ENUM_VALUE("sha256_neon", &ssh_sha256_neon)
#endif
#if HAVE_NEON_SHA512
    ENUM_VALUE("sha384_neon", &ssh_sha384_neon)
    ENUM_VALUE("sha512_neon", &ssh_sha512_neon)
#endif
    ENUM_VALUE("sha3_224", &ssh_sha3_224)
    ENUM_VALUE("sha3_256", &ssh_sha3_256)
    ENUM_VALUE("sha3_384", &ssh_sha3_384)
    ENUM_VALUE("sha3_512", &ssh_sha3_512)
    ENUM_VALUE("shake256_114bytes", &ssh_shake256_114bytes)
    ENUM_VALUE("blake2b", &ssh_blake2b)
END_ENUM_TYPE(hashalg)

BEGIN_ENUM_TYPE(macalg)
    ENUM_VALUE("hmac_md5", &ssh_hmac_md5)
    ENUM_VALUE("hmac_sha1", &ssh_hmac_sha1)
    ENUM_VALUE("hmac_sha1_buggy", &ssh_hmac_sha1_buggy)
    ENUM_VALUE("hmac_sha1_96", &ssh_hmac_sha1_96)
    ENUM_VALUE("hmac_sha1_96_buggy", &ssh_hmac_sha1_96_buggy)
    ENUM_VALUE("hmac_sha256", &ssh_hmac_sha256)
    ENUM_VALUE("poly1305", &ssh2_poly1305)
END_ENUM_TYPE(macalg)

BEGIN_ENUM_TYPE(keyalg)
    ENUM_VALUE("dsa", &ssh_dsa)
    ENUM_VALUE("rsa", &ssh_rsa)
    ENUM_VALUE("ed25519", &ssh_ecdsa_ed25519)
    ENUM_VALUE("ed448", &ssh_ecdsa_ed448)
    ENUM_VALUE("p256", &ssh_ecdsa_nistp256)
    ENUM_VALUE("p384", &ssh_ecdsa_nistp384)
    ENUM_VALUE("p521", &ssh_ecdsa_nistp521)
END_ENUM_TYPE(keyalg)

BEGIN_ENUM_TYPE(cipheralg)
    ENUM_VALUE("3des_ctr", &ssh_3des_ssh2_ctr)
    ENUM_VALUE("3des_ssh2", &ssh_3des_ssh2)
    ENUM_VALUE("3des_ssh1", &ssh_3des_ssh1)
    ENUM_VALUE("des_cbc", &ssh_des)
    ENUM_VALUE("aes256_ctr", &ssh_aes256_sdctr)
    ENUM_VALUE("aes256_cbc", &ssh_aes256_cbc)
    ENUM_VALUE("aes192_ctr", &ssh_aes192_sdctr)
    ENUM_VALUE("aes192_cbc", &ssh_aes192_cbc)
    ENUM_VALUE("aes128_ctr", &ssh_aes128_sdctr)
    ENUM_VALUE("aes128_cbc", &ssh_aes128_cbc)
    ENUM_VALUE("aes256_ctr_sw", &ssh_aes256_sdctr_sw)
    ENUM_VALUE("aes256_cbc_sw", &ssh_aes256_cbc_sw)
    ENUM_VALUE("aes192_ctr_sw", &ssh_aes192_sdctr_sw)
    ENUM_VALUE("aes192_cbc_sw", &ssh_aes192_cbc_sw)
    ENUM_VALUE("aes128_ctr_sw", &ssh_aes128_sdctr_sw)
    ENUM_VALUE("aes128_cbc_sw", &ssh_aes128_cbc_sw)
#if HAVE_AES_NI
    ENUM_VALUE("aes256_ctr_ni", &ssh_aes256_sdctr_ni)
    ENUM_VALUE("aes256_cbc_ni", &ssh_aes256_cbc_ni)
    ENUM_VALUE("aes192_ctr_ni", &ssh_aes192_sdctr_ni)
    ENUM_VALUE("aes192_cbc_ni", &ssh_aes192_cbc_ni)
    ENUM_VALUE("aes128_ctr_ni", &ssh_aes128_sdctr_ni)
    ENUM_VALUE("aes128_cbc_ni", &ssh_aes128_cbc_ni)
#endif
#if HAVE_NEON_CRYPTO
    ENUM_VALUE("aes256_ctr_neon", &ssh_aes256_sdctr_neon)
    ENUM_VALUE("aes256_cbc_neon", &ssh_aes256_cbc_neon)
    ENUM_VALUE("aes192_ctr_neon", &ssh_aes192_sdctr_neon)
    ENUM_VALUE("aes192_cbc_neon", &ssh_aes192_cbc_neon)
    ENUM_VALUE("aes128_ctr_neon", &ssh_aes128_sdctr_neon)
    ENUM_VALUE("aes128_cbc_neon", &ssh_aes128_cbc_neon)
#endif
    ENUM_VALUE("blowfish_ctr", &ssh_blowfish_ssh2_ctr)
    ENUM_VALUE("blowfish_ssh2", &ssh_blowfish_ssh2)
    ENUM_VALUE("blowfish_ssh1", &ssh_blowfish_ssh1)
    ENUM_VALUE("arcfour256", &ssh_arcfour256_ssh2)
    ENUM_VALUE("arcfour128", &ssh_arcfour128_ssh2)
    ENUM_VALUE("chacha20_poly1305", &ssh2_chacha20_poly1305)
END_ENUM_TYPE(cipheralg)

BEGIN_ENUM_TYPE(dh_group)
    ENUM_VALUE("group1", &ssh_diffiehellman_group1_sha1)
    ENUM_VALUE("group14", &ssh_diffiehellman_group14_sha256)
END_ENUM_TYPE(dh_group)

BEGIN_ENUM_TYPE(ecdh_alg)
    ENUM_VALUE("curve25519", &ssh_ec_kex_curve25519)
    ENUM_VALUE("curve448", &ssh_ec_kex_curve448)
    ENUM_VALUE("nistp256", &ssh_ec_kex_nistp256)
    ENUM_VALUE("nistp384", &ssh_ec_kex_nistp384)
    ENUM_VALUE("nistp521", &ssh_ec_kex_nistp521)
END_ENUM_TYPE(ecdh_alg)

BEGIN_ENUM_TYPE(rsaorder)
    ENUM_VALUE("exponent_first", RSA_SSH1_EXPONENT_FIRST)
    ENUM_VALUE("modulus_first", RSA_SSH1_MODULUS_FIRST)
END_ENUM_TYPE(rsaorder)

BEGIN_ENUM_TYPE(primegenpolicy)
    ENUM_VALUE("probabilistic", &primegen_probabilistic)
    ENUM_VALUE("provable_fast", &primegen_provable_fast)
    ENUM_VALUE("provable_maurer_simple", &primegen_provable_maurer_simple)
    ENUM_VALUE("provable_maurer_complex", &primegen_provable_maurer_complex)
END_ENUM_TYPE(primegenpolicy)

BEGIN_ENUM_TYPE(argon2flavour)
    ENUM_VALUE("d", Argon2d)
    ENUM_VALUE("i", Argon2i)
    ENUM_VALUE("id", Argon2id)
    /* I expect to forget which spelling I chose, so let's support many */
    ENUM_VALUE("argon2d", Argon2d)
    ENUM_VALUE("argon2i", Argon2i)
    ENUM_VALUE("argon2id", Argon2id)
    ENUM_VALUE("Argon2d", Argon2d)
    ENUM_VALUE("Argon2i", Argon2i)
    ENUM_VALUE("Argon2id", Argon2id)
END_ENUM_TYPE(argon2flavour)

BEGIN_ENUM_TYPE(fptype)
    ENUM_VALUE("md5", SSH_FPTYPE_MD5)
    ENUM_VALUE("sha256", SSH_FPTYPE_SHA256)
END_ENUM_TYPE(fptype)

/*
 * cproxy.h already has a list macro mapping protocol-specified
 * strings to the list of HTTP Digest hash functions. Rather than
 * invent a separate one for testcrypt, reuse the existing names.
 */
BEGIN_ENUM_TYPE(httpdigesthash)
    #define DECL_ARRAY(id, str, alg, bits, accepted) ENUM_VALUE(str, id)
    HTTP_DIGEST_HASHES(DECL_ARRAY)
    #undef DECL_ARRAY
END_ENUM_TYPE(httpdigesthash)