mirror of
				https://github.com/python/cpython.git
				synced 2025-11-04 07:31:38 +00:00 
			
		
		
		
	
		
			
	
	
		
			45 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			45 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								   BLAKE2 reference source code package - optimized C implementations
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								   Written in 2012 by Samuel Neves <sneves@dei.uc.pt>
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								   To the extent possible under law, the author(s) have dedicated all copyright
							 | 
						||
| 
								 | 
							
								   and related and neighboring rights to this software to the public domain
							 | 
						||
| 
								 | 
							
								   worldwide. This software is distributed without any warranty.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								   You should have received a copy of the CC0 Public Domain Dedication along with
							 | 
						||
| 
								 | 
							
								   this software. If not, see <http://creativecommons.org/publicdomain/zero/1.0/>.
							 | 
						||
| 
								 | 
							
								*/
							 | 
						||
| 
								 | 
							
								#include <stdio.h>
							 | 
						||
| 
								 | 
							
								#include <string.h>
							 | 
						||
| 
								 | 
							
								#include "blake2.h"
							 | 
						||
| 
								 | 
							
								#include "blake2-kat.h"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								int main( int argc, char **argv )
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								  uint8_t key[BLAKE2B_KEYBYTES];
							 | 
						||
| 
								 | 
							
								  uint8_t buf[KAT_LENGTH];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  for( size_t i = 0; i < BLAKE2B_KEYBYTES; ++i )
							 | 
						||
| 
								 | 
							
								    key[i] = ( uint8_t )i;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  for( size_t i = 0; i < KAT_LENGTH; ++i )
							 | 
						||
| 
								 | 
							
								    buf[i] = ( uint8_t )i;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  for( size_t i = 0; i < KAT_LENGTH; ++i )
							 | 
						||
| 
								 | 
							
								  {
							 | 
						||
| 
								 | 
							
								    uint8_t hash[BLAKE2B_OUTBYTES];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if( blake2bp( hash, buf, key, BLAKE2B_OUTBYTES, i, BLAKE2B_KEYBYTES ) < 0 || 
							 | 
						||
| 
								 | 
							
								        0 != memcmp( hash, blake2bp_keyed_kat[i], BLAKE2B_OUTBYTES ) )
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								      puts( "error" );
							 | 
						||
| 
								 | 
							
								      return -1;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  puts( "ok" );
							 | 
						||
| 
								 | 
							
								  return 0;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 |