xref: /aosp_15_r20/system/keymaster/km_openssl/triple_des_operation.cpp (revision 789431f29546679ab5188a97751fb38e3018d44d)
1*789431f2SAndroid Build Coastguard Worker /*
2*789431f2SAndroid Build Coastguard Worker  * Copyright 2014 The Android Open Source Project
3*789431f2SAndroid Build Coastguard Worker  *
4*789431f2SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*789431f2SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*789431f2SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*789431f2SAndroid Build Coastguard Worker  *
8*789431f2SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*789431f2SAndroid Build Coastguard Worker  *
10*789431f2SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*789431f2SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*789431f2SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*789431f2SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*789431f2SAndroid Build Coastguard Worker  * limitations under the License.
15*789431f2SAndroid Build Coastguard Worker  */
16*789431f2SAndroid Build Coastguard Worker 
17*789431f2SAndroid Build Coastguard Worker #include "triple_des_operation.h"
18*789431f2SAndroid Build Coastguard Worker 
19*789431f2SAndroid Build Coastguard Worker namespace keymaster {
20*789431f2SAndroid Build Coastguard Worker 
21*789431f2SAndroid Build Coastguard Worker static const keymaster_block_mode_t supported_block_modes[] = {KM_MODE_ECB, KM_MODE_CBC};
22*789431f2SAndroid Build Coastguard Worker 
23*789431f2SAndroid Build Coastguard Worker const keymaster_block_mode_t*
SupportedBlockModes(size_t * block_mode_count) const24*789431f2SAndroid Build Coastguard Worker TripleDesEvpCipherDescription::SupportedBlockModes(size_t* block_mode_count) const {
25*789431f2SAndroid Build Coastguard Worker     *block_mode_count = array_length(supported_block_modes);
26*789431f2SAndroid Build Coastguard Worker     return supported_block_modes;
27*789431f2SAndroid Build Coastguard Worker }
28*789431f2SAndroid Build Coastguard Worker 
29*789431f2SAndroid Build Coastguard Worker const EVP_CIPHER*
GetCipherInstance(size_t key_size,keymaster_block_mode_t block_mode,keymaster_error_t * error) const30*789431f2SAndroid Build Coastguard Worker TripleDesEvpCipherDescription::GetCipherInstance(size_t key_size, keymaster_block_mode_t block_mode,
31*789431f2SAndroid Build Coastguard Worker                                                  keymaster_error_t* error) const {
32*789431f2SAndroid Build Coastguard Worker     *error = KM_ERROR_OK;
33*789431f2SAndroid Build Coastguard Worker 
34*789431f2SAndroid Build Coastguard Worker     switch (block_mode) {
35*789431f2SAndroid Build Coastguard Worker     case KM_MODE_ECB:
36*789431f2SAndroid Build Coastguard Worker         switch (key_size) {
37*789431f2SAndroid Build Coastguard Worker         case 16:
38*789431f2SAndroid Build Coastguard Worker             return EVP_des_ede();  // Note: OpenSSL 1.1.0 renamed this to EVP_des_ede_ecb
39*789431f2SAndroid Build Coastguard Worker         case 24:
40*789431f2SAndroid Build Coastguard Worker             return EVP_des_ede3();  // Note: OpenSSL 1.1.0 renamed this to EVP_des_ede3_ecb
41*789431f2SAndroid Build Coastguard Worker         default:
42*789431f2SAndroid Build Coastguard Worker             *error = KM_ERROR_UNSUPPORTED_KEY_SIZE;
43*789431f2SAndroid Build Coastguard Worker             break;
44*789431f2SAndroid Build Coastguard Worker         }
45*789431f2SAndroid Build Coastguard Worker         break;
46*789431f2SAndroid Build Coastguard Worker 
47*789431f2SAndroid Build Coastguard Worker     case KM_MODE_CBC:
48*789431f2SAndroid Build Coastguard Worker         switch (key_size) {
49*789431f2SAndroid Build Coastguard Worker         case 16:
50*789431f2SAndroid Build Coastguard Worker             return EVP_des_ede_cbc();
51*789431f2SAndroid Build Coastguard Worker         case 24:
52*789431f2SAndroid Build Coastguard Worker             return EVP_des_ede3_cbc();
53*789431f2SAndroid Build Coastguard Worker         default:
54*789431f2SAndroid Build Coastguard Worker             *error = KM_ERROR_UNSUPPORTED_KEY_SIZE;
55*789431f2SAndroid Build Coastguard Worker             break;
56*789431f2SAndroid Build Coastguard Worker         }
57*789431f2SAndroid Build Coastguard Worker         break;
58*789431f2SAndroid Build Coastguard Worker 
59*789431f2SAndroid Build Coastguard Worker     default:
60*789431f2SAndroid Build Coastguard Worker         *error = KM_ERROR_UNSUPPORTED_BLOCK_MODE;
61*789431f2SAndroid Build Coastguard Worker         break;
62*789431f2SAndroid Build Coastguard Worker     }
63*789431f2SAndroid Build Coastguard Worker 
64*789431f2SAndroid Build Coastguard Worker     assert(*error != KM_ERROR_OK);
65*789431f2SAndroid Build Coastguard Worker     return nullptr;
66*789431f2SAndroid Build Coastguard Worker }
67*789431f2SAndroid Build Coastguard Worker 
68*789431f2SAndroid Build Coastguard Worker static TripleDesEvpCipherDescription description;
GetCipherDescription() const69*789431f2SAndroid Build Coastguard Worker const EvpCipherDescription& TripleDesOperationFactory::GetCipherDescription() const {
70*789431f2SAndroid Build Coastguard Worker     return description;
71*789431f2SAndroid Build Coastguard Worker }
72*789431f2SAndroid Build Coastguard Worker 
73*789431f2SAndroid Build Coastguard Worker }  // namespace keymaster
74