Print this page
4185 New hash algorithm support

Split Close
Expand all
Collapse all
          --- old/usr/src/uts/common/sys/sha2.h
          +++ new/usr/src/uts/common/sys/sha2.h
↓ open down ↓ 14 lines elided ↑ open up ↑
  15   15   * If applicable, add the following below this CDDL HEADER, with the
  16   16   * fields enclosed by brackets "[]" replaced with your own identifying
  17   17   * information: Portions Copyright [yyyy] [name of copyright owner]
  18   18   *
  19   19   * CDDL HEADER END
  20   20   */
  21   21  /*
  22   22   * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
  23   23   * Use is subject to license terms.
  24   24   */
       25 +/* Copyright 2013 Saso Kiselkov.  All rights reserved. */
  25   26  
  26   27  #ifndef _SYS_SHA2_H
  27   28  #define _SYS_SHA2_H
  28   29  
  29   30  #include <sys/types.h>          /* for uint_* */
  30   31  
  31   32  #ifdef  __cplusplus
  32   33  extern "C" {
  33   34  #endif
  34   35  
  35   36  #define SHA2_HMAC_MIN_KEY_LEN   1       /* SHA2-HMAC min key length in bytes */
  36   37  #define SHA2_HMAC_MAX_KEY_LEN   INT_MAX /* SHA2-HMAC max key length in bytes */
  37   38  
  38   39  #define SHA256_DIGEST_LENGTH    32      /* SHA256 digest length in bytes */
  39   40  #define SHA384_DIGEST_LENGTH    48      /* SHA384 digest length in bytes */
  40   41  #define SHA512_DIGEST_LENGTH    64      /* SHA512 digest length in bytes */
  41   42  
       43 +/* Truncated versions of SHA-512 according to FIPS-180-4, section 5.3.6 */
       44 +#define SHA512_224_DIGEST_LENGTH        28      /* SHA512/224 digest length */
       45 +#define SHA512_256_DIGEST_LENGTH        32      /* SHA512/256 digest length */
       46 +
  42   47  #define SHA256_HMAC_BLOCK_SIZE  64      /* SHA256-HMAC block size */
  43   48  #define SHA512_HMAC_BLOCK_SIZE  128     /* SHA512-HMAC block size */
  44   49  
  45   50  #define SHA256                  0
  46   51  #define SHA256_HMAC             1
  47   52  #define SHA256_HMAC_GEN         2
  48   53  #define SHA384                  3
  49   54  #define SHA384_HMAC             4
  50   55  #define SHA384_HMAC_GEN         5
  51   56  #define SHA512                  6
  52   57  #define SHA512_HMAC             7
  53   58  #define SHA512_HMAC_GEN         8
       59 +#define SHA512_224              9
       60 +#define SHA512_256              10
  54   61  
  55   62  /*
  56   63   * SHA2 context.
  57   64   * The contents of this structure are a private interface between the
  58   65   * Init/Update/Final calls of the functions defined below.
  59   66   * Callers must never attempt to read or write any of the fields
  60   67   * in this structure directly.
  61   68   */
  62   69  typedef struct  {
  63   70          uint32_t algotype;              /* Algorithm Type */
↓ open down ↓ 59 lines elided ↑ open up ↑
 123  130   */
 124  131  typedef enum sha2_mech_type {
 125  132          SHA256_MECH_INFO_TYPE,          /* SUN_CKM_SHA256 */
 126  133          SHA256_HMAC_MECH_INFO_TYPE,     /* SUN_CKM_SHA256_HMAC */
 127  134          SHA256_HMAC_GEN_MECH_INFO_TYPE, /* SUN_CKM_SHA256_HMAC_GENERAL */
 128  135          SHA384_MECH_INFO_TYPE,          /* SUN_CKM_SHA384 */
 129  136          SHA384_HMAC_MECH_INFO_TYPE,     /* SUN_CKM_SHA384_HMAC */
 130  137          SHA384_HMAC_GEN_MECH_INFO_TYPE, /* SUN_CKM_SHA384_HMAC_GENERAL */
 131  138          SHA512_MECH_INFO_TYPE,          /* SUN_CKM_SHA512 */
 132  139          SHA512_HMAC_MECH_INFO_TYPE,     /* SUN_CKM_SHA512_HMAC */
 133      -        SHA512_HMAC_GEN_MECH_INFO_TYPE  /* SUN_CKM_SHA512_HMAC_GENERAL */
      140 +        SHA512_HMAC_GEN_MECH_INFO_TYPE, /* SUN_CKM_SHA512_HMAC_GENERAL */
      141 +        SHA512_224_MECH_INFO_TYPE,      /* SUN_CKM_SHA512_224 */
      142 +        SHA512_256_MECH_INFO_TYPE       /* SUN_CKM_SHA512_256 */
 134  143  } sha2_mech_type_t;
 135  144  
 136  145  #endif /* _SHA2_IMPL */
 137  146  
 138  147  #ifdef  __cplusplus
 139  148  }
 140  149  #endif
 141  150  
 142  151  #endif /* _SYS_SHA2_H */
    
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX