get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

GET /api/patches/84504/?format=api
HTTP 200 OK
Allow: GET, PUT, PATCH, HEAD, OPTIONS
Content-Type: application/json
Vary: Accept

{
    "id": 84504,
    "url": "http://patches.dpdk.org/api/patches/84504/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/20201124123249.14451-1-ibtisam.tariq@emumba.com/",
    "project": {
        "id": 1,
        "url": "http://patches.dpdk.org/api/projects/1/?format=api",
        "name": "DPDK",
        "link_name": "dpdk",
        "list_id": "dev.dpdk.org",
        "list_email": "dev@dpdk.org",
        "web_url": "http://core.dpdk.org",
        "scm_url": "git://dpdk.org/dpdk",
        "webscm_url": "http://git.dpdk.org/dpdk",
        "list_archive_url": "https://inbox.dpdk.org/dev",
        "list_archive_url_format": "https://inbox.dpdk.org/dev/{}",
        "commit_url_format": ""
    },
    "msgid": "<20201124123249.14451-1-ibtisam.tariq@emumba.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/20201124123249.14451-1-ibtisam.tariq@emumba.com",
    "date": "2020-11-24T12:32:43",
    "name": "[1/7] examples/fips_validation: enhance getopt_long usage",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "363989c662ae1f6b99b51edf011cf36daba64c6e",
    "submitter": {
        "id": 1680,
        "url": "http://patches.dpdk.org/api/people/1680/?format=api",
        "name": "Ibtisam Tariq",
        "email": "ibtisam.tariq@emumba.com"
    },
    "delegate": {
        "id": 24651,
        "url": "http://patches.dpdk.org/api/users/24651/?format=api",
        "username": "dmarchand",
        "first_name": "David",
        "last_name": "Marchand",
        "email": "david.marchand@redhat.com"
    },
    "mbox": "http://patches.dpdk.org/project/dpdk/patch/20201124123249.14451-1-ibtisam.tariq@emumba.com/mbox/",
    "series": [
        {
            "id": 14068,
            "url": "http://patches.dpdk.org/api/series/14068/?format=api",
            "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=14068",
            "date": "2020-11-24T12:32:43",
            "name": "[1/7] examples/fips_validation: enhance getopt_long usage",
            "version": 1,
            "mbox": "http://patches.dpdk.org/series/14068/mbox/"
        }
    ],
    "comments": "http://patches.dpdk.org/api/patches/84504/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/84504/checks/",
    "tags": {},
    "related": [],
    "headers": {
        "Return-Path": "<dev-bounces@dpdk.org>",
        "X-Original-To": "patchwork@inbox.dpdk.org",
        "Delivered-To": "patchwork@inbox.dpdk.org",
        "Received": [
            "from dpdk.org (dpdk.org [92.243.14.124])\n\tby inbox.dpdk.org (Postfix) with ESMTP id 78DEAA04B1;\n\tTue, 24 Nov 2020 13:33:29 +0100 (CET)",
            "from [92.243.14.124] (localhost [127.0.0.1])\n\tby dpdk.org (Postfix) with ESMTP id BEB3AC910;\n\tTue, 24 Nov 2020 13:33:27 +0100 (CET)",
            "from mail-wm1-f66.google.com (mail-wm1-f66.google.com\n [209.85.128.66]) by dpdk.org (Postfix) with ESMTP id 242BDC90E\n for <dev@dpdk.org>; Tue, 24 Nov 2020 13:33:26 +0100 (CET)",
            "by mail-wm1-f66.google.com with SMTP id a3so2685760wmb.5\n for <dev@dpdk.org>; Tue, 24 Nov 2020 04:33:26 -0800 (PST)",
            "from localhost.localdomain ([39.33.169.238])\n by smtp.gmail.com with ESMTPSA id w3sm5409034wma.3.2020.11.24.04.33.21\n (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);\n Tue, 24 Nov 2020 04:33:24 -0800 (PST)"
        ],
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=emumba-com.20150623.gappssmtp.com; s=20150623;\n h=from:to:cc:subject:date:message-id;\n bh=Q6uxIP1KLpWJpyh83MKF7dN9YDCkZrW+VQxRtS3muGA=;\n b=vnmq6cj6xuNIcNdRFXUtZ6aIlx47qONIb52Z2pS/QzTAmMAX+gq0vHcY/9ASjk6c8Q\n DKXCvFmmDrncbGqeLWj4yw59a/Fopm3bTIsV3jIZGOp+WyU6R0VjF3MpwPv8bda5wU1Y\n ghOr5Y7nK/YoWZ3Z2/IDZPWdJ8xPBx6N5J6JdsI/0NpdKs7l3ZQ7lFd/ZGUCZVw7wsul\n KqSGJ4rYwj9fIFk7kUOxiDANsKPLUksTAZT1gTMe79UOtxiQzML7FEyY6iCMLju3Y5R/\n Hn9C9lP2mR69ta8qHNdK46t/oUyrMq0VlnBxjPK27a5h+QBvswTU3+1qTejOxHZW6zZl\n CyDg==",
        "X-Google-DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=1e100.net; s=20161025;\n h=x-gm-message-state:from:to:cc:subject:date:message-id;\n bh=Q6uxIP1KLpWJpyh83MKF7dN9YDCkZrW+VQxRtS3muGA=;\n b=OdXrpztTJJxe8HUCCdW5SUUzwGhEgXYOOSzgXDNqSeCCPb2vF3+1k20Qtv+bvxJs+g\n rKjcFs9iOAGXv1YkpIcPv+0ntVlOSjw9N0mcfdw5JA5jrEH9Bk3Nifsu3WksIjwRdYz8\n eLUMjocD6ZOZFmThCuryrogze5ykjUWnbNp3jWwKZi++7u0fL/aNanWsHjMFBmD982zE\n 04d/MhnZJQi/ho/KXdstukYkZy9pEzeWnLO2MuLye3Xzo2ELE686C/9ZqAV0ECgqcTEg\n 3XnYL3meyuQ1VSNJzEXbhUJa8JA22DEtp/wxSUe3is3/vdNlH7eePXduVs2aPx+kesuo\n G39Q==",
        "X-Gm-Message-State": "AOAM531bOYCiDv6oHuSUlkw0OjW7tZL76CNaJnG1ncJA4IfeXDMjDu4D\n PQZjMbFesMmLhYDJJRTQrF2HUA==",
        "X-Google-Smtp-Source": "\n ABdhPJyyNP6EIZfV4BRC4qA2bHZIqn8yNleBDEPS6WVbQ5K017s60Ad91G/e70+e+MKPMKvAxPBbaw==",
        "X-Received": "by 2002:a1c:9cc9:: with SMTP id\n f192mr4328073wme.143.1606221204886;\n Tue, 24 Nov 2020 04:33:24 -0800 (PST)",
        "From": "Ibtisam Tariq <ibtisam.tariq@emumba.com>",
        "To": "maxime.coquelin@redhat.com, chenbo.xia@intel.com,\n cristian.dumitrescu@intel.com, jasvinder.singh@intel.com,\n john.mcnamara@intel.com, reshma.pattan@intel.com,\n konstantin.ananyev@intel.com, marko.kovacevic@intel.com",
        "Cc": "dev@dpdk.org,\n\tIbtisam Tariq <ibtisam.tariq@emumba.com>",
        "Date": "Tue, 24 Nov 2020 12:32:43 +0000",
        "Message-Id": "<20201124123249.14451-1-ibtisam.tariq@emumba.com>",
        "X-Mailer": "git-send-email 2.17.1",
        "Subject": "[dpdk-dev] [PATCH 1/7] examples/fips_validation: enhance\n\tgetopt_long usage",
        "X-BeenThere": "dev@dpdk.org",
        "X-Mailman-Version": "2.1.15",
        "Precedence": "list",
        "List-Id": "DPDK patches and discussions <dev.dpdk.org>",
        "List-Unsubscribe": "<https://mails.dpdk.org/options/dev>,\n <mailto:dev-request@dpdk.org?subject=unsubscribe>",
        "List-Archive": "<http://mails.dpdk.org/archives/dev/>",
        "List-Post": "<mailto:dev@dpdk.org>",
        "List-Help": "<mailto:dev-request@dpdk.org?subject=help>",
        "List-Subscribe": "<https://mails.dpdk.org/listinfo/dev>,\n <mailto:dev-request@dpdk.org?subject=subscribe>",
        "Errors-To": "dev-bounces@dpdk.org",
        "Sender": "\"dev\" <dev-bounces@dpdk.org>"
    },
    "content": "Instead of using getopt_long return value, strcmp was used to\ncompare the input parameters with the struct option array. This\npatch get rid of all those strcmp by directly binding each longopt\nwith an int enum. This is to improve readability and consistency in\nall examples.\n\nBugzilla ID: 238\nCc: marko.kovacevic@intel.com\n\nReported-by: David Marchand <david.marchand@redhat.com>\nSigned-off-by: Ibtisam Tariq <ibtisam.tariq@emumba.com>\n---\nv3:\n* None.\n\nv2:\n* Added parser_read_uint16 function to remove extra variable.\n* Remove extra indentations.\n* Remove extra block brackets in switch statement.\n* Replace the pre-processor with actual value, if it used once.\n* Change enum names to start with OPT_ and remove KEYWORD from enum names.\n\nv1:\n* enhance getopt_long usage.\n---\n examples/fips_validation/fips_validation.c |  16 ++\n examples/fips_validation/fips_validation.h |   3 +\n examples/fips_validation/main.c            | 253 +++++++++++----------\n 3 files changed, 157 insertions(+), 115 deletions(-)",
    "diff": "diff --git a/examples/fips_validation/fips_validation.c b/examples/fips_validation/fips_validation.c\nindex 4c3ed80c8..52a7bf952 100644\n--- a/examples/fips_validation/fips_validation.c\n+++ b/examples/fips_validation/fips_validation.c\n@@ -650,6 +650,22 @@ parser_read_uint32(uint32_t *value, char *p)\n \treturn 0;\n }\n \n+int\n+parser_read_uint16(uint16_t *value, const char *p)\n+{\n+\tuint64_t val = 0;\n+\tint ret = parser_read_uint64(&val, p);\n+\n+\tif (ret < 0)\n+\t\treturn ret;\n+\n+\tif (val > UINT16_MAX)\n+\t\treturn -ERANGE;\n+\n+\t*value = val;\n+\treturn 0;\n+}\n+\n void\n parse_write_hex_str(struct fips_val *src)\n {\ndiff --git a/examples/fips_validation/fips_validation.h b/examples/fips_validation/fips_validation.h\nindex 8396932f9..6cda4e0bd 100644\n--- a/examples/fips_validation/fips_validation.h\n+++ b/examples/fips_validation/fips_validation.h\n@@ -257,6 +257,9 @@ parser_read_uint32(uint32_t *value, char *p);\n int\n parser_read_uint32_val(const char *key, char *src, struct fips_val *val);\n \n+int\n+parser_read_uint16(uint16_t *value, const char *p);\n+\n int\n writeback_hex_str(const char *key, char *dst, struct fips_val *val);\n \ndiff --git a/examples/fips_validation/main.c b/examples/fips_validation/main.c\nindex cad6bcb18..36ed4b546 100644\n--- a/examples/fips_validation/main.c\n+++ b/examples/fips_validation/main.c\n@@ -15,17 +15,26 @@\n #include \"fips_validation.h\"\n #include \"fips_dev_self_test.h\"\n \n-#define REQ_FILE_PATH_KEYWORD\t\"req-file\"\n-#define RSP_FILE_PATH_KEYWORD\t\"rsp-file\"\n-#define MBUF_DATAROOM_KEYWORD\t\"mbuf-dataroom\"\n-#define FOLDER_KEYWORD\t\t\"path-is-folder\"\n-#define CRYPTODEV_KEYWORD\t\"cryptodev\"\n-#define CRYPTODEV_ID_KEYWORD\t\"cryptodev-id\"\n-#define CRYPTODEV_ST_KEYWORD\t\"self-test\"\n-#define CRYPTODEV_BK_ID_KEYWORD\t\"broken-test-id\"\n-#define CRYPTODEV_BK_DIR_KEY\t\"broken-test-dir\"\n-#define CRYPTODEV_ENC_KEYWORD\t\"enc\"\n-#define CRYPTODEV_DEC_KEYWORD\t\"dec\"\n+enum {\n+#define OPT_REQ_FILE_PATH\t\"req-file\"\n+\tOPT_REQ_FILE_PATH_NUM = 256,\n+#define OPT_RSP_FILE_PATH\t\"rsp-file\"\n+\tOPT_RSP_FILE_PATH_NUM,\n+#define OPT_MBUF_DATAROOM\t\"mbuf-dataroom\"\n+\tOPT_MBUF_DATAROOM_NUM,\n+#define OPT_FOLDER\t\t    \"path-is-folder\"\n+\tOPT_FOLDER_NUM,\n+#define OPT_CRYPTODEV\t    \"cryptodev\"\n+\tOPT_CRYPTODEV_NUM,\n+#define OPT_CRYPTODEV_ID\t\"cryptodev-id\"\n+\tOPT_CRYPTODEV_ID_NUM,\n+#define OPT_CRYPTODEV_ST\t\"self-test\"\n+\tOPT_CRYPTODEV_ST_NUM,\n+#define OPT_CRYPTODEV_BK_ID\t\"broken-test-id\"\n+\tOPT_CRYPTODEV_BK_ID_NUM,\n+#define OPT_CRYPTODEV_BK_DIR_KEY\t\"broken-test-dir\"\n+\tOPT_CRYPTODEV_BK_DIR_KEY_NUM,\n+};\n \n struct fips_test_vector vec;\n struct fips_test_interim_info info;\n@@ -212,10 +221,10 @@ cryptodev_fips_validate_usage(const char *prgname)\n \t\t\"  --%s: self test indicator\\n\"\n \t\t\"  --%s: self broken test ID\\n\"\n \t\t\"  --%s: self broken test direction\\n\",\n-\t\tprgname, REQ_FILE_PATH_KEYWORD, RSP_FILE_PATH_KEYWORD,\n-\t\tFOLDER_KEYWORD, MBUF_DATAROOM_KEYWORD, def_mbuf_seg_size,\n-\t\tCRYPTODEV_KEYWORD, CRYPTODEV_ID_KEYWORD, CRYPTODEV_ST_KEYWORD,\n-\t\tCRYPTODEV_BK_ID_KEYWORD, CRYPTODEV_BK_DIR_KEY);\n+\t\tprgname, OPT_REQ_FILE_PATH, OPT_RSP_FILE_PATH,\n+\t\tOPT_FOLDER, OPT_MBUF_DATAROOM, def_mbuf_seg_size,\n+\t\tOPT_CRYPTODEV, OPT_CRYPTODEV_ID, OPT_CRYPTODEV_ST,\n+\t\tOPT_CRYPTODEV_BK_ID, OPT_CRYPTODEV_BK_DIR_KEY);\n }\n \n static int\n@@ -226,16 +235,25 @@ cryptodev_fips_validate_parse_args(int argc, char **argv)\n \tchar **argvopt;\n \tint option_index;\n \tstruct option lgopts[] = {\n-\t\t\t{REQ_FILE_PATH_KEYWORD, required_argument, 0, 0},\n-\t\t\t{RSP_FILE_PATH_KEYWORD, required_argument, 0, 0},\n-\t\t\t{FOLDER_KEYWORD, no_argument, 0, 0},\n-\t\t\t{MBUF_DATAROOM_KEYWORD, required_argument, 0, 0},\n-\t\t\t{CRYPTODEV_KEYWORD, required_argument, 0, 0},\n-\t\t\t{CRYPTODEV_ID_KEYWORD, required_argument, 0, 0},\n-\t\t\t{CRYPTODEV_ST_KEYWORD, no_argument, 0, 0},\n-\t\t\t{CRYPTODEV_BK_ID_KEYWORD, required_argument, 0, 0},\n-\t\t\t{CRYPTODEV_BK_DIR_KEY, required_argument, 0, 0},\n-\t\t\t{NULL, 0, 0, 0}\n+\t\t{OPT_REQ_FILE_PATH, required_argument,\n+\t\t\t\tNULL, OPT_REQ_FILE_PATH_NUM},\n+\t\t{OPT_RSP_FILE_PATH, required_argument,\n+\t\t\t\tNULL, OPT_RSP_FILE_PATH_NUM},\n+\t\t{OPT_FOLDER, no_argument,\n+\t\t\t\tNULL, OPT_FOLDER_NUM},\n+\t\t{OPT_MBUF_DATAROOM, required_argument,\n+\t\t\t\tNULL, OPT_MBUF_DATAROOM_NUM},\n+\t\t{OPT_CRYPTODEV, required_argument,\n+\t\t\t\tNULL, OPT_CRYPTODEV_NUM},\n+\t\t{OPT_CRYPTODEV_ID, required_argument,\n+\t\t\t\tNULL, OPT_CRYPTODEV_ID_NUM},\n+\t\t{OPT_CRYPTODEV_ST, no_argument,\n+\t\t\t\tNULL, OPT_CRYPTODEV_ST_NUM},\n+\t\t{OPT_CRYPTODEV_BK_ID, required_argument,\n+\t\t\t\tNULL, OPT_CRYPTODEV_BK_ID_NUM},\n+\t\t{OPT_CRYPTODEV_BK_DIR_KEY, required_argument,\n+\t\t\t\tNULL, OPT_CRYPTODEV_BK_DIR_KEY_NUM},\n+\t\t{NULL, 0, 0, 0}\n \t};\n \n \targvopt = argv;\n@@ -248,108 +266,113 @@ cryptodev_fips_validate_parse_args(int argc, char **argv)\n \t\treturn -EINVAL;\n \t}\n \n-\twhile ((opt = getopt_long(argc, argvopt, \"s:\",\n+\twhile ((opt = getopt_long(argc, argvopt, \"\",\n \t\t\t\t  lgopts, &option_index)) != EOF) {\n \n+\t\tif (opt == '?') {\n+\t\t\tcryptodev_fips_validate_usage(prgname);\n+\t\t\treturn -1;\n+\t\t}\n+\n \t\tswitch (opt) {\n-\t\tcase 0:\n-\t\t\tif (strcmp(lgopts[option_index].name,\n-\t\t\t\t\tREQ_FILE_PATH_KEYWORD) == 0)\n-\t\t\t\tenv.req_path = optarg;\n-\t\t\telse if (strcmp(lgopts[option_index].name,\n-\t\t\t\t\tRSP_FILE_PATH_KEYWORD) == 0)\n-\t\t\t\tenv.rsp_path = optarg;\n-\t\t\telse if (strcmp(lgopts[option_index].name,\n-\t\t\t\t\tFOLDER_KEYWORD) == 0)\n-\t\t\t\tenv.is_path_folder = 1;\n-\t\t\telse if (strcmp(lgopts[option_index].name,\n-\t\t\t\t\tCRYPTODEV_KEYWORD) == 0) {\n-\t\t\t\tret = parse_cryptodev_arg(optarg);\n-\t\t\t\tif (ret < 0) {\n-\t\t\t\t\tcryptodev_fips_validate_usage(prgname);\n-\t\t\t\t\treturn -EINVAL;\n-\t\t\t\t}\n-\t\t\t} else if (strcmp(lgopts[option_index].name,\n-\t\t\t\t\tCRYPTODEV_ID_KEYWORD) == 0) {\n-\t\t\t\tret = parse_cryptodev_id_arg(optarg);\n-\t\t\t\tif (ret < 0) {\n-\t\t\t\t\tcryptodev_fips_validate_usage(prgname);\n-\t\t\t\t\treturn -EINVAL;\n-\t\t\t\t}\n-\t\t\t} else if (strcmp(lgopts[option_index].name,\n-\t\t\t\t\tCRYPTODEV_ST_KEYWORD) == 0) {\n-\t\t\t\tenv.self_test = 1;\n-\t\t\t} else if (strcmp(lgopts[option_index].name,\n-\t\t\t\t\tCRYPTODEV_BK_ID_KEYWORD) == 0) {\n-\t\t\t\tif (!env.broken_test_config) {\n-\t\t\t\t\tenv.broken_test_config = rte_malloc(\n-\t\t\t\t\t\tNULL,\n-\t\t\t\t\t\tsizeof(*env.broken_test_config),\n-\t\t\t\t\t\t0);\n-\t\t\t\t\tif (!env.broken_test_config)\n-\t\t\t\t\t\treturn -ENOMEM;\n-\n-\t\t\t\t\tenv.broken_test_config->expect_fail_dir =\n-\t\t\t\t\t\tself_test_dir_enc_auth_gen;\n-\t\t\t\t}\n+\t\tcase OPT_REQ_FILE_PATH_NUM:\n+\t\t\tenv.req_path = optarg;\n+\t\t\tbreak;\n \n-\t\t\t\tif (parser_read_uint32(\n-\t\t\t\t\t&env.broken_test_config->expect_fail_test_idx,\n-\t\t\t\t\t\toptarg) < 0) {\n-\t\t\t\t\trte_free(env.broken_test_config);\n-\t\t\t\t\tcryptodev_fips_validate_usage(prgname);\n-\t\t\t\t\treturn -EINVAL;\n-\t\t\t\t}\n-\t\t\t} else if (strcmp(lgopts[option_index].name,\n-\t\t\t\t\tCRYPTODEV_BK_DIR_KEY) == 0) {\n-\t\t\t\tif (!env.broken_test_config) {\n-\t\t\t\t\tenv.broken_test_config = rte_malloc(\n-\t\t\t\t\t\tNULL,\n-\t\t\t\t\t\tsizeof(*env.broken_test_config),\n-\t\t\t\t\t\t0);\n-\t\t\t\t\tif (!env.broken_test_config)\n-\t\t\t\t\t\treturn -ENOMEM;\n-\n-\t\t\t\t\tenv.broken_test_config->\n-\t\t\t\t\t\texpect_fail_test_idx = 0;\n-\t\t\t\t}\n+\t\tcase OPT_RSP_FILE_PATH_NUM:\n+\t\t\tenv.rsp_path = optarg;\n+\t\t\tbreak;\n \n-\t\t\t\tif (strcmp(optarg, CRYPTODEV_ENC_KEYWORD) == 0)\n-\t\t\t\t\tenv.broken_test_config->expect_fail_dir =\n-\t\t\t\t\t\tself_test_dir_enc_auth_gen;\n-\t\t\t\telse if (strcmp(optarg, CRYPTODEV_DEC_KEYWORD)\n-\t\t\t\t\t\t== 0)\n-\t\t\t\t\tenv.broken_test_config->expect_fail_dir =\n-\t\t\t\t\t\tself_test_dir_dec_auth_verify;\n-\t\t\t\telse {\n-\t\t\t\t\trte_free(env.broken_test_config);\n-\t\t\t\t\tcryptodev_fips_validate_usage(prgname);\n-\t\t\t\t\treturn -EINVAL;\n-\t\t\t\t}\n-\t\t\t} else if (strcmp(lgopts[option_index].name,\n-\t\t\t\t\tMBUF_DATAROOM_KEYWORD) == 0) {\n-\t\t\t\tuint32_t data_room_size;\n-\n-\t\t\t\tif (parser_read_uint32(&data_room_size,\n-\t\t\t\t\t\toptarg) < 0) {\n-\t\t\t\t\tcryptodev_fips_validate_usage(prgname);\n-\t\t\t\t\treturn -EINVAL;\n-\t\t\t\t}\n+\t\tcase OPT_FOLDER_NUM:\n+\t\t\tenv.is_path_folder = 1;\n+\t\t\tbreak;\n \n-\t\t\t\tif (data_room_size == 0 ||\n-\t\t\t\t\t\tdata_room_size > UINT16_MAX) {\n-\t\t\t\t\tcryptodev_fips_validate_usage(prgname);\n-\t\t\t\t\treturn -EINVAL;\n-\t\t\t\t}\n+\t\tcase OPT_CRYPTODEV_NUM:\n+\t\t\tret = parse_cryptodev_arg(optarg);\n+\t\t\tif (ret < 0) {\n+\t\t\t\tcryptodev_fips_validate_usage(prgname);\n+\t\t\t\treturn -EINVAL;\n+\t\t\t}\n+\t\t\tbreak;\n \n-\t\t\t\tenv.mbuf_data_room = data_room_size;\n-\t\t\t} else {\n+\t\tcase OPT_CRYPTODEV_ID_NUM:\n+\t\t\tret = parse_cryptodev_id_arg(optarg);\n+\t\t\tif (ret < 0) {\n \t\t\t\tcryptodev_fips_validate_usage(prgname);\n \t\t\t\treturn -EINVAL;\n \t\t\t}\n \t\t\tbreak;\n+\n+\t\tcase OPT_CRYPTODEV_ST_NUM:\n+\t\t\tenv.self_test = 1;\n+\t\t\tbreak;\n+\n+\t\tcase OPT_CRYPTODEV_BK_ID_NUM:\n+\t\t\tif (!env.broken_test_config) {\n+\t\t\t\tenv.broken_test_config = rte_malloc(\n+\t\t\t\t\tNULL,\n+\t\t\t\t\tsizeof(*env.broken_test_config),\n+\t\t\t\t\t0);\n+\t\t\t\tif (!env.broken_test_config)\n+\t\t\t\t\treturn -ENOMEM;\n+\n+\t\t\t\tenv.broken_test_config->expect_fail_dir =\n+\t\t\t\t\tself_test_dir_enc_auth_gen;\n+\t\t\t}\n+\n+\t\t\tif (parser_read_uint32(\n+\t\t\t\t&env.broken_test_config->expect_fail_test_idx,\n+\t\t\t\t\toptarg) < 0) {\n+\t\t\t\trte_free(env.broken_test_config);\n+\t\t\t\tcryptodev_fips_validate_usage(prgname);\n+\t\t\t\treturn -EINVAL;\n+\t\t\t}\n+\t\t\tbreak;\n+\n+\t\tcase OPT_CRYPTODEV_BK_DIR_KEY_NUM:\n+\t\t\tif (!env.broken_test_config) {\n+\t\t\t\tenv.broken_test_config = rte_malloc(\n+\t\t\t\t\tNULL,\n+\t\t\t\t\tsizeof(*env.broken_test_config),\n+\t\t\t\t\t0);\n+\t\t\t\tif (!env.broken_test_config)\n+\t\t\t\t\treturn -ENOMEM;\n+\n+\t\t\t\tenv.broken_test_config->expect_fail_test_idx =\n+\t\t\t\t\t0;\n+\t\t\t}\n+\n+\t\t\tif (strcmp(optarg, \"enc\") == 0)\n+\t\t\t\tenv.broken_test_config->expect_fail_dir =\n+\t\t\t\t\tself_test_dir_enc_auth_gen;\n+\t\t\telse if (strcmp(optarg, \"dec\")\n+\t\t\t\t\t== 0)\n+\t\t\t\tenv.broken_test_config->expect_fail_dir =\n+\t\t\t\t\tself_test_dir_dec_auth_verify;\n+\t\t\telse {\n+\t\t\t\trte_free(env.broken_test_config);\n+\t\t\t\tcryptodev_fips_validate_usage(prgname);\n+\t\t\t\treturn -EINVAL;\n+\t\t\t}\n+\t\t\tbreak;\n+\n+\n+\t\tcase OPT_MBUF_DATAROOM_NUM:\n+\t\t\tif (parser_read_uint16(&env.mbuf_data_room,\n+\t\t\t\t\toptarg) < 0) {\n+\t\t\t\tcryptodev_fips_validate_usage(prgname);\n+\t\t\t\treturn -EINVAL;\n+\t\t\t}\n+\n+\t\t\tif (env.mbuf_data_room == 0) {\n+\t\t\t\tcryptodev_fips_validate_usage(prgname);\n+\t\t\t\treturn -EINVAL;\n+\t\t\t}\n+\t\t\tbreak;\n+\n \t\tdefault:\n-\t\t\treturn -1;\n+\t\t\tcryptodev_fips_validate_usage(prgname);\n+\t\t\treturn -EINVAL;\n \t\t}\n \t}\n \n",
    "prefixes": [
        "1/7"
    ]
}