1*90e502c7SAndroid Build Coastguard Worker /* 2*90e502c7SAndroid Build Coastguard Worker * aes_icm.h 3*90e502c7SAndroid Build Coastguard Worker * 4*90e502c7SAndroid Build Coastguard Worker * Header for AES Integer Counter Mode. 5*90e502c7SAndroid Build Coastguard Worker * 6*90e502c7SAndroid Build Coastguard Worker * David A. McGrew 7*90e502c7SAndroid Build Coastguard Worker * Cisco Systems, Inc. 8*90e502c7SAndroid Build Coastguard Worker * 9*90e502c7SAndroid Build Coastguard Worker */ 10*90e502c7SAndroid Build Coastguard Worker 11*90e502c7SAndroid Build Coastguard Worker /* 12*90e502c7SAndroid Build Coastguard Worker * 13*90e502c7SAndroid Build Coastguard Worker * Copyright (c) 2001-2017, Cisco Systems, Inc. 14*90e502c7SAndroid Build Coastguard Worker * All rights reserved. 15*90e502c7SAndroid Build Coastguard Worker * 16*90e502c7SAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without 17*90e502c7SAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions 18*90e502c7SAndroid Build Coastguard Worker * are met: 19*90e502c7SAndroid Build Coastguard Worker * 20*90e502c7SAndroid Build Coastguard Worker * Redistributions of source code must retain the above copyright 21*90e502c7SAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer. 22*90e502c7SAndroid Build Coastguard Worker * 23*90e502c7SAndroid Build Coastguard Worker * Redistributions in binary form must reproduce the above 24*90e502c7SAndroid Build Coastguard Worker * copyright notice, this list of conditions and the following 25*90e502c7SAndroid Build Coastguard Worker * disclaimer in the documentation and/or other materials provided 26*90e502c7SAndroid Build Coastguard Worker * with the distribution. 27*90e502c7SAndroid Build Coastguard Worker * 28*90e502c7SAndroid Build Coastguard Worker * Neither the name of the Cisco Systems, Inc. nor the names of its 29*90e502c7SAndroid Build Coastguard Worker * contributors may be used to endorse or promote products derived 30*90e502c7SAndroid Build Coastguard Worker * from this software without specific prior written permission. 31*90e502c7SAndroid Build Coastguard Worker * 32*90e502c7SAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 33*90e502c7SAndroid Build Coastguard Worker * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 34*90e502c7SAndroid Build Coastguard Worker * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 35*90e502c7SAndroid Build Coastguard Worker * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 36*90e502c7SAndroid Build Coastguard Worker * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 37*90e502c7SAndroid Build Coastguard Worker * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 38*90e502c7SAndroid Build Coastguard Worker * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 39*90e502c7SAndroid Build Coastguard Worker * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 40*90e502c7SAndroid Build Coastguard Worker * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 41*90e502c7SAndroid Build Coastguard Worker * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 42*90e502c7SAndroid Build Coastguard Worker * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED 43*90e502c7SAndroid Build Coastguard Worker * OF THE POSSIBILITY OF SUCH DAMAGE. 44*90e502c7SAndroid Build Coastguard Worker * 45*90e502c7SAndroid Build Coastguard Worker */ 46*90e502c7SAndroid Build Coastguard Worker 47*90e502c7SAndroid Build Coastguard Worker #ifndef AES_ICM_H 48*90e502c7SAndroid Build Coastguard Worker #define AES_ICM_H 49*90e502c7SAndroid Build Coastguard Worker 50*90e502c7SAndroid Build Coastguard Worker #include "aes.h" 51*90e502c7SAndroid Build Coastguard Worker #include "cipher.h" 52*90e502c7SAndroid Build Coastguard Worker 53*90e502c7SAndroid Build Coastguard Worker typedef struct { 54*90e502c7SAndroid Build Coastguard Worker v128_t counter; /* holds the counter value */ 55*90e502c7SAndroid Build Coastguard Worker v128_t offset; /* initial offset value */ 56*90e502c7SAndroid Build Coastguard Worker v128_t keystream_buffer; /* buffers bytes of keystream */ 57*90e502c7SAndroid Build Coastguard Worker srtp_aes_expanded_key_t expanded_key; /* the cipher key */ 58*90e502c7SAndroid Build Coastguard Worker int bytes_in_buffer; /* number of unused bytes in buffer */ 59*90e502c7SAndroid Build Coastguard Worker int key_size; /* AES key size + 14 byte SALT */ 60*90e502c7SAndroid Build Coastguard Worker } srtp_aes_icm_ctx_t; 61*90e502c7SAndroid Build Coastguard Worker 62*90e502c7SAndroid Build Coastguard Worker #endif /* AES_ICM_H */ 63