550 lines
29 KiB
HTML
550 lines
29 KiB
HTML
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
|
<head>
|
|
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
<meta name="generator" content="Doxygen 1.8.6"/>
|
|
<title>Kinetis SDK v.2.0 API Reference Manual: LTC eDMA AES driver</title>
|
|
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="jquery.js"></script>
|
|
<script type="text/javascript" src="dynsections.js"></script>
|
|
<link href="navtree.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="resize.js"></script>
|
|
<script type="text/javascript" src="navtree.js"></script>
|
|
<script type="text/javascript">
|
|
$(document).ready(initResizable);
|
|
$(window).load(resizeHeight);
|
|
</script>
|
|
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="search/search.js"></script>
|
|
<script type="text/javascript">
|
|
$(document).ready(function() { searchBox.OnSelectItem(0); });
|
|
</script>
|
|
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
<link href="customdoxygen.css" rel="stylesheet" type="text/css"/>
|
|
</head>
|
|
<body>
|
|
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
<div id="titlearea">
|
|
<table cellspacing="0" cellpadding="0">
|
|
<tbody>
|
|
<tr style="height: 56px;">
|
|
<td id="projectlogo"><img alt="Logo" src="fs_logo.gif"/></td>
|
|
<td style="padding-left: 0.5em;">
|
|
<div id="projectname">Kinetis SDK v.2.0 API Reference Manual
|
|
 <span id="projectnumber">Rev. 0</span>
