Toggle navigation
Home
CycloneTCP
CycloneSSL
CycloneSSH
CycloneIPSEC
CycloneSTP
CycloneACME
CycloneCRYPTO
Download
Main Page
Data Structures
Files
File List
Globals
cyclone_crypto
hardware
s5d9
s5d9_crypto.c
Go to the documentation of this file.
1
/**
2
* @file s5d9_crypto.c
3
* @brief Synergy S5D9 hardware cryptographic accelerator (SCE7)
4
*
5
* @section License
6
*
7
* SPDX-License-Identifier: GPL-2.0-or-later
8
*
9
* Copyright (C) 2010-2024 Oryx Embedded SARL. All rights reserved.
10
*
11
* This file is part of CycloneCRYPTO Open.
12
*
13
* This program is free software; you can redistribute it and/or
14
* modify it under the terms of the GNU General Public License
15
* as published by the Free Software Foundation; either version 2
16
* of the License, or (at your option) any later version.
17
*
18
* This program is distributed in the hope that it will be useful,
19
* but WITHOUT ANY WARRANTY; without even the implied warranty of
20
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21
* GNU General Public License for more details.
22
*
23
* You should have received a copy of the GNU General Public License
24
* along with this program; if not, write to the Free Software Foundation,
25
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
26
*
27
* @author Oryx Embedded SARL (www.oryx-embedded.com)
28
* @version 2.4.4
29
**/
30
31
//Switch to the appropriate trace level
32
#define TRACE_LEVEL CRYPTO_TRACE_LEVEL
33
34
//Dependencies
35
#include "hw_sce_private.h"
36
#include "
core/crypto.h
"
37
#include "
hardware/s5d9/s5d9_crypto.h
"
38
#include "
debug.h
"
39
40
//Global variables
41
OsMutex
s5d9CryptoMutex
;
42
43
44
/**
45
* @brief Initialize hardware cryptographic accelerator
46
* @return Error code
47
**/
48
49
error_t
s5d9CryptoInit
(
void
)
50
{
51
ssp_err_t status;
52
53
//Initialize status code
54
status = SSP_SUCCESS;
55
56
//Create a mutex to prevent simultaneous access to the hardware
57
//cryptographic accelerator
58
if
(!
osCreateMutex
(&
s5d9CryptoMutex
))
59
{
60
//Failed to create mutex
61
status = SSP_ERR_CRYPTO_NOT_OPEN;
62
}
63
64
//Check status code
65
if
(status == SSP_SUCCESS)
66
{
67
//Initialize SCE7 module
68
status = HW_SCE_McuSpecificInit();
69
}
70
71
//Return status code
72
return
(status == SSP_SUCCESS) ?
NO_ERROR
:
ERROR_FAILURE
;
73
}
osCreateMutex
bool_t osCreateMutex(OsMutex *mutex)
Create a mutex object.
Definition:
os_port_chibios.c:370
s5d9CryptoInit
error_t s5d9CryptoInit(void)
Initialize hardware cryptographic accelerator.
Definition:
s5d9_crypto.c:49
error_t
error_t
Error codes.
Definition:
error.h:43
ERROR_FAILURE
@ ERROR_FAILURE
Generic error code.
Definition:
error.h:45
crypto.h
General definitions for cryptographic algorithms.
OsMutex
Mutex object.
Definition:
os_port_cmsis_rtos.h:136
s5d9CryptoMutex
OsMutex s5d9CryptoMutex
Definition:
s5d9_crypto.c:41
NO_ERROR
@ NO_ERROR
Success.
Definition:
error.h:44
debug.h
Debugging facilities.
s5d9_crypto.h
Synergy S5D9 hardware cryptographic accelerator (SCE7)