MCUXpresso_LPC55S69/docs/MCUXpresso SDK API Referenc.../a00241.html

669 lines
33 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.5"/>
<title>MCUXpresso SDK API Reference Manual: casper_driver_pkha</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">MCUXpresso SDK API Reference Manual
&#160;<span id="projectnumber">Rev 2.15.000</span>
</div>
<div id="projectbrief">NXP Semiconductors</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.5 -->
<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&#160;Page</span></a></li>
<li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
<li><a href="modules.html"><span>API&#160;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('a00241.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">&#160;</span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark">&#160;</span>Data Structures</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark">&#160;</span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark">&#160;</span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark">&#160;</span>Typedefs</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark">&#160;</span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark">&#160;</span>Enumerator</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark">&#160;</span>Groups</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(8)"><span class="SelectionMark">&#160;</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="#func-members">Functions</a> </div>
<div class="headertitle">
<div class="title">casper_driver_pkha<div class="ingroups"><a class="el" href="a00239.html">CASPER: The Cryptographic Accelerator and Signal Processing Engine with RAM sharing</a></div></div> </div>
</div><!--header-->
<div class="contents">
<a name="details" id="details"></a><h2 class="groupheader">Overview</h2>
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a>
Functions</h2></td></tr>
<tr class="memitem:gae23f6641bd6344e7ed2b6daf34be6ab4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00241.html#gae23f6641bd6344e7ed2b6daf34be6ab4">CASPER_ModExp</a> (CASPER_Type *base, const uint8_t *signature, const uint8_t *pubN, size_t wordLen, uint32_t pubE, uint8_t *plaintext)</td></tr>
<tr class="memdesc:gae23f6641bd6344e7ed2b6daf34be6ab4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Performs modular exponentiation - (A^E) mod N. <a href="#gae23f6641bd6344e7ed2b6daf34be6ab4">More...</a><br/></td></tr>
<tr class="separator:gae23f6641bd6344e7ed2b6daf34be6ab4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ga56316671d80e86e7a17fbaa73cd074cd"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00241.html#ga56316671d80e86e7a17fbaa73cd074cd">CASPER_ecc_init</a> (<a class="el" href="a00240.html#gaeb3f0a23391e5fed42912a2775e12d44">casper_algo_t</a> curve)</td></tr>
<tr class="memdesc:ga56316671d80e86e7a17fbaa73cd074cd"><td class="mdescLeft">&#160;</td><td class="mdescRight">Initialize prime modulus mod in Casper memory . <a href="#ga56316671d80e86e7a17fbaa73cd074cd">More...</a><br/></td></tr>
<tr class="separator:ga56316671d80e86e7a17fbaa73cd074cd"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gac491ade7e7adfc6326e5c2f0a88ab88a"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00241.html#gac491ade7e7adfc6326e5c2f0a88ab88a">CASPER_ECC_SECP256R1_Mul</a> (CASPER_Type *base, uint32_t resX[8], uint32_t resY[8], uint32_t X[8], uint32_t Y[8], uint32_t scalar[8])</td></tr>
<tr class="memdesc:gac491ade7e7adfc6326e5c2f0a88ab88a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Performs ECC secp256r1 point single scalar multiplication. <a href="#gac491ade7e7adfc6326e5c2f0a88ab88a">More...</a><br/></td></tr>
<tr class="separator:gac491ade7e7adfc6326e5c2f0a88ab88a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ga8945a091e4852097e8be400c20c7e683"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00241.html#ga8945a091e4852097e8be400c20c7e683">CASPER_ECC_SECP256R1_MulAdd</a> (CASPER_Type *base, uint32_t resX[8], uint32_t resY[8], uint32_t X1[8], uint32_t Y1[8], uint32_t scalar1[8], uint32_t X2[8], uint32_t Y2[8], uint32_t scalar2[8])</td></tr>
<tr class="memdesc:ga8945a091e4852097e8be400c20c7e683"><td class="mdescLeft">&#160;</td><td class="mdescRight">Performs ECC secp256r1 point double scalar multiplication. <a href="#ga8945a091e4852097e8be400c20c7e683">More...</a><br/></td></tr>
<tr class="separator:ga8945a091e4852097e8be400c20c7e683"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gab51cd9db278d376a0fd37407d19893b0"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00241.html#gab51cd9db278d376a0fd37407d19893b0">CASPER_ECC_SECP384R1_Mul</a> (CASPER_Type *base, uint32_t resX[12], uint32_t resY[12], uint32_t X[12], uint32_t Y[12], uint32_t scalar[12])</td></tr>
<tr class="memdesc:gab51cd9db278d376a0fd37407d19893b0"><td class="mdescLeft">&#160;</td><td class="mdescRight">Performs ECC secp384r1 point single scalar multiplication. <a href="#gab51cd9db278d376a0fd37407d19893b0">More...</a><br/></td></tr>
<tr class="separator:gab51cd9db278d376a0fd37407d19893b0"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ga69fac3671477c8bcd9ccf1ed0f70a4e9"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00241.html#ga69fac3671477c8bcd9ccf1ed0f70a4e9">CASPER_ECC_SECP384R1_MulAdd</a> (CASPER_Type *base, uint32_t resX[12], uint32_t resY[12], uint32_t X1[12], uint32_t Y1[12], uint32_t scalar1[12], uint32_t X2[12], uint32_t Y2[12], uint32_t scalar2[12])</td></tr>
<tr class="memdesc:ga69fac3671477c8bcd9ccf1ed0f70a4e9"><td class="mdescLeft">&#160;</td><td class="mdescRight">Performs ECC secp384r1 point double scalar multiplication. <a href="#ga69fac3671477c8bcd9ccf1ed0f70a4e9">More...</a><br/></td></tr>
<tr class="separator:ga69fac3671477c8bcd9ccf1ed0f70a4e9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gacb1e9d71e66f066201612a09b933efbb"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00241.html#gacb1e9d71e66f066201612a09b933efbb">CASPER_ECC_SECP521R1_Mul</a> (CASPER_Type *base, uint32_t resX[18], uint32_t resY[18], uint32_t X[18], uint32_t Y[18], uint32_t scalar[18])</td></tr>
<tr class="memdesc:gacb1e9d71e66f066201612a09b933efbb"><td class="mdescLeft">&#160;</td><td class="mdescRight">Performs ECC secp521r1 point single scalar multiplication. <a href="#gacb1e9d71e66f066201612a09b933efbb">More...</a><br/></td></tr>
<tr class="separator:gacb1e9d71e66f066201612a09b933efbb"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gae82edbc3987d06b88a3313f0fbde10f4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00241.html#gae82edbc3987d06b88a3313f0fbde10f4">CASPER_ECC_SECP521R1_MulAdd</a> (CASPER_Type *base, uint32_t resX[18], uint32_t resY[18], uint32_t X1[18], uint32_t Y1[18], uint32_t scalar1[18], uint32_t X2[18], uint32_t Y2[18], uint32_t scalar2[18])</td></tr>
<tr class="memdesc:gae82edbc3987d06b88a3313f0fbde10f4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Performs ECC secp521r1 point double scalar multiplication. <a href="#gae82edbc3987d06b88a3313f0fbde10f4">More...</a><br/></td></tr>
<tr class="separator:gae82edbc3987d06b88a3313f0fbde10f4"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<h2 class="groupheader">Function Documentation</h2>
<a class="anchor" id="gae23f6641bd6344e7ed2b6daf34be6ab4"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void CASPER_ModExp </td>
<td>(</td>
<td class="paramtype">CASPER_Type *&#160;</td>
<td class="paramname"><em>base</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const uint8_t *&#160;</td>
<td class="paramname"><em>signature</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const uint8_t *&#160;</td>
<td class="paramname"><em>pubN</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">size_t&#160;</td>
<td class="paramname"><em>wordLen</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>pubE</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint8_t *&#160;</td>
<td class="paramname"><em>plaintext</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>This function performs modular exponentiation.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir"></td><td class="paramname">base</td><td>CASPER base address </td></tr>
<tr><td class="paramdir"></td><td class="paramname">signature</td><td>first addend (in little endian format) </td></tr>
<tr><td class="paramdir"></td><td class="paramname">pubN</td><td>modulus (in little endian format) </td></tr>
<tr><td class="paramdir"></td><td class="paramname">wordLen</td><td>Size of pubN in bytes </td></tr>
<tr><td class="paramdir"></td><td class="paramname">pubE</td><td>exponent </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">plaintext</td><td>Output array to store result of operation (in little endian format) </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a class="anchor" id="ga56316671d80e86e7a17fbaa73cd074cd"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void CASPER_ecc_init </td>
<td>(</td>
<td class="paramtype"><a class="el" href="a00240.html#gaeb3f0a23391e5fed42912a2775e12d44">casper_algo_t</a>&#160;</td>
<td class="paramname"><em>curve</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Set the prime modulus mod in Casper memory and set N_wordlen according to selected algorithm.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramname">curve</td><td>elliptic curve algoritm </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a class="anchor" id="gac491ade7e7adfc6326e5c2f0a88ab88a"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void CASPER_ECC_SECP256R1_Mul </td>
<td>(</td>
<td class="paramtype">CASPER_Type *&#160;</td>
<td class="paramname"><em>base</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>resX</em>[8], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>resY</em>[8], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>X</em>[8], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>Y</em>[8], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>scalar</em>[8]&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>This function performs ECC secp256r1 point single scalar multiplication [resX; resY] = scalar * [X; Y] Coordinates are affine in normal form, little endian. Scalars are little endian. All arrays are little endian byte arrays, uint32_t type is used only to enforce the 32-bit alignment (0-mod-4 address).</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir"></td><td class="paramname">base</td><td>CASPER base address </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">resX</td><td>Output X affine coordinate in normal form, little endian. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">resY</td><td>Output Y affine coordinate in normal form, little endian. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">X</td><td>Input X affine coordinate in normal form, little endian. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">Y</td><td>Input Y affine coordinate in normal form, little endian. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">scalar</td><td>Input scalar integer, in normal form, little endian. </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a class="anchor" id="ga8945a091e4852097e8be400c20c7e683"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void CASPER_ECC_SECP256R1_MulAdd </td>
<td>(</td>
<td class="paramtype">CASPER_Type *&#160;</td>
<td class="paramname"><em>base</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>resX</em>[8], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>resY</em>[8], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>X1</em>[8], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>Y1</em>[8], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>scalar1</em>[8], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>X2</em>[8], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>Y2</em>[8], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>scalar2</em>[8]&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>This function performs ECC secp256r1 point double scalar multiplication [resX; resY] = scalar1 * [X1; Y1] + scalar2 * [X2; Y2] Coordinates are affine in normal form, little endian. Scalars are little endian. All arrays are little endian byte arrays, uint32_t type is used only to enforce the 32-bit alignment (0-mod-4 address).</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir"></td><td class="paramname">base</td><td>CASPER base address </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">resX</td><td>Output X affine coordinate. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">resY</td><td>Output Y affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">X1</td><td>Input X1 affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">Y1</td><td>Input Y1 affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">scalar1</td><td>Input scalar1 integer. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">X2</td><td>Input X2 affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">Y2</td><td>Input Y2 affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">scalar2</td><td>Input scalar2 integer. </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a class="anchor" id="gab51cd9db278d376a0fd37407d19893b0"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void CASPER_ECC_SECP384R1_Mul </td>
<td>(</td>
<td class="paramtype">CASPER_Type *&#160;</td>
<td class="paramname"><em>base</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>resX</em>[12], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>resY</em>[12], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>X</em>[12], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>Y</em>[12], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>scalar</em>[12]&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>This function performs ECC secp384r1 point single scalar multiplication [resX; resY] = scalar * [X; Y] Coordinates are affine in normal form, little endian. Scalars are little endian. All arrays are little endian byte arrays, uint32_t type is used only to enforce the 32-bit alignment (0-mod-4 address).</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir"></td><td class="paramname">base</td><td>CASPER base address </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">resX</td><td>Output X affine coordinate in normal form, little endian. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">resY</td><td>Output Y affine coordinate in normal form, little endian. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">X</td><td>Input X affine coordinate in normal form, little endian. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">Y</td><td>Input Y affine coordinate in normal form, little endian. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">scalar</td><td>Input scalar integer, in normal form, little endian. </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a class="anchor" id="ga69fac3671477c8bcd9ccf1ed0f70a4e9"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void CASPER_ECC_SECP384R1_MulAdd </td>
<td>(</td>
<td class="paramtype">CASPER_Type *&#160;</td>
<td class="paramname"><em>base</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>resX</em>[12], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>resY</em>[12], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>X1</em>[12], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>Y1</em>[12], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>scalar1</em>[12], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>X2</em>[12], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>Y2</em>[12], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>scalar2</em>[12]&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>This function performs ECC secp384r1 point double scalar multiplication [resX; resY] = scalar1 * [X1; Y1] + scalar2 * [X2; Y2] Coordinates are affine in normal form, little endian. Scalars are little endian. All arrays are little endian byte arrays, uint32_t type is used only to enforce the 32-bit alignment (0-mod-4 address).</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir"></td><td class="paramname">base</td><td>CASPER base address </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">resX</td><td>Output X affine coordinate. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">resY</td><td>Output Y affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">X1</td><td>Input X1 affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">Y1</td><td>Input Y1 affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">scalar1</td><td>Input scalar1 integer. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">X2</td><td>Input X2 affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">Y2</td><td>Input Y2 affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">scalar2</td><td>Input scalar2 integer. </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a class="anchor" id="gacb1e9d71e66f066201612a09b933efbb"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void CASPER_ECC_SECP521R1_Mul </td>
<td>(</td>
<td class="paramtype">CASPER_Type *&#160;</td>
<td class="paramname"><em>base</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>resX</em>[18], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>resY</em>[18], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>X</em>[18], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>Y</em>[18], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>scalar</em>[18]&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>This function performs ECC secp521r1 point single scalar multiplication [resX; resY] = scalar * [X; Y] Coordinates are affine in normal form, little endian. Scalars are little endian. All arrays are little endian byte arrays, uint32_t type is used only to enforce the 32-bit alignment (0-mod-4 address).</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir"></td><td class="paramname">base</td><td>CASPER base address </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">resX</td><td>Output X affine coordinate in normal form, little endian. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">resY</td><td>Output Y affine coordinate in normal form, little endian. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">X</td><td>Input X affine coordinate in normal form, little endian. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">Y</td><td>Input Y affine coordinate in normal form, little endian. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">scalar</td><td>Input scalar integer, in normal form, little endian. </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a class="anchor" id="gae82edbc3987d06b88a3313f0fbde10f4"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void CASPER_ECC_SECP521R1_MulAdd </td>
<td>(</td>
<td class="paramtype">CASPER_Type *&#160;</td>
<td class="paramname"><em>base</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>resX</em>[18], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>resY</em>[18], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>X1</em>[18], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>Y1</em>[18], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>scalar1</em>[18], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>X2</em>[18], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>Y2</em>[18], </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint32_t&#160;</td>
<td class="paramname"><em>scalar2</em>[18]&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>This function performs ECC secp521r1 point double scalar multiplication [resX; resY] = scalar1 * [X1; Y1] + scalar2 * [X2; Y2] Coordinates are affine in normal form, little endian. Scalars are little endian. All arrays are little endian byte arrays, uint32_t type is used only to enforce the 32-bit alignment (0-mod-4 address).</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir"></td><td class="paramname">base</td><td>CASPER base address </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">resX</td><td>Output X affine coordinate. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">resY</td><td>Output Y affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">X1</td><td>Input X1 affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">Y1</td><td>Input Y1 affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">scalar1</td><td>Input scalar1 integer. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">X2</td><td>Input X2 affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">Y2</td><td>Input Y2 affine coordinate. </td></tr>
<tr><td class="paramdir"></td><td class="paramname">scalar2</td><td>Input scalar2 integer. </td></tr>
</table>
</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">&copy; 2016 NXP Semiconductors. All rights reserved.
</li>
</ul>
</div>
</body>
</html>