tor-browser

The Tor Browser
git clone https://git.dasho.dev/tor-browser.git
Log | Files | Refs | README | LICENSE

sha1_driver.c (16388B)


      1 /*
      2 * sha1_driver.c
      3 *
      4 * a test driver for SHA-1
      5 *
      6 * David A. McGrew
      7 * Cisco Systems, Inc.
      8 */
      9 
     10 /*
     11 *
     12 * Copyright (c) 2001-2017, Cisco Systems, Inc.
     13 * All rights reserved.
     14 *
     15 * Redistribution and use in source and binary forms, with or without
     16 * modification, are permitted provided that the following conditions
     17 * are met:
     18 *
     19 *   Redistributions of source code must retain the above copyright
     20 *   notice, this list of conditions and the following disclaimer.
     21 *
     22 *   Redistributions in binary form must reproduce the above
     23 *   copyright notice, this list of conditions and the following
     24 *   disclaimer in the documentation and/or other materials provided
     25 *   with the distribution.
     26 *
     27 *   Neither the name of the Cisco Systems, Inc. nor the names of its
     28 *   contributors may be used to endorse or promote products derived
     29 *   from this software without specific prior written permission.
     30 *
     31 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
     32 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
     33 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
     34 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
     35 * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
     36 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
     37 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
     38 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     39 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
     40 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     41 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
     42 * OF THE POSSIBILITY OF SUCH DAMAGE.
     43 *
     44 */
     45 
     46 #ifdef HAVE_CONFIG_H
     47 #include <config.h>
     48 #endif
     49 
     50 #include <stdio.h>
     51 #include <string.h>
     52 #include "sha1.h"
     53 #include "util.h"
     54 
     55 #define SHA_PASS 0
     56 #define SHA_FAIL 1
     57 
     58 #define MAX_HASH_DATA_LEN 1024
     59 #define MAX_HASH_OUT_LEN 20
     60 
     61 typedef struct hash_test_case_t {
     62    unsigned data_len;               /* number of octets in data        */
     63    unsigned hash_len;               /* number of octets output by hash */
     64    uint8_t data[MAX_HASH_DATA_LEN]; /* message data                    */
     65    uint8_t hash[MAX_HASH_OUT_LEN];  /* expected hash output            */
     66    struct hash_test_case_t *next_test_case;
     67 } hash_test_case_t;
     68 
     69 hash_test_case_t *sha1_test_case_list;
     70 
     71 srtp_err_status_t hash_test_case_add(hash_test_case_t **list_ptr,
     72                                     char *hex_data,
     73                                     unsigned data_len,
     74                                     char *hex_hash,
     75                                     unsigned hash_len)
     76 {
     77    hash_test_case_t *list_head = *list_ptr;
     78    hash_test_case_t *test_case;
     79    unsigned tmp_len;
     80 
     81    test_case = malloc(sizeof(hash_test_case_t));
     82    if (test_case == NULL)
     83        return srtp_err_status_alloc_fail;
     84 
     85    tmp_len = hex_string_to_octet_string((char *)test_case->data, hex_data,
     86                                         data_len * 2);
     87    if (tmp_len != data_len * 2) {
     88        free(test_case);
     89        return srtp_err_status_parse_err;
     90    }
     91 
     92    tmp_len = hex_string_to_octet_string((char *)test_case->hash, hex_hash,
     93                                         hash_len * 2);
     94    if (tmp_len != hash_len * 2) {
     95        free(test_case);
     96        return srtp_err_status_parse_err;
     97    }
     98 
     99    test_case->data_len = data_len;
    100    test_case->hash_len = hash_len;
    101 
    102    /* add the new test case to the head of the list */
    103    test_case->next_test_case = list_head;
    104    *list_ptr = test_case;
    105 
    106    return srtp_err_status_ok;
    107 }
    108 
    109 srtp_err_status_t sha1_test_case_validate(const hash_test_case_t *test_case)
    110 {
    111    srtp_sha1_ctx_t ctx;
    112    uint32_t hash_value[5];
    113 
    114    if (test_case == NULL)
    115        return srtp_err_status_bad_param;
    116 
    117    if (test_case->hash_len != 20)
    118        return srtp_err_status_bad_param;
    119    if (test_case->data_len > MAX_HASH_DATA_LEN)
    120        return srtp_err_status_bad_param;
    121 
    122    srtp_sha1_init(&ctx);
    123    srtp_sha1_update(&ctx, test_case->data, test_case->data_len);
    124    srtp_sha1_final(&ctx, hash_value);
    125    if (0 == memcmp(test_case->hash, hash_value, 20)) {
    126 #if VERBOSE
    127        printf("PASSED: reference value: %s\n",
    128               octet_string_hex_string((const uint8_t *)test_case->hash, 20));
    129        printf("PASSED: computed value:  %s\n",
    130               octet_string_hex_string((const uint8_t *)hash_value, 20));
    131 #endif
    132        return srtp_err_status_ok;
    133    }
    134 
    135    printf("reference value: %s\n",
    136           octet_string_hex_string((const uint8_t *)test_case->hash, 20));
    137    printf("computed value:  %s\n",
    138           octet_string_hex_string((const uint8_t *)hash_value, 20));
    139 
    140    return srtp_err_status_algo_fail;
    141 }
    142 
    143 struct hex_sha1_test_case_t {
    144    unsigned bit_len;
    145    char hex_data[MAX_HASH_DATA_LEN * 2];
    146    char hex_hash[40 + 1];
    147 };
    148 
    149 srtp_err_status_t sha1_add_test_cases(void)
    150 {
    151    int i;
    152    srtp_err_status_t err;
    153 
    154    /*
    155     * these test cases are taken from the "SHA-1 Sample Vectors"
    156     * provided by NIST at http://csrc.nist.gov/cryptval/shs.html
    157     */
    158 
    159    struct hex_sha1_test_case_t tc[] = {
    160        { 0, "", "da39a3ee5e6b4b0d3255bfef95601890afd80709" },
    161        { 8, "a8", "99f2aa95e36f95c2acb0eaf23998f030638f3f15" },
    162        { 16, "3000", "f944dcd635f9801f7ac90a407fbc479964dec024" },
    163        { 24, "42749e", "a444319e9b6cc1e8464c511ec0969c37d6bb2619" },
    164        { 32, "9fc3fe08", "16a0ff84fcc156fd5d3ca3a744f20a232d172253" },
    165        { 40, "b5c1c6f1af", "fec9deebfcdedaf66dda525e1be43597a73a1f93" },
    166        { 48, "e47571e5022e", "8ce051181f0ed5e9d0c498f6bc4caf448d20deb5" },
    167        { 56, "3e1b28839fb758", "67da53837d89e03bf652ef09c369a3415937cfd3" },
    168        { 64, "a81350cbb224cb90", "305e4ff9888ad855a78573cddf4c5640cce7e946" },
    169        { 72, "c243d167923dec3ce1",
    170          "5902b77b3265f023f9bbc396ba1a93fa3509bde7" },
    171        { 80, "50ac18c59d6a37a29bf4",
    172          "fcade5f5d156bf6f9af97bdfa9c19bccfb4ff6ab" },
    173        { 88, "98e2b611ad3b1cccf634f6",
    174          "1d20fbe00533c10e3cbd6b27088a5de0c632c4b5" },
    175        { 96, "73fe9afb68e1e8712e5d4eec",
    176          "7e1b7e0f7a8f3455a9c03e9580fd63ae205a2d93" },
    177        { 104, "9e701ed7d412a9226a2a130e66",
    178          "706f0677146307b20bb0e8d6311e329966884d13" },
    179        { 112, "6d3ee90413b0a7cbf69e5e6144ca",
    180          "a7241a703aaf0d53fe142f86bf2e849251fa8dff" },
    181        { 120, "fae24d56514efcb530fd4802f5e71f",
    182          "400f53546916d33ad01a5e6df66822dfbdc4e9e6" },
    183        { 128, "c5a22dd6eda3fe2bdc4ddb3ce6b35fd1",
    184          "fac8ab93c1ae6c16f0311872b984f729dc928ccd" },
    185        { 136, "d98cded2adabf08fda356445c781802d95",
    186          "fba6d750c18da58f6e2aab10112b9a5ef3301b3b" },
    187        { 144, "bcc6d7087a84f00103ccb32e5f5487a751a2",
    188          "29d27c2d44c205c8107f0351b05753ac708226b6" },
    189        { 152, "36ecacb1055434190dbbc556c48bafcb0feb0d",
    190          "b971bfc1ebd6f359e8d74cb7ecfe7f898d0ba845" },
    191        { 160, "5ff9edb69e8f6bbd498eb4537580b7fba7ad31d0",
    192          "96d08c430094b9fcc164ad2fb6f72d0a24268f68" },
    193        { 168, "c95b441d8270822a46a798fae5defcf7b26abace36",
    194          "a287ea752a593d5209e287881a09c49fa3f0beb1" },
    195        { 176, "83104c1d8a55b28f906f1b72cb53f68cbb097b44f860",
    196          "a06c713779cbd88519ed4a585ac0cb8a5e9d612b" },
    197        { 184, "755175528d55c39c56493d697b790f099a5ce741f7754b",
    198          "bff7d52c13a3688132a1d407b1ab40f5b5ace298" },
    199        { 192, "088fc38128bbdb9fd7d65228b3184b3faac6c8715f07272f",
    200          "c7566b91d7b6f56bdfcaa9781a7b6841aacb17e9" },
    201        { 200, "a4a586eb9245a6c87e3adf1009ac8a49f46c07e14185016895",
    202          "ffa30c0b5c550ea4b1e34f8a60ec9295a1e06ac1" },
    203        { 208, "8e7c555270c006092c2a3189e2a526b873e2e269f0fb28245256",
    204          "29e66ed23e914351e872aa761df6e4f1a07f4b81" },
    205        { 216, "a5f3bfa6bb0ba3b59f6b9cbdef8a558ec565e8aa3121f405e7f2f0",
    206          "b28cf5e5b806a01491d41f69bd9248765c5dc292" },
    207        { 224, "589054f0d2bd3c2c85b466bfd8ce18e6ec3e0b87d944cd093ba36469",
    208          "60224fb72c46069652cd78bcd08029ef64da62f3" },
    209        { 232, "a0abb12083b5bbc78128601bf1cbdbc0fdf4b862b24d899953d8da0ff3",
    210          "b72c4a86f72608f24c05f3b9088ef92fba431df7" },
    211        { 240, "82143f4cea6fadbf998e128a8811dc75301cf1db4f079501ea568da68eeb",
    212          "73779ad5d6b71b9b8328ef7220ff12eb167076ac" },
    213        { 248, "9f1231dd6df1ff7bc0b0d4f989d048672683ce35d956d2f57913046267e6f3",
    214          "a09671d4452d7cf50015c914a1e31973d20cc1a0" },
    215        { 256,
    216          "041c512b5eed791f80d3282f3a28df263bb1df95e1239a7650e5670fc2187919",
    217          "e88cdcd233d99184a6fd260b8fca1b7f7687aee0" },
    218        { 264,
    219          "17e81f6ae8c2e5579d69dafa6e070e7111461552d314b691e7a3e7a4feb3fae418",
    220          "010def22850deb1168d525e8c84c28116cb8a269" },
    221        { 272,
    222          "d15976b23a1d712ad28fad04d805f572026b54dd64961fda94d5355a0cc9862"
    223          "0cf77",
    224          "aeaa40ba1717ed5439b1e6ea901b294ba500f9ad" },
    225        { 280,
    226          "09fce4d434f6bd32a44e04b848ff50ec9f642a8a85b37a264dc73f130f22838"
    227          "443328f",
    228          "c6433791238795e34f080a5f1f1723f065463ca0" },
    229        { 288,
    230          "f17af27d776ec82a257d8d46d2b46b639462c56984cc1be9c1222eadb8b2659"
    231          "4a25c709d",
    232          "e21e22b89c1bb944a32932e6b2a2f20d491982c3" },
    233        { 296,
    234          "b13ce635d6f8758143ffb114f2f601cb20b6276951416a2f94fbf4ad081779d"
    235          "79f4f195b22",
    236          "575323a9661f5d28387964d2ba6ab92c17d05a8a" },
    237        { 304,
    238          "5498793f60916ff1c918dde572cdea76da8629ba4ead6d065de3dfb48de94d2"
    239          "34cc1c5002910",
    240          "feb44494af72f245bfe68e86c4d7986d57c11db7" },
    241        { 312,
    242          "498a1e0b39fa49582ae688cd715c86fbaf8a81b8b11b4d1594c49c902d197c8"
    243          "ba8a621fd6e3be5",
    244          "cff2290b3648ba2831b98dde436a72f9ebf51eee" },
    245        { 320,
    246          "3a36ae71521f9af628b3e34dcb0d4513f84c78ee49f10416a98857150b8b15c"
    247          "b5c83afb4b570376e",
    248          "9b4efe9d27b965905b0c3dab67b8d7c9ebacd56c" },
    249        { 328,
    250          "dcc76b40ae0ea3ba253e92ac50fcde791662c5b6c948538cffc2d95e9de99ca"
    251          "c34dfca38910db2678f",
    252          "afedb0ff156205bcd831cbdbda43db8b0588c113" },
    253        { 336,
    254          "5b5ec6ec4fd3ad9c4906f65c747fd4233c11a1736b6b228b92e90cddabb0c7c"
    255          "2fcf9716d3fad261dff33",
    256          "8deb1e858f88293a5e5e4d521a34b2a4efa70fc4" },
    257        { 344,
    258          "df48a37b29b1d6de4e94717d60cdb4293fcf170bba388bddf7a9035a15d433f"
    259          "20fd697c3e4c8b8c5f590ab",
    260          "95cbdac0f74afa69cebd0e5c7defbc6faf0cbeaf" },
    261        { 352,
    262          "1f179b3b82250a65e1b0aee949e218e2f45c7a8dbfd6ba08de05c55acfc226b"
    263          "48c68d7f7057e5675cd96fcfc",
    264          "f0307bcb92842e5ae0cd4f4f14f3df7f877fbef2" },
    265        { 360,
    266          "ee3d72da3a44d971578972a8e6780ce64941267e0f7d0179b214fa97855e179"
    267          "0e888e09fbe3a70412176cb3b54",
    268          "7b13bb0dbf14964bd63b133ac85e22100542ef55" },
    269        { 368,
    270          "d4d4c7843d312b30f610b3682254c8be96d5f6684503f8fbfbcd15774fc1b08"
    271          "4d3741afb8d24aaa8ab9c104f7258",
    272          "c314d2b6cf439be678d2a74e890d96cfac1c02ed" },
    273        { 376,
    274          "32c094944f5936a190a0877fb9178a7bf60ceae36fd530671c5b38c5dbd5e6a"
    275          "6c0d615c2ac8ad04b213cc589541cf6",
    276          "4d0be361e410b47a9d67d8ce0bb6a8e01c53c078" },
    277        { 384,
    278          "e5d3180c14bf27a5409fa12b104a8fd7e9639609bfde6ee82bbf9648be2546d"
    279          "29688a65e2e3f3da47a45ac14343c9c02",
    280          "e5353431ffae097f675cbf498869f6fbb6e1c9f2" },
    281        { 392,
    282          "e7b6e4b69f724327e41e1188a37f4fe38b1dba19cbf5a7311d6e32f1038e97a"
    283          "b506ee05aebebc1eed09fc0e357109818b9",
    284          "b8720a7068a085c018ab18961de2765aa6cd9ac4" },
    285        { 400,
    286          "bc880cb83b8ac68ef2fedc2da95e7677ce2aa18b0e2d8b322701f67af7d5e7a"
    287          "0d96e9e33326ccb7747cfff0852b961bfd475",
    288          "b0732181568543ba85f2b6da602b4b065d9931aa" },
    289        { 408,
    290          "235ea9c2ba7af25400f2e98a47a291b0bccdaad63faa2475721fda5510cc7da"
    291          "d814bce8dabb611790a6abe56030b798b75c944",
    292          "9c22674cf3222c3ba921672694aafee4ce67b96b" },
    293        { 416,
    294          "07e3e29fed63104b8410f323b975fd9fba53f636af8c4e68a53fb202ca35dd9"
    295          "ee07cb169ec5186292e44c27e5696a967f5e67709",
    296          "d128335f4cecca9066cdae08958ce656ff0b4cfc" },
    297        { 424,
    298          "65d2a1dd60a517eb27bfbf530cf6a5458f9d5f4730058bd9814379547f34241"
    299          "822bf67e6335a6d8b5ed06abf8841884c636a25733f",
    300          "0b67c57ac578de88a2ae055caeaec8bb9b0085a0" },
    301        { 432,
    302          "dcc86b3bd461615bab739d8daafac231c0f462e819ad29f9f14058f3ab5b759"
    303          "41d4241ea2f17ebb8a458831b37a9b16dead4a76a9b0e",
    304          "c766f912a89d4ccda88e0cce6a713ef5f178b596" },
    305        { 440,
    306          "4627d54f0568dc126b62a8c35fb46a9ac5024400f2995e51635636e1afc4373"
    307          "dbb848eb32df23914230560b82477e9c3572647a7f2bb92",
    308          "9aa3925a9dcb177b15ccff9b78e70cf344858779" },
    309        { 448,
    310          "ba531affd4381168ef24d8b275a84d9254c7f5cc55fded53aa8024b2c5c5c8a"
    311          "a7146fe1d1b83d62b70467e9a2e2cb67b3361830adbab28d7",
    312          "4811fa30042fc076acf37c8e2274d025307e5943" },
    313        { 456,
    314          "8764dcbcf89dcf4282eb644e3d568bdccb4b13508bfa7bfe0ffc05efd1390be"
    315          "22109969262992d377691eb4f77f3d59ea8466a74abf57b2ef4",
    316          "6743018450c9730761ee2b130df9b91c1e118150" },
    317        { 464,
    318          "497d9df9ddb554f3d17870b1a31986c1be277bc44feff713544217a9f579623"
    319          "d18b5ffae306c25a45521d2759a72c0459b58957255ab592f3be4",
    320          "71ad4a19d37d92a5e6ef3694ddbeb5aa61ada645" },
    321        { 472,
    322          "72c3c2e065aefa8d9f7a65229e818176eef05da83f835107ba90ec2e95472e7"
    323          "3e538f783b416c04654ba8909f26a12db6e5c4e376b7615e4a25819",
    324          "a7d9dc68dacefb7d6116186048cb355cc548e11d" },
    325        { 480,
    326          "7cc9894454d0055ab5069a33984e2f712bef7e3124960d33559f5f3b81906bb"
    327          "66fe64da13c153ca7f5cabc89667314c32c01036d12ecaf5f9a78de98",
    328          "142e429f0522ba5abf5131fa81df82d355b96909" },
    329        { 488,
    330          "74e8404d5a453c5f4d306f2cfa338ca65501c840ddab3fb82117933483afd69"
    331          "13c56aaf8a0a0a6b2a342fc3d9dc7599f4a850dfa15d06c61966d74ea59",
    332          "ef72db70dcbcab991e9637976c6faf00d22caae9" },
    333        { 496,
    334          "46fe5ed326c8fe376fcc92dc9e2714e2240d3253b105adfbb256ff7a19bc409"
    335          "75c604ad7c0071c4fd78a7cb64786e1bece548fa4833c04065fe593f6fb10",
    336          "f220a7457f4588d639dc21407c942e9843f8e26b" },
    337        { 504,
    338          "836dfa2524d621cf07c3d2908835de859e549d35030433c796b81272fd8bc03"
    339          "48e8ddbc7705a5ad1fdf2155b6bc48884ac0cd376925f069a37849c089c864"
    340          "5",
    341          "ddd2117b6e309c233ede85f962a0c2fc215e5c69" },
    342        { 512,
    343          "7e3a4c325cb9c52b88387f93d01ae86d42098f5efa7f9457388b5e74b6d28b2"
    344          "438d42d8b64703324d4aa25ab6aad153ae30cd2b2af4d5e5c00a8a2d0220c61"
    345          "16",
    346          "a3054427cdb13f164a610b348702724c808a0dcc" }
    347    };
    348 
    349    for (i = 0; i < 65; i++) {
    350        err = hash_test_case_add(&sha1_test_case_list, tc[i].hex_data,
    351                                 tc[i].bit_len / 8, tc[i].hex_hash, 20);
    352        if (err) {
    353            printf("error adding hash test case (code %d)\n", err);
    354            return err;
    355        }
    356    }
    357 
    358    return srtp_err_status_ok;
    359 }
    360 
    361 srtp_err_status_t sha1_dealloc_test_cases(void)
    362 {
    363    hash_test_case_t *t, *next;
    364 
    365    for (t = sha1_test_case_list; t != NULL; t = next) {
    366        next = t->next_test_case;
    367        free(t);
    368    }
    369 
    370    sha1_test_case_list = NULL;
    371 
    372    return srtp_err_status_ok;
    373 }
    374 
    375 srtp_err_status_t sha1_validate(void)
    376 {
    377    hash_test_case_t *test_case;
    378    srtp_err_status_t err;
    379 
    380    err = sha1_add_test_cases();
    381    if (err) {
    382        printf("error adding SHA1 test cases (error code %d)\n", err);
    383        return err;
    384    }
    385 
    386    if (sha1_test_case_list == NULL)
    387        return srtp_err_status_cant_check;
    388 
    389    test_case = sha1_test_case_list;
    390    while (test_case != NULL) {
    391        err = sha1_test_case_validate(test_case);
    392        if (err) {
    393            printf("error validating hash test case (error code %d)\n", err);
    394            return err;
    395        }
    396        test_case = test_case->next_test_case;
    397    }
    398 
    399    sha1_dealloc_test_cases();
    400 
    401    return srtp_err_status_ok;
    402 }
    403 
    404 int main(void)
    405 {
    406    srtp_err_status_t err;
    407 
    408    printf("sha1 test driver\n");
    409 
    410    err = sha1_validate();
    411    if (err) {
    412        printf("SHA1 did not pass validation testing\n");
    413        return 1;
    414    }
    415    printf("SHA1 passed validation tests\n");
    416 
    417    return 0;
    418 }