xref: /aosp_15_r20/external/libsrtp2/crypto/cipher/null_cipher.c (revision 90e502c7aef8d77d0622bb67d75435c6190cfc1a)
1*90e502c7SAndroid Build Coastguard Worker /*
2*90e502c7SAndroid Build Coastguard Worker  * null_cipher.c
3*90e502c7SAndroid Build Coastguard Worker  *
4*90e502c7SAndroid Build Coastguard Worker  * A null cipher implementation.  This cipher leaves the plaintext
5*90e502c7SAndroid Build Coastguard Worker  * unchanged.
6*90e502c7SAndroid Build Coastguard Worker  *
7*90e502c7SAndroid Build Coastguard Worker  * David A. McGrew
8*90e502c7SAndroid Build Coastguard Worker  * Cisco Systems, Inc.
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 #ifdef HAVE_CONFIG_H
48*90e502c7SAndroid Build Coastguard Worker #include <config.h>
49*90e502c7SAndroid Build Coastguard Worker #endif
50*90e502c7SAndroid Build Coastguard Worker 
51*90e502c7SAndroid Build Coastguard Worker #include "datatypes.h"
52*90e502c7SAndroid Build Coastguard Worker #include "null_cipher.h"
53*90e502c7SAndroid Build Coastguard Worker #include "err.h" /* for srtp_debug */
54*90e502c7SAndroid Build Coastguard Worker #include "alloc.h"
55*90e502c7SAndroid Build Coastguard Worker #include "cipher_types.h"
56*90e502c7SAndroid Build Coastguard Worker 
srtp_null_cipher_alloc(srtp_cipher_t ** c,int key_len,int tlen)57*90e502c7SAndroid Build Coastguard Worker static srtp_err_status_t srtp_null_cipher_alloc(srtp_cipher_t **c,
58*90e502c7SAndroid Build Coastguard Worker                                                 int key_len,
59*90e502c7SAndroid Build Coastguard Worker                                                 int tlen)
60*90e502c7SAndroid Build Coastguard Worker {
61*90e502c7SAndroid Build Coastguard Worker     extern const srtp_cipher_type_t srtp_null_cipher;
62*90e502c7SAndroid Build Coastguard Worker 
63*90e502c7SAndroid Build Coastguard Worker     debug_print(srtp_mod_cipher, "allocating cipher with key length %d",
64*90e502c7SAndroid Build Coastguard Worker                 key_len);
65*90e502c7SAndroid Build Coastguard Worker 
66*90e502c7SAndroid Build Coastguard Worker     /* allocate memory a cipher of type null_cipher */
67*90e502c7SAndroid Build Coastguard Worker     *c = (srtp_cipher_t *)srtp_crypto_alloc(sizeof(srtp_cipher_t));
68*90e502c7SAndroid Build Coastguard Worker     if (*c == NULL) {
69*90e502c7SAndroid Build Coastguard Worker         return srtp_err_status_alloc_fail;
70*90e502c7SAndroid Build Coastguard Worker     }
71*90e502c7SAndroid Build Coastguard Worker 
72*90e502c7SAndroid Build Coastguard Worker     /* set pointers */
73*90e502c7SAndroid Build Coastguard Worker     (*c)->algorithm = SRTP_NULL_CIPHER;
74*90e502c7SAndroid Build Coastguard Worker     (*c)->type = &srtp_null_cipher;
75*90e502c7SAndroid Build Coastguard Worker     (*c)->state = (void *)0x1; /* The null cipher does not maintain state */
76*90e502c7SAndroid Build Coastguard Worker 
77*90e502c7SAndroid Build Coastguard Worker     /* set key size */
78*90e502c7SAndroid Build Coastguard Worker     (*c)->key_len = key_len;
79*90e502c7SAndroid Build Coastguard Worker 
80*90e502c7SAndroid Build Coastguard Worker     return srtp_err_status_ok;
81*90e502c7SAndroid Build Coastguard Worker }
82*90e502c7SAndroid Build Coastguard Worker 
srtp_null_cipher_dealloc(srtp_cipher_t * c)83*90e502c7SAndroid Build Coastguard Worker static srtp_err_status_t srtp_null_cipher_dealloc(srtp_cipher_t *c)
84*90e502c7SAndroid Build Coastguard Worker {
85*90e502c7SAndroid Build Coastguard Worker     extern const srtp_cipher_type_t srtp_null_cipher;
86*90e502c7SAndroid Build Coastguard Worker 
87*90e502c7SAndroid Build Coastguard Worker     /* zeroize entire state*/
88*90e502c7SAndroid Build Coastguard Worker     octet_string_set_to_zero(c, sizeof(srtp_cipher_t));
89*90e502c7SAndroid Build Coastguard Worker 
90*90e502c7SAndroid Build Coastguard Worker     /* free memory of type null_cipher */
91*90e502c7SAndroid Build Coastguard Worker     srtp_crypto_free(c);
92*90e502c7SAndroid Build Coastguard Worker 
93*90e502c7SAndroid Build Coastguard Worker     return srtp_err_status_ok;
94*90e502c7SAndroid Build Coastguard Worker }
95*90e502c7SAndroid Build Coastguard Worker 
srtp_null_cipher_init(void * cv,const uint8_t * key)96*90e502c7SAndroid Build Coastguard Worker static srtp_err_status_t srtp_null_cipher_init(void *cv, const uint8_t *key)
97*90e502c7SAndroid Build Coastguard Worker {
98*90e502c7SAndroid Build Coastguard Worker     /* srtp_null_cipher_ctx_t *c = (srtp_null_cipher_ctx_t *)cv; */
99*90e502c7SAndroid Build Coastguard Worker 
100*90e502c7SAndroid Build Coastguard Worker     debug_print(srtp_mod_cipher, "initializing null cipher", NULL);
101*90e502c7SAndroid Build Coastguard Worker 
102*90e502c7SAndroid Build Coastguard Worker     return srtp_err_status_ok;
103*90e502c7SAndroid Build Coastguard Worker }
104*90e502c7SAndroid Build Coastguard Worker 
srtp_null_cipher_set_iv(void * cv,uint8_t * iv,srtp_cipher_direction_t dir)105*90e502c7SAndroid Build Coastguard Worker static srtp_err_status_t srtp_null_cipher_set_iv(void *cv,
106*90e502c7SAndroid Build Coastguard Worker                                                  uint8_t *iv,
107*90e502c7SAndroid Build Coastguard Worker                                                  srtp_cipher_direction_t dir)
108*90e502c7SAndroid Build Coastguard Worker {
109*90e502c7SAndroid Build Coastguard Worker     /* srtp_null_cipher_ctx_t *c = (srtp_null_cipher_ctx_t *)cv; */
110*90e502c7SAndroid Build Coastguard Worker     return srtp_err_status_ok;
111*90e502c7SAndroid Build Coastguard Worker }
112*90e502c7SAndroid Build Coastguard Worker 
srtp_null_cipher_encrypt(void * cv,unsigned char * buf,unsigned int * bytes_to_encr)113*90e502c7SAndroid Build Coastguard Worker static srtp_err_status_t srtp_null_cipher_encrypt(void *cv,
114*90e502c7SAndroid Build Coastguard Worker                                                   unsigned char *buf,
115*90e502c7SAndroid Build Coastguard Worker                                                   unsigned int *bytes_to_encr)
116*90e502c7SAndroid Build Coastguard Worker {
117*90e502c7SAndroid Build Coastguard Worker     /* srtp_null_cipher_ctx_t *c = (srtp_null_cipher_ctx_t *)cv; */
118*90e502c7SAndroid Build Coastguard Worker     return srtp_err_status_ok;
119*90e502c7SAndroid Build Coastguard Worker }
120*90e502c7SAndroid Build Coastguard Worker 
121*90e502c7SAndroid Build Coastguard Worker static const char srtp_null_cipher_description[] = "null cipher";
122*90e502c7SAndroid Build Coastguard Worker 
123*90e502c7SAndroid Build Coastguard Worker static const srtp_cipher_test_case_t srtp_null_cipher_test_0 = {
124*90e502c7SAndroid Build Coastguard Worker     0,    /* octets in key            */
125*90e502c7SAndroid Build Coastguard Worker     NULL, /* key                      */
126*90e502c7SAndroid Build Coastguard Worker     0,    /* packet index             */
127*90e502c7SAndroid Build Coastguard Worker     0,    /* octets in plaintext      */
128*90e502c7SAndroid Build Coastguard Worker     NULL, /* plaintext                */
129*90e502c7SAndroid Build Coastguard Worker     0,    /* octets in plaintext      */
130*90e502c7SAndroid Build Coastguard Worker     NULL, /* ciphertext               */
131*90e502c7SAndroid Build Coastguard Worker     0,    /* */
132*90e502c7SAndroid Build Coastguard Worker     NULL, /* */
133*90e502c7SAndroid Build Coastguard Worker     0,    /* */
134*90e502c7SAndroid Build Coastguard Worker     NULL  /* pointer to next testcase */
135*90e502c7SAndroid Build Coastguard Worker };
136*90e502c7SAndroid Build Coastguard Worker 
137*90e502c7SAndroid Build Coastguard Worker /*
138*90e502c7SAndroid Build Coastguard Worker  * note: the decrypt function is idential to the encrypt function
139*90e502c7SAndroid Build Coastguard Worker  */
140*90e502c7SAndroid Build Coastguard Worker 
141*90e502c7SAndroid Build Coastguard Worker const srtp_cipher_type_t srtp_null_cipher = {
142*90e502c7SAndroid Build Coastguard Worker     srtp_null_cipher_alloc,       /* */
143*90e502c7SAndroid Build Coastguard Worker     srtp_null_cipher_dealloc,     /* */
144*90e502c7SAndroid Build Coastguard Worker     srtp_null_cipher_init,        /* */
145*90e502c7SAndroid Build Coastguard Worker     0,                            /* set_aad */
146*90e502c7SAndroid Build Coastguard Worker     srtp_null_cipher_encrypt,     /* */
147*90e502c7SAndroid Build Coastguard Worker     srtp_null_cipher_encrypt,     /* */
148*90e502c7SAndroid Build Coastguard Worker     srtp_null_cipher_set_iv,      /* */
149*90e502c7SAndroid Build Coastguard Worker     0,                            /* get_tag */
150*90e502c7SAndroid Build Coastguard Worker     srtp_null_cipher_description, /* */
151*90e502c7SAndroid Build Coastguard Worker     &srtp_null_cipher_test_0,     /* */
152*90e502c7SAndroid Build Coastguard Worker     SRTP_NULL_CIPHER              /* */
153*90e502c7SAndroid Build Coastguard Worker };
154