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 WorkerTripleDesEvpCipherDescription::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 WorkerTripleDesEvpCipherDescription::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 Workerconst 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