Add multi segmented test for TLS 1.3 and multi segmented out of place tests for DTLS 1.2 and TLS 1.3.
Signed-off-by: Aakash Sasidharan <asasidha...@marvell.com> --- app/test/test_cryptodev.c | 69 ++++++++++++++++++++++----------------- 1 file changed, 39 insertions(+), 30 deletions(-) diff --git a/app/test/test_cryptodev.c b/app/test/test_cryptodev.c index 89b54729eb..0afc13a7b6 100644 --- a/app/test/test_cryptodev.c +++ b/app/test/test_cryptodev.c @@ -12224,11 +12224,11 @@ test_tls_1_2_record_proto_display_list(void) } static int -test_tls_1_2_record_proto_sgl(void) +test_tls_record_proto_sgl(enum rte_security_tls_version tls_version) { struct tls_record_test_flags flags = { .nb_segs_in_mbuf = 5, - .tls_version = RTE_SECURITY_VERSION_TLS_1_2 + .tls_version = tls_version }; struct crypto_testsuite_params *ts_params = &testsuite_params; struct rte_cryptodev_info dev_info; @@ -12242,6 +12242,12 @@ test_tls_1_2_record_proto_sgl(void) return test_tls_record_proto_all(&flags); } +static int +test_tls_1_2_record_proto_sgl(void) +{ + return test_tls_record_proto_sgl(RTE_SECURITY_VERSION_TLS_1_2); +} + static int test_tls_record_proto_sgl_data_walkthrough(enum rte_security_tls_version tls_version) { @@ -12577,20 +12583,7 @@ test_dtls_1_2_record_proto_antireplay4096(void) static int test_dtls_1_2_record_proto_sgl(void) { - struct tls_record_test_flags flags = { - .nb_segs_in_mbuf = 5, - .tls_version = RTE_SECURITY_VERSION_DTLS_1_2 - }; - struct crypto_testsuite_params *ts_params = &testsuite_params; - struct rte_cryptodev_info dev_info; - - rte_cryptodev_info_get(ts_params->valid_devs[0], &dev_info); - if (!(dev_info.feature_flags & RTE_CRYPTODEV_FF_IN_PLACE_SGL)) { - printf("Device doesn't support in-place scatter-gather. Test Skipped.\n"); - return TEST_SKIPPED; - } - - return test_tls_record_proto_all(&flags); + return test_tls_record_proto_sgl(RTE_SECURITY_VERSION_DTLS_1_2); } static int @@ -12599,6 +12592,12 @@ test_dtls_1_2_record_proto_sgl_data_walkthrough(void) return test_tls_record_proto_sgl_data_walkthrough(RTE_SECURITY_VERSION_DTLS_1_2); } +static int +test_dtls_1_2_record_proto_sgl_oop(void) +{ + return test_tls_record_proto_sgl_oop(RTE_SECURITY_VERSION_DTLS_1_2); +} + static int test_dtls_1_2_record_proto_corrupt_pkt(void) { @@ -12819,23 +12818,21 @@ test_tls_1_3_record_proto_data_walkthrough(void) } static int -test_tls_1_3_record_proto_sgl_data_walkthrough(void) +test_tls_1_3_record_proto_sgl(void) { - struct tls_record_test_flags flags = { - .nb_segs_in_mbuf = 5, - .tls_version = RTE_SECURITY_VERSION_TLS_1_3, - .data_walkthrough = true - }; - struct crypto_testsuite_params *ts_params = &testsuite_params; - struct rte_cryptodev_info dev_info; + return test_tls_record_proto_sgl(RTE_SECURITY_VERSION_TLS_1_3); +} - rte_cryptodev_info_get(ts_params->valid_devs[0], &dev_info); - if (!(dev_info.feature_flags & RTE_CRYPTODEV_FF_IN_PLACE_SGL)) { - printf("Device doesn't support in-place scatter-gather. Test Skipped.\n"); - return TEST_SKIPPED; - } +static int +test_tls_1_3_record_proto_sgl_data_walkthrough(void) +{ + return test_tls_record_proto_sgl_data_walkthrough(RTE_SECURITY_VERSION_TLS_1_3); +} - return test_tls_record_proto_all(&flags); +static int +test_tls_1_3_record_proto_sgl_oop(void) +{ + return test_tls_record_proto_sgl_oop(RTE_SECURITY_VERSION_TLS_1_3); } #endif @@ -18153,6 +18150,10 @@ static struct unit_test_suite dtls12_record_proto_testsuite = { "Multi-segmented mode data walkthrough", ut_setup_security, ut_teardown, test_dtls_1_2_record_proto_sgl_data_walkthrough), + TEST_CASE_NAMED_ST( + "Multi-segmented mode out of place", + ut_setup_security, ut_teardown, + test_dtls_1_2_record_proto_sgl_oop), TEST_CASE_NAMED_ST( "Packet corruption", ut_setup_security, ut_teardown, @@ -18294,10 +18295,18 @@ static struct unit_test_suite tls13_record_proto_testsuite = { "Data walkthrough combined test alg list", ut_setup_security, ut_teardown, test_tls_1_3_record_proto_data_walkthrough), + TEST_CASE_NAMED_ST( + "Multi-segmented mode", + ut_setup_security, ut_teardown, + test_tls_1_3_record_proto_sgl), TEST_CASE_NAMED_ST( "Multi-segmented mode data walkthrough", ut_setup_security, ut_teardown, test_tls_1_3_record_proto_sgl_data_walkthrough), + TEST_CASE_NAMED_ST( + "Multi-segmented mode out of place", + ut_setup_security, ut_teardown, + test_tls_1_3_record_proto_sgl_oop), TEST_CASES_END() /**< NULL terminate unit test array */ } }; -- 2.25.1