1*29316b9cSGordon Ross /* 2*29316b9cSGordon Ross * This file and its contents are supplied under the terms of the 3*29316b9cSGordon Ross * Common Development and Distribution License (), version 1.0. 4*29316b9cSGordon Ross * You may only use this file in accordance with the terms of version 5*29316b9cSGordon Ross * 1.0 of the CDDL. 6*29316b9cSGordon Ross * 7*29316b9cSGordon Ross * A full copy of the text of the CDDL should have accompanied this 8*29316b9cSGordon Ross * source. A copy of the CDDL is also available via the Internet at 9*29316b9cSGordon Ross * http://www.illumos.org/license/CDDL. 10*29316b9cSGordon Ross */ 11*29316b9cSGordon Ross 12*29316b9cSGordon Ross /* 13*29316b9cSGordon Ross * Copyright 2019 Joyent, Inc. 14*29316b9cSGordon Ross */ 15*29316b9cSGordon Ross 16*29316b9cSGordon Ross #include <sys/types.h> 17*29316b9cSGordon Ross 18*29316b9cSGordon Ross /* 19*29316b9cSGordon Ross * Test data from RFC2202 20*29316b9cSGordon Ross */ 21*29316b9cSGordon Ross 22*29316b9cSGordon Ross static uint8_t KEY0[] = { 23*29316b9cSGordon Ross 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 24*29316b9cSGordon Ross 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 25*29316b9cSGordon Ross 0x0b, 0x0b, 0x0b, 0x0b 26*29316b9cSGordon Ross }; 27*29316b9cSGordon Ross 28*29316b9cSGordon Ross /* "Hi There" */ 29*29316b9cSGordon Ross static uint8_t DATA0[] = { 0x48, 0x69, 0x20, 0x54, 0x68, 0x65, 0x72, 0x65 }; 30*29316b9cSGordon Ross 31*29316b9cSGordon Ross static uint8_t HMAC0[] = { 32*29316b9cSGordon Ross 0xb6, 0x17, 0x31, 0x86, 0x55, 0x05, 0x72, 0x64, 33*29316b9cSGordon Ross 0xe2, 0x8b, 0xc0, 0xb6, 0xfb, 0x37, 0x8c, 0x8e, 34*29316b9cSGordon Ross 0xf1, 0x46, 0xbe, 0x00 35*29316b9cSGordon Ross }; 36*29316b9cSGordon Ross 37*29316b9cSGordon Ross 38*29316b9cSGordon Ross /* "Jefe" */ 39*29316b9cSGordon Ross static uint8_t KEY1[] = { 0x4a, 0x65, 0x66, 0x65 }; 40*29316b9cSGordon Ross 41*29316b9cSGordon Ross /* "what do ya want for nothing?" */ 42*29316b9cSGordon Ross static uint8_t DATA1[] = { 43*29316b9cSGordon Ross 0x77, 0x68, 0x61, 0x74, 0x20, 0x64, 0x6f, 0x20, 44*29316b9cSGordon Ross 0x79, 0x61, 0x20, 0x77, 0x61, 0x6e, 0x74, 0x20, 45*29316b9cSGordon Ross 0x66, 0x6f, 0x72, 0x20, 0x6e, 0x6f, 0x74, 0x68, 46*29316b9cSGordon Ross 0x69, 0x6e, 0x67, 0x3f 47*29316b9cSGordon Ross }; 48*29316b9cSGordon Ross 49*29316b9cSGordon Ross static uint8_t HMAC1[] = { 50*29316b9cSGordon Ross 0xef, 0xfc, 0xdf, 0x6a, 0xe5, 0xeb, 0x2f, 0xa2, 51*29316b9cSGordon Ross 0xd2, 0x74, 0x16, 0xd5, 0xf1, 0x84, 0xdf, 0x9c, 52*29316b9cSGordon Ross 0x25, 0x9a, 0x7c, 0x79 53*29316b9cSGordon Ross }; 54*29316b9cSGordon Ross 55*29316b9cSGordon Ross 56*29316b9cSGordon Ross static uint8_t KEY2[] = { 57*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 58*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 59*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa 60*29316b9cSGordon Ross }; 61*29316b9cSGordon Ross 62*29316b9cSGordon Ross static uint8_t DATA2[] = { 63*29316b9cSGordon Ross 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 64*29316b9cSGordon Ross 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 65*29316b9cSGordon Ross 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 66*29316b9cSGordon Ross 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 67*29316b9cSGordon Ross 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 68*29316b9cSGordon Ross 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 69*29316b9cSGordon Ross 0xdd, 0xdd 70*29316b9cSGordon Ross }; 71*29316b9cSGordon Ross 72*29316b9cSGordon Ross static uint8_t HMAC2[] = { 73*29316b9cSGordon Ross 0x12, 0x5d, 0x73, 0x42, 0xb9, 0xac, 0x11, 0xcd, 74*29316b9cSGordon Ross 0x91, 0xa3, 0x9a, 0xf4, 0x8a, 0xa1, 0x7b, 0x4f, 75*29316b9cSGordon Ross 0x63, 0xf1, 0x75, 0xd3 76*29316b9cSGordon Ross }; 77*29316b9cSGordon Ross 78*29316b9cSGordon Ross 79*29316b9cSGordon Ross static uint8_t KEY3[] = { 80*29316b9cSGordon Ross 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 81*29316b9cSGordon Ross 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 82*29316b9cSGordon Ross 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 83*29316b9cSGordon Ross 0x19 84*29316b9cSGordon Ross }; 85*29316b9cSGordon Ross 86*29316b9cSGordon Ross static uint8_t DATA3[] = { 87*29316b9cSGordon Ross 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 88*29316b9cSGordon Ross 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 89*29316b9cSGordon Ross 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 90*29316b9cSGordon Ross 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 91*29316b9cSGordon Ross 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 92*29316b9cSGordon Ross 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 93*29316b9cSGordon Ross 0xcd, 0xcd 94*29316b9cSGordon Ross }; 95*29316b9cSGordon Ross 96*29316b9cSGordon Ross static uint8_t HMAC3[] = { 97*29316b9cSGordon Ross 0x4c, 0x90, 0x07, 0xf4, 0x02, 0x62, 0x50, 0xc6, 98*29316b9cSGordon Ross 0xbc, 0x84, 0x14, 0xf9, 0xbf, 0x50, 0xc8, 0x6c, 99*29316b9cSGordon Ross 0x2d, 0x72, 0x35, 0xda 100*29316b9cSGordon Ross }; 101*29316b9cSGordon Ross 102*29316b9cSGordon Ross 103*29316b9cSGordon Ross static uint8_t KEY4[] = { 104*29316b9cSGordon Ross 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 105*29316b9cSGordon Ross 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 106*29316b9cSGordon Ross 0x0c, 0x0c, 0x0c, 0x0c 107*29316b9cSGordon Ross }; 108*29316b9cSGordon Ross 109*29316b9cSGordon Ross /* "Test With Truncation" */ 110*29316b9cSGordon Ross static uint8_t DATA4[] = { 111*29316b9cSGordon Ross 0x54, 0x65, 0x73, 0x74, 0x20, 0x57, 0x69, 0x74, 112*29316b9cSGordon Ross 0x68, 0x20, 0x54, 0x72, 0x75, 0x6e, 0x63, 0x61, 113*29316b9cSGordon Ross 0x74, 0x69, 0x6f, 0x6e 114*29316b9cSGordon Ross }; 115*29316b9cSGordon Ross 116*29316b9cSGordon Ross static uint8_t HMAC4[] = { 117*29316b9cSGordon Ross 0x4c, 0x1a, 0x03, 0x42, 0x4b, 0x55, 0xe0, 0x7f, 118*29316b9cSGordon Ross 0xe7, 0xf2, 0x7b, 0xe1, 0xd5, 0x8b, 0xb9, 0x32, 119*29316b9cSGordon Ross 0x4a, 0x9a, 0x5a, 0x04 120*29316b9cSGordon Ross }; 121*29316b9cSGordon Ross 122*29316b9cSGordon Ross 123*29316b9cSGordon Ross static uint8_t KEY5[] = { 124*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 125*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 126*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 127*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 128*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 129*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 130*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 131*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 132*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 133*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa 134*29316b9cSGordon Ross }; 135*29316b9cSGordon Ross 136*29316b9cSGordon Ross /* "Test Using Larger Than Block-Size Key - Hash Key First" */ 137*29316b9cSGordon Ross static uint8_t DATA5[] = { 138*29316b9cSGordon Ross 0x54, 0x65, 0x73, 0x74, 0x20, 0x55, 0x73, 0x69, 139*29316b9cSGordon Ross 0x6e, 0x67, 0x20, 0x4c, 0x61, 0x72, 0x67, 0x65, 140*29316b9cSGordon Ross 0x72, 0x20, 0x54, 0x68, 0x61, 0x6e, 0x20, 0x42, 141*29316b9cSGordon Ross 0x6c, 0x6f, 0x63, 0x6b, 0x2d, 0x53, 0x69, 0x7a, 142*29316b9cSGordon Ross 0x65, 0x20, 0x4b, 0x65, 0x79, 0x20, 0x2d, 0x20, 143*29316b9cSGordon Ross 0x48, 0x61, 0x73, 0x68, 0x20, 0x4b, 0x65, 0x79, 144*29316b9cSGordon Ross 0x20, 0x46, 0x69, 0x72, 0x73, 0x74 145*29316b9cSGordon Ross }; 146*29316b9cSGordon Ross 147*29316b9cSGordon Ross static uint8_t HMAC5[] = { 148*29316b9cSGordon Ross 0xaa, 0x4a, 0xe5, 0xe1, 0x52, 0x72, 0xd0, 0x0e, 149*29316b9cSGordon Ross 0x95, 0x70, 0x56, 0x37, 0xce, 0x8a, 0x3b, 0x55, 150*29316b9cSGordon Ross 0xed, 0x40, 0x21, 0x12 151*29316b9cSGordon Ross }; 152*29316b9cSGordon Ross 153*29316b9cSGordon Ross 154*29316b9cSGordon Ross static uint8_t KEY6[] = { 155*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 156*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 157*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 158*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 159*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 160*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 161*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 162*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 163*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 164*29316b9cSGordon Ross 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa 165*29316b9cSGordon Ross }; 166*29316b9cSGordon Ross 167*29316b9cSGordon Ross /* 168*29316b9cSGordon Ross * "Test Using Larger Than Block-Size Key and Larger Than One Block-Size Data" 169*29316b9cSGordon Ross */ 170*29316b9cSGordon Ross static uint8_t DATA6[] = { 171*29316b9cSGordon Ross 0x54, 0x65, 0x73, 0x74, 0x20, 0x55, 0x73, 0x69, 172*29316b9cSGordon Ross 0x6e, 0x67, 0x20, 0x4c, 0x61, 0x72, 0x67, 0x65, 173*29316b9cSGordon Ross 0x72, 0x20, 0x54, 0x68, 0x61, 0x6e, 0x20, 0x42, 174*29316b9cSGordon Ross 0x6c, 0x6f, 0x63, 0x6b, 0x2d, 0x53, 0x69, 0x7a, 175*29316b9cSGordon Ross 0x65, 0x20, 0x4b, 0x65, 0x79, 0x20, 0x61, 0x6e, 176*29316b9cSGordon Ross 0x64, 0x20, 0x4c, 0x61, 0x72, 0x67, 0x65, 0x72, 177*29316b9cSGordon Ross 0x20, 0x54, 0x68, 0x61, 0x6e, 0x20, 0x4f, 0x6e, 178*29316b9cSGordon Ross 0x65, 0x20, 0x42, 0x6c, 0x6f, 0x63, 0x6b, 0x2d, 179*29316b9cSGordon Ross 0x53, 0x69, 0x7a, 0x65, 0x20, 0x44, 0x61, 0x74, 180*29316b9cSGordon Ross 0x61 181*29316b9cSGordon Ross }; 182*29316b9cSGordon Ross static uint8_t HMAC6[] = { 183*29316b9cSGordon Ross 0xe8, 0xe9, 0x9d, 0x0f, 0x45, 0x23, 0x7d, 0x78, 184*29316b9cSGordon Ross 0x6d, 0x6b, 0xba, 0xa7, 0x96, 0x5c, 0x78, 0x08, 185*29316b9cSGordon Ross 0xbb, 0xff, 0x1a, 0x91 186*29316b9cSGordon Ross }; 187