blob: eaa60b4fa74cc0cfb48b5c4713eed4acc3165e9c [file] [log] [blame]
David Brown5153bd62017-01-06 11:16:53 -07001/*
2 * Licensed to the Apache Software Foundation (ASF) under one
3 * or more contributor license agreements. See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership. The ASF licenses this file
6 * to you under the Apache License, Version 2.0 (the
7 * "License"); you may not use this file except in compliance
8 * with the License. You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing,
13 * software distributed under the License is distributed on an
14 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15 * KIND, either express or implied. See the License for the
16 * specific language governing permissions and limitations
17 * under the License.
18 */
19
20#include <zephyr.h>
David Brown5153bd62017-01-06 11:16:53 -070021#include <string.h>
22
23#include "os/os_heap.h"
24
Marti Bolivara4818a52018-04-12 13:02:38 -040025#ifdef CONFIG_BOOT_USE_MBEDTLS
Fabio Utzig28ee5b02017-12-12 08:10:40 -020026
David Brown5153bd62017-01-06 11:16:53 -070027#include <mbedtls/platform.h>
David Brown0bae9652017-10-19 16:45:09 -060028#include <mbedtls/memory_buffer_alloc.h>
David Brown5153bd62017-01-06 11:16:53 -070029
David Brown0bae9652017-10-19 16:45:09 -060030/*
31 * This is the heap for mbed TLS. The value needed depends on the key
Fabio Utzig105b59a2019-05-13 15:08:12 -070032 * size and algorithm used.
33 *
34 * - RSA-2048 signing without encryption is known to work well with 6144 bytes;
35 * - When using RSA-2048-OAEP encryption + RSA-2048 signing, or RSA-3072
36 * signing (no encryption) 10240 bytes seems to be enough.
37 *
38 * NOTE: RSA-3072 signing + RSA-2048-OAEP might require growing the size...
David Brown0bae9652017-10-19 16:45:09 -060039 */
Fabio Utzig105b59a2019-05-13 15:08:12 -070040#if (CONFIG_BOOT_SIGNATURE_TYPE_RSA_LEN == 2048) && !defined(CONFIG_BOOT_ENCRYPT_RSA)
David Brown0bae9652017-10-19 16:45:09 -060041#define CRYPTO_HEAP_SIZE 6144
Fabio Utzig4541b532018-12-17 09:17:15 -020042#else
Fabio Utzig6f4d8f82019-12-12 18:46:06 -030043# if !defined(MBEDTLS_RSA_NO_CRT)
44# define CRYPTO_HEAP_SIZE 10240
45# else
46# define CRYPTO_HEAP_SIZE 16384
47# endif
Fabio Utzig4541b532018-12-17 09:17:15 -020048#endif
David Brown5153bd62017-01-06 11:16:53 -070049
David Brown0bae9652017-10-19 16:45:09 -060050static unsigned char mempool[CRYPTO_HEAP_SIZE];
David Brown5153bd62017-01-06 11:16:53 -070051
52/*
53 * Initialize mbedtls to be able to use the local heap.
54 */
55void os_heap_init(void)
56{
David Brown0bae9652017-10-19 16:45:09 -060057 mbedtls_memory_buffer_alloc_init(mempool, sizeof(mempool));
David Brown5153bd62017-01-06 11:16:53 -070058}
David Browne9771ef2017-11-14 11:38:06 -070059#else
60void os_heap_init(void)
61{
62}
63#endif