OpenCores
URL https://opencores.org/ocsvn/bluespec_md6/bluespec_md6/trunk

Subversion Repositories bluespec_md6

[/] [bluespec_md6/] [trunk/] [C_implementation/] [md6_nist.c] - Diff between revs 2 and 7

Only display areas with differences | Details | Blame | View Log

Rev 2 Rev 7
/* File:    md6_nist.c
/* File:    md6_nist.c
** Author:  Ronald L. Rivest
** Author:  Ronald L. Rivest
** Address: Room 32G-692 Stata Center
** Address: Room 32G-692 Stata Center
**          32 Vassar Street
**          32 Vassar Street
**          Cambridge, MA 02139
**          Cambridge, MA 02139
** Email:   rivest@mit.edu
** Email:   rivest@mit.edu
** Date:    9/25/2008
** Date:    9/25/2008
**
**
** (The following license is known as "The MIT License")
** (The following license is known as "The MIT License")
**
**
** Copyright (c) 2008 Ronald L. Rivest
** Copyright (c) 2008 Ronald L. Rivest
**
**
** Permission is hereby granted, free of charge, to any person obtaining a copy
** Permission is hereby granted, free of charge, to any person obtaining a copy
** of this software and associated documentation files (the "Software"), to deal
** of this software and associated documentation files (the "Software"), to deal
** in the Software without restriction, including without limitation the rights
** in the Software without restriction, including without limitation the rights
** to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
** to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
** copies of the Software, and to permit persons to whom the Software is
** copies of the Software, and to permit persons to whom the Software is
** furnished to do so, subject to the following conditions:
** furnished to do so, subject to the following conditions:
**
**
** The above copyright notice and this permission notice shall be included in
** The above copyright notice and this permission notice shall be included in
** all copies or substantial portions of the Software.
** all copies or substantial portions of the Software.
**
**
** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
** IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
** IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
** FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
** FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
** AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
** AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
** LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
** LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
** OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
** OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
** THE SOFTWARE.
** THE SOFTWARE.
**
**
** (end of license)
** (end of license)
**
**
** This is part of the definition of the MD6 hash function.
** This is part of the definition of the MD6 hash function.
** The files defining the MD6 hash function are:
** The files defining the MD6 hash function are:
**    md6.h
**    md6.h
**    md6_compress.c
**    md6_compress.c
**    md6_mode.c
**    md6_mode.c
**
**
** The files defining the interface between MD6 and the NIST SHA-3
** The files defining the interface between MD6 and the NIST SHA-3
** API are:
** API are:
**    md6_nist.h
**    md6_nist.h
**    md6_nist.c
**    md6_nist.c
** The NIST SHA-3 API is defined in:
** The NIST SHA-3 API is defined in:
**    http://www.csrc.nist.gov/groups/ST/hash/documents/SHA3-C-API.pdf
**    http://www.csrc.nist.gov/groups/ST/hash/documents/SHA3-C-API.pdf
**
**
** See  http://groups.csail.mit.edu/cis/md6  for more information.
** See  http://groups.csail.mit.edu/cis/md6  for more information.
*/
*/
 
 
#include <stdio.h>
#include <stdio.h>
#include "md6.h"
#include "md6.h"
#include "md6_nist.h"
#include "md6_nist.h"
 
 
HashReturn Init( hashState *state,
HashReturn Init( hashState *state,
                 int hashbitlen
                 int hashbitlen
                 )
                 )
{ int err;
{ int err;
  if ((err = md6_init( (md6_state *) state,
  if ((err = md6_init( (md6_state *) state,
                       hashbitlen
                       hashbitlen
                       )))
                       )))
    return err;
    return err;
  state->hashbitlen = hashbitlen;
  state->hashbitlen = hashbitlen;
  return SUCCESS;
  return SUCCESS;
}
}
 
 
HashReturn Update( hashState *state,
HashReturn Update( hashState *state,
                   const BitSequence *data,
                   const BitSequence *data,
                   DataLength databitlen
                   DataLength databitlen
                   )
                   )
{ return md6_update( (md6_state *) state,
{ return md6_update( (md6_state *) state,
                     (unsigned char *)data,
                     (unsigned char *)data,
                     (uint64_t) databitlen );
                     (uint64_t) databitlen );
}
}
 
 
HashReturn Final( hashState *state,
HashReturn Final( hashState *state,
                  BitSequence *hashval
                  BitSequence *hashval
                  )
                  )
{ return md6_final( (md6_state *) state,
{ return md6_final( (md6_state *) state,
                    (unsigned char *) hashval
                    (unsigned char *) hashval
                    );
                    );
}
}
 
 
HashReturn Hash( int hashbitlen,
HashReturn Hash( int hashbitlen,
                 const BitSequence *data,
                 const BitSequence *data,
                 DataLength databitlen,
                 DataLength databitlen,
                 BitSequence *hashval
                 BitSequence *hashval
                 )
                 )
{ int err;
{ int err;
  md6_state state;
  md6_state state;
  if ((err = Init( &state, hashbitlen )))
  if ((err = Init( &state, hashbitlen )))
    return err;
    return err;
  if ((err = Update( &state, data, databitlen )))
  if ((err = Update( &state, data, databitlen )))
    return err;
    return err;
  return Final( &state, hashval );
  return Final( &state, hashval );
}
}
 
 
 
 
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.