##// END OF EJS Templates
test-sparse-revlog: abstract the last snapshot we use during test...
test-sparse-revlog: abstract the last snapshot we use during test The actual revision number might change when we alter the input data or the algorithm. Lets make this more maintainable.

File last commit:

r44558:b4420cea default
r53330:9db98b50 default
Show More
ubc_check.h
57 lines | 1.8 KiB | text/x-c | CLexer
Augie Fackler
sha1dc: import latest version from github...
r44509 /***
* Copyright 2017 Marc Stevens <marc@marc-stevens.nl>, Dan Shumow <danshu@microsoft.com>
* Distributed under the MIT Software License.
* See accompanying file LICENSE.txt or copy at
* https://opensource.org/licenses/MIT
***/
/*
// this file was generated by the 'parse_bitrel' program in the tools section
// using the data files from directory 'tools/data/3565'
//
// sha1_dvs contains a list of SHA-1 Disturbance Vectors (DV) to check
// dvType, dvK and dvB define the DV: I(K,B) or II(K,B) (see the paper)
// dm[80] is the expanded message block XOR-difference defined by the DV
// testt is the step to do the recompression from for collision detection
// maski and maskb define the bit to check for each DV in the dvmask returned by ubc_check
//
// ubc_check takes as input an expanded message block and verifies the unavoidable bitconditions for all listed DVs
// it returns a dvmask where each bit belonging to a DV is set if all unavoidable bitconditions for that DV have been met
// thus one needs to do the recompression check for each DV that has its bit set
*/
#ifndef SHA1DC_UBC_CHECK_H
#define SHA1DC_UBC_CHECK_H
#if defined(__cplusplus)
extern "C" {
#endif
#ifndef SHA1DC_NO_STANDARD_INCLUDES
Matt Harbison
sha1dc: avoid including the nonexistent stdint.h with Visual Studio 2008...
r44558 #if !defined(_MSC_VER) || _MSC_VER >= 1600
Augie Fackler
sha1dc: import latest version from github...
r44509 #include <stdint.h>
Matt Harbison
sha1dc: avoid including the nonexistent stdint.h with Visual Studio 2008...
r44558 #else
/* prior to Visual Studio 2010 */
typedef unsigned __int32 uint32_t;
#endif
Augie Fackler
sha1dc: import latest version from github...
r44509 #endif
#define DVMASKSIZE 1
typedef struct { int dvType; int dvK; int dvB; int testt; int maski; int maskb; uint32_t dm[80]; } dv_info_t;
extern dv_info_t sha1_dvs[];
void ubc_check(const uint32_t W[80], uint32_t dvmask[DVMASKSIZE]);
#define DOSTORESTATE58
#define DOSTORESTATE65
#define CHECK_DVMASK(_DVMASK) (0 != _DVMASK[0])
#if defined(__cplusplus)
}
#endif
#ifdef SHA1DC_CUSTOM_TRAILING_INCLUDE_UBC_CHECK_H
#include SHA1DC_CUSTOM_TRAILING_INCLUDE_UBC_CHECK_H
#endif
#endif