Skip to content

Commit 7656891

Browse files
authored
Merge pull request ARMmbed#9638 from itayzafrir/crypto-access-control
Crypto Service - keys access control
2 parents 7027eac + 37cc257 commit 7656891

File tree

3 files changed

+279
-6
lines changed

3 files changed

+279
-6
lines changed
Lines changed: 92 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,92 @@
1+
/*
2+
* Copyright (c) 2019, Arm Limited and affiliates
3+
* SPDX-License-Identifier: Apache-2.0
4+
*
5+
* Licensed under the Apache License, Version 2.0 (the "License");
6+
* you may not use this file except in compliance with the License.
7+
* You may obtain a copy of the License at
8+
*
9+
* http://www.apache.org/licenses/LICENSE-2.0
10+
*
11+
* Unless required by applicable law or agreed to in writing, software
12+
* distributed under the License is distributed on an "AS IS" BASIS,
13+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14+
* See the License for the specific language governing permissions and
15+
* limitations under the License.
16+
*/
17+
18+
#include <string.h>
19+
20+
#include "psa_crypto_access_control.h"
21+
#include "psa_crypto_core.h"
22+
#include "psa_crypto_slot_management.h"
23+
24+
#if defined(TARGET_TFM)
25+
#define SPM_PANIC(format, ...) \
26+
{ \
27+
while(1){}; \
28+
}
29+
#else
30+
#include "spm_panic.h"
31+
#endif
32+
33+
typedef struct psa_crypto_access_control_s {
34+
psa_key_handle_t key_handle;
35+
int32_t partition_id;
36+
} psa_crypto_access_control_t;
37+
38+
static psa_crypto_access_control_t crypto_access_control_arr[PSA_KEY_SLOT_COUNT];
39+
40+
static inline void psa_crypto_access_control_reset()
41+
{
42+
memset(crypto_access_control_arr, 0, sizeof(crypto_access_control_arr));
43+
}
44+
45+
void psa_crypto_access_control_init(void)
46+
{
47+
psa_crypto_access_control_reset();
48+
}
49+
50+
void psa_crypto_access_control_destroy(void)
51+
{
52+
psa_crypto_access_control_reset();
53+
}
54+
55+
void psa_crypto_access_control_register_handle(psa_key_handle_t key_handle, int32_t partition_id)
56+
{
57+
for (size_t i = 0; i < PSA_KEY_SLOT_COUNT; i++) {
58+
if (crypto_access_control_arr[i].key_handle == 0 &&
59+
crypto_access_control_arr[i].partition_id == 0) {
60+
crypto_access_control_arr[i].key_handle = key_handle;
61+
crypto_access_control_arr[i].partition_id = partition_id;
62+
return;
63+
}
64+
}
65+
66+
SPM_PANIC("psa_crypto_access_control_register_handle failed");
67+
}
68+
69+
void psa_crypto_access_control_unregister_handle(psa_key_handle_t key_handle)
70+
{
71+
for (size_t i = 0; i < PSA_KEY_SLOT_COUNT; i++) {
72+
if (crypto_access_control_arr[i].key_handle == key_handle) {
73+
crypto_access_control_arr[i].key_handle = 0;
74+
crypto_access_control_arr[i].partition_id = 0;
75+
return;
76+
}
77+
}
78+
79+
SPM_PANIC("psa_crypto_access_control_unregister_handle failed");
80+
}
81+
82+
uint8_t psa_crypto_access_control_is_handle_permitted(psa_key_handle_t key_handle, int32_t partition_id)
83+
{
84+
for (size_t i = 0; i < PSA_KEY_SLOT_COUNT; i++) {
85+
if (crypto_access_control_arr[i].key_handle == key_handle &&
86+
crypto_access_control_arr[i].partition_id == partition_id) {
87+
return 1;
88+
}
89+
}
90+
91+
return 0;
92+
}
Lines changed: 40 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
1+
/*
2+
* Copyright (c) 2019, Arm Limited and affiliates
3+
* SPDX-License-Identifier: Apache-2.0
4+
*
5+
* Licensed under the Apache License, Version 2.0 (the "License");
6+
* you may not use this file except in compliance with the License.
7+
* You may obtain a copy of the License at
8+
*
9+
* http://www.apache.org/licenses/LICENSE-2.0
10+
*
11+
* Unless required by applicable law or agreed to in writing, software
12+
* distributed under the License is distributed on an "AS IS" BASIS,
13+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14+
* See the License for the specific language governing permissions and
15+
* limitations under the License.
16+
*/
17+
18+
#ifndef PSA_CRYPTO_ACCESS_CONTROL_H
19+
#define PSA_CRYPTO_ACCESS_CONTROL_H
20+
21+
#include <stdint.h>
22+
23+
#include "crypto_platform.h"
24+
25+
/* initialize the module, resets all tracked information */
26+
void psa_crypto_access_control_init(void);
27+
28+
/* deinitialize the module, resets all tracked information */
29+
void psa_crypto_access_control_destroy(void);
30+
31+
/* tracks and associates the key_handle with partition_id */
32+
void psa_crypto_access_control_register_handle(psa_key_handle_t key_handle, int32_t partition_id);
33+
34+
/* removes tracking of the key_handle */
35+
void psa_crypto_access_control_unregister_handle(psa_key_handle_t key_handle);
36+
37+
/* checks if the key_handle is associated with the partition_id, returns 0 is false otherwise 1 */
38+
uint8_t psa_crypto_access_control_is_handle_permitted(psa_key_handle_t key_handle, int32_t partition_id);
39+
40+
#endif /* PSA_CRYPTO_ACCESS_CONTROL_H */

0 commit comments

Comments
 (0)