blob: 158d52c276c64a8a5e4a239f33c495edea3fc966 [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
25#define MBEDTLS_CONFIG_FILE CONFIG_MBEDTLS_CFG_FILE
26#include <mbedtls/platform.h>
David Brown0bae9652017-10-19 16:45:09 -060027#include <mbedtls/memory_buffer_alloc.h>
David Brown5153bd62017-01-06 11:16:53 -070028
David Brown0bae9652017-10-19 16:45:09 -060029/*
30 * This is the heap for mbed TLS. The value needed depends on the key
31 * size and algorithm used. For RSA-2048, 6144 bytes seems to be
32 * enough.
33 */
34#define CRYPTO_HEAP_SIZE 6144
David Brown5153bd62017-01-06 11:16:53 -070035
David Brown0bae9652017-10-19 16:45:09 -060036static unsigned char mempool[CRYPTO_HEAP_SIZE];
David Brown5153bd62017-01-06 11:16:53 -070037
38/*
39 * Initialize mbedtls to be able to use the local heap.
40 */
41void os_heap_init(void)
42{
David Brown0bae9652017-10-19 16:45:09 -060043 mbedtls_memory_buffer_alloc_init(mempool, sizeof(mempool));
David Brown5153bd62017-01-06 11:16:53 -070044}