Toggle navigation
Home
CycloneTCP
CycloneSSL
CycloneSSH
CycloneIPSEC
CycloneSTP
CycloneACME
CycloneCRYPTO
Download
Main Page
Data Structures
Files
File List
Globals
cyclone_crypto
hardware
rx65n
rx65n_crypto.c
Go to the documentation of this file.
1
/**
2
* @file rx65n_crypto.c
3
* @brief RX65N hardware cryptographic accelerator (TSIP)
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 "r_tsip_rx_if.h"
36
#include "
core/crypto.h
"
37
#include "
hardware/rx65n/rx65n_crypto.h
"
38
#include "
debug.h
"
39
40
//Global variables
41
OsMutex
rx65nCryptoMutex
;
42
43
44
/**
45
* @brief Initialize hardware cryptographic accelerator
46
* @return Error code
47
**/
48
49
error_t
rx65nCryptoInit
(
void
)
50
{
51
e_tsip_err_t status;
52
53
//Initialize status code
54
status = TSIP_SUCCESS;
55
56
//Create a mutex to prevent simultaneous access to the hardware
57
//cryptographic accelerator
58
if
(!
osCreateMutex
(&
rx65nCryptoMutex
))
59
{
60
//Failed to create mutex
61
status = TSIP_ERR_FAIL;
62
}
63
64
//Check status code
65
if
(status == TSIP_SUCCESS)
66
{
67
//Initialize TSIP module
68
status = R_TSIP_Open(NULL, NULL);
69
}
70
71
//Return status code
72
return
(status == TSIP_SUCCESS) ?
NO_ERROR
:
ERROR_FAILURE
;
73
}
osCreateMutex
bool_t osCreateMutex(OsMutex *mutex)
Create a mutex object.
Definition:
os_port_chibios.c:370
rx65nCryptoInit
error_t rx65nCryptoInit(void)
Initialize hardware cryptographic accelerator.
Definition:
rx65n_crypto.c:49
rx65nCryptoMutex
OsMutex rx65nCryptoMutex
Definition:
rx65n_crypto.c:41
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
rx65n_crypto.h
RX65N hardware cryptographic accelerator (TSIP)
NO_ERROR
@ NO_ERROR
Success.
Definition:
error.h:44
debug.h
Debugging facilities.