|
|
</div>
|
|
<div id="projectbrief">Freescale Semiconductor, Inc.</div>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<!-- end header part -->
|
|
<!-- Generated by Doxygen 1.8.6 -->
|
|
<script type="text/javascript">
|
|
var searchBox = new SearchBox("searchBox", "search",false,'Search');
|
|
</script>
|
|
<div id="navrow1" class="tabs">
|
|
<ul class="tablist">
|
|
<li><a href="index.html"><span>Main Page</span></a></li>
|
|
<li><a href="pages.html"><span>Related Pages</span></a></li>
|
|
<li><a href="modules.html"><span>API Reference</span></a></li>
|
|
<li>
|
|
<div id="MSearchBox" class="MSearchBoxInactive">
|
|
<span class="left">
|
|
<img id="MSearchSelect" src="search/mag_sel.png"
|
|
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
alt=""/>
|
|
<input type="text" id="MSearchField" value="Search" accesskey="S"
|
|
onfocus="searchBox.OnSearchFieldFocus(true)"
|
|
onblur="searchBox.OnSearchFieldFocus(false)"
|
|
onkeyup="searchBox.OnSearchFieldChange(event)"/>
|
|
</span><span class="right">
|
|
<a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
|
|
</span>
|
|
</div>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div><!-- top -->
|
|
<div id="side-nav" class="ui-resizable side-nav-resizable">
|
|
<div id="nav-tree">
|
|
<div id="nav-tree-contents">
|
|
<div id="nav-sync" class="sync"></div>
|
|
</div>
|
|
</div>
|
|
<div id="splitbar" style="-moz-user-select:none;"
|
|
class="ui-resizable-handle">
|
|
</div>
|
|
</div>
|
|
<script type="text/javascript">
|
|
$(document).ready(function(){initNavTree('group__ltc__edma__driver__aes.html','');});
|
|
</script>
|
|
<div id="doc-content">
|
|
<!-- window showing the filter options -->
|
|
<div id="MSearchSelectWindow"
|
|
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
<a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark"> </span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark"> </span>Data Structures</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark"> </span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark"> </span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark"> </span>Typedefs</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark"> </span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark"> </span>Enumerator</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark"> </span>Groups</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(8)"><span class="SelectionMark"> </span>Pages</a></div>
|
|
|
|
<!-- iframe showing the search results (closed by default) -->
|
|
<div id="MSearchResultsWindow">
|
|
<iframe src="javascript:void(0)" frameborder="0"
|
|
name="MSearchResults" id="MSearchResults">
|
|
</iframe>
|
|
</div>
|
|
|
|
<div class="header">
|
|
<div class="summary">
|
|
<a href="#define-members">Macros</a> |
|
|
<a href="#func-members">Functions</a> </div>
|
|
<div class="headertitle">
|
|
<div class="title">LTC eDMA AES driver<div class="ingroups"><a class="el" href="group__ltc__edma__driver.html">LTC Non-blocking eDMA APIs</a></div></div> </div>
|
|
</div><!--header-->
|
|
<div class="contents">
|
|
<a name="details" id="details"></a><h2 class="groupheader">Overview</h2>
|
|
<p>This section describes the programming interface of the LTC EDMA AES driver. </p>
|
|
<table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="define-members"></a>
|
|
Macros</h2></td></tr>
|
|
<tr class="memitem:ga153b1bda00df624919e1fce8dc3b9aae"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ga153b1bda00df624919e1fce8dc3b9aae"></a>
|
|
#define </td><td class="memItemRight" valign="bottom"><a class="el" href="group__ltc__edma__driver__aes.html#ga153b1bda00df624919e1fce8dc3b9aae">LTC_AES_DecryptCtrEDMA</a>(base, handle, input, output, size, counter, key, keySize, counterlast, szLeft)   <a class="el" href="group__ltc__edma__driver__aes.html#gad36d9219457ff9618c7b38180761d9f3">LTC_AES_CryptCtrEDMA</a>(base, handle, input, output, size, counter, key, keySize, counterlast, szLeft)</td></tr>
|
|
<tr class="memdesc:ga153b1bda00df624919e1fce8dc3b9aae"><td class="mdescLeft"> </td><td class="mdescRight">AES CTR decrypt is mapped to the AES CTR generic operation. <br/></td></tr>
|
|
<tr class="separator:ga153b1bda00df624919e1fce8dc3b9aae"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:gad7b8af8e0b417716cca43d5135213cbb"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="gad7b8af8e0b417716cca43d5135213cbb"></a>
|
|
#define </td><td class="memItemRight" valign="bottom"><a class="el" href="group__ltc__edma__driver__aes.html#gad7b8af8e0b417716cca43d5135213cbb">LTC_AES_EncryptCtrEDMA</a>(base, handle, input, output, size, counter, key, keySize, counterlast, szLeft)   <a class="el" href="group__ltc__edma__driver__aes.html#gad36d9219457ff9618c7b38180761d9f3">LTC_AES_CryptCtrEDMA</a>(base, handle, input, output, size, counter, key, keySize, counterlast, szLeft)</td></tr>
|
|
<tr class="memdesc:gad7b8af8e0b417716cca43d5135213cbb"><td class="mdescLeft"> </td><td class="mdescRight">AES CTR encrypt is mapped to the AES CTR generic operation. <br/></td></tr>
|
|
<tr class="separator:gad7b8af8e0b417716cca43d5135213cbb"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table><table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a>
|
|
Functions</h2></td></tr>
|
|
<tr class="memitem:ga3121a6c1b7feaeaaa2765c4150e0f46d"><td class="memItemLeft" align="right" valign="top">status_t </td><td class="memItemRight" valign="bottom"><a class="el" href="group__ltc__edma__driver__aes.html#ga3121a6c1b7feaeaaa2765c4150e0f46d">LTC_AES_EncryptEcbEDMA</a> (LTC_Type *base, ltc_edma_handle_t *handle, const uint8_t *plaintext, uint8_t *ciphertext, uint32_t size, const uint8_t *key, uint32_t keySize)</td></tr>
|
|
<tr class="memdesc:ga3121a6c1b7feaeaaa2765c4150e0f46d"><td class="mdescLeft"> </td><td class="mdescRight">Encrypts AES using the ECB block mode. <a href="#ga3121a6c1b7feaeaaa2765c4150e0f46d">More...</a><br/></td></tr>
|
|
<tr class="separator:ga3121a6c1b7feaeaaa2765c4150e0f46d"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ga99240b0b534844dbc0548177d3751334"><td class="memItemLeft" align="right" valign="top">status_t </td><td class="memItemRight" valign="bottom"><a class="el" href="group__ltc__edma__driver__aes.html#ga99240b0b534844dbc0548177d3751334">LTC_AES_DecryptEcbEDMA</a> (LTC_Type *base, ltc_edma_handle_t *handle, const uint8_t *ciphertext, uint8_t *plaintext, uint32_t size, const uint8_t *key, uint32_t keySize, <a class="el" href="group__ltc__driver__aes.html#ga27d8eb054f08682d9514d575e682eafb">ltc_aes_key_t</a> keyType)</td></tr>
|
|
<tr class="memdesc:ga99240b0b534844dbc0548177d3751334"><td class="mdescLeft"> </td><td class="mdescRight">Decrypts AES using ECB block mode. <a href="#ga99240b0b534844dbc0548177d3751334">More...</a><br/></td></tr>
|
|
<tr class="separator:ga99240b0b534844dbc0548177d3751334"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ga66c51352763fa816367cbf65ade7bb0e"><td class="memItemLeft" align="right" valign="top">status_t </td><td class="memItemRight" valign="bottom"><a class="el" href="group__ltc__edma__driver__aes.html#ga66c51352763fa816367cbf65ade7bb0e">LTC_AES_EncryptCbcEDMA</a> (LTC_Type *base, ltc_edma_handle_t *handle, const uint8_t *plaintext, uint8_t *ciphertext, uint32_t size, const uint8_t iv[<a class="el" href="group__ltc__driver__aes.html#ga5a2bfdc6fb7984ec4735fae9af33c637">LTC_AES_IV_SIZE</a>], const uint8_t *key, uint32_t keySize)</td></tr>
|
|
<tr class="memdesc:ga66c51352763fa816367cbf65ade7bb0e"><td class="mdescLeft"> </td><td class="mdescRight">Encrypts AES using CBC block mode. <a href="#ga66c51352763fa816367cbf65ade7bb0e">More...</a><br/></td></tr>
|
|
<tr class="separator:ga66c51352763fa816367cbf65ade7bb0e"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:gae65a84cb3fc0a7741edcf7e6118a8613"><td class="memItemLeft" align="right" valign="top">status_t </td><td class="memItemRight" valign="bottom"><a class="el" href="group__ltc__edma__driver__aes.html#gae65a84cb3fc0a7741edcf7e6118a8613">LTC_AES_DecryptCbcEDMA</a> (LTC_Type *base, ltc_edma_handle_t *handle, const uint8_t *ciphertext, uint8_t *plaintext, uint32_t size, const uint8_t iv[<a class="el" href="group__ltc__driver__aes.html#ga5a2bfdc6fb7984ec4735fae9af33c637">LTC_AES_IV_SIZE</a>], const uint8_t *key, uint32_t keySize, <a class="el" href="group__ltc__driver__aes.html#ga27d8eb054f08682d9514d575e682eafb">ltc_aes_key_t</a> keyType)</td></tr>
|
|
<tr class="memdesc:gae65a84cb3fc0a7741edcf7e6118a8613"><td class="mdescLeft"> </td><td class="mdescRight">Decrypts AES using CBC block mode. <a href="#gae65a84cb3fc0a7741edcf7e6118a8613">More...</a><br/></td></tr>
|
|
<tr class="separator:gae65a84cb3fc0a7741edcf7e6118a8613"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:gad36d9219457ff9618c7b38180761d9f3"><td class="memItemLeft" align="right" valign="top">status_t </td><td class="memItemRight" valign="bottom"><a class="el" href="group__ltc__edma__driver__aes.html#gad36d9219457ff9618c7b38180761d9f3">LTC_AES_CryptCtrEDMA</a> (LTC_Type *base, ltc_edma_handle_t *handle, const uint8_t *input, uint8_t *output, uint32_t size, uint8_t counter[<a class="el" href="group__ltc__driver__aes.html#gacd3ad4fc9a5754f2c8eaee6ef5f93377">LTC_AES_BLOCK_SIZE</a>], const uint8_t *key, uint32_t keySize, uint8_t counterlast[<a class="el" href="group__ltc__driver__aes.html#gacd3ad4fc9a5754f2c8eaee6ef5f93377">LTC_AES_BLOCK_SIZE</a>], uint32_t *szLeft)</td></tr>
|
|
<tr class="memdesc:gad36d9219457ff9618c7b38180761d9f3"><td class="mdescLeft"> </td><td class="mdescRight">Encrypts or decrypts AES using CTR block mode. <a href="#gad36d9219457ff9618c7b38180761d9f3">More...</a><br/></td></tr>
|
|
<tr class="separator:gad36d9219457ff9618c7b38180761d9f3"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table>
|
|
<h2 class="groupheader">Function Documentation</h2>
|
|
<a class="anchor" id="ga3121a6c1b7feaeaaa2765c4150e0f46d"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">status_t LTC_AES_EncryptEcbEDMA </td>
|
|
<td>(</td>
|
|
<td class="paramtype">LTC_Type * </td>
|
|
<td class="paramname"><em>base</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">ltc_edma_handle_t * </td>
|
|
<td class="paramname"><em>handle</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const uint8_t * </td>
|
|
<td class="paramname"><em>plaintext</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint8_t * </td>
|
|
<td class="paramname"><em>ciphertext</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint32_t </td>
|
|
<td class="paramname"><em>size</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const uint8_t * </td>
|
|
<td class="paramname"><em>key</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint32_t </td>
|
|
<td class="paramname"><em>keySize</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>Encrypts AES using the ECB block mode.</p>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramdir"></td><td class="paramname">base</td><td>LTC peripheral base address </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">handle</td><td>pointer to ltc_edma_handle_t structure which stores the transaction state. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">plaintext</td><td>Input plain text to encrypt </td></tr>
|
|
<tr><td class="paramdir">[out]</td><td class="paramname">ciphertext</td><td>Output cipher text </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">size</td><td>Size of input and output data in bytes. Must be multiple of 16 bytes. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">key</td><td>Input key to use for encryption </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">keySize</td><td>Size of the input key, in bytes. Must be 16, 24, or 32. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>Status from encrypt operation </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="ga99240b0b534844dbc0548177d3751334"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">status_t LTC_AES_DecryptEcbEDMA </td>
|
|
<td>(</td>
|
|
<td class="paramtype">LTC_Type * </td>
|
|
<td class="paramname"><em>base</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">ltc_edma_handle_t * </td>
|
|
<td class="paramname"><em>handle</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const uint8_t * </td>
|
|
<td class="paramname"><em>ciphertext</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint8_t * </td>
|
|
<td class="paramname"><em>plaintext</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint32_t </td>
|
|
<td class="paramname"><em>size</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const uint8_t * </td>
|
|
<td class="paramname"><em>key</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint32_t </td>
|
|
<td class="paramname"><em>keySize</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="el" href="group__ltc__driver__aes.html#ga27d8eb054f08682d9514d575e682eafb">ltc_aes_key_t</a> </td>
|
|
<td class="paramname"><em>keyType</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>Decrypts AES using ECB block mode.</p>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramdir"></td><td class="paramname">base</td><td>LTC peripheral base address </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">handle</td><td>pointer to ltc_edma_handle_t structure which stores the transaction state. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">ciphertext</td><td>Input cipher text to decrypt </td></tr>
|
|
<tr><td class="paramdir">[out]</td><td class="paramname">plaintext</td><td>Output plain text </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">size</td><td>Size of input and output data in bytes. Must be multiple of 16 bytes. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">key</td><td>Input key. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">keySize</td><td>Size of the input key, in bytes. Must be 16, 24, or 32. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">keyType</td><td>Input type of the key (allows to directly load decrypt key for AES ECB decrypt operation.) </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>Status from decrypt operation </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="ga66c51352763fa816367cbf65ade7bb0e"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">status_t LTC_AES_EncryptCbcEDMA </td>
|
|
<td>(</td>
|
|
<td class="paramtype">LTC_Type * </td>
|
|
<td class="paramname"><em>base</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">ltc_edma_handle_t * </td>
|
|
<td class="paramname"><em>handle</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const uint8_t * </td>
|
|
<td class="paramname"><em>plaintext</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint8_t * </td>
|
|
<td class="paramname"><em>ciphertext</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint32_t </td>
|
|
<td class="paramname"><em>size</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const uint8_t </td>
|
|
<td class="paramname"><em>iv</em>[LTC_AES_IV_SIZE], </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const uint8_t * </td>
|
|
<td class="paramname"><em>key</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint32_t </td>
|
|
<td class="paramname"><em>keySize</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramdir"></td><td class="paramname">base</td><td>LTC peripheral base address </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">handle</td><td>pointer to ltc_edma_handle_t structure which stores the transaction state. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">plaintext</td><td>Input plain text to encrypt </td></tr>
|
|
<tr><td class="paramdir">[out]</td><td class="paramname">ciphertext</td><td>Output cipher text </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">size</td><td>Size of input and output data in bytes. Must be multiple of 16 bytes. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">iv</td><td>Input initial vector to combine with the first input block. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">key</td><td>Input key to use for encryption </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">keySize</td><td>Size of the input key, in bytes. Must be 16, 24, or 32. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>Status from encrypt operation </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="gae65a84cb3fc0a7741edcf7e6118a8613"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">status_t LTC_AES_DecryptCbcEDMA </td>
|
|
<td>(</td>
|
|
<td class="paramtype">LTC_Type * </td>
|
|
<td class="paramname"><em>base</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">ltc_edma_handle_t * </td>
|
|
<td class="paramname"><em>handle</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const uint8_t * </td>
|
|
<td class="paramname"><em>ciphertext</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint8_t * </td>
|
|
<td class="paramname"><em>plaintext</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint32_t </td>
|
|
<td class="paramname"><em>size</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const uint8_t </td>
|
|
<td class="paramname"><em>iv</em>[LTC_AES_IV_SIZE], </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const uint8_t * </td>
|
|
<td class="paramname"><em>key</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint32_t </td>
|
|
<td class="paramname"><em>keySize</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="el" href="group__ltc__driver__aes.html#ga27d8eb054f08682d9514d575e682eafb">ltc_aes_key_t</a> </td>
|
|
<td class="paramname"><em>keyType</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramdir"></td><td class="paramname">base</td><td>LTC peripheral base address </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">handle</td><td>pointer to ltc_edma_handle_t structure which stores the transaction state. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">ciphertext</td><td>Input cipher text to decrypt </td></tr>
|
|
<tr><td class="paramdir">[out]</td><td class="paramname">plaintext</td><td>Output plain text </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">size</td><td>Size of input and output data in bytes. Must be multiple of 16 bytes. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">iv</td><td>Input initial vector to combine with the first input block. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">key</td><td>Input key to use for decryption </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">keySize</td><td>Size of the input key, in bytes. Must be 16, 24, or 32. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">keyType</td><td>Input type of the key (allows to directly load decrypt key for AES CBC decrypt operation.) </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>Status from decrypt operation </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="gad36d9219457ff9618c7b38180761d9f3"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">status_t LTC_AES_CryptCtrEDMA </td>
|
|
<td>(</td>
|
|
<td class="paramtype">LTC_Type * </td>
|
|
<td class="paramname"><em>base</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">ltc_edma_handle_t * </td>
|
|
<td class="paramname"><em>handle</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const uint8_t * </td>
|
|
<td class="paramname"><em>input</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint8_t * </td>
|
|
<td class="paramname"><em>output</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint32_t </td>
|
|
<td class="paramname"><em>size</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint8_t </td>
|
|
<td class="paramname"><em>counter</em>[LTC_AES_BLOCK_SIZE], </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const uint8_t * </td>
|
|
<td class="paramname"><em>key</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint32_t </td>
|
|
<td class="paramname"><em>keySize</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint8_t </td>
|
|
<td class="paramname"><em>counterlast</em>[LTC_AES_BLOCK_SIZE], </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">uint32_t * </td>
|
|
<td class="paramname"><em>szLeft</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>Encrypts or decrypts AES using CTR block mode. AES CTR mode uses only forward AES cipher and same algorithm for encryption and decryption. The only difference between encryption and decryption is that, for encryption, the input argument is plain text and the output argument is cipher text. For decryption, the input argument is cipher text and the output argument is plain text.</p>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramdir"></td><td class="paramname">base</td><td>LTC peripheral base address </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">handle</td><td>pointer to ltc_edma_handle_t structure which stores the transaction state. </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">input</td><td>Input data for CTR block mode </td></tr>
|
|
<tr><td class="paramdir">[out]</td><td class="paramname">output</td><td>Output data for CTR block mode </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">size</td><td>Size of input and output data in bytes </td></tr>
|
|
<tr><td class="paramdir">[in,out]</td><td class="paramname">counter</td><td>Input counter (updates on return) </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">key</td><td>Input key to use for forward AES cipher </td></tr>
|
|
<tr><td class="paramdir"></td><td class="paramname">keySize</td><td>Size of the input key, in bytes. Must be 16, 24, or 32. </td></tr>
|
|
<tr><td class="paramdir">[out]</td><td class="paramname">counterlast</td><td>Output cipher of last counter, for chained CTR calls. NULL can be passed if chained calls are not used. </td></tr>
|
|
<tr><td class="paramdir">[out]</td><td class="paramname">szLeft</td><td>Output number of bytes in left unused in counterlast block. NULL can be passed if chained calls are not used. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>Status from encrypt operation </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
</div><!-- contents -->
|
|
</div><!-- doc-content -->
|
|
<!-- HTML footer for doxygen 1.8.5-->
|
|
<!-- start footer part -->
|
|
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
|
|
<ul class="foot">
|
|
<li class="footer">© 2016 NXP Semiconductors. All rights reserved.
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</body>
|
|
</html>
|