1cabdff1aSopenharmony_ci/* 2cabdff1aSopenharmony_ci * Copyright (C) 2007 Michael Niedermayer <michaelni@gmx.at> 3cabdff1aSopenharmony_ci * Copyright (C) 2009 Konstantin Shishkov 4cabdff1aSopenharmony_ci * Copyright (C) 2013 James Almer 5cabdff1aSopenharmony_ci * based on BSD-licensed SHA-2 code by Aaron D. Gifford 6cabdff1aSopenharmony_ci * 7cabdff1aSopenharmony_ci * This file is part of FFmpeg. 8cabdff1aSopenharmony_ci * 9cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or 10cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public 11cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either 12cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version. 13cabdff1aSopenharmony_ci * 14cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful, 15cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 16cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 17cabdff1aSopenharmony_ci * Lesser General Public License for more details. 18cabdff1aSopenharmony_ci * 19cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public 20cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software 21cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 22cabdff1aSopenharmony_ci */ 23cabdff1aSopenharmony_ci 24cabdff1aSopenharmony_ci#include <stdio.h> 25cabdff1aSopenharmony_ci 26cabdff1aSopenharmony_ci#include "libavutil/mem.h" 27cabdff1aSopenharmony_ci#include "libavutil/sha512.h" 28cabdff1aSopenharmony_ci 29cabdff1aSopenharmony_ciint main(void) 30cabdff1aSopenharmony_ci{ 31cabdff1aSopenharmony_ci int i, j, k; 32cabdff1aSopenharmony_ci struct AVSHA512 *ctx; 33cabdff1aSopenharmony_ci unsigned char digest[64]; 34cabdff1aSopenharmony_ci static const int lengths[4] = { 224, 256, 384, 512 }; 35cabdff1aSopenharmony_ci 36cabdff1aSopenharmony_ci ctx = av_sha512_alloc(); 37cabdff1aSopenharmony_ci if (!ctx) 38cabdff1aSopenharmony_ci return 1; 39cabdff1aSopenharmony_ci 40cabdff1aSopenharmony_ci for (j = 0; j < 4; j++) { 41cabdff1aSopenharmony_ci if (j < 2) printf("Testing SHA-512/%d\n", lengths[j]); 42cabdff1aSopenharmony_ci else printf("Testing SHA-%d\n", lengths[j]); 43cabdff1aSopenharmony_ci for (k = 0; k < 3; k++) { 44cabdff1aSopenharmony_ci av_sha512_init(ctx, lengths[j]); 45cabdff1aSopenharmony_ci if (k == 0) 46cabdff1aSopenharmony_ci av_sha512_update(ctx, "abc", 3); 47cabdff1aSopenharmony_ci else if (k == 1) 48cabdff1aSopenharmony_ci av_sha512_update(ctx, "abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmn" 49cabdff1aSopenharmony_ci "hijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu", 112); 50cabdff1aSopenharmony_ci else 51cabdff1aSopenharmony_ci for (i = 0; i < 1000*1000; i++) 52cabdff1aSopenharmony_ci av_sha512_update(ctx, "a", 1); 53cabdff1aSopenharmony_ci av_sha512_final(ctx, digest); 54cabdff1aSopenharmony_ci for (i = 0; i < lengths[j] >> 3; i++) 55cabdff1aSopenharmony_ci printf("%02X", digest[i]); 56cabdff1aSopenharmony_ci putchar('\n'); 57cabdff1aSopenharmony_ci } 58cabdff1aSopenharmony_ci switch (j) { //test vectors (from FIPS PUB 180-4 Apendix A) 59cabdff1aSopenharmony_ci case 0: 60cabdff1aSopenharmony_ci printf("4634270f 707b6a54 daae7530 460842e2 0e37ed26 5ceee9a4 3e8924aa\n" 61cabdff1aSopenharmony_ci "23fec5bb 94d60b23 30819264 0b0c4533 35d66473 4fe40e72 68674af9\n" 62cabdff1aSopenharmony_ci "37ab331d 76f0d36d e422bd0e deb22a28 accd487b 7a8453ae 965dd287\n"); 63cabdff1aSopenharmony_ci break; 64cabdff1aSopenharmony_ci case 1: 65cabdff1aSopenharmony_ci printf("53048e26 81941ef9 9b2e29b7 6b4c7dab e4c2d0c6 34fc6d46 e0e2f131 07e7af23\n" 66cabdff1aSopenharmony_ci "3928e184 fb8690f8 40da3988 121d31be 65cb9d3e f83ee614 6feac861 e19b563a\n" 67cabdff1aSopenharmony_ci "9a59a052 930187a9 7038cae6 92f30708 aa649192 3ef51943 94dc68d5 6c74fb21\n"); 68cabdff1aSopenharmony_ci break; 69cabdff1aSopenharmony_ci case 2: 70cabdff1aSopenharmony_ci printf("cb00753f 45a35e8b b5a03d69 9ac65007 272c32ab 0eded163 " 71cabdff1aSopenharmony_ci "1a8b605a 43ff5bed 8086072b a1e7cc23 58baeca1 34c825a7\n" 72cabdff1aSopenharmony_ci "09330c33 f71147e8 3d192fc7 82cd1b47 53111b17 3b3b05d2 " 73cabdff1aSopenharmony_ci "2fa08086 e3b0f712 fcc7c71a 557e2db9 66c3e9fa 91746039\n" 74cabdff1aSopenharmony_ci "9d0e1809 716474cb 086e834e 310a4a1c ed149e9c 00f24852 " 75cabdff1aSopenharmony_ci "7972cec5 704c2a5b 07b8b3dc 38ecc4eb ae97ddd8 7f3d8985\n"); 76cabdff1aSopenharmony_ci break; 77cabdff1aSopenharmony_ci case 3: 78cabdff1aSopenharmony_ci printf("ddaf35a1 93617aba cc417349 ae204131 12e6fa4e 89a97ea2 0a9eeee6 4b55d39a " 79cabdff1aSopenharmony_ci "2192992a 274fc1a8 36ba3c23 a3feebbd 454d4423 643ce80e 2a9ac94f a54ca49f\n" 80cabdff1aSopenharmony_ci "8e959b75 dae313da 8cf4f728 14fc143f 8f7779c6 eb9f7fa1 7299aead b6889018 " 81cabdff1aSopenharmony_ci "501d289e 4900f7e4 331b99de c4b5433a c7d329ee b6dd2654 5e96e55b 874be909\n" 82cabdff1aSopenharmony_ci "e718483d 0ce76964 4e2e42c7 bc15b463 8e1f98b1 3b204428 5632a803 afa973eb " 83cabdff1aSopenharmony_ci "de0ff244 877ea60a 4cb0432c e577c31b eb009c5c 2c49aa2e 4eadb217 ad8cc09b\n"); 84cabdff1aSopenharmony_ci break; 85cabdff1aSopenharmony_ci } 86cabdff1aSopenharmony_ci } 87cabdff1aSopenharmony_ci av_free(ctx); 88cabdff1aSopenharmony_ci 89cabdff1aSopenharmony_ci return 0; 90cabdff1aSopenharmony_ci} 91