summaryrefslogtreecommitdiff
Diffstat
-rwxr-xr-x4.0/AmlogicKeymaster4Device.cpp571
-rwxr-xr-x4.0/android.hardware.keymaster@4.0-service.amlogic.rc4
-rwxr-xr-x4.0/service.cpp43
-rwxr-xr-x[-rw-r--r--]8efb1e1c-37e5-4326-a5d68c33726c7d57.ta11646
-rwxr-xr-xAmlogicKeymaster.cpp352
-rwxr-xr-x[-rw-r--r--]Android.mk125
-rw-r--r--aml_keymaster_device.cpp1021
-rw-r--r--aml_keymaster_device.h194
-rw-r--r--aml_keymaster_ipc.cpp128
-rw-r--r--aml_keymaster_ipc.h33
-rwxr-xr-xinclude/amlogic_keymaster/AmlogicKeymaster.h86
-rwxr-xr-xinclude/amlogic_keymaster/AmlogicKeymaster4Device.h105
-rwxr-xr-xinclude/amlogic_keymaster/amlogic_keymaster_messages.h222
-rwxr-xr-xinclude/amlogic_keymaster/ipc/amlogic_keymaster_ipc.h52
-rwxr-xr-x[-rw-r--r--]include/amlogic_keymaster/ipc/keymaster_ipc.h (renamed from keymaster_ipc.h)17
-rwxr-xr-xipc/amlogic_keymaster_ipc.cpp325
-rw-r--r--module.cpp61
-rw-r--r--unit_test/android_keymaster_messages_test.cpp732
-rw-r--r--unit_test/android_keymaster_test.cpp3976
-rw-r--r--unit_test/android_keymaster_test_utils.cpp902
-rw-r--r--unit_test/android_keymaster_test_utils.h470
-rw-r--r--unit_test/android_keymaster_utils.h306
-rw-r--r--unit_test/attestation_record.cpp690
-rw-r--r--unit_test/attestation_record.h62
-rw-r--r--unit_test/attestation_record_test.cpp145
-rw-r--r--unit_test/authorization_set_test.cpp745
-rw-r--r--unit_test/ecies_kem_test.cpp73
-rw-r--r--unit_test/gtest_main.cpp34
-rw-r--r--unit_test/hkdf_test.cpp78
-rw-r--r--unit_test/hmac_test.cpp84
-rw-r--r--unit_test/kdf1_test.cpp60
-rw-r--r--unit_test/kdf2_test.cpp86
-rw-r--r--unit_test/kdf_test.cpp46
-rw-r--r--unit_test/key_blob_test.cpp362
-rw-r--r--unit_test/keymaster0_engine.h103
-rw-r--r--unit_test/keymaster1_engine.h123
-rw-r--r--unit_test/keymaster_configuration_test.cpp68
-rw-r--r--unit_test/keymaster_enforcement_test.cpp872
-rw-r--r--unit_test/keymaster_tags.cpp173
-rw-r--r--unit_test/nist_curve_key_exchange_test.cpp219
-rw-r--r--unit_test/openssl_utils.h100
-rw-r--r--unit_test/sw_rsa_attest_root.key.pem15
42 files changed, 6493 insertions, 19016 deletions
diff --git a/aml_keymaster_ipc.cpp b/aml_keymaster_ipc.cpp
deleted file mode 100644
index 7270db6..0000000
--- a/aml_keymaster_ipc.cpp
+++ b/dev/null
@@ -1,128 +0,0 @@
-/*
- * Copyright (C) 2015 The Android Open Source Project
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-#define LOG_TAG "AmlKeymaster"
-
-#include <errno.h>
-#include <stdlib.h>
-#include <string.h>
-#include <unistd.h>
-
-#include <log/log.h>
-
-#include "keymaster_ipc.h"
-#include "aml_keymaster_ipc.h"
-
-TEEC_Result aml_keymaster_connect(TEEC_Context *c, TEEC_Session *s) {
- TEEC_Result result = TEEC_SUCCESS;
- TEEC_UUID svc_id = TA_KEYMASTER_UUID;
- TEEC_Operation operation;
- uint32_t err_origin;
- struct timespec time;
- uint64_t millis = 0;
-
- memset(&operation, 0, sizeof(operation));
-
- /* Initialize Context */
- result = TEEC_InitializeContext(NULL, c);
-
- if (result != TEEC_SUCCESS) {
- ALOGD("TEEC_InitializeContext failed with error = %x\n", result);
- return result;
- }
- /* Open Session */
- result = TEEC_OpenSession(c, s, &svc_id,
- TEEC_LOGIN_PUBLIC,
- NULL, NULL,
- &err_origin);
-
- if (result != TEEC_SUCCESS) {
- ALOGD("TEEC_Opensession failed with code 0x%x origin 0x%x",result, err_origin);
- TEEC_FinalizeContext(c);
- return result;
- }
-
- int res = clock_gettime(CLOCK_BOOTTIME, &time);
- if (res < 0)
- millis = 0;
- else
- millis = (time.tv_sec * 1000) + (time.tv_nsec / 1000 / 1000);
-
- /* Init TA */
- operation.paramTypes = TEEC_PARAM_TYPES(
- TEEC_VALUE_INPUT, TEEC_NONE,
- TEEC_NONE, TEEC_NONE);
-
- operation.params[0].value.a = (millis >> 32);
- operation.params[0].value.b = (millis & 0xffffffff);
-
- result = TEEC_InvokeCommand(s,
- KM_TA_INIT,
- &operation,
- NULL);
-
- ALOGE("create id: %d, ctx: %p, ctx: %p\n", s->session_id, s->ctx, c);
- return result;
-}
-
-TEEC_Result aml_keymaster_call(TEEC_Session *s, uint32_t cmd, void* in, uint32_t in_size, uint8_t* out,
- uint32_t* out_size) {
- TEEC_Result res = TEEC_SUCCESS;
- TEEC_Operation op;
- uint32_t ret_orig;
-
- memset(&op, 0, sizeof(op));
-
- op.params[0].tmpref.buffer = in;
- op.params[0].tmpref.size = in_size;
- op.params[1].tmpref.buffer = out;
- op.params[1].tmpref.size = *out_size;
- op.paramTypes = TEEC_PARAM_TYPES(
- TEEC_MEMREF_TEMP_INPUT,
- TEEC_MEMREF_TEMP_OUTPUT,
- TEEC_VALUE_OUTPUT,
- TEEC_NONE);
-
- ALOGE("id: %d, ctx: %p, cmd: %d\n", s->session_id, s->ctx, cmd);
- res = TEEC_InvokeCommand(s, cmd, &op, &ret_orig);
- if (res != TEEC_SUCCESS) {
- ALOGE("Invoke cmd: %u failed with res(%x), ret_orig(%x), return(%d)\n",
- cmd, res, ret_orig, op.params[2].value.a);
- } else {
- *out_size = op.params[2].value.b;
- }
-
- return res;
-}
-
-TEEC_Result aml_keymaster_disconnect(TEEC_Context *c, TEEC_Session *s) {
- TEEC_Operation operation;
- TEEC_Result result = TEEC_SUCCESS;
-
- operation.paramTypes = TEEC_PARAM_TYPES(
- TEEC_NONE, TEEC_NONE,
- TEEC_NONE, TEEC_NONE);
-
- result = TEEC_InvokeCommand(s,
- KM_TA_TERM,
- &operation,
- NULL);
-
- TEEC_CloseSession(s);
- TEEC_FinalizeContext(c);
-
- return result;
-}