无线传感器密钥管理算法

源代码在线查看: mac.nc

软件大小: 44 K
上传用户: llll45356874
关键词: 无线传感器 密钥管理 算法
下载地址: 免注册下载 普通下载 VIP

相关代码

				/*									tab:4
				 *
				 *
				 * "Copyright (c) 2000-2002 The Regents of the University  of California.  
				 * All rights reserved.
				 *
				 * Permission to use, copy, modify, and distribute this software and its
				 * documentation for any purpose, without fee, and without written agreement is
				 * hereby granted, provided that the above copyright notice, the following
				 * two paragraphs and the author appear in all copies of this software.
				 * 
				 * IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR
				 * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT
				 * OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF THE UNIVERSITY OF
				 * CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
				 * 
				 * THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES,
				 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
				 * AND FITNESS FOR A PARTICULAR PURPOSE.  THE SOFTWARE PROVIDED HEREUNDER IS
				 * ON AN "AS IS" BASIS, AND THE UNIVERSITY OF CALIFORNIA HAS NO OBLIGATION TO
				 * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS."
				 *
				 * Authors: Naveen Sastry
				 * Date:    10/18/02
				 */
				includes crypto;
				/**
				 * Interface to compute a message authentication code.
				 */
				interface MAC
				{
				  /**
				   * Initializes the MAC layer and stores any local state into the context
				   * variable. The context variable should be used for future invocations
				   * which share this key. It uses the preferred block size of the underlying
				   * BlockCipher
				   *
				   * @param context opaque data structure to hold the module specific state
				   *        associated with this key.
				   * @param keySize length of the key in bytes.
				   * @param key pointer to a buffer containing keySize bytes of shared key data
				   * @return Whether initialization was successful. The command may be
				   *         unsuccessful if the key size or blockSize are not valid for the
				   *         given cipher implementation. 
				   */
				  command result_t init (MACContext * context, uint8_t keySize, uint8_t * key);
				                         
				  /**
				   * Initializes an invocation of an incremental MAC computation. This is
				   * provided for asynchronous operation so that the MAC may be incrementally
				   * computed. Partial state is stored in the context.
				   *
				   * @param context opaque data structure to hold the module specific state
				   *        associated with this invocation of the incremental computation.
				   * @param length the total length of data that is forthcoming
				   * @return whether the incremental initialization was successful. This can
				   *        fail if the underlying cipher operation fails.
				   */
				  command result_t initIncrementalMAC (MACContext * context, uint16_t length);
				
				  /**
				   * Computes an incremental MAC on msgLen bytes of the msg. This call is
				   * tied to the initIncrementalMAC call, which must be made first. This call
				   * can fail if the msgLen provided exceeds the amount specified earlier or
				   * if a block cipher operation fails.
				   *
				   * @param context opaque data structure to hold the module specific state
				   *        associated with this invocation of the incremental computation.
				   * @param msg the message data to add to the incremental computation.
				   * @param msgLen number of bytes to add for the incremental computation.
				   * @return whether the incremental mac computation succeeded or not. It can
				   *        fail if more data is provided than the initial initialization
				   *        indicated or if the underlying block cipher fails.
				   */
				  command result_t incrementalMAC (MACContext * context, uint8_t * msg, 
				                                   uint16_t msgLen);
				
				  /**
				   * Returns the actual MAC code from an in-progress incremental MAC
				   * computation. The initIncrementalMAC and length bytes of data must have
				   * been computed using the provided context for this function to succeed.
				   * This function may fail if the requested MAC size exceeds the underlying
				   * cipher block size, or if the incremental MAC computation has not yet
				   * finished.
				   *
				   * @param context opaque data structure to hold the module specific state
				   *        associated with this invocation of the incremental computation.
				   * @param MAC resulting buffer of at least macSize to hold the generated MAC
				   * @param macSize the number of bytes of MAC to generate. This must be
				   *        less than or equal to the underlying blockCipher block size.
				   * @return whether the command succeeded or not. It can fail if the
				   *        underlying block cipher fails or if not all expected data was
				   *        received from the initialization function
				   */
				  command result_t getIncrementalMAC (MACContext * context, uint8_t * MAC,
				                                      uint8_t macSize);
				
				  /**
				   * Computes a non-incremental MAC calculation on the given message. The
				   * key from the init() call will be used for the MAC calculation.
				   *
				   * @param context opaque data structure to hold the module specific state
				   *        associated with this invocation of the incremental computation.
				   * @param msg a buffer of length size on which the MAC will be calculated
				   * @param length the total length of the msg
				   * @param buffer of at least macSize where the resulting MAC calculation
				   *        will be stored.
				   * @param macSzie the number of bytes of MAC to generate. This must be
				   *        less than or equal to the underlying blockCipher block size.
				   * @return whether the command suceeds or not. It can fail if the underlying
				   *        blockCipher fails. 
				   */
				  command result_t MAC (MACContext * context, uint8_t * msg, uint16_t length,
				                        uint8_t *MAC, uint8_t macSize);
				}
							

相关资源