]> begriffs open source - cmsis/blob - main/Core/group__intrinsic__SIMD__gr.html
Update documentation for branch main
[cmsis] / main / Core / group__intrinsic__SIMD__gr.html
1 <!-- HTML header for doxygen 1.9.6-->
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml" lang="en-US">
4 <head>
5 <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
6 <meta http-equiv="X-UA-Compatible" content="IE=11"/>
7 <meta name="viewport" content="width=device-width, initial-scale=1"/>
8 <title>CMSIS-Core (Cortex-M): Intrinsic Functions for SIMD Instructions</title>
9 <link href="doxygen.css" rel="stylesheet" type="text/css" />
10 <script type="text/javascript" src="jquery.js"></script>
11 <script type="text/javascript" src="dynsections.js"></script>
12 <script type="text/javascript" src="tabs.js"></script>
13 <script type="text/javascript" src="footer.js"></script>
14 <script type="text/javascript" src="navtree.js"></script>
15 <link href="navtree.css" rel="stylesheet" type="text/css"/>
16 <script type="text/javascript" src="resize.js"></script>
17 <script type="text/javascript" src="navtreedata.js"></script>
18 <script type="text/javascript" src="navtree.js"></script>
19 <link href="search/search.css" rel="stylesheet" type="text/css"/>
20 <script type="text/javascript" src="search/searchdata.js"></script>
21 <script type="text/javascript" src="search/search.js"></script>
22 <script type="text/javascript">
23 /* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
24   $(document).ready(function() { init_search(); });
25 /* @license-end */
26 </script>
27 <script type="text/javascript" src="darkmode_toggle.js"></script>
28 <link href="extra_stylesheet.css" rel="stylesheet" type="text/css"/>
29 <link href="extra_navtree.css" rel="stylesheet" type="text/css"/>
30 <link href="extra_search.css" rel="stylesheet" type="text/css"/>
31 <link href="extra_tabs.css" rel="stylesheet" type="text/css"/>
32 <link href="version.css" rel="stylesheet" type="text/css"/>
33 <script type="text/javascript" src="../../version.js"></script>
34 </head>
35 <body>
36 <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
37 <div id="titlearea">
38 <table cellspacing="0" cellpadding="0">
39  <tbody>
40  <tr style="height: 55px;">
41   <td id="projectlogo" style="padding: 1.5em;"><img alt="Logo" src="cmsis_logo_white_small.png"/></td>
42   <td style="padding-left: 1em; padding-bottom: 1em;padding-top: 1em;">
43    <div id="projectname">CMSIS-Core (Cortex-M)
44    &#160;<span id="projectnumber"><script type="text/javascript">
45      <!--
46      writeHeader.call(this);
47      writeVersionDropdown.call(this, "CMSIS-Core (Cortex-M)");
48      //-->
49     </script>
50    </span>
51    </div>
52    <div id="projectbrief">CMSIS-Core support for Cortex-M processor-based devices</div>
53   </td>
54    <td>        <div id="MSearchBox" class="MSearchBoxInactive">
55         <span class="left">
56           <span id="MSearchSelect"                onmouseover="return searchBox.OnSearchSelectShow()"                onmouseout="return searchBox.OnSearchSelectHide()">&#160;</span>
57           <input type="text" id="MSearchField" value="" placeholder="Search" accesskey="S"
58                onfocus="searchBox.OnSearchFieldFocus(true)" 
59                onblur="searchBox.OnSearchFieldFocus(false)" 
60                onkeyup="searchBox.OnSearchFieldChange(event)"/>
61           </span><span class="right">
62             <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.svg" alt=""/></a>
63           </span>
64         </div>
65 </td>
66   <!--END !PROJECT_NAME-->
67  </tr>
68  </tbody>
69 </table>
70 </div>
71 <!-- end header part -->
72 <div id="CMSISnav" class="tabs1">
73   <ul class="tablist">
74     <script type="text/javascript">
75       writeComponentTabs.call(this);
76     </script>
77   </ul>
78 </div>
79 <script type="text/javascript">
80   writeSubComponentTabs.call(this);
81 </script>
82 <!-- Generated by Doxygen 1.9.6 -->
83 <script type="text/javascript">
84 /* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
85 var searchBox = new SearchBox("searchBox", "search/",'.html');
86 /* @license-end */
87 </script>
88 </div><!-- top -->
89 <div id="side-nav" class="ui-resizable side-nav-resizable">
90   <div id="nav-tree">
91     <div id="nav-tree-contents">
92       <div id="nav-sync" class="sync"></div>
93     </div>
94   </div>
95   <div id="splitbar" style="-moz-user-select:none;" 
96        class="ui-resizable-handle">
97   </div>
98 </div>
99 <script type="text/javascript">
100 /* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
101 $(document).ready(function(){initNavTree('group__intrinsic__SIMD__gr.html',''); initResizable(); });
102 /* @license-end */
103 </script>
104 <div id="doc-content">
105 <!-- window showing the filter options -->
106 <div id="MSearchSelectWindow"
107      onmouseover="return searchBox.OnSearchSelectShow()"
108      onmouseout="return searchBox.OnSearchSelectHide()"
109      onkeydown="return searchBox.OnSearchSelectKey(event)">
110 </div>
111
112 <!-- iframe showing the search results (closed by default) -->
113 <div id="MSearchResultsWindow">
114 <div id="MSearchResults">
115 <div class="SRPage">
116 <div id="SRIndex">
117 <div id="SRResults"></div>
118 <div class="SRStatus" id="Loading">Loading...</div>
119 <div class="SRStatus" id="Searching">Searching...</div>
120 <div class="SRStatus" id="NoMatches">No Matches</div>
121 </div>
122 </div>
123 </div>
124 </div>
125
126 <div class="header">
127   <div class="summary">
128 <a href="#func-members">Functions</a>  </div>
129   <div class="headertitle"><div class="title">Intrinsic Functions for SIMD Instructions</div></div>
130 </div><!--header-->
131 <div class="contents">
132
133 <p>Access to dedicated SIMD instructions available on Armv7E-M (Cortex-M4/M7), Armv8-M Mainline (Cortex-M33/M35P), and Armv8.1-M (Cortex-M55/M85).  
134 <a href="#details">More...</a></p>
135 <table class="memberdecls">
136 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a>
137 Functions</h2></td></tr>
138 <tr class="memitem:gaefb8ebf3a54e197464da1ff69a44f4b5"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gaefb8ebf3a54e197464da1ff69a44f4b5">__PKHBT</a> (uint32_t val1, uint32_t val2, uint32_t val3)</td></tr>
139 <tr class="memdesc:gaefb8ebf3a54e197464da1ff69a44f4b5"><td class="mdescLeft">&#160;</td><td class="mdescRight">Halfword packing instruction. Combines bits[15:0] of <em>val1</em> with bits[31:16] of <em>val2</em> levitated with the <em>val3</em>.  <br /></td></tr>
140 <tr class="separator:gaefb8ebf3a54e197464da1ff69a44f4b5"><td class="memSeparator" colspan="2">&#160;</td></tr>
141 <tr class="memitem:gafd8fe4a6d87e947caa81a69ec36c1666"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gafd8fe4a6d87e947caa81a69ec36c1666">__PKHTB</a> (uint32_t val1, uint32_t val2, uint32_t val3)</td></tr>
142 <tr class="memdesc:gafd8fe4a6d87e947caa81a69ec36c1666"><td class="mdescLeft">&#160;</td><td class="mdescRight">Halfword packing instruction. Combines bits[31:16] of <em>val1</em> with bits[15:0] of <em>val2</em> right-shifted with the <em>val3</em>.  <br /></td></tr>
143 <tr class="separator:gafd8fe4a6d87e947caa81a69ec36c1666"><td class="memSeparator" colspan="2">&#160;</td></tr>
144 <tr class="memitem:ga17b873f246c9f5e9355760ffef3dad4a"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga17b873f246c9f5e9355760ffef3dad4a">__QADD</a> (uint32_t val1, uint32_t val2)</td></tr>
145 <tr class="memdesc:ga17b873f246c9f5e9355760ffef3dad4a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting saturating add.  <br /></td></tr>
146 <tr class="separator:ga17b873f246c9f5e9355760ffef3dad4a"><td class="memSeparator" colspan="2">&#160;</td></tr>
147 <tr class="memitem:gae83a53ec04b496304bed6d9fe8f7461b"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gae83a53ec04b496304bed6d9fe8f7461b">__QADD16</a> (uint32_t val1, uint32_t val2)</td></tr>
148 <tr class="memdesc:gae83a53ec04b496304bed6d9fe8f7461b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting dual 16-bit saturating addition.  <br /></td></tr>
149 <tr class="separator:gae83a53ec04b496304bed6d9fe8f7461b"><td class="memSeparator" colspan="2">&#160;</td></tr>
150 <tr class="memitem:gaf2f5a9132dcfc6d01d34cd971c425713"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gaf2f5a9132dcfc6d01d34cd971c425713">__QADD8</a> (uint32_t val1, uint32_t val2)</td></tr>
151 <tr class="memdesc:gaf2f5a9132dcfc6d01d34cd971c425713"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting quad 8-bit saturating addition.  <br /></td></tr>
152 <tr class="separator:gaf2f5a9132dcfc6d01d34cd971c425713"><td class="memSeparator" colspan="2">&#160;</td></tr>
153 <tr class="memitem:ga87618799672e1511e33964bc71467eb3"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga87618799672e1511e33964bc71467eb3">__QASX</a> (uint32_t val1, uint32_t val2)</td></tr>
154 <tr class="memdesc:ga87618799672e1511e33964bc71467eb3"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting dual 16-bit add and subtract with exchange.  <br /></td></tr>
155 <tr class="separator:ga87618799672e1511e33964bc71467eb3"><td class="memSeparator" colspan="2">&#160;</td></tr>
156 <tr class="memitem:gab41eb2b17512ab01d476fc9d5bd19520"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gab41eb2b17512ab01d476fc9d5bd19520">__QSAX</a> (uint32_t val1, uint32_t val2)</td></tr>
157 <tr class="memdesc:gab41eb2b17512ab01d476fc9d5bd19520"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting dual 16-bit subtract and add with exchange.  <br /></td></tr>
158 <tr class="separator:gab41eb2b17512ab01d476fc9d5bd19520"><td class="memSeparator" colspan="2">&#160;</td></tr>
159 <tr class="memitem:ga3ba259f8f05a36f7b88b469a71ffc096"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga3ba259f8f05a36f7b88b469a71ffc096">__QSUB</a> (uint32_t val1, uint32_t val2)</td></tr>
160 <tr class="memdesc:ga3ba259f8f05a36f7b88b469a71ffc096"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting saturating subtract.  <br /></td></tr>
161 <tr class="separator:ga3ba259f8f05a36f7b88b469a71ffc096"><td class="memSeparator" colspan="2">&#160;</td></tr>
162 <tr class="memitem:gad089605c16df9823a2c8aaa37777aae5"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gad089605c16df9823a2c8aaa37777aae5">__QSUB16</a> (uint32_t val1, uint32_t val2)</td></tr>
163 <tr class="memdesc:gad089605c16df9823a2c8aaa37777aae5"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting dual 16-bit saturating subtract.  <br /></td></tr>
164 <tr class="separator:gad089605c16df9823a2c8aaa37777aae5"><td class="memSeparator" colspan="2">&#160;</td></tr>
165 <tr class="memitem:ga753493a65493880c28baa82c151a0d61"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga753493a65493880c28baa82c151a0d61">__QSUB8</a> (uint32_t val1, uint32_t val2)</td></tr>
166 <tr class="memdesc:ga753493a65493880c28baa82c151a0d61"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting quad 8-bit saturating subtract.  <br /></td></tr>
167 <tr class="separator:ga753493a65493880c28baa82c151a0d61"><td class="memSeparator" colspan="2">&#160;</td></tr>
168 <tr class="memitem:gad0bf46373a1c05aabf64517e84be5984"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gad0bf46373a1c05aabf64517e84be5984">__SADD16</a> (uint32_t val1, uint32_t val2)</td></tr>
169 <tr class="memdesc:gad0bf46373a1c05aabf64517e84be5984"><td class="mdescLeft">&#160;</td><td class="mdescRight">GE setting dual 16-bit signed addition.  <br /></td></tr>
170 <tr class="separator:gad0bf46373a1c05aabf64517e84be5984"><td class="memSeparator" colspan="2">&#160;</td></tr>
171 <tr class="memitem:gac20aa0f741d0a1494d58c531e38d5785"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gac20aa0f741d0a1494d58c531e38d5785">__SADD8</a> (uint32_t val1, uint32_t val2)</td></tr>
172 <tr class="memdesc:gac20aa0f741d0a1494d58c531e38d5785"><td class="mdescLeft">&#160;</td><td class="mdescRight">GE setting quad 8-bit signed addition.  <br /></td></tr>
173 <tr class="separator:gac20aa0f741d0a1494d58c531e38d5785"><td class="memSeparator" colspan="2">&#160;</td></tr>
174 <tr class="memitem:ga5845084fd99c872e98cf5553d554de2a"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga5845084fd99c872e98cf5553d554de2a">__SASX</a> (uint32_t val1, uint32_t val2)</td></tr>
175 <tr class="memdesc:ga5845084fd99c872e98cf5553d554de2a"><td class="mdescLeft">&#160;</td><td class="mdescRight">GE setting dual 16-bit addition and subtraction with exchange.  <br /></td></tr>
176 <tr class="separator:ga5845084fd99c872e98cf5553d554de2a"><td class="memSeparator" colspan="2">&#160;</td></tr>
177 <tr class="memitem:gaf5448e591fe49161b6759b48aecb08fe"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gaf5448e591fe49161b6759b48aecb08fe">__SEL</a> (uint32_t val1, uint32_t val2)</td></tr>
178 <tr class="memdesc:gaf5448e591fe49161b6759b48aecb08fe"><td class="mdescLeft">&#160;</td><td class="mdescRight">Select bytes based on GE bits.  <br /></td></tr>
179 <tr class="separator:gaf5448e591fe49161b6759b48aecb08fe"><td class="memSeparator" colspan="2">&#160;</td></tr>
180 <tr class="memitem:ga15d8899a173effb8ad8c7268da32b60e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga15d8899a173effb8ad8c7268da32b60e">__SHADD16</a> (uint32_t val1, uint32_t val2)</td></tr>
181 <tr class="memdesc:ga15d8899a173effb8ad8c7268da32b60e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit signed addition with halved results.  <br /></td></tr>
182 <tr class="separator:ga15d8899a173effb8ad8c7268da32b60e"><td class="memSeparator" colspan="2">&#160;</td></tr>
183 <tr class="memitem:ga524575b442ea01aec10c762bf4d85fea"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga524575b442ea01aec10c762bf4d85fea">__SHADD8</a> (uint32_t val1, uint32_t val2)</td></tr>
184 <tr class="memdesc:ga524575b442ea01aec10c762bf4d85fea"><td class="mdescLeft">&#160;</td><td class="mdescRight">Quad 8-bit signed addition with halved results.  <br /></td></tr>
185 <tr class="separator:ga524575b442ea01aec10c762bf4d85fea"><td class="memSeparator" colspan="2">&#160;</td></tr>
186 <tr class="memitem:gae0a649035f67627464fd80e7218c89d5"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gae0a649035f67627464fd80e7218c89d5">__SHASX</a> (uint32_t val1, uint32_t val2)</td></tr>
187 <tr class="memdesc:gae0a649035f67627464fd80e7218c89d5"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit signed addition and subtraction with halved results.  <br /></td></tr>
188 <tr class="separator:gae0a649035f67627464fd80e7218c89d5"><td class="memSeparator" colspan="2">&#160;</td></tr>
189 <tr class="memitem:gafadbd89c36b5addcf1ca10dd392db3e9"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gafadbd89c36b5addcf1ca10dd392db3e9">__SHSAX</a> (uint32_t val1, uint32_t val2)</td></tr>
190 <tr class="memdesc:gafadbd89c36b5addcf1ca10dd392db3e9"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit signed subtraction and addition with halved results.  <br /></td></tr>
191 <tr class="separator:gafadbd89c36b5addcf1ca10dd392db3e9"><td class="memSeparator" colspan="2">&#160;</td></tr>
192 <tr class="memitem:ga31328467f0f91b8ff9ae9a01682ad3bf"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga31328467f0f91b8ff9ae9a01682ad3bf">__SHSUB16</a> (uint32_t val1, uint32_t val2)</td></tr>
193 <tr class="memdesc:ga31328467f0f91b8ff9ae9a01682ad3bf"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit signed subtraction with halved results.  <br /></td></tr>
194 <tr class="separator:ga31328467f0f91b8ff9ae9a01682ad3bf"><td class="memSeparator" colspan="2">&#160;</td></tr>
195 <tr class="memitem:gac3ec7215b354d925a239f3b31df2b77b"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gac3ec7215b354d925a239f3b31df2b77b">__SHSUB8</a> (uint32_t val1, uint32_t val2)</td></tr>
196 <tr class="memdesc:gac3ec7215b354d925a239f3b31df2b77b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Quad 8-bit signed subtraction with halved results.  <br /></td></tr>
197 <tr class="separator:gac3ec7215b354d925a239f3b31df2b77b"><td class="memSeparator" colspan="2">&#160;</td></tr>
198 <tr class="memitem:gae0c86f3298532183f3a29f5bb454d354"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gae0c86f3298532183f3a29f5bb454d354">__SMLAD</a> (uint32_t val1, uint32_t val2, uint32_t val3)</td></tr>
199 <tr class="memdesc:gae0c86f3298532183f3a29f5bb454d354"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting dual 16-bit signed multiply with single 32-bit accumulator.  <br /></td></tr>
200 <tr class="separator:gae0c86f3298532183f3a29f5bb454d354"><td class="memSeparator" colspan="2">&#160;</td></tr>
201 <tr class="memitem:ga9c286d330f4fb29b256335add91eec9f"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga9c286d330f4fb29b256335add91eec9f">__SMLADX</a> (uint32_t val1, uint32_t val2, uint32_t val3)</td></tr>
202 <tr class="memdesc:ga9c286d330f4fb29b256335add91eec9f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting pre-exchanged dual 16-bit signed multiply with single 32-bit accumulator.  <br /></td></tr>
203 <tr class="separator:ga9c286d330f4fb29b256335add91eec9f"><td class="memSeparator" colspan="2">&#160;</td></tr>
204 <tr class="memitem:gad80e9b20c1736fd798f897362273a146"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gad80e9b20c1736fd798f897362273a146">__SMLALD</a> (uint32_t val1, uint32_t val2, uint64_t val3)</td></tr>
205 <tr class="memdesc:gad80e9b20c1736fd798f897362273a146"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit signed multiply with single 64-bit accumulator.  <br /></td></tr>
206 <tr class="separator:gad80e9b20c1736fd798f897362273a146"><td class="memSeparator" colspan="2">&#160;</td></tr>
207 <tr class="memitem:gad1adad1b3f2667328cc0db6c6b4f41cf"><td class="memItemLeft" align="right" valign="top">unsigned long long&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gad1adad1b3f2667328cc0db6c6b4f41cf">__SMLALDX</a> (uint32_t val1, uint32_t val2, unsigned long long val3)</td></tr>
208 <tr class="memdesc:gad1adad1b3f2667328cc0db6c6b4f41cf"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit signed multiply with exchange with single 64-bit accumulator.  <br /></td></tr>
209 <tr class="separator:gad1adad1b3f2667328cc0db6c6b4f41cf"><td class="memSeparator" colspan="2">&#160;</td></tr>
210 <tr class="memitem:gaf4350af7f2030c36f43b2c104a9d16cd"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gaf4350af7f2030c36f43b2c104a9d16cd">__SMLSD</a> (uint32_t val1, uint32_t val2, uint32_t val3)</td></tr>
211 <tr class="memdesc:gaf4350af7f2030c36f43b2c104a9d16cd"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting dual 16-bit signed multiply subtract with 32-bit accumulate.  <br /></td></tr>
212 <tr class="separator:gaf4350af7f2030c36f43b2c104a9d16cd"><td class="memSeparator" colspan="2">&#160;</td></tr>
213 <tr class="memitem:ga5290ce5564770ad124910d2583dc0a9e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga5290ce5564770ad124910d2583dc0a9e">__SMLSDX</a> (uint32_t val1, uint32_t val2, uint32_t val3)</td></tr>
214 <tr class="memdesc:ga5290ce5564770ad124910d2583dc0a9e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting dual 16-bit signed multiply with exchange subtract with 32-bit accumulate.  <br /></td></tr>
215 <tr class="separator:ga5290ce5564770ad124910d2583dc0a9e"><td class="memSeparator" colspan="2">&#160;</td></tr>
216 <tr class="memitem:ga5611f7314e0c8f53da377918dfbf42ee"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga5611f7314e0c8f53da377918dfbf42ee">__SMLSLD</a> (uint32_t val1, uint32_t val2, uint64_t val3)</td></tr>
217 <tr class="memdesc:ga5611f7314e0c8f53da377918dfbf42ee"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting dual 16-bit signed multiply subtract with 64-bit accumulate.  <br /></td></tr>
218 <tr class="separator:ga5611f7314e0c8f53da377918dfbf42ee"><td class="memSeparator" colspan="2">&#160;</td></tr>
219 <tr class="memitem:ga83e69ef81057d3cbd06863d729385187"><td class="memItemLeft" align="right" valign="top">unsigned long long&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga83e69ef81057d3cbd06863d729385187">__SMLSLDX</a> (uint32_t val1, uint32_t val2, unsigned long long val3)</td></tr>
220 <tr class="memdesc:ga83e69ef81057d3cbd06863d729385187"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting dual 16-bit signed multiply with exchange subtract with 64-bit accumulate.  <br /></td></tr>
221 <tr class="separator:ga83e69ef81057d3cbd06863d729385187"><td class="memSeparator" colspan="2">&#160;</td></tr>
222 <tr class="memitem:gaea60757232f740ec6b09980eebb614ff"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gaea60757232f740ec6b09980eebb614ff">__SMMLA</a> (int32_t val1, int32_t val2, int32_t val3)</td></tr>
223 <tr class="memdesc:gaea60757232f740ec6b09980eebb614ff"><td class="mdescLeft">&#160;</td><td class="mdescRight">32-bit signed multiply with 32-bit truncated accumulator.  <br /></td></tr>
224 <tr class="separator:gaea60757232f740ec6b09980eebb614ff"><td class="memSeparator" colspan="2">&#160;</td></tr>
225 <tr class="memitem:gae326e368a1624d2dfb4b97c626939257"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gae326e368a1624d2dfb4b97c626939257">__SMUAD</a> (uint32_t val1, uint32_t val2)</td></tr>
226 <tr class="memdesc:gae326e368a1624d2dfb4b97c626939257"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting sum of dual 16-bit signed multiply.  <br /></td></tr>
227 <tr class="separator:gae326e368a1624d2dfb4b97c626939257"><td class="memSeparator" colspan="2">&#160;</td></tr>
228 <tr class="memitem:gaee6390f86965cb662500f690b0012092"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gaee6390f86965cb662500f690b0012092">__SMUADX</a> (uint32_t val1, uint32_t val2)</td></tr>
229 <tr class="memdesc:gaee6390f86965cb662500f690b0012092"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting sum of dual 16-bit signed multiply with exchange.  <br /></td></tr>
230 <tr class="separator:gaee6390f86965cb662500f690b0012092"><td class="memSeparator" colspan="2">&#160;</td></tr>
231 <tr class="memitem:ga039142a5368840683cf329cb55b73f84"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga039142a5368840683cf329cb55b73f84">__SMUSD</a> (uint32_t val1, uint32_t val2)</td></tr>
232 <tr class="memdesc:ga039142a5368840683cf329cb55b73f84"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit signed multiply returning difference.  <br /></td></tr>
233 <tr class="separator:ga039142a5368840683cf329cb55b73f84"><td class="memSeparator" colspan="2">&#160;</td></tr>
234 <tr class="memitem:gabb5bcba694bf17b141c32e6a8474f60e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gabb5bcba694bf17b141c32e6a8474f60e">__SMUSDX</a> (uint32_t val1, uint32_t val2)</td></tr>
235 <tr class="memdesc:gabb5bcba694bf17b141c32e6a8474f60e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit signed multiply with exchange returning difference.  <br /></td></tr>
236 <tr class="separator:gabb5bcba694bf17b141c32e6a8474f60e"><td class="memSeparator" colspan="2">&#160;</td></tr>
237 <tr class="memitem:ga95e666b82216066bf6064d1244e6883c"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga95e666b82216066bf6064d1244e6883c">__SSAT16</a> (uint32_t val1, const uint32_t val2)</td></tr>
238 <tr class="memdesc:ga95e666b82216066bf6064d1244e6883c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting dual 16-bit saturate.  <br /></td></tr>
239 <tr class="separator:ga95e666b82216066bf6064d1244e6883c"><td class="memSeparator" colspan="2">&#160;</td></tr>
240 <tr class="memitem:ga9d3bc5c539f9bd50f7d59ffa37ac6a65"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga9d3bc5c539f9bd50f7d59ffa37ac6a65">__SSAX</a> (uint32_t val1, uint32_t val2)</td></tr>
241 <tr class="memdesc:ga9d3bc5c539f9bd50f7d59ffa37ac6a65"><td class="mdescLeft">&#160;</td><td class="mdescRight">GE setting dual 16-bit signed subtraction and addition with exchange.  <br /></td></tr>
242 <tr class="separator:ga9d3bc5c539f9bd50f7d59ffa37ac6a65"><td class="memSeparator" colspan="2">&#160;</td></tr>
243 <tr class="memitem:ga4262f73be75efbac6b46ab7c71aa6cbc"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga4262f73be75efbac6b46ab7c71aa6cbc">__SSUB16</a> (uint32_t val1, uint32_t val2)</td></tr>
244 <tr class="memdesc:ga4262f73be75efbac6b46ab7c71aa6cbc"><td class="mdescLeft">&#160;</td><td class="mdescRight">GE setting dual 16-bit signed subtraction.  <br /></td></tr>
245 <tr class="separator:ga4262f73be75efbac6b46ab7c71aa6cbc"><td class="memSeparator" colspan="2">&#160;</td></tr>
246 <tr class="memitem:gaba63bb52e1e93fb527e26f3d474da12e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gaba63bb52e1e93fb527e26f3d474da12e">__SSUB8</a> (uint32_t val1, uint32_t val2)</td></tr>
247 <tr class="memdesc:gaba63bb52e1e93fb527e26f3d474da12e"><td class="mdescLeft">&#160;</td><td class="mdescRight">GE setting quad 8-bit signed subtraction.  <br /></td></tr>
248 <tr class="separator:gaba63bb52e1e93fb527e26f3d474da12e"><td class="memSeparator" colspan="2">&#160;</td></tr>
249 <tr class="memitem:gac540b4fc41d30778ba102d2a65db5589"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gac540b4fc41d30778ba102d2a65db5589">__SXTAB16</a> (uint32_t val1, uint32_t val2)</td></tr>
250 <tr class="memdesc:gac540b4fc41d30778ba102d2a65db5589"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual extracted 8-bit to 16-bit signed addition.  <br /></td></tr>
251 <tr class="separator:gac540b4fc41d30778ba102d2a65db5589"><td class="memSeparator" colspan="2">&#160;</td></tr>
252 <tr class="memitem:gaf0029ec2b0decbff4df5bc6f4352bba4"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gaf0029ec2b0decbff4df5bc6f4352bba4">__SXTAB16_RORn</a> (uint32_t val1, uint32_t val2, uint32_r rotate)</td></tr>
253 <tr class="memdesc:gaf0029ec2b0decbff4df5bc6f4352bba4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Rotate right, followed by sign extension of two 8-bits with add to 16-bits.  <br /></td></tr>
254 <tr class="separator:gaf0029ec2b0decbff4df5bc6f4352bba4"><td class="memSeparator" colspan="2">&#160;</td></tr>
255 <tr class="memitem:ga38dce3dd13ba212e80ec3cff4abeb11a"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga38dce3dd13ba212e80ec3cff4abeb11a">__SXTB16</a> (uint32_t val)</td></tr>
256 <tr class="memdesc:ga38dce3dd13ba212e80ec3cff4abeb11a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual extract 8-bits and sign extend each to 16-bits.  <br /></td></tr>
257 <tr class="separator:ga38dce3dd13ba212e80ec3cff4abeb11a"><td class="memSeparator" colspan="2">&#160;</td></tr>
258 <tr class="memitem:gaef7e08ba1dbaaae1efdb76c113155ed1"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gaef7e08ba1dbaaae1efdb76c113155ed1">__SXTB16_RORn</a> (uint32_t val, uint32_r rotate)</td></tr>
259 <tr class="memdesc:gaef7e08ba1dbaaae1efdb76c113155ed1"><td class="mdescLeft">&#160;</td><td class="mdescRight">Rotate right, dual extract 8-bits and sign extend each to 16-bits.  <br /></td></tr>
260 <tr class="separator:gaef7e08ba1dbaaae1efdb76c113155ed1"><td class="memSeparator" colspan="2">&#160;</td></tr>
261 <tr class="memitem:gaa1160f0cf76d6aa292fbad54a1aa6b74"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gaa1160f0cf76d6aa292fbad54a1aa6b74">__UADD16</a> (uint32_t val1, uint32_t val2)</td></tr>
262 <tr class="memdesc:gaa1160f0cf76d6aa292fbad54a1aa6b74"><td class="mdescLeft">&#160;</td><td class="mdescRight">GE setting dual 16-bit unsigned addition.  <br /></td></tr>
263 <tr class="separator:gaa1160f0cf76d6aa292fbad54a1aa6b74"><td class="memSeparator" colspan="2">&#160;</td></tr>
264 <tr class="memitem:gab3d7fd00d113b20fb3741a17394da762"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gab3d7fd00d113b20fb3741a17394da762">__UADD8</a> (uint32_t val1, uint32_t val2)</td></tr>
265 <tr class="memdesc:gab3d7fd00d113b20fb3741a17394da762"><td class="mdescLeft">&#160;</td><td class="mdescRight">GE setting quad 8-bit unsigned addition.  <br /></td></tr>
266 <tr class="separator:gab3d7fd00d113b20fb3741a17394da762"><td class="memSeparator" colspan="2">&#160;</td></tr>
267 <tr class="memitem:ga980353d2c72ebb879282e49f592fddc0"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga980353d2c72ebb879282e49f592fddc0">__UASX</a> (uint32_t val1, uint32_t val2)</td></tr>
268 <tr class="memdesc:ga980353d2c72ebb879282e49f592fddc0"><td class="mdescLeft">&#160;</td><td class="mdescRight">GE setting dual 16-bit unsigned addition and subtraction with exchange.  <br /></td></tr>
269 <tr class="separator:ga980353d2c72ebb879282e49f592fddc0"><td class="memSeparator" colspan="2">&#160;</td></tr>
270 <tr class="memitem:gabd0b0e2da2e6364e176d051687702b86"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gabd0b0e2da2e6364e176d051687702b86">__UHADD16</a> (uint32_t val1, uint32_t val2)</td></tr>
271 <tr class="memdesc:gabd0b0e2da2e6364e176d051687702b86"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit unsigned addition with halved results.  <br /></td></tr>
272 <tr class="separator:gabd0b0e2da2e6364e176d051687702b86"><td class="memSeparator" colspan="2">&#160;</td></tr>
273 <tr class="memitem:ga3a14e5485e59bf0f23595b7c2a94eb0b"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga3a14e5485e59bf0f23595b7c2a94eb0b">__UHADD8</a> (uint32_t val1, uint32_t val2)</td></tr>
274 <tr class="memdesc:ga3a14e5485e59bf0f23595b7c2a94eb0b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Quad 8-bit unsigned addition with halved results.  <br /></td></tr>
275 <tr class="separator:ga3a14e5485e59bf0f23595b7c2a94eb0b"><td class="memSeparator" colspan="2">&#160;</td></tr>
276 <tr class="memitem:ga028f0732b961fb6e5209326fb3855261"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga028f0732b961fb6e5209326fb3855261">__UHASX</a> (uint32_t val1, uint32_t val2)</td></tr>
277 <tr class="memdesc:ga028f0732b961fb6e5209326fb3855261"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit unsigned addition and subtraction with halved results and exchange.  <br /></td></tr>
278 <tr class="separator:ga028f0732b961fb6e5209326fb3855261"><td class="memSeparator" colspan="2">&#160;</td></tr>
279 <tr class="memitem:ga09e129e6613329aab87c89f1108b7ed7"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga09e129e6613329aab87c89f1108b7ed7">__UHSAX</a> (uint32_t val1, uint32_t val2)</td></tr>
280 <tr class="memdesc:ga09e129e6613329aab87c89f1108b7ed7"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit unsigned subtraction and addition with halved results and exchange.  <br /></td></tr>
281 <tr class="separator:ga09e129e6613329aab87c89f1108b7ed7"><td class="memSeparator" colspan="2">&#160;</td></tr>
282 <tr class="memitem:ga1f7545b8dc33bb97982731cb9d427a69"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga1f7545b8dc33bb97982731cb9d427a69">__UHSUB16</a> (uint32_t val1, uint32_t val2)</td></tr>
283 <tr class="memdesc:ga1f7545b8dc33bb97982731cb9d427a69"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit unsigned subtraction with halved results.  <br /></td></tr>
284 <tr class="separator:ga1f7545b8dc33bb97982731cb9d427a69"><td class="memSeparator" colspan="2">&#160;</td></tr>
285 <tr class="memitem:ga48a55df1c3e73923b73819d7c19b392d"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga48a55df1c3e73923b73819d7c19b392d">__UHSUB8</a> (uint32_t val1, uint32_t val2)</td></tr>
286 <tr class="memdesc:ga48a55df1c3e73923b73819d7c19b392d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Quad 8-bit unsigned subtraction with halved results.  <br /></td></tr>
287 <tr class="separator:ga48a55df1c3e73923b73819d7c19b392d"><td class="memSeparator" colspan="2">&#160;</td></tr>
288 <tr class="memitem:ga9e2cc5117e79578a08b25f1e89022966"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga9e2cc5117e79578a08b25f1e89022966">__UQADD16</a> (uint32_t val1, uint32_t val2)</td></tr>
289 <tr class="memdesc:ga9e2cc5117e79578a08b25f1e89022966"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit unsigned saturating addition.  <br /></td></tr>
290 <tr class="separator:ga9e2cc5117e79578a08b25f1e89022966"><td class="memSeparator" colspan="2">&#160;</td></tr>
291 <tr class="memitem:gafa9af218db3934a692fb06fa728d8031"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gafa9af218db3934a692fb06fa728d8031">__UQADD8</a> (uint32_t val1, uint32_t val2)</td></tr>
292 <tr class="memdesc:gafa9af218db3934a692fb06fa728d8031"><td class="mdescLeft">&#160;</td><td class="mdescRight">Quad 8-bit unsigned saturating addition.  <br /></td></tr>
293 <tr class="separator:gafa9af218db3934a692fb06fa728d8031"><td class="memSeparator" colspan="2">&#160;</td></tr>
294 <tr class="memitem:ga5eff3ae5eabcd73f3049996ca391becb"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga5eff3ae5eabcd73f3049996ca391becb">__UQASX</a> (uint32_t val1, uint32_t val2)</td></tr>
295 <tr class="memdesc:ga5eff3ae5eabcd73f3049996ca391becb"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit unsigned saturating addition and subtraction with exchange.  <br /></td></tr>
296 <tr class="separator:ga5eff3ae5eabcd73f3049996ca391becb"><td class="memSeparator" colspan="2">&#160;</td></tr>
297 <tr class="memitem:gadecfdfabc328d8939d49d996f2fd4482"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gadecfdfabc328d8939d49d996f2fd4482">__UQSAX</a> (uint32_t val1, uint32_t val2)</td></tr>
298 <tr class="memdesc:gadecfdfabc328d8939d49d996f2fd4482"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit unsigned saturating subtraction and addition with exchange.  <br /></td></tr>
299 <tr class="separator:gadecfdfabc328d8939d49d996f2fd4482"><td class="memSeparator" colspan="2">&#160;</td></tr>
300 <tr class="memitem:ga5ec4e2e231d15e5c692233feb3806187"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga5ec4e2e231d15e5c692233feb3806187">__UQSUB16</a> (uint32_t val1, uint32_t val2)</td></tr>
301 <tr class="memdesc:ga5ec4e2e231d15e5c692233feb3806187"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual 16-bit unsigned saturating subtraction.  <br /></td></tr>
302 <tr class="separator:ga5ec4e2e231d15e5c692233feb3806187"><td class="memSeparator" colspan="2">&#160;</td></tr>
303 <tr class="memitem:ga9736fe816aec74fe886e7fb949734eab"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga9736fe816aec74fe886e7fb949734eab">__UQSUB8</a> (uint32_t val1, uint32_t val2)</td></tr>
304 <tr class="memdesc:ga9736fe816aec74fe886e7fb949734eab"><td class="mdescLeft">&#160;</td><td class="mdescRight">Quad 8-bit unsigned saturating subtraction.  <br /></td></tr>
305 <tr class="separator:ga9736fe816aec74fe886e7fb949734eab"><td class="memSeparator" colspan="2">&#160;</td></tr>
306 <tr class="memitem:gac8855c07044239ea775c8128013204f0"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gac8855c07044239ea775c8128013204f0">__USAD8</a> (uint32_t val1, uint32_t val2)</td></tr>
307 <tr class="memdesc:gac8855c07044239ea775c8128013204f0"><td class="mdescLeft">&#160;</td><td class="mdescRight">Unsigned sum of quad 8-bit unsigned absolute difference.  <br /></td></tr>
308 <tr class="separator:gac8855c07044239ea775c8128013204f0"><td class="memSeparator" colspan="2">&#160;</td></tr>
309 <tr class="memitem:gad032bd21f013c5d29f5fcb6b0f02bc3f"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gad032bd21f013c5d29f5fcb6b0f02bc3f">__USADA8</a> (uint32_t val1, uint32_t val2, uint32_t val3)</td></tr>
310 <tr class="memdesc:gad032bd21f013c5d29f5fcb6b0f02bc3f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Unsigned sum of quad 8-bit unsigned absolute difference with 32-bit accumulate.  <br /></td></tr>
311 <tr class="separator:gad032bd21f013c5d29f5fcb6b0f02bc3f"><td class="memSeparator" colspan="2">&#160;</td></tr>
312 <tr class="memitem:ga967f516afff5900cf30f1a81907cdd89"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga967f516afff5900cf30f1a81907cdd89">__USAT16</a> (uint32_t val1, const uint32_t val2)</td></tr>
313 <tr class="memdesc:ga967f516afff5900cf30f1a81907cdd89"><td class="mdescLeft">&#160;</td><td class="mdescRight">Q setting dual 16-bit unsigned saturate.  <br /></td></tr>
314 <tr class="separator:ga967f516afff5900cf30f1a81907cdd89"><td class="memSeparator" colspan="2">&#160;</td></tr>
315 <tr class="memitem:ga578a082747436772c482c96d7a58e45e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga578a082747436772c482c96d7a58e45e">__USAX</a> (uint32_t val1, uint32_t val2)</td></tr>
316 <tr class="memdesc:ga578a082747436772c482c96d7a58e45e"><td class="mdescLeft">&#160;</td><td class="mdescRight">GE setting dual 16-bit unsigned subtract and add with exchange.  <br /></td></tr>
317 <tr class="separator:ga578a082747436772c482c96d7a58e45e"><td class="memSeparator" colspan="2">&#160;</td></tr>
318 <tr class="memitem:ga9f2b77e11fc4a77b26c36c423ed45b4e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#ga9f2b77e11fc4a77b26c36c423ed45b4e">__USUB16</a> (uint32_t val1, uint32_t val2)</td></tr>
319 <tr class="memdesc:ga9f2b77e11fc4a77b26c36c423ed45b4e"><td class="mdescLeft">&#160;</td><td class="mdescRight">GE setting dual 16-bit unsigned subtract.  <br /></td></tr>
320 <tr class="separator:ga9f2b77e11fc4a77b26c36c423ed45b4e"><td class="memSeparator" colspan="2">&#160;</td></tr>
321 <tr class="memitem:gacb7257dc3b8e9acbd0ef0e31ff87d4b8"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gacb7257dc3b8e9acbd0ef0e31ff87d4b8">__USUB8</a> (uint32_t val1, uint32_t val2)</td></tr>
322 <tr class="memdesc:gacb7257dc3b8e9acbd0ef0e31ff87d4b8"><td class="mdescLeft">&#160;</td><td class="mdescRight">GE setting quad 8-bit unsigned subtract.  <br /></td></tr>
323 <tr class="separator:gacb7257dc3b8e9acbd0ef0e31ff87d4b8"><td class="memSeparator" colspan="2">&#160;</td></tr>
324 <tr class="memitem:gad25ce96db0f17096bbd815f4817faf09"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gad25ce96db0f17096bbd815f4817faf09">__UXTAB16</a> (uint32_t val1, uint32_t val2)</td></tr>
325 <tr class="memdesc:gad25ce96db0f17096bbd815f4817faf09"><td class="mdescLeft">&#160;</td><td class="mdescRight">Extracted 16-bit to 32-bit unsigned addition.  <br /></td></tr>
326 <tr class="separator:gad25ce96db0f17096bbd815f4817faf09"><td class="memSeparator" colspan="2">&#160;</td></tr>
327 <tr class="memitem:gab41d713653b16f8d9fef44d14e397228"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__intrinsic__SIMD__gr.html#gab41d713653b16f8d9fef44d14e397228">__UXTB16</a> (uint32_t val)</td></tr>
328 <tr class="memdesc:gab41d713653b16f8d9fef44d14e397228"><td class="mdescLeft">&#160;</td><td class="mdescRight">Dual extract 8-bits and zero-extend to 16-bits.  <br /></td></tr>
329 <tr class="separator:gab41d713653b16f8d9fef44d14e397228"><td class="memSeparator" colspan="2">&#160;</td></tr>
330 </table>
331 <a name="details" id="details"></a><h2 class="groupheader">Description</h2>
332 <p>Access to dedicated SIMD instructions available on Armv7E-M (Cortex-M4/M7), Armv8-M Mainline (Cortex-M33/M35P), and Armv8.1-M (Cortex-M55/M85). </p>
333 <p><b>Single Instruction Multiple Data (SIMD)</b> extensions are provided <b>only for Cortex-M4 and Cortex-M7 cores</b> to simplify development of application software. SIMD extensions increase the processing capability without materially increasing the power consumption. The SIMD extensions are completely transparent to the operating system (OS), allowing existing OS ports to be used.</p>
334 <p><b>SIMD Features:</b></p>
335 <ul>
336 <li>Simultaneous computation of 2x16-bit or 4x8-bit operands</li>
337 <li>Fractional arithmetic</li>
338 <li>User definable saturation modes (arbitrary word-width)</li>
339 <li>Dual 16x16 multiply-add/subtract 32x32 fractional MAC</li>
340 <li>Simultaneous 8/16-bit select operations</li>
341 <li>Performance up to 3.2 GOPS at 800MHz</li>
342 <li>Performance is achieved with a "near zero" increase in power consumption on a typical implementation</li>
343 </ul>
344 <p><b>Examples:</b> </p>
345 <p><b>Addition:</b> Add two values using SIMD function</p>
346 <div class="fragment"><div class="line">uint32_t add_halfwords(uint32_t val1, uint32_t val2)</div>
347 <div class="line">{</div>
348 <div class="line">  <span class="keywordflow">return</span> <a class="code hl_function" href="group__intrinsic__SIMD__gr.html#gad0bf46373a1c05aabf64517e84be5984">__SADD16</a>(val1, val2);</div>
349 <div class="line">}</div>
350 <div class="ttc" id="agroup__intrinsic__SIMD__gr_html_gad0bf46373a1c05aabf64517e84be5984"><div class="ttname"><a href="group__intrinsic__SIMD__gr.html#gad0bf46373a1c05aabf64517e84be5984">__SADD16</a></div><div class="ttdeci">uint32_t __SADD16(uint32_t val1, uint32_t val2)</div><div class="ttdoc">GE setting dual 16-bit signed addition.</div></div>
351 </div><!-- fragment --><p><b>Subtraction:</b> Subtract two values using SIMD function</p>
352 <div class="fragment"><div class="line">uint32_t sub_halfwords(uint32_t val1, uint32_t val2)</div>
353 <div class="line">{</div>
354 <div class="line">  <span class="keywordflow">return</span> <a class="code hl_function" href="group__intrinsic__SIMD__gr.html#ga4262f73be75efbac6b46ab7c71aa6cbc">__SSUB16</a>(val1, val2);</div>
355 <div class="line">}</div>
356 <div class="ttc" id="agroup__intrinsic__SIMD__gr_html_ga4262f73be75efbac6b46ab7c71aa6cbc"><div class="ttname"><a href="group__intrinsic__SIMD__gr.html#ga4262f73be75efbac6b46ab7c71aa6cbc">__SSUB16</a></div><div class="ttdeci">uint32_t __SSUB16(uint32_t val1, uint32_t val2)</div><div class="ttdoc">GE setting dual 16-bit signed subtraction.</div></div>
357 </div><!-- fragment --><p><b>Multiplication:</b> Performing a multiplication using SIMD function</p>
358 <div class="fragment"><div class="line">uint32_t dual_mul_add_products(uint32_t val1, uint32_t val2)</div>
359 <div class="line">{</div>
360 <div class="line">  <span class="keywordflow">return</span> <a class="code hl_function" href="group__intrinsic__SIMD__gr.html#gae326e368a1624d2dfb4b97c626939257">__SMUAD</a>(val1, val2);</div>
361 <div class="line">}</div>
362 <div class="ttc" id="agroup__intrinsic__SIMD__gr_html_gae326e368a1624d2dfb4b97c626939257"><div class="ttname"><a href="group__intrinsic__SIMD__gr.html#gae326e368a1624d2dfb4b97c626939257">__SMUAD</a></div><div class="ttdeci">uint32_t __SMUAD(uint32_t val1, uint32_t val2)</div><div class="ttdoc">Q setting sum of dual 16-bit signed multiply.</div></div>
363 </div><!-- fragment --> <h2 class="groupheader">Function Documentation</h2>
364 <a id="gaefb8ebf3a54e197464da1ff69a44f4b5" name="gaefb8ebf3a54e197464da1ff69a44f4b5"></a>
365 <h2 class="memtitle"><span class="permalink"><a href="#gaefb8ebf3a54e197464da1ff69a44f4b5">&#9670;&#160;</a></span>__PKHBT()</h2>
366
367 <div class="memitem">
368 <div class="memproto">
369       <table class="memname">
370         <tr>
371           <td class="memname">uint32_t __PKHBT </td>
372           <td>(</td>
373           <td class="paramtype">uint32_t&#160;</td>
374           <td class="paramname"><em>val1</em>, </td>
375         </tr>
376         <tr>
377           <td class="paramkey"></td>
378           <td></td>
379           <td class="paramtype">uint32_t&#160;</td>
380           <td class="paramname"><em>val2</em>, </td>
381         </tr>
382         <tr>
383           <td class="paramkey"></td>
384           <td></td>
385           <td class="paramtype">uint32_t&#160;</td>
386           <td class="paramname"><em>val3</em>&#160;</td>
387         </tr>
388         <tr>
389           <td></td>
390           <td>)</td>
391           <td></td><td></td>
392         </tr>
393       </table>
394 </div><div class="memdoc">
395
396 <p>Halfword packing instruction. Combines bits[15:0] of <em>val1</em> with bits[31:16] of <em>val2</em> levitated with the <em>val3</em>. </p>
397 <p>Combine a halfword from one register with a halfword from another register. The second argument can be left-shifted before extraction of the halfword. The registers PC and SP are not allowed as arguments. This instruction does not change the flags.</p>
398 <dl class="params"><dt>Parameters</dt><dd>
399   <table class="params">
400     <tr><td class="paramname">val1</td><td>first 16-bit operands </td></tr>
401     <tr><td class="paramname">val2</td><td>second 16-bit operands </td></tr>
402     <tr><td class="paramname">val3</td><td>value for left-shifting <em>val2</em>. Value range [0..31].</td></tr>
403   </table>
404   </dd>
405 </dl>
406 <dl class="section return"><dt>Returns</dt><dd>the combination of halfwords.</dd></dl>
407 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]</div>
408 <div class="line">res[31:16] = val2[31:16]&lt;&lt;val3</div>
409 </div><!-- fragment --> </dd></dl>
410
411 </div>
412 </div>
413 <a id="gafd8fe4a6d87e947caa81a69ec36c1666" name="gafd8fe4a6d87e947caa81a69ec36c1666"></a>
414 <h2 class="memtitle"><span class="permalink"><a href="#gafd8fe4a6d87e947caa81a69ec36c1666">&#9670;&#160;</a></span>__PKHTB()</h2>
415
416 <div class="memitem">
417 <div class="memproto">
418       <table class="memname">
419         <tr>
420           <td class="memname">uint32_t __PKHTB </td>
421           <td>(</td>
422           <td class="paramtype">uint32_t&#160;</td>
423           <td class="paramname"><em>val1</em>, </td>
424         </tr>
425         <tr>
426           <td class="paramkey"></td>
427           <td></td>
428           <td class="paramtype">uint32_t&#160;</td>
429           <td class="paramname"><em>val2</em>, </td>
430         </tr>
431         <tr>
432           <td class="paramkey"></td>
433           <td></td>
434           <td class="paramtype">uint32_t&#160;</td>
435           <td class="paramname"><em>val3</em>&#160;</td>
436         </tr>
437         <tr>
438           <td></td>
439           <td>)</td>
440           <td></td><td></td>
441         </tr>
442       </table>
443 </div><div class="memdoc">
444
445 <p>Halfword packing instruction. Combines bits[31:16] of <em>val1</em> with bits[15:0] of <em>val2</em> right-shifted with the <em>val3</em>. </p>
446 <p>Combines a halfword from one register with a halfword from another register. The second argument can be right-shifted before extraction of the halfword. The registers PC and SP are not allowed as arguments. This instruction does not change the flags.</p>
447 <dl class="params"><dt>Parameters</dt><dd>
448   <table class="params">
449     <tr><td class="paramname">val1</td><td>second 16-bit operands </td></tr>
450     <tr><td class="paramname">val2</td><td>first 16-bit operands </td></tr>
451     <tr><td class="paramname">val3</td><td>value for right-shifting <em>val2</em>. Value range [1..32].</td></tr>
452   </table>
453   </dd>
454 </dl>
455 <dl class="section return"><dt>Returns</dt><dd>the combination of halfwords.</dd></dl>
456 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val2[15:0]&gt;&gt;val3</div>
457 <div class="line">res[31:16] = val1[31:16]</div>
458 </div><!-- fragment --> </dd></dl>
459
460 </div>
461 </div>
462 <a id="ga17b873f246c9f5e9355760ffef3dad4a" name="ga17b873f246c9f5e9355760ffef3dad4a"></a>
463 <h2 class="memtitle"><span class="permalink"><a href="#ga17b873f246c9f5e9355760ffef3dad4a">&#9670;&#160;</a></span>__QADD()</h2>
464
465 <div class="memitem">
466 <div class="memproto">
467       <table class="memname">
468         <tr>
469           <td class="memname">uint32_t __QADD </td>
470           <td>(</td>
471           <td class="paramtype">uint32_t&#160;</td>
472           <td class="paramname"><em>val1</em>, </td>
473         </tr>
474         <tr>
475           <td class="paramkey"></td>
476           <td></td>
477           <td class="paramtype">uint32_t&#160;</td>
478           <td class="paramname"><em>val2</em>&#160;</td>
479         </tr>
480         <tr>
481           <td></td>
482           <td>)</td>
483           <td></td><td></td>
484         </tr>
485       </table>
486 </div><div class="memdoc">
487
488 <p>Q setting saturating add. </p>
489 <p>This function enables you to obtain the saturating add of two integers.<br  />
490  The Q bit is set if the operation saturates.</p>
491 <dl class="params"><dt>Parameters</dt><dd>
492   <table class="params">
493     <tr><td class="paramname">val1</td><td>first summand of the saturating add operation. </td></tr>
494     <tr><td class="paramname">val2</td><td>second summand of the saturating add operation.</td></tr>
495   </table>
496   </dd>
497 </dl>
498 <dl class="section return"><dt>Returns</dt><dd>the saturating addition of val1 and val2.</dd></dl>
499 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[31:0] = SAT(val1 + SAT(val2))</div>
500 </div><!-- fragment --> </dd></dl>
501
502 </div>
503 </div>
504 <a id="gae83a53ec04b496304bed6d9fe8f7461b" name="gae83a53ec04b496304bed6d9fe8f7461b"></a>
505 <h2 class="memtitle"><span class="permalink"><a href="#gae83a53ec04b496304bed6d9fe8f7461b">&#9670;&#160;</a></span>__QADD16()</h2>
506
507 <div class="memitem">
508 <div class="memproto">
509       <table class="memname">
510         <tr>
511           <td class="memname">uint32_t __QADD16 </td>
512           <td>(</td>
513           <td class="paramtype">uint32_t&#160;</td>
514           <td class="paramname"><em>val1</em>, </td>
515         </tr>
516         <tr>
517           <td class="paramkey"></td>
518           <td></td>
519           <td class="paramtype">uint32_t&#160;</td>
520           <td class="paramname"><em>val2</em>&#160;</td>
521         </tr>
522         <tr>
523           <td></td>
524           <td>)</td>
525           <td></td><td></td>
526         </tr>
527       </table>
528 </div><div class="memdoc">
529
530 <p>Q setting dual 16-bit saturating addition. </p>
531 <p>This function enables you to perform two 16-bit integer arithmetic additions in parallel, saturating the results to the 16-bit signed integer range -2<sup>15</sup> &lt;= x &lt;= 2<sup>15</sup> - 1.</p>
532 <dl class="params"><dt>Parameters</dt><dd>
533   <table class="params">
534     <tr><td class="paramname">val1</td><td>first two 16-bit summands. </td></tr>
535     <tr><td class="paramname">val2</td><td>second two 16-bit summands.</td></tr>
536   </table>
537   </dd>
538 </dl>
539 <dl class="section return"><dt>Returns</dt><dd><ul>
540 <li>the saturated addition of the low halfwords, in the low halfword of the return value. </li>
541 <li>the saturated addition of the high halfwords, in the high halfword of the return value.</li>
542 </ul>
543 </dd></dl>
544 <dl class="section user"><dt></dt><dd>The returned results are saturated to the 16-bit signed integer range -2<sup>15</sup> &lt;= x &lt;= 2<sup>15</sup> - 1</dd></dl>
545 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  + val2[15:0]</div>
546 <div class="line">res[31:16] = val1[31:16] + val2[31:16]</div>
547 </div><!-- fragment --> </dd></dl>
548
549 </div>
550 </div>
551 <a id="gaf2f5a9132dcfc6d01d34cd971c425713" name="gaf2f5a9132dcfc6d01d34cd971c425713"></a>
552 <h2 class="memtitle"><span class="permalink"><a href="#gaf2f5a9132dcfc6d01d34cd971c425713">&#9670;&#160;</a></span>__QADD8()</h2>
553
554 <div class="memitem">
555 <div class="memproto">
556       <table class="memname">
557         <tr>
558           <td class="memname">uint32_t __QADD8 </td>
559           <td>(</td>
560           <td class="paramtype">uint32_t&#160;</td>
561           <td class="paramname"><em>val1</em>, </td>
562         </tr>
563         <tr>
564           <td class="paramkey"></td>
565           <td></td>
566           <td class="paramtype">uint32_t&#160;</td>
567           <td class="paramname"><em>val2</em>&#160;</td>
568         </tr>
569         <tr>
570           <td></td>
571           <td>)</td>
572           <td></td><td></td>
573         </tr>
574       </table>
575 </div><div class="memdoc">
576
577 <p>Q setting quad 8-bit saturating addition. </p>
578 <p>This function enables you to perform four 8-bit integer additions, saturating the results to the 8-bit signed integer range -2<sup>7</sup> &lt;= x &lt;= 2<sup>7</sup> - 1. </p><dl class="params"><dt>Parameters</dt><dd>
579   <table class="params">
580     <tr><td class="paramname">val1</td><td>first four 8-bit summands. </td></tr>
581     <tr><td class="paramname">val2</td><td>second four 8-bit summands.</td></tr>
582   </table>
583   </dd>
584 </dl>
585 <dl class="section return"><dt>Returns</dt><dd><ul>
586 <li>the saturated addition of the first byte of each operand in the first byte of the return value. </li>
587 <li>the saturated addition of the second byte of each operand in the second byte of the return value. </li>
588 <li>the saturated addition of the third byte of each operand in the third byte of the return value. </li>
589 <li>the saturated addition of the fourth byte of each operand in the fourth byte of the return value. </li>
590 </ul>
591 </dd></dl>
592 <dl class="section user"><dt></dt><dd>The returned results are saturated to the 8-bit signed integer range -2<sup>7</sup> &lt;= x &lt;= 2<sup>7</sup> - 1.</dd></dl>
593 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[7:0]   = val1[7:0]   + val2[7:0]</div>
594 <div class="line">res[15:8]  = val1[15:8]  + val2[15:8]</div>
595 <div class="line">res[23:16] = val1[23:16] + val2[23:16]</div>
596 <div class="line">res[31:24] = val1[31:24] + val2[31:24]</div>
597 </div><!-- fragment --> </dd></dl>
598
599 </div>
600 </div>
601 <a id="ga87618799672e1511e33964bc71467eb3" name="ga87618799672e1511e33964bc71467eb3"></a>
602 <h2 class="memtitle"><span class="permalink"><a href="#ga87618799672e1511e33964bc71467eb3">&#9670;&#160;</a></span>__QASX()</h2>
603
604 <div class="memitem">
605 <div class="memproto">
606       <table class="memname">
607         <tr>
608           <td class="memname">uint32_t __QASX </td>
609           <td>(</td>
610           <td class="paramtype">uint32_t&#160;</td>
611           <td class="paramname"><em>val1</em>, </td>
612         </tr>
613         <tr>
614           <td class="paramkey"></td>
615           <td></td>
616           <td class="paramtype">uint32_t&#160;</td>
617           <td class="paramname"><em>val2</em>&#160;</td>
618         </tr>
619         <tr>
620           <td></td>
621           <td>)</td>
622           <td></td><td></td>
623         </tr>
624       </table>
625 </div><div class="memdoc">
626
627 <p>Q setting dual 16-bit add and subtract with exchange. </p>
628 <p>This function enables you to exchange the halfwords of the one operand, then add the high halfwords and subtract the low halfwords, saturating the results to the 16-bit signed integer range -2<sup>15</sup> &lt;= x &lt;= 2<sup>15</sup> - 1.</p>
629 <dl class="params"><dt>Parameters</dt><dd>
630   <table class="params">
631     <tr><td class="paramname">val1</td><td>first operand for the subtraction in the low halfword, and the first operand for the addition in the high halfword. </td></tr>
632     <tr><td class="paramname">val2</td><td>second operand for the subtraction in the high halfword, and the second operand for the addition in the low halfword.</td></tr>
633   </table>
634   </dd>
635 </dl>
636 <dl class="section return"><dt>Returns</dt><dd><ul>
637 <li>the saturated subtraction of the high halfword in the second operand from the low halfword in the first operand, in the low halfword of the return value. </li>
638 <li>the saturated addition of the high halfword in the first operand and the low halfword in the second operand, in the high halfword of the return value.</li>
639 </ul>
640 </dd></dl>
641 <dl class="section user"><dt></dt><dd>The returned results are saturated to the 16-bit signed integer range -2<sup>15</sup> &lt;= x &lt;= 2<sup>15</sup> - 1.</dd></dl>
642 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  - val2[31:16]</div>
643 <div class="line">res[31:16] = val1[31:16] + val2[15:0]</div>
644 </div><!-- fragment --> </dd></dl>
645
646 </div>
647 </div>
648 <a id="gab41eb2b17512ab01d476fc9d5bd19520" name="gab41eb2b17512ab01d476fc9d5bd19520"></a>
649 <h2 class="memtitle"><span class="permalink"><a href="#gab41eb2b17512ab01d476fc9d5bd19520">&#9670;&#160;</a></span>__QSAX()</h2>
650
651 <div class="memitem">
652 <div class="memproto">
653       <table class="memname">
654         <tr>
655           <td class="memname">uint32_t __QSAX </td>
656           <td>(</td>
657           <td class="paramtype">uint32_t&#160;</td>
658           <td class="paramname"><em>val1</em>, </td>
659         </tr>
660         <tr>
661           <td class="paramkey"></td>
662           <td></td>
663           <td class="paramtype">uint32_t&#160;</td>
664           <td class="paramname"><em>val2</em>&#160;</td>
665         </tr>
666         <tr>
667           <td></td>
668           <td>)</td>
669           <td></td><td></td>
670         </tr>
671       </table>
672 </div><div class="memdoc">
673
674 <p>Q setting dual 16-bit subtract and add with exchange. </p>
675 <p>This function enables you to exchange the halfwords of one operand, then subtract the high halfwords and add the low halfwords, saturating the results to the 16-bit signed integer range -2<sup>15</sup> &lt;= x &lt;= 2<sup>15</sup> - 1.</p>
676 <dl class="params"><dt>Parameters</dt><dd>
677   <table class="params">
678     <tr><td class="paramname">val1</td><td>first operand for the addition in the low halfword, and the first operand for the subtraction in the high halfword. </td></tr>
679     <tr><td class="paramname">val2</td><td>second operand for the addition in the high halfword, and the second operand for the subtraction in the low halfword.</td></tr>
680   </table>
681   </dd>
682 </dl>
683 <dl class="section return"><dt>Returns</dt><dd><ul>
684 <li>the saturated addition of the low halfword of the first operand and the high halfword of the second operand, in the low halfword of the return value. </li>
685 <li>the saturated subtraction of the low halfword of the second operand from the high halfword of the first operand, in the high halfword of the return value. </li>
686 </ul>
687 </dd></dl>
688 <dl class="section user"><dt></dt><dd>The returned results are saturated to the 16-bit signed integer range -2<sup>15</sup> &lt;= x &lt;= 2<sup>15</sup> - 1.</dd></dl>
689 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  + val2[31:16]</div>
690 <div class="line">res[31:16] = val1[31:16] - val2[15:0]</div>
691 </div><!-- fragment --> </dd></dl>
692
693 </div>
694 </div>
695 <a id="ga3ba259f8f05a36f7b88b469a71ffc096" name="ga3ba259f8f05a36f7b88b469a71ffc096"></a>
696 <h2 class="memtitle"><span class="permalink"><a href="#ga3ba259f8f05a36f7b88b469a71ffc096">&#9670;&#160;</a></span>__QSUB()</h2>
697
698 <div class="memitem">
699 <div class="memproto">
700       <table class="memname">
701         <tr>
702           <td class="memname">uint32_t __QSUB </td>
703           <td>(</td>
704           <td class="paramtype">uint32_t&#160;</td>
705           <td class="paramname"><em>val1</em>, </td>
706         </tr>
707         <tr>
708           <td class="paramkey"></td>
709           <td></td>
710           <td class="paramtype">uint32_t&#160;</td>
711           <td class="paramname"><em>val2</em>&#160;</td>
712         </tr>
713         <tr>
714           <td></td>
715           <td>)</td>
716           <td></td><td></td>
717         </tr>
718       </table>
719 </div><div class="memdoc">
720
721 <p>Q setting saturating subtract. </p>
722 <p>This function enables you to obtain the saturating subtraction of two integers.<br  />
723  The Q bit is set if the operation saturates.</p>
724 <dl class="params"><dt>Parameters</dt><dd>
725   <table class="params">
726     <tr><td class="paramname">val1</td><td>minuend of the saturating subtraction operation. </td></tr>
727     <tr><td class="paramname">val2</td><td>subtrahend of the saturating subtraction operation.</td></tr>
728   </table>
729   </dd>
730 </dl>
731 <dl class="section return"><dt>Returns</dt><dd>the saturating subtraction of val1 and val2.</dd></dl>
732 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[31:0] = SAT(val1 - SAT(val2))</div>
733 </div><!-- fragment --> </dd></dl>
734
735 </div>
736 </div>
737 <a id="gad089605c16df9823a2c8aaa37777aae5" name="gad089605c16df9823a2c8aaa37777aae5"></a>
738 <h2 class="memtitle"><span class="permalink"><a href="#gad089605c16df9823a2c8aaa37777aae5">&#9670;&#160;</a></span>__QSUB16()</h2>
739
740 <div class="memitem">
741 <div class="memproto">
742       <table class="memname">
743         <tr>
744           <td class="memname">uint32_t __QSUB16 </td>
745           <td>(</td>
746           <td class="paramtype">uint32_t&#160;</td>
747           <td class="paramname"><em>val1</em>, </td>
748         </tr>
749         <tr>
750           <td class="paramkey"></td>
751           <td></td>
752           <td class="paramtype">uint32_t&#160;</td>
753           <td class="paramname"><em>val2</em>&#160;</td>
754         </tr>
755         <tr>
756           <td></td>
757           <td>)</td>
758           <td></td><td></td>
759         </tr>
760       </table>
761 </div><div class="memdoc">
762
763 <p>Q setting dual 16-bit saturating subtract. </p>
764 <p>This function enables you to perform two 16-bit integer subtractions, saturating the results to the 16-bit signed integer range -2<sup>15</sup> &lt;= x &lt;= 2<sup>15</sup> - 1.</p>
765 <dl class="params"><dt>Parameters</dt><dd>
766   <table class="params">
767     <tr><td class="paramname">val1</td><td>first two 16-bit operands. </td></tr>
768     <tr><td class="paramname">val2</td><td>second two 16-bit operands.</td></tr>
769   </table>
770   </dd>
771 </dl>
772 <dl class="section return"><dt>Returns</dt><dd><ul>
773 <li>the saturated subtraction of the low halfword in the second operand from the low halfword in the first operand, in the low halfword of the returned result. </li>
774 <li>the saturated subtraction of the high halfword in the second operand from the high halfword in the first operand, in the high halfword of the returned result.</li>
775 </ul>
776 </dd></dl>
777 <dl class="section user"><dt></dt><dd>The returned results are saturated to the 16-bit signed integer range -2<sup>15</sup> &lt;= x &lt;= 2<sup>15</sup> - 1.</dd></dl>
778 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  - val2[15:0]</div>
779 <div class="line">res[31:16] = val1[31:16] - val2[31:16]</div>
780 </div><!-- fragment --> </dd></dl>
781
782 </div>
783 </div>
784 <a id="ga753493a65493880c28baa82c151a0d61" name="ga753493a65493880c28baa82c151a0d61"></a>
785 <h2 class="memtitle"><span class="permalink"><a href="#ga753493a65493880c28baa82c151a0d61">&#9670;&#160;</a></span>__QSUB8()</h2>
786
787 <div class="memitem">
788 <div class="memproto">
789       <table class="memname">
790         <tr>
791           <td class="memname">uint32_t __QSUB8 </td>
792           <td>(</td>
793           <td class="paramtype">uint32_t&#160;</td>
794           <td class="paramname"><em>val1</em>, </td>
795         </tr>
796         <tr>
797           <td class="paramkey"></td>
798           <td></td>
799           <td class="paramtype">uint32_t&#160;</td>
800           <td class="paramname"><em>val2</em>&#160;</td>
801         </tr>
802         <tr>
803           <td></td>
804           <td>)</td>
805           <td></td><td></td>
806         </tr>
807       </table>
808 </div><div class="memdoc">
809
810 <p>Q setting quad 8-bit saturating subtract. </p>
811 <p>This function enables you to perform four 8-bit integer subtractions, saturating the results to the 8-bit signed integer range -2<sup>7</sup> &lt;= x &lt;= 2<sup>7</sup> - 1.</p>
812 <dl class="params"><dt>Parameters</dt><dd>
813   <table class="params">
814     <tr><td class="paramname">val1</td><td>first four 8-bit operands. </td></tr>
815     <tr><td class="paramname">val2</td><td>second four 8-bit operands.</td></tr>
816   </table>
817   </dd>
818 </dl>
819 <dl class="section return"><dt>Returns</dt><dd><ul>
820 <li>the subtraction of the first byte in the second operand from the first byte in the first operand, in the first bytes of the return value. </li>
821 <li>the subtraction of the second byte in the second operand from the second byte in the first operand, in the second byte of the return value. </li>
822 <li>the subtraction of the third byte in the second operand from the third byte in the first operand, in the third byte of the return value. </li>
823 <li>the subtraction of the fourth byte in the second operand from the fourth byte in the first operand, in the fourth byte of the return value.</li>
824 </ul>
825 </dd></dl>
826 <dl class="section user"><dt></dt><dd>The returned results are saturated to the 8-bit signed integer range -2<sup>7</sup> &lt;= x &lt;= 2<sup>7</sup> - 1.</dd></dl>
827 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[7:0]   = val1[7:0]   - val2[7:0]</div>
828 <div class="line">res[15:8]  = val1[15:8]  - val2[15:8]</div>
829 <div class="line">res[23:16] = val1[23:16] - val2[23:16]</div>
830 <div class="line">res[31:24] = val1[31:24] - val2[31:24]</div>
831 </div><!-- fragment --> </dd></dl>
832
833 </div>
834 </div>
835 <a id="gad0bf46373a1c05aabf64517e84be5984" name="gad0bf46373a1c05aabf64517e84be5984"></a>
836 <h2 class="memtitle"><span class="permalink"><a href="#gad0bf46373a1c05aabf64517e84be5984">&#9670;&#160;</a></span>__SADD16()</h2>
837
838 <div class="memitem">
839 <div class="memproto">
840       <table class="memname">
841         <tr>
842           <td class="memname">uint32_t __SADD16 </td>
843           <td>(</td>
844           <td class="paramtype">uint32_t&#160;</td>
845           <td class="paramname"><em>val1</em>, </td>
846         </tr>
847         <tr>
848           <td class="paramkey"></td>
849           <td></td>
850           <td class="paramtype">uint32_t&#160;</td>
851           <td class="paramname"><em>val2</em>&#160;</td>
852         </tr>
853         <tr>
854           <td></td>
855           <td>)</td>
856           <td></td><td></td>
857         </tr>
858       </table>
859 </div><div class="memdoc">
860
861 <p>GE setting dual 16-bit signed addition. </p>
862 <p>This function enables you to perform two 16-bit signed integer additions.<br  />
863  The GE bits in the APSR are set according to the results of the additions.</p>
864 <dl class="params"><dt>Parameters</dt><dd>
865   <table class="params">
866     <tr><td class="paramname">val1</td><td>first two 16-bit summands. </td></tr>
867     <tr><td class="paramname">val2</td><td>second two 16-bit summands.</td></tr>
868   </table>
869   </dd>
870 </dl>
871 <dl class="section return"><dt>Returns</dt><dd><ul>
872 <li>the addition of the low halfwords in the low halfword of the return value. </li>
873 <li>the addition of the high halfwords in the high halfword of the return value.</li>
874 </ul>
875 </dd></dl>
876 <dl class="section user"><dt></dt><dd>Each bit in APSR.GE is set or cleared for each byte in the return value, depending on the results of the operation. </dd></dl>
877 <dl class="section user"><dt></dt><dd>If <em>res</em> is the return value, then: <ul>
878 <li>if res[15:0] &gt;= 0 then APSR.GE[1:0] = 11 else 00 </li>
879 <li>if res[31:16] &gt;= 0 then APSR.GE[3:2] = 11 else 00</li>
880 </ul>
881 </dd></dl>
882 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  + val2[15:0]</div>
883 <div class="line">res[31:16] = val1[31:16] + val2[31:16]</div>
884 </div><!-- fragment --> </dd></dl>
885
886 </div>
887 </div>
888 <a id="gac20aa0f741d0a1494d58c531e38d5785" name="gac20aa0f741d0a1494d58c531e38d5785"></a>
889 <h2 class="memtitle"><span class="permalink"><a href="#gac20aa0f741d0a1494d58c531e38d5785">&#9670;&#160;</a></span>__SADD8()</h2>
890
891 <div class="memitem">
892 <div class="memproto">
893       <table class="memname">
894         <tr>
895           <td class="memname">uint32_t __SADD8 </td>
896           <td>(</td>
897           <td class="paramtype">uint32_t&#160;</td>
898           <td class="paramname"><em>val1</em>, </td>
899         </tr>
900         <tr>
901           <td class="paramkey"></td>
902           <td></td>
903           <td class="paramtype">uint32_t&#160;</td>
904           <td class="paramname"><em>val2</em>&#160;</td>
905         </tr>
906         <tr>
907           <td></td>
908           <td>)</td>
909           <td></td><td></td>
910         </tr>
911       </table>
912 </div><div class="memdoc">
913
914 <p>GE setting quad 8-bit signed addition. </p>
915 <p>This function performs four 8-bit signed integer additions. The GE bits of the APSR are set according to the results of the additions. </p><dl class="params"><dt>Parameters</dt><dd>
916   <table class="params">
917     <tr><td class="paramname">val1</td><td>first four 8-bit summands. </td></tr>
918     <tr><td class="paramname">val2</td><td>second four 8-bit summands.</td></tr>
919   </table>
920   </dd>
921 </dl>
922 <dl class="section return"><dt>Returns</dt><dd><ul>
923 <li>the addition of the first bytes from each operand, in the first byte of the return value. </li>
924 <li>the addition of the second bytes of each operand, in the second byte of the return value. </li>
925 <li>the addition of the third bytes of each operand, in the third byte of the return value. </li>
926 <li>the addition of the fourth bytes of each operand, in the fourth byte of the return value. </li>
927 </ul>
928 </dd></dl>
929 <dl class="section user"><dt></dt><dd>Each bit in APSR.GE is set or cleared for each byte in the return value, depending on the results of the operation. </dd></dl>
930 <dl class="section user"><dt></dt><dd>If <em>res</em> is the return value, then: <ul>
931 <li>if res[7:0] &gt;= 0 then APSR.GE[0] = 1 else 0 </li>
932 <li>if res[15:8] &gt;= 0 then APSR.GE[1] = 1 else 0 </li>
933 <li>if res[23:16] &gt;= 0 then APSR.GE[2] = 1 else 0 </li>
934 <li>if res[31:24] &gt;= 0 then APSR.GE[3] = 1 else 0</li>
935 </ul>
936 </dd></dl>
937 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[7:0]   = val1[7:0]   + val2[7:0]</div>
938 <div class="line">res[15:8]  = val1[15:8]  + val2[15:8]</div>
939 <div class="line">res[23:16] = val1[23:16] + val2[23:16]</div>
940 <div class="line">res[31:24] = val1[31:24] + val2[31:24]</div>
941 </div><!-- fragment --> </dd></dl>
942
943 </div>
944 </div>
945 <a id="ga5845084fd99c872e98cf5553d554de2a" name="ga5845084fd99c872e98cf5553d554de2a"></a>
946 <h2 class="memtitle"><span class="permalink"><a href="#ga5845084fd99c872e98cf5553d554de2a">&#9670;&#160;</a></span>__SASX()</h2>
947
948 <div class="memitem">
949 <div class="memproto">
950       <table class="memname">
951         <tr>
952           <td class="memname">uint32_t __SASX </td>
953           <td>(</td>
954           <td class="paramtype">uint32_t&#160;</td>
955           <td class="paramname"><em>val1</em>, </td>
956         </tr>
957         <tr>
958           <td class="paramkey"></td>
959           <td></td>
960           <td class="paramtype">uint32_t&#160;</td>
961           <td class="paramname"><em>val2</em>&#160;</td>
962         </tr>
963         <tr>
964           <td></td>
965           <td>)</td>
966           <td></td><td></td>
967         </tr>
968       </table>
969 </div><div class="memdoc">
970
971 <p>GE setting dual 16-bit addition and subtraction with exchange. </p>
972 <p>This function inserts an SASX instruction into the instruction stream generated by the compiler. It enables you to exchange the halfwords of the second operand, add the high halfwords and subtract the low halfwords.<br  />
973  The GE bits in the APRS are set according to the results.</p>
974 <dl class="params"><dt>Parameters</dt><dd>
975   <table class="params">
976     <tr><td class="paramname">val1</td><td>first operand for the subtraction in the low halfword, and the first operand for the addition in the high halfword. </td></tr>
977     <tr><td class="paramname">val2</td><td>second operand for the subtraction in the high halfword, and the second operand for the addition in the low halfword.</td></tr>
978   </table>
979   </dd>
980 </dl>
981 <dl class="section return"><dt>Returns</dt><dd><ul>
982 <li>the subtraction of the high halfword in the second operand from the low halfword in the first operand, in the low halfword of the return value. </li>
983 <li>the addition of the high halfword in the first operand and the low halfword in the second operand, in the high halfword of the return value.</li>
984 </ul>
985 </dd></dl>
986 <dl class="section user"><dt></dt><dd>Each bit in APSR.GE is set or cleared for each byte in the return value, depending on the results of the operation. </dd></dl>
987 <dl class="section user"><dt></dt><dd>If <em>res</em> is the return value, then: <ul>
988 <li>if res[15:0] &gt;= 0 then APSR.GE[1:0] = 11 else 00 </li>
989 <li>if res[31:16] &gt;= 0 then APSR.GE[3:2] = 11 else 00</li>
990 </ul>
991 </dd></dl>
992 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  - val2[31:16]</div>
993 <div class="line">res[31:16] = val1[31:16] + val2[15:0]</div>
994 </div><!-- fragment --> </dd></dl>
995
996 </div>
997 </div>
998 <a id="gaf5448e591fe49161b6759b48aecb08fe" name="gaf5448e591fe49161b6759b48aecb08fe"></a>
999 <h2 class="memtitle"><span class="permalink"><a href="#gaf5448e591fe49161b6759b48aecb08fe">&#9670;&#160;</a></span>__SEL()</h2>
1000
1001 <div class="memitem">
1002 <div class="memproto">
1003       <table class="memname">
1004         <tr>
1005           <td class="memname">uint32_t __SEL </td>
1006           <td>(</td>
1007           <td class="paramtype">uint32_t&#160;</td>
1008           <td class="paramname"><em>val1</em>, </td>
1009         </tr>
1010         <tr>
1011           <td class="paramkey"></td>
1012           <td></td>
1013           <td class="paramtype">uint32_t&#160;</td>
1014           <td class="paramname"><em>val2</em>&#160;</td>
1015         </tr>
1016         <tr>
1017           <td></td>
1018           <td>)</td>
1019           <td></td><td></td>
1020         </tr>
1021       </table>
1022 </div><div class="memdoc">
1023
1024 <p>Select bytes based on GE bits. </p>
1025 <p>This function inserts a SEL instruction into the instruction stream generated by the compiler. It enables you to select bytes from the input parameters, whereby the bytes that are selected depend upon the results of previous SIMD instruction function. The results of previous SIMD instruction function are represented by the Greater than or Equal flags in the Application Program Status Register (APSR). The __SEL function works equally well on both halfword and byte operand function results. This is because halfword operand operations set two (duplicate) GE bits per value.</p>
1026 <dl class="params"><dt>Parameters</dt><dd>
1027   <table class="params">
1028     <tr><td class="paramname">val1</td><td>four selectable 8-bit values. </td></tr>
1029     <tr><td class="paramname">val2</td><td>four selectable 8-bit values.</td></tr>
1030   </table>
1031   </dd>
1032 </dl>
1033 <dl class="section return"><dt>Returns</dt><dd>The function selects bytes from the input parameters and returns them in the return value, res, according to the following criteria: <ul>
1034 <li>if APSR.GE[0] == 1 then res[7:0] = val1[7:0] else res[7:0] = val2[7:0] </li>
1035 <li>if APSR.GE[1] == 1 then res[15:8] = val1[15:8] else res[15:8] = val2[15:8] </li>
1036 <li>if APSR.GE[2] == 1 then res[23:16] = val1[23:16] else res[23:16] = val2[23:16] </li>
1037 <li>if APSR.GE[3] == 1 then res[31;24] = val1[31:24] else res = val2[31:24] </li>
1038 </ul>
1039 </dd></dl>
1040
1041 </div>
1042 </div>
1043 <a id="ga15d8899a173effb8ad8c7268da32b60e" name="ga15d8899a173effb8ad8c7268da32b60e"></a>
1044 <h2 class="memtitle"><span class="permalink"><a href="#ga15d8899a173effb8ad8c7268da32b60e">&#9670;&#160;</a></span>__SHADD16()</h2>
1045
1046 <div class="memitem">
1047 <div class="memproto">
1048       <table class="memname">
1049         <tr>
1050           <td class="memname">uint32_t __SHADD16 </td>
1051           <td>(</td>
1052           <td class="paramtype">uint32_t&#160;</td>
1053           <td class="paramname"><em>val1</em>, </td>
1054         </tr>
1055         <tr>
1056           <td class="paramkey"></td>
1057           <td></td>
1058           <td class="paramtype">uint32_t&#160;</td>
1059           <td class="paramname"><em>val2</em>&#160;</td>
1060         </tr>
1061         <tr>
1062           <td></td>
1063           <td>)</td>
1064           <td></td><td></td>
1065         </tr>
1066       </table>
1067 </div><div class="memdoc">
1068
1069 <p>Dual 16-bit signed addition with halved results. </p>
1070 <p>This function enables you to perform two signed 16-bit integer additions, halving the results.</p>
1071 <dl class="params"><dt>Parameters</dt><dd>
1072   <table class="params">
1073     <tr><td class="paramname">val1</td><td>first two 16-bit summands. </td></tr>
1074     <tr><td class="paramname">val2</td><td>second two 16-bit summands.</td></tr>
1075   </table>
1076   </dd>
1077 </dl>
1078 <dl class="section return"><dt>Returns</dt><dd><ul>
1079 <li>the halved addition of the low halfwords, in the low halfword of the return value. </li>
1080 <li>the halved addition of the high halfwords, in the high halfword of the return value.</li>
1081 </ul>
1082 </dd></dl>
1083 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  + val2[15:0]  &gt;&gt; 1</div>
1084 <div class="line">res[31:16] = val1[31:16] + val2[31:16] &gt;&gt; 1</div>
1085 </div><!-- fragment --> </dd></dl>
1086
1087 </div>
1088 </div>
1089 <a id="ga524575b442ea01aec10c762bf4d85fea" name="ga524575b442ea01aec10c762bf4d85fea"></a>
1090 <h2 class="memtitle"><span class="permalink"><a href="#ga524575b442ea01aec10c762bf4d85fea">&#9670;&#160;</a></span>__SHADD8()</h2>
1091
1092 <div class="memitem">
1093 <div class="memproto">
1094       <table class="memname">
1095         <tr>
1096           <td class="memname">uint32_t __SHADD8 </td>
1097           <td>(</td>
1098           <td class="paramtype">uint32_t&#160;</td>
1099           <td class="paramname"><em>val1</em>, </td>
1100         </tr>
1101         <tr>
1102           <td class="paramkey"></td>
1103           <td></td>
1104           <td class="paramtype">uint32_t&#160;</td>
1105           <td class="paramname"><em>val2</em>&#160;</td>
1106         </tr>
1107         <tr>
1108           <td></td>
1109           <td>)</td>
1110           <td></td><td></td>
1111         </tr>
1112       </table>
1113 </div><div class="memdoc">
1114
1115 <p>Quad 8-bit signed addition with halved results. </p>
1116 <p>This function enables you to perform four signed 8-bit integer additions, halving the results. </p><dl class="params"><dt>Parameters</dt><dd>
1117   <table class="params">
1118     <tr><td class="paramname">val1</td><td>first four 8-bit summands. </td></tr>
1119     <tr><td class="paramname">val2</td><td>second four 8-bit summands.</td></tr>
1120   </table>
1121   </dd>
1122 </dl>
1123 <dl class="section return"><dt>Returns</dt><dd><ul>
1124 <li>the halved addition of the first bytes from each operand, in the first byte of the return value. </li>
1125 <li>the halved addition of the second bytes from each operand, in the second byte of the return value. </li>
1126 <li>the halved addition of the third bytes from each operand, in the third byte of the return value. </li>
1127 <li>the halved addition of the fourth bytes from each operand, in the fourth byte of the return value.</li>
1128 </ul>
1129 </dd></dl>
1130 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[7:0]   = val1[7:0]   + val2[7:0]  &gt;&gt; 1</div>
1131 <div class="line">res[15:8]  = val1[15:8]  + val2[15:8] &gt;&gt; 1</div>
1132 <div class="line">res[23:16] = val1[23:16] + val2[23:16] &gt;&gt; 1</div>
1133 <div class="line">res[31:24] = val1[31:24] + val2[31:24] &gt;&gt; 1</div>
1134 </div><!-- fragment --> </dd></dl>
1135
1136 </div>
1137 </div>
1138 <a id="gae0a649035f67627464fd80e7218c89d5" name="gae0a649035f67627464fd80e7218c89d5"></a>
1139 <h2 class="memtitle"><span class="permalink"><a href="#gae0a649035f67627464fd80e7218c89d5">&#9670;&#160;</a></span>__SHASX()</h2>
1140
1141 <div class="memitem">
1142 <div class="memproto">
1143       <table class="memname">
1144         <tr>
1145           <td class="memname">uint32_t __SHASX </td>
1146           <td>(</td>
1147           <td class="paramtype">uint32_t&#160;</td>
1148           <td class="paramname"><em>val1</em>, </td>
1149         </tr>
1150         <tr>
1151           <td class="paramkey"></td>
1152           <td></td>
1153           <td class="paramtype">uint32_t&#160;</td>
1154           <td class="paramname"><em>val2</em>&#160;</td>
1155         </tr>
1156         <tr>
1157           <td></td>
1158           <td>)</td>
1159           <td></td><td></td>
1160         </tr>
1161       </table>
1162 </div><div class="memdoc">
1163
1164 <p>Dual 16-bit signed addition and subtraction with halved results. </p>
1165 <p>This function enables you to exchange the two halfwords of one operand, perform one signed 16-bit integer addition and one signed 16-bit subtraction, and halve the results.</p>
1166 <dl class="params"><dt>Parameters</dt><dd>
1167   <table class="params">
1168     <tr><td class="paramname">val1</td><td>first 16-bit operands. </td></tr>
1169     <tr><td class="paramname">val2</td><td>second 16-bit operands.</td></tr>
1170   </table>
1171   </dd>
1172 </dl>
1173 <dl class="section return"><dt>Returns</dt><dd><ul>
1174 <li>the halved subtraction of the high halfword in the second operand from the low halfword in the first operand, in the low halfword of the return value. </li>
1175 <li>the halved addition of the low halfword in the second operand and the high halfword in the first operand, in the high halfword of the return value.</li>
1176 </ul>
1177 </dd></dl>
1178 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = (val1[15:0]  - val2[31:16]) &gt;&gt; 1</div>
1179 <div class="line">res[31:16] = (val1[31:16] + val2[15:0] ) &gt;&gt; 1</div>
1180 </div><!-- fragment --> </dd></dl>
1181
1182 </div>
1183 </div>
1184 <a id="gafadbd89c36b5addcf1ca10dd392db3e9" name="gafadbd89c36b5addcf1ca10dd392db3e9"></a>
1185 <h2 class="memtitle"><span class="permalink"><a href="#gafadbd89c36b5addcf1ca10dd392db3e9">&#9670;&#160;</a></span>__SHSAX()</h2>
1186
1187 <div class="memitem">
1188 <div class="memproto">
1189       <table class="memname">
1190         <tr>
1191           <td class="memname">uint32_t __SHSAX </td>
1192           <td>(</td>
1193           <td class="paramtype">uint32_t&#160;</td>
1194           <td class="paramname"><em>val1</em>, </td>
1195         </tr>
1196         <tr>
1197           <td class="paramkey"></td>
1198           <td></td>
1199           <td class="paramtype">uint32_t&#160;</td>
1200           <td class="paramname"><em>val2</em>&#160;</td>
1201         </tr>
1202         <tr>
1203           <td></td>
1204           <td>)</td>
1205           <td></td><td></td>
1206         </tr>
1207       </table>
1208 </div><div class="memdoc">
1209
1210 <p>Dual 16-bit signed subtraction and addition with halved results. </p>
1211 <p>This function enables you to exchange the two halfwords of one operand, perform one signed 16-bit integer subtraction and one signed 16-bit addition, and halve the results.</p>
1212 <dl class="params"><dt>Parameters</dt><dd>
1213   <table class="params">
1214     <tr><td class="paramname">val1</td><td>first 16-bit operands. </td></tr>
1215     <tr><td class="paramname">val2</td><td>second 16-bit operands.</td></tr>
1216   </table>
1217   </dd>
1218 </dl>
1219 <dl class="section return"><dt>Returns</dt><dd><ul>
1220 <li>the halved addition of the low halfword in the first operand and the high halfword in the second operand, in the low halfword of the return value. </li>
1221 <li>the halved subtraction of the low halfword in the second operand from the high halfword in the first operand, in the high halfword of the return value.</li>
1222 </ul>
1223 </dd></dl>
1224 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = (val1[15:0]  + val2[31:16]) &gt;&gt; 1</div>
1225 <div class="line">res[31:16] = (val1[31:16] - val2[15:0] ) &gt;&gt; 1</div>
1226 </div><!-- fragment --> </dd></dl>
1227
1228 </div>
1229 </div>
1230 <a id="ga31328467f0f91b8ff9ae9a01682ad3bf" name="ga31328467f0f91b8ff9ae9a01682ad3bf"></a>
1231 <h2 class="memtitle"><span class="permalink"><a href="#ga31328467f0f91b8ff9ae9a01682ad3bf">&#9670;&#160;</a></span>__SHSUB16()</h2>
1232
1233 <div class="memitem">
1234 <div class="memproto">
1235       <table class="memname">
1236         <tr>
1237           <td class="memname">uint32_t __SHSUB16 </td>
1238           <td>(</td>
1239           <td class="paramtype">uint32_t&#160;</td>
1240           <td class="paramname"><em>val1</em>, </td>
1241         </tr>
1242         <tr>
1243           <td class="paramkey"></td>
1244           <td></td>
1245           <td class="paramtype">uint32_t&#160;</td>
1246           <td class="paramname"><em>val2</em>&#160;</td>
1247         </tr>
1248         <tr>
1249           <td></td>
1250           <td>)</td>
1251           <td></td><td></td>
1252         </tr>
1253       </table>
1254 </div><div class="memdoc">
1255
1256 <p>Dual 16-bit signed subtraction with halved results. </p>
1257 <p>This function enables you to perform two signed 16-bit integer subtractions, halving the results.</p>
1258 <dl class="params"><dt>Parameters</dt><dd>
1259   <table class="params">
1260     <tr><td class="paramname">val1</td><td>first two 16-bit operands. </td></tr>
1261     <tr><td class="paramname">val2</td><td>second two 16-bit operands.</td></tr>
1262   </table>
1263   </dd>
1264 </dl>
1265 <dl class="section return"><dt>Returns</dt><dd><ul>
1266 <li>the halved subtraction of the low halfword in the second operand from the low halfword in the first operand, in the low halfword of the returned result. </li>
1267 <li>the halved subtraction of the high halfword in the second operand from the high halfword in the first operand, in the high halfword of the returned result.</li>
1268 </ul>
1269 </dd></dl>
1270 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  - val2[15:0]   &gt;&gt; 1</div>
1271 <div class="line">res[31:16] = val1[31:16] - val2[31:16]  &gt;&gt; 1</div>
1272 </div><!-- fragment --> </dd></dl>
1273
1274 </div>
1275 </div>
1276 <a id="gac3ec7215b354d925a239f3b31df2b77b" name="gac3ec7215b354d925a239f3b31df2b77b"></a>
1277 <h2 class="memtitle"><span class="permalink"><a href="#gac3ec7215b354d925a239f3b31df2b77b">&#9670;&#160;</a></span>__SHSUB8()</h2>
1278
1279 <div class="memitem">
1280 <div class="memproto">
1281       <table class="memname">
1282         <tr>
1283           <td class="memname">uint32_t __SHSUB8 </td>
1284           <td>(</td>
1285           <td class="paramtype">uint32_t&#160;</td>
1286           <td class="paramname"><em>val1</em>, </td>
1287         </tr>
1288         <tr>
1289           <td class="paramkey"></td>
1290           <td></td>
1291           <td class="paramtype">uint32_t&#160;</td>
1292           <td class="paramname"><em>val2</em>&#160;</td>
1293         </tr>
1294         <tr>
1295           <td></td>
1296           <td>)</td>
1297           <td></td><td></td>
1298         </tr>
1299       </table>
1300 </div><div class="memdoc">
1301
1302 <p>Quad 8-bit signed subtraction with halved results. </p>
1303 <p>This function enables you to perform four signed 8-bit integer subtractions, halving the results.</p>
1304 <dl class="params"><dt>Parameters</dt><dd>
1305   <table class="params">
1306     <tr><td class="paramname">val1</td><td>first four 8-bit operands. </td></tr>
1307     <tr><td class="paramname">val2</td><td>second four 8-bit operands.</td></tr>
1308   </table>
1309   </dd>
1310 </dl>
1311 <dl class="section return"><dt>Returns</dt><dd><ul>
1312 <li>the halved subtraction of the first byte in the second operand from the first byte in the first operand, in the first bytes of the return value. </li>
1313 <li>the halved subtraction of the second byte in the second operand from the second byte in the first operand, in the second byte of the return value. </li>
1314 <li>the halved subtraction of the third byte in the second operand from the third byte in the first operand, in the third byte of the return value. </li>
1315 <li>the halved subtraction of the fourth byte in the second operand from the fourth byte in the first operand, in the fourth byte of the return value.</li>
1316 </ul>
1317 </dd></dl>
1318 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[7:0]   = val1[7:0]   - val2[7:0]   &gt;&gt; 1</div>
1319 <div class="line">res[15:8]  = val1[15:8]  - val2[15:8]  &gt;&gt; 1</div>
1320 <div class="line">res[23:16] = val1[23:16] - val2[23:16] &gt;&gt; 1</div>
1321 <div class="line">res[31:24] = val1[31:24] - val2[31:24] &gt;&gt; 1</div>
1322 </div><!-- fragment --> </dd></dl>
1323
1324 </div>
1325 </div>
1326 <a id="gae0c86f3298532183f3a29f5bb454d354" name="gae0c86f3298532183f3a29f5bb454d354"></a>
1327 <h2 class="memtitle"><span class="permalink"><a href="#gae0c86f3298532183f3a29f5bb454d354">&#9670;&#160;</a></span>__SMLAD()</h2>
1328
1329 <div class="memitem">
1330 <div class="memproto">
1331       <table class="memname">
1332         <tr>
1333           <td class="memname">uint32_t __SMLAD </td>
1334           <td>(</td>
1335           <td class="paramtype">uint32_t&#160;</td>
1336           <td class="paramname"><em>val1</em>, </td>
1337         </tr>
1338         <tr>
1339           <td class="paramkey"></td>
1340           <td></td>
1341           <td class="paramtype">uint32_t&#160;</td>
1342           <td class="paramname"><em>val2</em>, </td>
1343         </tr>
1344         <tr>
1345           <td class="paramkey"></td>
1346           <td></td>
1347           <td class="paramtype">uint32_t&#160;</td>
1348           <td class="paramname"><em>val3</em>&#160;</td>
1349         </tr>
1350         <tr>
1351           <td></td>
1352           <td>)</td>
1353           <td></td><td></td>
1354         </tr>
1355       </table>
1356 </div><div class="memdoc">
1357
1358 <p>Q setting dual 16-bit signed multiply with single 32-bit accumulator. </p>
1359 <p>This function enables you to perform two signed 16-bit multiplications, adding both results to a 32-bit accumulate operand.<br  />
1360  The Q bit is set if the addition overflows. Overflow cannot occur during the multiplications.</p>
1361 <dl class="params"><dt>Parameters</dt><dd>
1362   <table class="params">
1363     <tr><td class="paramname">val1</td><td>first 16-bit operands for each multiplication. </td></tr>
1364     <tr><td class="paramname">val2</td><td>second 16-bit operands for each multiplication. </td></tr>
1365     <tr><td class="paramname">val3</td><td>accumulate value.</td></tr>
1366   </table>
1367   </dd>
1368 </dl>
1369 <dl class="section return"><dt>Returns</dt><dd>the product of each multiplication added to the accumulate value, as a 32-bit integer.</dd></dl>
1370 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">p1 = val1[15:0]  * val2[15:0]</div>
1371 <div class="line">p2 = val1[31:16] * val2[31:16]</div>
1372 <div class="line">res[31:0] = p1 + p2 + val3[31:0]</div>
1373 </div><!-- fragment --> </dd></dl>
1374
1375 </div>
1376 </div>
1377 <a id="ga9c286d330f4fb29b256335add91eec9f" name="ga9c286d330f4fb29b256335add91eec9f"></a>
1378 <h2 class="memtitle"><span class="permalink"><a href="#ga9c286d330f4fb29b256335add91eec9f">&#9670;&#160;</a></span>__SMLADX()</h2>
1379
1380 <div class="memitem">
1381 <div class="memproto">
1382       <table class="memname">
1383         <tr>
1384           <td class="memname">uint32_t __SMLADX </td>
1385           <td>(</td>
1386           <td class="paramtype">uint32_t&#160;</td>
1387           <td class="paramname"><em>val1</em>, </td>
1388         </tr>
1389         <tr>
1390           <td class="paramkey"></td>
1391           <td></td>
1392           <td class="paramtype">uint32_t&#160;</td>
1393           <td class="paramname"><em>val2</em>, </td>
1394         </tr>
1395         <tr>
1396           <td class="paramkey"></td>
1397           <td></td>
1398           <td class="paramtype">uint32_t&#160;</td>
1399           <td class="paramname"><em>val3</em>&#160;</td>
1400         </tr>
1401         <tr>
1402           <td></td>
1403           <td>)</td>
1404           <td></td><td></td>
1405         </tr>
1406       </table>
1407 </div><div class="memdoc">
1408
1409 <p>Q setting pre-exchanged dual 16-bit signed multiply with single 32-bit accumulator. </p>
1410 <p>This function enables you to perform two signed 16-bit multiplications with exchanged halfwords of the second operand, adding both results to a 32-bit accumulate operand.<br  />
1411  The Q bit is set if the addition overflows. Overflow cannot occur during the multiplications.</p>
1412 <dl class="params"><dt>Parameters</dt><dd>
1413   <table class="params">
1414     <tr><td class="paramname">val1</td><td>first 16-bit operands for each multiplication. </td></tr>
1415     <tr><td class="paramname">val2</td><td>second 16-bit operands for each multiplication. </td></tr>
1416     <tr><td class="paramname">val3</td><td>accumulate value.</td></tr>
1417   </table>
1418   </dd>
1419 </dl>
1420 <dl class="section return"><dt>Returns</dt><dd>the product of each multiplication with exchanged halfwords of the second operand added to the accumulate value, as a 32-bit integer.</dd></dl>
1421 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">p1 = val1[15:0]  * val2[31:16]</div>
1422 <div class="line">p2 = val1[31:16] * val2[15:0]</div>
1423 <div class="line">res[31:0] = p1 + p2 + val3[31:0]</div>
1424 </div><!-- fragment --> </dd></dl>
1425
1426 </div>
1427 </div>
1428 <a id="gad80e9b20c1736fd798f897362273a146" name="gad80e9b20c1736fd798f897362273a146"></a>
1429 <h2 class="memtitle"><span class="permalink"><a href="#gad80e9b20c1736fd798f897362273a146">&#9670;&#160;</a></span>__SMLALD()</h2>
1430
1431 <div class="memitem">
1432 <div class="memproto">
1433       <table class="memname">
1434         <tr>
1435           <td class="memname">uint64_t __SMLALD </td>
1436           <td>(</td>
1437           <td class="paramtype">uint32_t&#160;</td>
1438           <td class="paramname"><em>val1</em>, </td>
1439         </tr>
1440         <tr>
1441           <td class="paramkey"></td>
1442           <td></td>
1443           <td class="paramtype">uint32_t&#160;</td>
1444           <td class="paramname"><em>val2</em>, </td>
1445         </tr>
1446         <tr>
1447           <td class="paramkey"></td>
1448           <td></td>
1449           <td class="paramtype">uint64_t&#160;</td>
1450           <td class="paramname"><em>val3</em>&#160;</td>
1451         </tr>
1452         <tr>
1453           <td></td>
1454           <td>)</td>
1455           <td></td><td></td>
1456         </tr>
1457       </table>
1458 </div><div class="memdoc">
1459
1460 <p>Dual 16-bit signed multiply with single 64-bit accumulator. </p>
1461 <p>This function enables you to perform two signed 16-bit multiplications, adding both results to a 64-bit accumulate operand. Overflow is only possible as a result of the 64-bit addition. This overflow is not detected if it occurs. Instead, the result wraps around modulo2<sup>64</sup>.</p>
1462 <dl class="params"><dt>Parameters</dt><dd>
1463   <table class="params">
1464     <tr><td class="paramname">val1</td><td>first 16-bit operands for each multiplication. </td></tr>
1465     <tr><td class="paramname">val2</td><td>second 16-bit operands for each multiplication. </td></tr>
1466     <tr><td class="paramname">val3</td><td>accumulate value.</td></tr>
1467   </table>
1468   </dd>
1469 </dl>
1470 <dl class="section return"><dt>Returns</dt><dd>the product of each multiplication added to the accumulate value.</dd></dl>
1471 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">p1 = val1[15:0]  * val2[15:0]</div>
1472 <div class="line">p2 = val1[31:16] * val2[31:16]</div>
1473 <div class="line">sum = p1 + p2 + val3[63:32][31:0]</div>
1474 <div class="line">res[63:32] = sum[63:32]</div>
1475 <div class="line">res[31:0]  = sum[31:0]</div>
1476 </div><!-- fragment --> </dd></dl>
1477
1478 </div>
1479 </div>
1480 <a id="gad1adad1b3f2667328cc0db6c6b4f41cf" name="gad1adad1b3f2667328cc0db6c6b4f41cf"></a>
1481 <h2 class="memtitle"><span class="permalink"><a href="#gad1adad1b3f2667328cc0db6c6b4f41cf">&#9670;&#160;</a></span>__SMLALDX()</h2>
1482
1483 <div class="memitem">
1484 <div class="memproto">
1485       <table class="memname">
1486         <tr>
1487           <td class="memname">unsigned long long __SMLALDX </td>
1488           <td>(</td>
1489           <td class="paramtype">uint32_t&#160;</td>
1490           <td class="paramname"><em>val1</em>, </td>
1491         </tr>
1492         <tr>
1493           <td class="paramkey"></td>
1494           <td></td>
1495           <td class="paramtype">uint32_t&#160;</td>
1496           <td class="paramname"><em>val2</em>, </td>
1497         </tr>
1498         <tr>
1499           <td class="paramkey"></td>
1500           <td></td>
1501           <td class="paramtype">unsigned long long&#160;</td>
1502           <td class="paramname"><em>val3</em>&#160;</td>
1503         </tr>
1504         <tr>
1505           <td></td>
1506           <td>)</td>
1507           <td></td><td></td>
1508         </tr>
1509       </table>
1510 </div><div class="memdoc">
1511
1512 <p>Dual 16-bit signed multiply with exchange with single 64-bit accumulator. </p>
1513 <p>This function enables you to exchange the halfwords of the second operand, and perform two signed 16-bit multiplications, adding both results to a 64-bit accumulate operand. Overflow is only possible as a result of the 64-bit addition. This overflow is not detected if it occurs. Instead, the result wraps around modulo2<sup>64</sup>.</p>
1514 <dl class="params"><dt>Parameters</dt><dd>
1515   <table class="params">
1516     <tr><td class="paramname">val1</td><td>first 16-bit operands for each multiplication. </td></tr>
1517     <tr><td class="paramname">val2</td><td>second 16-bit operands for each multiplication. </td></tr>
1518     <tr><td class="paramname">val3</td><td>accumulate value.</td></tr>
1519   </table>
1520   </dd>
1521 </dl>
1522 <dl class="section return"><dt>Returns</dt><dd>the product of each multiplication added to the accumulate value.</dd></dl>
1523 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">p1 = val1[15:0]  * val2[31:16]</div>
1524 <div class="line">p2 = val1[31:16] * val2[15:0]</div>
1525 <div class="line">sum = p1 + p2 + val3[63:32][31:0]</div>
1526 <div class="line">res[63:32] = sum[63:32]</div>
1527 <div class="line">res[31:0] = sum[31:0]</div>
1528 </div><!-- fragment --> </dd></dl>
1529
1530 </div>
1531 </div>
1532 <a id="gaf4350af7f2030c36f43b2c104a9d16cd" name="gaf4350af7f2030c36f43b2c104a9d16cd"></a>
1533 <h2 class="memtitle"><span class="permalink"><a href="#gaf4350af7f2030c36f43b2c104a9d16cd">&#9670;&#160;</a></span>__SMLSD()</h2>
1534
1535 <div class="memitem">
1536 <div class="memproto">
1537       <table class="memname">
1538         <tr>
1539           <td class="memname">uint32_t __SMLSD </td>
1540           <td>(</td>
1541           <td class="paramtype">uint32_t&#160;</td>
1542           <td class="paramname"><em>val1</em>, </td>
1543         </tr>
1544         <tr>
1545           <td class="paramkey"></td>
1546           <td></td>
1547           <td class="paramtype">uint32_t&#160;</td>
1548           <td class="paramname"><em>val2</em>, </td>
1549         </tr>
1550         <tr>
1551           <td class="paramkey"></td>
1552           <td></td>
1553           <td class="paramtype">uint32_t&#160;</td>
1554           <td class="paramname"><em>val3</em>&#160;</td>
1555         </tr>
1556         <tr>
1557           <td></td>
1558           <td>)</td>
1559           <td></td><td></td>
1560         </tr>
1561       </table>
1562 </div><div class="memdoc">
1563
1564 <p>Q setting dual 16-bit signed multiply subtract with 32-bit accumulate. </p>
1565 <p>This function enables you to perform two 16-bit signed multiplications, take the difference of the products, subtracting the high halfword product from the low halfword product, and add the difference to a 32-bit accumulate operand.<br  />
1566  The Q bit is set if the accumulation overflows. Overflow cannot occur during the multiplications or the subtraction.</p>
1567 <dl class="params"><dt>Parameters</dt><dd>
1568   <table class="params">
1569     <tr><td class="paramname">val1</td><td>first 16-bit operands for each multiplication. </td></tr>
1570     <tr><td class="paramname">val2</td><td>second 16-bit operands for each multiplication. </td></tr>
1571     <tr><td class="paramname">val3</td><td>accumulate value.</td></tr>
1572   </table>
1573   </dd>
1574 </dl>
1575 <dl class="section return"><dt>Returns</dt><dd>the difference of the product of each multiplication, added to the accumulate value.</dd></dl>
1576 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">p1 = val1[15:0]  * val2[15:0]</div>
1577 <div class="line">p2 = val1[31:16] * val2[31:16]</div>
1578 <div class="line">res[31:0] = p1 - p2 + val3[31:0]</div>
1579 </div><!-- fragment --> </dd></dl>
1580
1581 </div>
1582 </div>
1583 <a id="ga5290ce5564770ad124910d2583dc0a9e" name="ga5290ce5564770ad124910d2583dc0a9e"></a>
1584 <h2 class="memtitle"><span class="permalink"><a href="#ga5290ce5564770ad124910d2583dc0a9e">&#9670;&#160;</a></span>__SMLSDX()</h2>
1585
1586 <div class="memitem">
1587 <div class="memproto">
1588       <table class="memname">
1589         <tr>
1590           <td class="memname">uint32_t __SMLSDX </td>
1591           <td>(</td>
1592           <td class="paramtype">uint32_t&#160;</td>
1593           <td class="paramname"><em>val1</em>, </td>
1594         </tr>
1595         <tr>
1596           <td class="paramkey"></td>
1597           <td></td>
1598           <td class="paramtype">uint32_t&#160;</td>
1599           <td class="paramname"><em>val2</em>, </td>
1600         </tr>
1601         <tr>
1602           <td class="paramkey"></td>
1603           <td></td>
1604           <td class="paramtype">uint32_t&#160;</td>
1605           <td class="paramname"><em>val3</em>&#160;</td>
1606         </tr>
1607         <tr>
1608           <td></td>
1609           <td>)</td>
1610           <td></td><td></td>
1611         </tr>
1612       </table>
1613 </div><div class="memdoc">
1614
1615 <p>Q setting dual 16-bit signed multiply with exchange subtract with 32-bit accumulate. </p>
1616 <p>This function enables you to exchange the halfwords in the second operand, then perform two 16-bit signed multiplications. The difference of the products is added to a 32-bit accumulate operand.<br  />
1617  The Q bit is set if the addition overflows. Overflow cannot occur during the multiplications or the subtraction.</p>
1618 <dl class="params"><dt>Parameters</dt><dd>
1619   <table class="params">
1620     <tr><td class="paramname">val1</td><td>first 16-bit operands for each multiplication. </td></tr>
1621     <tr><td class="paramname">val2</td><td>second 16-bit operands for each multiplication. </td></tr>
1622     <tr><td class="paramname">val3</td><td>accumulate value.</td></tr>
1623   </table>
1624   </dd>
1625 </dl>
1626 <dl class="section return"><dt>Returns</dt><dd>the difference of the product of each multiplication, added to the accumulate value.</dd></dl>
1627 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">p1 = val1[15:0]  * val2[31:16]</div>
1628 <div class="line">p2 = val1[31:16] * val2[15:0]</div>
1629 <div class="line">res[31:0] = p1 - p2 + val3[31:0]</div>
1630 </div><!-- fragment --> </dd></dl>
1631
1632 </div>
1633 </div>
1634 <a id="ga5611f7314e0c8f53da377918dfbf42ee" name="ga5611f7314e0c8f53da377918dfbf42ee"></a>
1635 <h2 class="memtitle"><span class="permalink"><a href="#ga5611f7314e0c8f53da377918dfbf42ee">&#9670;&#160;</a></span>__SMLSLD()</h2>
1636
1637 <div class="memitem">
1638 <div class="memproto">
1639       <table class="memname">
1640         <tr>
1641           <td class="memname">uint64_t __SMLSLD </td>
1642           <td>(</td>
1643           <td class="paramtype">uint32_t&#160;</td>
1644           <td class="paramname"><em>val1</em>, </td>
1645         </tr>
1646         <tr>
1647           <td class="paramkey"></td>
1648           <td></td>
1649           <td class="paramtype">uint32_t&#160;</td>
1650           <td class="paramname"><em>val2</em>, </td>
1651         </tr>
1652         <tr>
1653           <td class="paramkey"></td>
1654           <td></td>
1655           <td class="paramtype">uint64_t&#160;</td>
1656           <td class="paramname"><em>val3</em>&#160;</td>
1657         </tr>
1658         <tr>
1659           <td></td>
1660           <td>)</td>
1661           <td></td><td></td>
1662         </tr>
1663       </table>
1664 </div><div class="memdoc">
1665
1666 <p>Q setting dual 16-bit signed multiply subtract with 64-bit accumulate. </p>
1667 <p>This function It enables you to perform two 16-bit signed multiplications, take the difference of the products, subtracting the high halfword product from the low halfword product, and add the difference to a 64-bit accumulate operand. Overflow cannot occur during the multiplications or the subtraction. Overflow can occur as a result of the 64-bit addition, and this overflow is not detected. Instead, the result wraps round to modulo2<sup>64</sup>.</p>
1668 <dl class="params"><dt>Parameters</dt><dd>
1669   <table class="params">
1670     <tr><td class="paramname">val1</td><td>first 16-bit operands for each multiplication. </td></tr>
1671     <tr><td class="paramname">val2</td><td>second 16-bit operands for each multiplication. </td></tr>
1672     <tr><td class="paramname">val3</td><td>accumulate value.</td></tr>
1673   </table>
1674   </dd>
1675 </dl>
1676 <dl class="section return"><dt>Returns</dt><dd>the difference of the product of each multiplication, added to the accumulate value.</dd></dl>
1677 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">p1 = val1[15:0]  * val2[15:0]</div>
1678 <div class="line">p2 = val1[31:16] * val2[31:16]</div>
1679 <div class="line">res[63:0] = p1 - p2 + val3[63:0]</div>
1680 </div><!-- fragment --> </dd></dl>
1681
1682 </div>
1683 </div>
1684 <a id="ga83e69ef81057d3cbd06863d729385187" name="ga83e69ef81057d3cbd06863d729385187"></a>
1685 <h2 class="memtitle"><span class="permalink"><a href="#ga83e69ef81057d3cbd06863d729385187">&#9670;&#160;</a></span>__SMLSLDX()</h2>
1686
1687 <div class="memitem">
1688 <div class="memproto">
1689       <table class="memname">
1690         <tr>
1691           <td class="memname">unsigned long long __SMLSLDX </td>
1692           <td>(</td>
1693           <td class="paramtype">uint32_t&#160;</td>
1694           <td class="paramname"><em>val1</em>, </td>
1695         </tr>
1696         <tr>
1697           <td class="paramkey"></td>
1698           <td></td>
1699           <td class="paramtype">uint32_t&#160;</td>
1700           <td class="paramname"><em>val2</em>, </td>
1701         </tr>
1702         <tr>
1703           <td class="paramkey"></td>
1704           <td></td>
1705           <td class="paramtype">unsigned long long&#160;</td>
1706           <td class="paramname"><em>val3</em>&#160;</td>
1707         </tr>
1708         <tr>
1709           <td></td>
1710           <td>)</td>
1711           <td></td><td></td>
1712         </tr>
1713       </table>
1714 </div><div class="memdoc">
1715
1716 <p>Q setting dual 16-bit signed multiply with exchange subtract with 64-bit accumulate. </p>
1717 <p>This function enables you to exchange the halfwords of the second operand, perform two 16-bit multiplications, adding the difference of the products to a 64-bit accumulate operand. Overflow cannot occur during the multiplications or the subtraction. Overflow can occur as a result of the 64-bit addition, and this overflow is not detected. Instead, the result wraps round to modulo2<sup>64</sup>.</p>
1718 <dl class="params"><dt>Parameters</dt><dd>
1719   <table class="params">
1720     <tr><td class="paramname">val1</td><td>first 16-bit operands for each multiplication. </td></tr>
1721     <tr><td class="paramname">val2</td><td>second 16-bit operands for each multiplication. </td></tr>
1722     <tr><td class="paramname">val3</td><td>accumulate value.</td></tr>
1723   </table>
1724   </dd>
1725 </dl>
1726 <dl class="section return"><dt>Returns</dt><dd>the difference of the product of each multiplication, added to the accumulate value.</dd></dl>
1727 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">p1 = val1[15:0]  * val2[31:16]</div>
1728 <div class="line">p2 = val1[31:16] * val2[15:0]</div>
1729 <div class="line">res[63:0] = p1 - p2 + val3[63:0]</div>
1730 </div><!-- fragment --> </dd></dl>
1731
1732 </div>
1733 </div>
1734 <a id="gaea60757232f740ec6b09980eebb614ff" name="gaea60757232f740ec6b09980eebb614ff"></a>
1735 <h2 class="memtitle"><span class="permalink"><a href="#gaea60757232f740ec6b09980eebb614ff">&#9670;&#160;</a></span>__SMMLA()</h2>
1736
1737 <div class="memitem">
1738 <div class="memproto">
1739       <table class="memname">
1740         <tr>
1741           <td class="memname">uint32_t __SMMLA </td>
1742           <td>(</td>
1743           <td class="paramtype">int32_t&#160;</td>
1744           <td class="paramname"><em>val1</em>, </td>
1745         </tr>
1746         <tr>
1747           <td class="paramkey"></td>
1748           <td></td>
1749           <td class="paramtype">int32_t&#160;</td>
1750           <td class="paramname"><em>val2</em>, </td>
1751         </tr>
1752         <tr>
1753           <td class="paramkey"></td>
1754           <td></td>
1755           <td class="paramtype">int32_t&#160;</td>
1756           <td class="paramname"><em>val3</em>&#160;</td>
1757         </tr>
1758         <tr>
1759           <td></td>
1760           <td>)</td>
1761           <td></td><td></td>
1762         </tr>
1763       </table>
1764 </div><div class="memdoc">
1765
1766 <p>32-bit signed multiply with 32-bit truncated accumulator. </p>
1767 <p>This function enables you to perform a signed 32-bit multiplications, adding the most significant 32 bits of the 64-bit result to a 32-bit accumulate operand.<br  />
1768 </p>
1769 <dl class="params"><dt>Parameters</dt><dd>
1770   <table class="params">
1771     <tr><td class="paramname">val1</td><td>first operand for multiplication. </td></tr>
1772     <tr><td class="paramname">val2</td><td>second operand for multiplication. </td></tr>
1773     <tr><td class="paramname">val3</td><td>accumulate value.</td></tr>
1774   </table>
1775   </dd>
1776 </dl>
1777 <dl class="section return"><dt>Returns</dt><dd>the product of multiplication (most significant 32 bits) is added to the accumulate value, as a 32-bit integer.</dd></dl>
1778 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">p = val1 * val2</div>
1779 <div class="line">res[31:0] = p[61:32] + val3[31:0]</div>
1780 </div><!-- fragment --> </dd></dl>
1781
1782 </div>
1783 </div>
1784 <a id="gae326e368a1624d2dfb4b97c626939257" name="gae326e368a1624d2dfb4b97c626939257"></a>
1785 <h2 class="memtitle"><span class="permalink"><a href="#gae326e368a1624d2dfb4b97c626939257">&#9670;&#160;</a></span>__SMUAD()</h2>
1786
1787 <div class="memitem">
1788 <div class="memproto">
1789       <table class="memname">
1790         <tr>
1791           <td class="memname">uint32_t __SMUAD </td>
1792           <td>(</td>
1793           <td class="paramtype">uint32_t&#160;</td>
1794           <td class="paramname"><em>val1</em>, </td>
1795         </tr>
1796         <tr>
1797           <td class="paramkey"></td>
1798           <td></td>
1799           <td class="paramtype">uint32_t&#160;</td>
1800           <td class="paramname"><em>val2</em>&#160;</td>
1801         </tr>
1802         <tr>
1803           <td></td>
1804           <td>)</td>
1805           <td></td><td></td>
1806         </tr>
1807       </table>
1808 </div><div class="memdoc">
1809
1810 <p>Q setting sum of dual 16-bit signed multiply. </p>
1811 <p>This function enables you to perform two 16-bit signed multiplications, adding the products together.<br  />
1812  The Q bit is set if the addition overflows.</p>
1813 <dl class="params"><dt>Parameters</dt><dd>
1814   <table class="params">
1815     <tr><td class="paramname">val1</td><td>first 16-bit operands for each multiplication. </td></tr>
1816     <tr><td class="paramname">val2</td><td>second 16-bit operands for each multiplication.</td></tr>
1817   </table>
1818   </dd>
1819 </dl>
1820 <dl class="section return"><dt>Returns</dt><dd>the sum of the products of the two 16-bit signed multiplications.</dd></dl>
1821 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">p1 = val1[15:0]  * val2[15:0]</div>
1822 <div class="line">p2 = val1[31:16] * val2[31:16]</div>
1823 <div class="line">res[31:0] = p1 + p2</div>
1824 </div><!-- fragment --> </dd></dl>
1825
1826 </div>
1827 </div>
1828 <a id="gaee6390f86965cb662500f690b0012092" name="gaee6390f86965cb662500f690b0012092"></a>
1829 <h2 class="memtitle"><span class="permalink"><a href="#gaee6390f86965cb662500f690b0012092">&#9670;&#160;</a></span>__SMUADX()</h2>
1830
1831 <div class="memitem">
1832 <div class="memproto">
1833       <table class="memname">
1834         <tr>
1835           <td class="memname">uint32_t __SMUADX </td>
1836           <td>(</td>
1837           <td class="paramtype">uint32_t&#160;</td>
1838           <td class="paramname"><em>val1</em>, </td>
1839         </tr>
1840         <tr>
1841           <td class="paramkey"></td>
1842           <td></td>
1843           <td class="paramtype">uint32_t&#160;</td>
1844           <td class="paramname"><em>val2</em>&#160;</td>
1845         </tr>
1846         <tr>
1847           <td></td>
1848           <td>)</td>
1849           <td></td><td></td>
1850         </tr>
1851       </table>
1852 </div><div class="memdoc">
1853
1854 <p>Q setting sum of dual 16-bit signed multiply with exchange. </p>
1855 <p>This function enables you to perform two 16-bit signed multiplications with exchanged halfwords of the second operand, adding the products together.<br  />
1856  The Q bit is set if the addition overflows.</p>
1857 <dl class="params"><dt>Parameters</dt><dd>
1858   <table class="params">
1859     <tr><td class="paramname">val1</td><td>first 16-bit operands for each multiplication. </td></tr>
1860     <tr><td class="paramname">val2</td><td>second 16-bit operands for each multiplication.</td></tr>
1861   </table>
1862   </dd>
1863 </dl>
1864 <dl class="section return"><dt>Returns</dt><dd>the sum of the products of the two 16-bit signed multiplications with exchanged halfwords of the second operand.</dd></dl>
1865 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">p1 = val1[15:0]  * val2[31:16]</div>
1866 <div class="line">p2 = val1[31:16] * val2[15:0]</div>
1867 <div class="line">res[31:0] = p1 + p2</div>
1868 </div><!-- fragment --> </dd></dl>
1869
1870 </div>
1871 </div>
1872 <a id="ga039142a5368840683cf329cb55b73f84" name="ga039142a5368840683cf329cb55b73f84"></a>
1873 <h2 class="memtitle"><span class="permalink"><a href="#ga039142a5368840683cf329cb55b73f84">&#9670;&#160;</a></span>__SMUSD()</h2>
1874
1875 <div class="memitem">
1876 <div class="memproto">
1877       <table class="memname">
1878         <tr>
1879           <td class="memname">uint32_t __SMUSD </td>
1880           <td>(</td>
1881           <td class="paramtype">uint32_t&#160;</td>
1882           <td class="paramname"><em>val1</em>, </td>
1883         </tr>
1884         <tr>
1885           <td class="paramkey"></td>
1886           <td></td>
1887           <td class="paramtype">uint32_t&#160;</td>
1888           <td class="paramname"><em>val2</em>&#160;</td>
1889         </tr>
1890         <tr>
1891           <td></td>
1892           <td>)</td>
1893           <td></td><td></td>
1894         </tr>
1895       </table>
1896 </div><div class="memdoc">
1897
1898 <p>Dual 16-bit signed multiply returning difference. </p>
1899 <p>This function enables you to perform two 16-bit signed multiplications, taking the difference of the products by subtracting the high halfword product from the low halfword product.</p>
1900 <dl class="params"><dt>Parameters</dt><dd>
1901   <table class="params">
1902     <tr><td class="paramname">val1</td><td>first 16-bit operands for each multiplication. </td></tr>
1903     <tr><td class="paramname">val2</td><td>second 16-bit operands for each multiplication.</td></tr>
1904   </table>
1905   </dd>
1906 </dl>
1907 <dl class="section return"><dt>Returns</dt><dd>the difference of the products of the two 16-bit signed multiplications.</dd></dl>
1908 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">p1 = val1[15:0]  * val2[15:0]</div>
1909 <div class="line">p2 = val1[31:16] * val2[31:16]</div>
1910 <div class="line">res[31:0] = p1 - p2</div>
1911 </div><!-- fragment --> </dd></dl>
1912
1913 </div>
1914 </div>
1915 <a id="gabb5bcba694bf17b141c32e6a8474f60e" name="gabb5bcba694bf17b141c32e6a8474f60e"></a>
1916 <h2 class="memtitle"><span class="permalink"><a href="#gabb5bcba694bf17b141c32e6a8474f60e">&#9670;&#160;</a></span>__SMUSDX()</h2>
1917
1918 <div class="memitem">
1919 <div class="memproto">
1920       <table class="memname">
1921         <tr>
1922           <td class="memname">uint32_t __SMUSDX </td>
1923           <td>(</td>
1924           <td class="paramtype">uint32_t&#160;</td>
1925           <td class="paramname"><em>val1</em>, </td>
1926         </tr>
1927         <tr>
1928           <td class="paramkey"></td>
1929           <td></td>
1930           <td class="paramtype">uint32_t&#160;</td>
1931           <td class="paramname"><em>val2</em>&#160;</td>
1932         </tr>
1933         <tr>
1934           <td></td>
1935           <td>)</td>
1936           <td></td><td></td>
1937         </tr>
1938       </table>
1939 </div><div class="memdoc">
1940
1941 <p>Dual 16-bit signed multiply with exchange returning difference. </p>
1942 <p>This function enables you to perform two 16-bit signed multiplications, subtracting one of the products from the other. The halfwords of the second operand are exchanged before performing the arithmetic. This produces top * bottom and bottom * top multiplication.</p>
1943 <dl class="params"><dt>Parameters</dt><dd>
1944   <table class="params">
1945     <tr><td class="paramname">val1</td><td>first 16-bit operands for each multiplication. </td></tr>
1946     <tr><td class="paramname">val2</td><td>second 16-bit operands for each multiplication.</td></tr>
1947   </table>
1948   </dd>
1949 </dl>
1950 <dl class="section return"><dt>Returns</dt><dd>the difference of the products of the two 16-bit signed multiplications.</dd></dl>
1951 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">p1 = val1[15:0]  * val2[31:16]</div>
1952 <div class="line">p2 = val1[31:16] * val2[15:0]</div>
1953 <div class="line">res[31:0] = p1 - p2</div>
1954 </div><!-- fragment --> </dd></dl>
1955
1956 </div>
1957 </div>
1958 <a id="ga95e666b82216066bf6064d1244e6883c" name="ga95e666b82216066bf6064d1244e6883c"></a>
1959 <h2 class="memtitle"><span class="permalink"><a href="#ga95e666b82216066bf6064d1244e6883c">&#9670;&#160;</a></span>__SSAT16()</h2>
1960
1961 <div class="memitem">
1962 <div class="memproto">
1963       <table class="memname">
1964         <tr>
1965           <td class="memname">uint32_t __SSAT16 </td>
1966           <td>(</td>
1967           <td class="paramtype">uint32_t&#160;</td>
1968           <td class="paramname"><em>val1</em>, </td>
1969         </tr>
1970         <tr>
1971           <td class="paramkey"></td>
1972           <td></td>
1973           <td class="paramtype">const uint32_t&#160;</td>
1974           <td class="paramname"><em>val2</em>&#160;</td>
1975         </tr>
1976         <tr>
1977           <td></td>
1978           <td>)</td>
1979           <td></td><td></td>
1980         </tr>
1981       </table>
1982 </div><div class="memdoc">
1983
1984 <p>Q setting dual 16-bit saturate. </p>
1985 <p>This function enables you to saturate two signed 16-bit values to a selected signed range.<br  />
1986  The Q bit is set if either operation saturates.</p>
1987 <dl class="params"><dt>Parameters</dt><dd>
1988   <table class="params">
1989     <tr><td class="paramname">val1</td><td>two signed 16-bit values to be saturated. </td></tr>
1990     <tr><td class="paramname">val2</td><td>bit position for saturation, an integral constant expression in the range 1 to 16.</td></tr>
1991   </table>
1992   </dd>
1993 </dl>
1994 <dl class="section return"><dt>Returns</dt><dd>the sum of the absolute differences of the following bytes, added to the accumulation value: <ul>
1995 <li>the signed saturation of the low halfword in <em>val1</em>, saturated to the bit position specified in <em>val2</em> and returned in the low halfword of the return value. </li>
1996 <li>the signed saturation of the high halfword in <em>val1</em>, saturated to the bit position specified in <em>val2</em> and returned in the high halfword of the return value.</li>
1997 </ul>
1998 </dd></dl>
1999 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">Saturate halfwords in val1 to the <span class="keywordtype">signed</span> range specified by the bit position in val2</div>
2000 </div><!-- fragment --> </dd></dl>
2001
2002 </div>
2003 </div>
2004 <a id="ga9d3bc5c539f9bd50f7d59ffa37ac6a65" name="ga9d3bc5c539f9bd50f7d59ffa37ac6a65"></a>
2005 <h2 class="memtitle"><span class="permalink"><a href="#ga9d3bc5c539f9bd50f7d59ffa37ac6a65">&#9670;&#160;</a></span>__SSAX()</h2>
2006
2007 <div class="memitem">
2008 <div class="memproto">
2009       <table class="memname">
2010         <tr>
2011           <td class="memname">uint32_t __SSAX </td>
2012           <td>(</td>
2013           <td class="paramtype">uint32_t&#160;</td>
2014           <td class="paramname"><em>val1</em>, </td>
2015         </tr>
2016         <tr>
2017           <td class="paramkey"></td>
2018           <td></td>
2019           <td class="paramtype">uint32_t&#160;</td>
2020           <td class="paramname"><em>val2</em>&#160;</td>
2021         </tr>
2022         <tr>
2023           <td></td>
2024           <td>)</td>
2025           <td></td><td></td>
2026         </tr>
2027       </table>
2028 </div><div class="memdoc">
2029
2030 <p>GE setting dual 16-bit signed subtraction and addition with exchange. </p>
2031 <p>This function enables you to exchange the two halfwords of one operand and perform one 16-bit integer subtraction and one 16-bit addition.<br  />
2032  The GE bits in the APSR are set according to the results.</p>
2033 <dl class="params"><dt>Parameters</dt><dd>
2034   <table class="params">
2035     <tr><td class="paramname">val1</td><td>first operand for the addition in the low halfword, and the first operand for the subtraction in the high halfword. </td></tr>
2036     <tr><td class="paramname">val2</td><td>second operand for the addition in the high halfword, and the second operand for the subtraction in the low halfword.</td></tr>
2037   </table>
2038   </dd>
2039 </dl>
2040 <dl class="section return"><dt>Returns</dt><dd><ul>
2041 <li>the addition of the low halfword in the first operand and the high halfword in the second operand, in the low halfword of the return value. </li>
2042 <li>the subtraction of the low halfword in the second operand from the high halfword in the first operand, in the high halfword of the return value. </li>
2043 </ul>
2044 </dd></dl>
2045 <dl class="section user"><dt></dt><dd>Each bit in APSR.GE is set or cleared for each byte in the return value, depending on the results of the operation. </dd></dl>
2046 <dl class="section user"><dt></dt><dd>If <em>res</em> is the return value, then: <ul>
2047 <li>if res[15:0] &gt;= 0 then APSR.GE[1:0] = 11 else 00 </li>
2048 <li>if res[31:16] &gt;= 0 then APSR.GE[3:2] = 11 else 00</li>
2049 </ul>
2050 </dd></dl>
2051 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  + val2[31:16]</div>
2052 <div class="line">res[31:16] = val1[31:16] - val2[15:0]</div>
2053 </div><!-- fragment --> </dd></dl>
2054
2055 </div>
2056 </div>
2057 <a id="ga4262f73be75efbac6b46ab7c71aa6cbc" name="ga4262f73be75efbac6b46ab7c71aa6cbc"></a>
2058 <h2 class="memtitle"><span class="permalink"><a href="#ga4262f73be75efbac6b46ab7c71aa6cbc">&#9670;&#160;</a></span>__SSUB16()</h2>
2059
2060 <div class="memitem">
2061 <div class="memproto">
2062       <table class="memname">
2063         <tr>
2064           <td class="memname">uint32_t __SSUB16 </td>
2065           <td>(</td>
2066           <td class="paramtype">uint32_t&#160;</td>
2067           <td class="paramname"><em>val1</em>, </td>
2068         </tr>
2069         <tr>
2070           <td class="paramkey"></td>
2071           <td></td>
2072           <td class="paramtype">uint32_t&#160;</td>
2073           <td class="paramname"><em>val2</em>&#160;</td>
2074         </tr>
2075         <tr>
2076           <td></td>
2077           <td>)</td>
2078           <td></td><td></td>
2079         </tr>
2080       </table>
2081 </div><div class="memdoc">
2082
2083 <p>GE setting dual 16-bit signed subtraction. </p>
2084 <p>This function enables you to perform two 16-bit signed integer subtractions.<br  />
2085  The GE bits in the APSR are set according to the results.</p>
2086 <dl class="params"><dt>Parameters</dt><dd>
2087   <table class="params">
2088     <tr><td class="paramname">val1</td><td>first two 16-bit operands of each subtraction. </td></tr>
2089     <tr><td class="paramname">val2</td><td>second two 16-bit operands of each subtraction.</td></tr>
2090   </table>
2091   </dd>
2092 </dl>
2093 <dl class="section return"><dt>Returns</dt><dd><ul>
2094 <li>the subtraction of the low halfword in the second operand from the low halfword in the first operand, in the low halfword of the return value. </li>
2095 <li>the subtraction of the high halfword in the second operand from the high halfword in the first operand, in the high halfword of the return value.</li>
2096 </ul>
2097 </dd></dl>
2098 <dl class="section user"><dt></dt><dd>Each bit in APSR.GE is set or cleared for each byte in the return value, depending on the results of the operation. </dd></dl>
2099 <dl class="section user"><dt></dt><dd>If <ul>
2100 <li>res is the return value, then: </li>
2101 <li>if res[15:0] &gt;= 0 then APSR.GE[1:0] = 11 else 00 </li>
2102 <li>if res[31:16] &gt;= 0 then APSR.GE[3:2] = 11 else 00</li>
2103 </ul>
2104 </dd></dl>
2105 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  - val2[15:0]</div>
2106 <div class="line">res[31:16] = val1[31:16] - val2[31:16]</div>
2107 </div><!-- fragment --> </dd></dl>
2108
2109 </div>
2110 </div>
2111 <a id="gaba63bb52e1e93fb527e26f3d474da12e" name="gaba63bb52e1e93fb527e26f3d474da12e"></a>
2112 <h2 class="memtitle"><span class="permalink"><a href="#gaba63bb52e1e93fb527e26f3d474da12e">&#9670;&#160;</a></span>__SSUB8()</h2>
2113
2114 <div class="memitem">
2115 <div class="memproto">
2116       <table class="memname">
2117         <tr>
2118           <td class="memname">uint32_t __SSUB8 </td>
2119           <td>(</td>
2120           <td class="paramtype">uint32_t&#160;</td>
2121           <td class="paramname"><em>val1</em>, </td>
2122         </tr>
2123         <tr>
2124           <td class="paramkey"></td>
2125           <td></td>
2126           <td class="paramtype">uint32_t&#160;</td>
2127           <td class="paramname"><em>val2</em>&#160;</td>
2128         </tr>
2129         <tr>
2130           <td></td>
2131           <td>)</td>
2132           <td></td><td></td>
2133         </tr>
2134       </table>
2135 </div><div class="memdoc">
2136
2137 <p>GE setting quad 8-bit signed subtraction. </p>
2138 <p>This function enables you to perform four 8-bit signed integer subtractions.<br  />
2139  The GE bits in the APSR are set according to the results.</p>
2140 <dl class="params"><dt>Parameters</dt><dd>
2141   <table class="params">
2142     <tr><td class="paramname">val1</td><td>first four 8-bit operands of each subtraction. </td></tr>
2143     <tr><td class="paramname">val2</td><td>second four 8-bit operands of each subtraction.</td></tr>
2144   </table>
2145   </dd>
2146 </dl>
2147 <dl class="section return"><dt>Returns</dt><dd><ul>
2148 <li>the subtraction of the first byte in the second operand from the first byte in the first operand, in the first bytes of the return value. </li>
2149 <li>the subtraction of the second byte in the second operand from the second byte in the first operand, in the second byte of the return value. </li>
2150 <li>the subtraction of the third byte in the second operand from the third byte in the first operand, in the third byte of the return value. </li>
2151 <li>the subtraction of the fourth byte in the second operand from the fourth byte in the first operand, in the fourth byte of the return value.</li>
2152 </ul>
2153 </dd></dl>
2154 <dl class="section user"><dt>Each bit in APSR.GE is set or cleared for each byte in the return value, depending on</dt><dd>the results of the operation.</dd></dl>
2155 <dl class="section user"><dt></dt><dd>If <em>res</em> is the return value, then: <ul>
2156 <li>if res[8:0] &gt;= 0 then APSR.GE[0] = 1 else 0 </li>
2157 <li>if res[15:8] &gt;= 0 then APSR.GE[1] = 1 else 0 </li>
2158 <li>if res[23:16] &gt;= 0 then APSR.GE[2] = 1 else 0 </li>
2159 <li>if res[31:24] &gt;= 0 then APSR.GE[3] = 1 else 0</li>
2160 </ul>
2161 </dd></dl>
2162 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[7:0]   = val1[7:0]   - val2[7:0]</div>
2163 <div class="line">res[15:8]  = val1[15:8]  - val2[15:8]</div>
2164 <div class="line">res[23:16] = val1[23:16] - val2[23:16]</div>
2165 <div class="line">res[31:24] = val1[31:24] - val2[31:24]</div>
2166 </div><!-- fragment --> </dd></dl>
2167
2168 </div>
2169 </div>
2170 <a id="gac540b4fc41d30778ba102d2a65db5589" name="gac540b4fc41d30778ba102d2a65db5589"></a>
2171 <h2 class="memtitle"><span class="permalink"><a href="#gac540b4fc41d30778ba102d2a65db5589">&#9670;&#160;</a></span>__SXTAB16()</h2>
2172
2173 <div class="memitem">
2174 <div class="memproto">
2175       <table class="memname">
2176         <tr>
2177           <td class="memname">uint32_t __SXTAB16 </td>
2178           <td>(</td>
2179           <td class="paramtype">uint32_t&#160;</td>
2180           <td class="paramname"><em>val1</em>, </td>
2181         </tr>
2182         <tr>
2183           <td class="paramkey"></td>
2184           <td></td>
2185           <td class="paramtype">uint32_t&#160;</td>
2186           <td class="paramname"><em>val2</em>&#160;</td>
2187         </tr>
2188         <tr>
2189           <td></td>
2190           <td>)</td>
2191           <td></td><td></td>
2192         </tr>
2193       </table>
2194 </div><div class="memdoc">
2195
2196 <p>Dual extracted 8-bit to 16-bit signed addition. </p>
2197 <p>This function enables you to extract two 8-bit values from the second operand (at bit positions [7:0] and [23:16]), sign-extend them to 16-bits each, and add the results to the first operand.</p>
2198 <dl class="params"><dt>Parameters</dt><dd>
2199   <table class="params">
2200     <tr><td class="paramname">val1</td><td>values added to the zero-extended to 16-bit values. </td></tr>
2201     <tr><td class="paramname">val2</td><td>two 8-bit values to be extracted and zero-extended.</td></tr>
2202   </table>
2203   </dd>
2204 </dl>
2205 <dl class="section return"><dt>Returns</dt><dd>the addition of <em>val1</em> and <em>val2</em>, where the 8-bit values in val2[7:0] and val2[23:16] have been extracted and sign-extended prior to the addition.</dd></dl>
2206 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  + SignExtended(val2[7:0])</div>
2207 <div class="line">res[31:16] = val1[31:16] + SignExtended(val2[23:16])</div>
2208 </div><!-- fragment --> </dd></dl>
2209
2210 </div>
2211 </div>
2212 <a id="gaf0029ec2b0decbff4df5bc6f4352bba4" name="gaf0029ec2b0decbff4df5bc6f4352bba4"></a>
2213 <h2 class="memtitle"><span class="permalink"><a href="#gaf0029ec2b0decbff4df5bc6f4352bba4">&#9670;&#160;</a></span>__SXTAB16_RORn()</h2>
2214
2215 <div class="memitem">
2216 <div class="memproto">
2217       <table class="memname">
2218         <tr>
2219           <td class="memname">uint32_t __SXTAB16_RORn </td>
2220           <td>(</td>
2221           <td class="paramtype">uint32_t&#160;</td>
2222           <td class="paramname"><em>val1</em>, </td>
2223         </tr>
2224         <tr>
2225           <td class="paramkey"></td>
2226           <td></td>
2227           <td class="paramtype">uint32_t&#160;</td>
2228           <td class="paramname"><em>val2</em>, </td>
2229         </tr>
2230         <tr>
2231           <td class="paramkey"></td>
2232           <td></td>
2233           <td class="paramtype">uint32_r&#160;</td>
2234           <td class="paramname"><em>rotate</em>&#160;</td>
2235         </tr>
2236         <tr>
2237           <td></td>
2238           <td>)</td>
2239           <td></td><td></td>
2240         </tr>
2241       </table>
2242 </div><div class="memdoc">
2243
2244 <p>Rotate right, followed by sign extension of two 8-bits with add to 16-bits. </p>
2245 <p>This function enables you to rotate the second operand by 8/16/24 bit as specified by the third operand, extract two 8-bit values from the rotated result (at bit positions [7:0] and [23:16]), sign-extend them to 16-bits each, and add the results to the first operand.</p>
2246 <dl class="params"><dt>Parameters</dt><dd>
2247   <table class="params">
2248     <tr><td class="paramname">val1</td><td>two 16-bit values in val1[15:0] and val1[31:16] </td></tr>
2249     <tr><td class="paramname">val2</td><td>two 8-bit values in val[7:0] and val[23:16] to be sign-extended post rotation </td></tr>
2250     <tr><td class="paramname">rotate</td><td>number of bits to rotate val2. Constant rotate value of 8, 16 and 24 can be optimally used with a single __SXTAB16 instruction. Any other valid constant rotate value will result in use of two instructions, __ROR and __SXTAB16</td></tr>
2251   </table>
2252   </dd>
2253 </dl>
2254 <dl class="section return"><dt>Returns</dt><dd>the addition of <em>val1</em> and <em>val2</em>, where the rotated 8-bit values in val2[7:0] and val2[23:16] have been extracted and sign-extended prior to the addition.</dd></dl>
2255 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">val2       = Rotate(val2, rotate)</div>
2256 <div class="line">res[15:0]  = val1[15:0]  + SignExtended(val2[7:0])</div>
2257 <div class="line">res[31:16] = val1[31:16] + SignExtended(val2[23:16])</div>
2258 </div><!-- fragment --> </dd></dl>
2259
2260 </div>
2261 </div>
2262 <a id="ga38dce3dd13ba212e80ec3cff4abeb11a" name="ga38dce3dd13ba212e80ec3cff4abeb11a"></a>
2263 <h2 class="memtitle"><span class="permalink"><a href="#ga38dce3dd13ba212e80ec3cff4abeb11a">&#9670;&#160;</a></span>__SXTB16()</h2>
2264
2265 <div class="memitem">
2266 <div class="memproto">
2267       <table class="memname">
2268         <tr>
2269           <td class="memname">uint32_t __SXTB16 </td>
2270           <td>(</td>
2271           <td class="paramtype">uint32_t&#160;</td>
2272           <td class="paramname"><em>val</em></td><td>)</td>
2273           <td></td>
2274         </tr>
2275       </table>
2276 </div><div class="memdoc">
2277
2278 <p>Dual extract 8-bits and sign extend each to 16-bits. </p>
2279 <p>This function enables you to extract two 8-bit values from an operand and sign-extend them to 16 bits each.</p>
2280 <dl class="params"><dt>Parameters</dt><dd>
2281   <table class="params">
2282     <tr><td class="paramname">val</td><td>two 8-bit values in val[7:0] and val[23:16] to be sign-extended.</td></tr>
2283   </table>
2284   </dd>
2285 </dl>
2286 <dl class="section return"><dt>Returns</dt><dd>the 8-bit values sign-extended to 16-bit values. <ul>
2287 <li>sign-extended value of val[7:0] in the low halfword of the return value. </li>
2288 <li>sign-extended value of val[23:16] in the high halfword of the return value.</li>
2289 </ul>
2290 </dd></dl>
2291 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = SignExtended(val[7:0]</div>
2292 <div class="line">res[31:16] = SignExtended(val[23:16]</div>
2293 </div><!-- fragment --> </dd></dl>
2294
2295 </div>
2296 </div>
2297 <a id="gaef7e08ba1dbaaae1efdb76c113155ed1" name="gaef7e08ba1dbaaae1efdb76c113155ed1"></a>
2298 <h2 class="memtitle"><span class="permalink"><a href="#gaef7e08ba1dbaaae1efdb76c113155ed1">&#9670;&#160;</a></span>__SXTB16_RORn()</h2>
2299
2300 <div class="memitem">
2301 <div class="memproto">
2302       <table class="memname">
2303         <tr>
2304           <td class="memname">uint32_t __SXTB16_RORn </td>
2305           <td>(</td>
2306           <td class="paramtype">uint32_t&#160;</td>
2307           <td class="paramname"><em>val</em>, </td>
2308         </tr>
2309         <tr>
2310           <td class="paramkey"></td>
2311           <td></td>
2312           <td class="paramtype">uint32_r&#160;</td>
2313           <td class="paramname"><em>rotate</em>&#160;</td>
2314         </tr>
2315         <tr>
2316           <td></td>
2317           <td>)</td>
2318           <td></td><td></td>
2319         </tr>
2320       </table>
2321 </div><div class="memdoc">
2322
2323 <p>Rotate right, dual extract 8-bits and sign extend each to 16-bits. </p>
2324 <p>This function enables you to rotate an operand by 8/16/24 bit, extract two 8-bit values and sign-extend them to 16 bits each.</p>
2325 <dl class="params"><dt>Parameters</dt><dd>
2326   <table class="params">
2327     <tr><td class="paramname">val</td><td>two 8-bit values in val[7:0] and val[23:16] to be sign-extended. </td></tr>
2328     <tr><td class="paramname">rotate</td><td>number of bits to rotate val. Constant rotate value of 8, 16 and 24 can be optimally used with a single __SXTB16 instruction. Any other valid constant rotate value will result in use of two instructions, __ROR and __SXTB16</td></tr>
2329   </table>
2330   </dd>
2331 </dl>
2332 <dl class="section return"><dt>Returns</dt><dd>the 8-bit values sign-extended to 16-bit values. <ul>
2333 <li>sign-extended value of val[7:0] in the low halfword of the return value. </li>
2334 <li>sign-extended value of val[23:16] in the high halfword of the return value.</li>
2335 </ul>
2336 </dd></dl>
2337 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">val        = Rotate(val, rotate)</div>
2338 <div class="line">res[15:0]  = SignExtended(val[7:0])</div>
2339 <div class="line">res[31:16] = SignExtended(val[23:16])</div>
2340 </div><!-- fragment --> </dd></dl>
2341
2342 </div>
2343 </div>
2344 <a id="gaa1160f0cf76d6aa292fbad54a1aa6b74" name="gaa1160f0cf76d6aa292fbad54a1aa6b74"></a>
2345 <h2 class="memtitle"><span class="permalink"><a href="#gaa1160f0cf76d6aa292fbad54a1aa6b74">&#9670;&#160;</a></span>__UADD16()</h2>
2346
2347 <div class="memitem">
2348 <div class="memproto">
2349       <table class="memname">
2350         <tr>
2351           <td class="memname">uint32_t __UADD16 </td>
2352           <td>(</td>
2353           <td class="paramtype">uint32_t&#160;</td>
2354           <td class="paramname"><em>val1</em>, </td>
2355         </tr>
2356         <tr>
2357           <td class="paramkey"></td>
2358           <td></td>
2359           <td class="paramtype">uint32_t&#160;</td>
2360           <td class="paramname"><em>val2</em>&#160;</td>
2361         </tr>
2362         <tr>
2363           <td></td>
2364           <td>)</td>
2365           <td></td><td></td>
2366         </tr>
2367       </table>
2368 </div><div class="memdoc">
2369
2370 <p>GE setting dual 16-bit unsigned addition. </p>
2371 <p>This function enables you to perform two 16-bit unsigned integer additions.<br  />
2372  The GE bits in the APSR are set according to the results.</p>
2373 <dl class="params"><dt>Parameters</dt><dd>
2374   <table class="params">
2375     <tr><td class="paramname">val1</td><td>first two 16-bit summands for each addition. </td></tr>
2376     <tr><td class="paramname">val2</td><td>second two 16-bit summands for each addition.</td></tr>
2377   </table>
2378   </dd>
2379 </dl>
2380 <dl class="section return"><dt>Returns</dt><dd><ul>
2381 <li>the addition of the low halfwords in each operand, in the low halfword of the return value. </li>
2382 <li>the addition of the high halfwords in each operand, in the high halfword of the return value.</li>
2383 </ul>
2384 </dd></dl>
2385 <dl class="section user"><dt></dt><dd>Each bit in APSR.GE is set or cleared for each byte in the return value, depending on the results of the operation. </dd></dl>
2386 <dl class="section user"><dt></dt><dd>If <em>res</em> is the return value, then: <ul>
2387 <li>if res[15:0] &gt;= 0x10000 then APSR.GE[0] = 11 else 00 </li>
2388 <li>if res[31:16] &gt;= 0x10000 then APSR.GE[1] = 11 else 00</li>
2389 </ul>
2390 </dd></dl>
2391 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  + val2[15:0]</div>
2392 <div class="line">res[31:16] = val1[31:16] + val2[31:16]</div>
2393 </div><!-- fragment --> </dd></dl>
2394
2395 </div>
2396 </div>
2397 <a id="gab3d7fd00d113b20fb3741a17394da762" name="gab3d7fd00d113b20fb3741a17394da762"></a>
2398 <h2 class="memtitle"><span class="permalink"><a href="#gab3d7fd00d113b20fb3741a17394da762">&#9670;&#160;</a></span>__UADD8()</h2>
2399
2400 <div class="memitem">
2401 <div class="memproto">
2402       <table class="memname">
2403         <tr>
2404           <td class="memname">uint32_t __UADD8 </td>
2405           <td>(</td>
2406           <td class="paramtype">uint32_t&#160;</td>
2407           <td class="paramname"><em>val1</em>, </td>
2408         </tr>
2409         <tr>
2410           <td class="paramkey"></td>
2411           <td></td>
2412           <td class="paramtype">uint32_t&#160;</td>
2413           <td class="paramname"><em>val2</em>&#160;</td>
2414         </tr>
2415         <tr>
2416           <td></td>
2417           <td>)</td>
2418           <td></td><td></td>
2419         </tr>
2420       </table>
2421 </div><div class="memdoc">
2422
2423 <p>GE setting quad 8-bit unsigned addition. </p>
2424 <p>This function enables you to perform four unsigned 8-bit integer additions. The GE bits of the APSR are set according to the results.</p>
2425 <dl class="params"><dt>Parameters</dt><dd>
2426   <table class="params">
2427     <tr><td class="paramname">val1</td><td>first four 8-bit summands for each addition. </td></tr>
2428     <tr><td class="paramname">val2</td><td>second four 8-bit summands for each addition.</td></tr>
2429   </table>
2430   </dd>
2431 </dl>
2432 <dl class="section return"><dt>Returns</dt><dd><ul>
2433 <li>the addition of the first bytes from each operand, in the first byte of the return value. </li>
2434 <li>the addition of the second bytes from each operand, in the second byte of the return value. </li>
2435 <li>the addition of the third bytes from each operand, in the third byte of the return value. </li>
2436 <li>the addition of the fourth bytes from each operand, in the fourth byte of the return value.</li>
2437 </ul>
2438 </dd></dl>
2439 <dl class="section user"><dt></dt><dd>Each bit in APSR.GE is set or cleared for each byte in the return value, depending on the results of the operation.</dd></dl>
2440 <dl class="section user"><dt></dt><dd>If <em>res</em> is the return value, then: <ul>
2441 <li>if res[7:0] &gt;= 0x100 then APSR.GE[0] = 1 else 0 </li>
2442 <li>if res[15:8] &gt;= 0x100 then APSR.GE[1] = 1 else 0 </li>
2443 <li>if res[23:16] &gt;= 0x100 then APSR.GE[2] = 1 else 0 </li>
2444 <li>if res[31:24] &gt;= 0x100 then APSR.GE[3] = 1 else 0</li>
2445 </ul>
2446 </dd></dl>
2447 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[7:0]   = val1[7:0]   + val2[7:0]</div>
2448 <div class="line">res[15:8]  = val1[15:8]  + val2[15:8]</div>
2449 <div class="line">res[23:16] = val1[23:16] + val2[23:16]</div>
2450 <div class="line">res[31:24] = val1[31:24] + val2[31:24]</div>
2451 </div><!-- fragment --> </dd></dl>
2452
2453 </div>
2454 </div>
2455 <a id="ga980353d2c72ebb879282e49f592fddc0" name="ga980353d2c72ebb879282e49f592fddc0"></a>
2456 <h2 class="memtitle"><span class="permalink"><a href="#ga980353d2c72ebb879282e49f592fddc0">&#9670;&#160;</a></span>__UASX()</h2>
2457
2458 <div class="memitem">
2459 <div class="memproto">
2460       <table class="memname">
2461         <tr>
2462           <td class="memname">uint32_t __UASX </td>
2463           <td>(</td>
2464           <td class="paramtype">uint32_t&#160;</td>
2465           <td class="paramname"><em>val1</em>, </td>
2466         </tr>
2467         <tr>
2468           <td class="paramkey"></td>
2469           <td></td>
2470           <td class="paramtype">uint32_t&#160;</td>
2471           <td class="paramname"><em>val2</em>&#160;</td>
2472         </tr>
2473         <tr>
2474           <td></td>
2475           <td>)</td>
2476           <td></td><td></td>
2477         </tr>
2478       </table>
2479 </div><div class="memdoc">
2480
2481 <p>GE setting dual 16-bit unsigned addition and subtraction with exchange. </p>
2482 <p>This function enables you to exchange the two halfwords of the second operand, add the high halfwords and subtract the low halfwords.<br  />
2483  The GE bits in the APSR are set according to the results.</p>
2484 <dl class="params"><dt>Parameters</dt><dd>
2485   <table class="params">
2486     <tr><td class="paramname">val1</td><td>first operand for the subtraction in the low halfword, and the first operand for the addition in the high halfword. </td></tr>
2487     <tr><td class="paramname">val2</td><td>second operand for the subtraction in the high halfword and the second operand for the addition in the low halfword.</td></tr>
2488   </table>
2489   </dd>
2490 </dl>
2491 <dl class="section return"><dt>Returns</dt><dd><ul>
2492 <li>the subtraction of the high halfword in the second operand from the low halfword in the first operand, in the low halfword of the return value. </li>
2493 <li>the addition of the high halfword in the first operand and the low halfword in the second operand, in the high halfword of the return value.</li>
2494 </ul>
2495 </dd></dl>
2496 <dl class="section user"><dt></dt><dd>Each bit in APSR.GE is set or cleared for each byte in the return value, depending on the results of the operation.</dd></dl>
2497 <dl class="section user"><dt>If <em>res</em> is the return value, then:</dt><dd><ul>
2498 <li>if res[15:0] &gt;= 0 then APSR.GE[1:0] = 11 else 00 </li>
2499 <li>if res[31:16] &gt;= 0x10000 then APSR.GE[3:2] = 11 else 00</li>
2500 </ul>
2501 </dd></dl>
2502 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  - val2[31:16]</div>
2503 <div class="line">res[31:16] = val1[31:16] + val2[15:0]</div>
2504 </div><!-- fragment --> </dd></dl>
2505
2506 </div>
2507 </div>
2508 <a id="gabd0b0e2da2e6364e176d051687702b86" name="gabd0b0e2da2e6364e176d051687702b86"></a>
2509 <h2 class="memtitle"><span class="permalink"><a href="#gabd0b0e2da2e6364e176d051687702b86">&#9670;&#160;</a></span>__UHADD16()</h2>
2510
2511 <div class="memitem">
2512 <div class="memproto">
2513       <table class="memname">
2514         <tr>
2515           <td class="memname">uint32_t __UHADD16 </td>
2516           <td>(</td>
2517           <td class="paramtype">uint32_t&#160;</td>
2518           <td class="paramname"><em>val1</em>, </td>
2519         </tr>
2520         <tr>
2521           <td class="paramkey"></td>
2522           <td></td>
2523           <td class="paramtype">uint32_t&#160;</td>
2524           <td class="paramname"><em>val2</em>&#160;</td>
2525         </tr>
2526         <tr>
2527           <td></td>
2528           <td>)</td>
2529           <td></td><td></td>
2530         </tr>
2531       </table>
2532 </div><div class="memdoc">
2533
2534 <p>Dual 16-bit unsigned addition with halved results. </p>
2535 <p>This function enables you to perform two unsigned 16-bit integer additions, halving the results.</p>
2536 <dl class="params"><dt>Parameters</dt><dd>
2537   <table class="params">
2538     <tr><td class="paramname">val1</td><td>first two 16-bit summands. </td></tr>
2539     <tr><td class="paramname">val2</td><td>second two 16-bit summands.</td></tr>
2540   </table>
2541   </dd>
2542 </dl>
2543 <dl class="section return"><dt>Returns</dt><dd><ul>
2544 <li>the halved addition of the low halfwords in each operand, in the low halfword of the return value. </li>
2545 <li>the halved addition of the high halfwords in each operand, in the high halfword of the return value.</li>
2546 </ul>
2547 </dd></dl>
2548 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  + val2[15:0]   &gt;&gt; 1</div>
2549 <div class="line">res[31:16] = val1[31:16] + val2[31:16]  &gt;&gt; 1</div>
2550 </div><!-- fragment --> </dd></dl>
2551
2552 </div>
2553 </div>
2554 <a id="ga3a14e5485e59bf0f23595b7c2a94eb0b" name="ga3a14e5485e59bf0f23595b7c2a94eb0b"></a>
2555 <h2 class="memtitle"><span class="permalink"><a href="#ga3a14e5485e59bf0f23595b7c2a94eb0b">&#9670;&#160;</a></span>__UHADD8()</h2>
2556
2557 <div class="memitem">
2558 <div class="memproto">
2559       <table class="memname">
2560         <tr>
2561           <td class="memname">uint32_t __UHADD8 </td>
2562           <td>(</td>
2563           <td class="paramtype">uint32_t&#160;</td>
2564           <td class="paramname"><em>val1</em>, </td>
2565         </tr>
2566         <tr>
2567           <td class="paramkey"></td>
2568           <td></td>
2569           <td class="paramtype">uint32_t&#160;</td>
2570           <td class="paramname"><em>val2</em>&#160;</td>
2571         </tr>
2572         <tr>
2573           <td></td>
2574           <td>)</td>
2575           <td></td><td></td>
2576         </tr>
2577       </table>
2578 </div><div class="memdoc">
2579
2580 <p>Quad 8-bit unsigned addition with halved results. </p>
2581 <p>This function enables you to perform four unsigned 8-bit integer additions, halving the results.</p>
2582 <dl class="params"><dt>Parameters</dt><dd>
2583   <table class="params">
2584     <tr><td class="paramname">val1</td><td>first four 8-bit summands. </td></tr>
2585     <tr><td class="paramname">val2</td><td>second four 8-bit summands.</td></tr>
2586   </table>
2587   </dd>
2588 </dl>
2589 <dl class="section return"><dt>Returns</dt><dd><ul>
2590 <li>the halved addition of the first bytes in each operand, in the first byte of the return value. </li>
2591 <li>the halved addition of the second bytes in each operand, in the second byte of the return value. </li>
2592 <li>the halved addition of the third bytes in each operand, in the third byte of the return value. </li>
2593 <li>the halved addition of the fourth bytes in each operand, in the fourth byte of the return value.</li>
2594 </ul>
2595 </dd></dl>
2596 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[7:0]   = val1[7:0]   + val2[7:0]   &gt;&gt; 1</div>
2597 <div class="line">res[15:8]  = val1[15:8]  + val2[15:8]  &gt;&gt; 1</div>
2598 <div class="line">res[23:16] = val1[23:16] + val2[23:16] &gt;&gt; 1</div>
2599 <div class="line">res[31:24] = val1[31:24] + val2[31:24] &gt;&gt; 1</div>
2600 </div><!-- fragment --> </dd></dl>
2601
2602 </div>
2603 </div>
2604 <a id="ga028f0732b961fb6e5209326fb3855261" name="ga028f0732b961fb6e5209326fb3855261"></a>
2605 <h2 class="memtitle"><span class="permalink"><a href="#ga028f0732b961fb6e5209326fb3855261">&#9670;&#160;</a></span>__UHASX()</h2>
2606
2607 <div class="memitem">
2608 <div class="memproto">
2609       <table class="memname">
2610         <tr>
2611           <td class="memname">uint32_t __UHASX </td>
2612           <td>(</td>
2613           <td class="paramtype">uint32_t&#160;</td>
2614           <td class="paramname"><em>val1</em>, </td>
2615         </tr>
2616         <tr>
2617           <td class="paramkey"></td>
2618           <td></td>
2619           <td class="paramtype">uint32_t&#160;</td>
2620           <td class="paramname"><em>val2</em>&#160;</td>
2621         </tr>
2622         <tr>
2623           <td></td>
2624           <td>)</td>
2625           <td></td><td></td>
2626         </tr>
2627       </table>
2628 </div><div class="memdoc">
2629
2630 <p>Dual 16-bit unsigned addition and subtraction with halved results and exchange. </p>
2631 <p>This function enables you to exchange the halfwords of the second operand, add the high halfwords and subtract the low halfwords, halving the results.</p>
2632 <dl class="params"><dt>Parameters</dt><dd>
2633   <table class="params">
2634     <tr><td class="paramname">val1</td><td>first operand for the subtraction in the low halfword, and the first operand for the addition in the high halfword. </td></tr>
2635     <tr><td class="paramname">val2</td><td>second operand for the subtraction in the high halfword, and the second operand for the addition in the low halfword.</td></tr>
2636   </table>
2637   </dd>
2638 </dl>
2639 <dl class="section return"><dt>Returns</dt><dd><ul>
2640 <li>the halved subtraction of the high halfword in the second operand from the low halfword in the first operand. </li>
2641 <li>the halved addition of the high halfword in the first operand and the low halfword in the second operand.</li>
2642 </ul>
2643 </dd></dl>
2644 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = (val1[15:0]  - val2[31:16]) &gt;&gt; 1</div>
2645 <div class="line">res[31:16] = (val1[31:16] + val2[15:0] ) &gt;&gt; 1</div>
2646 </div><!-- fragment --> </dd></dl>
2647
2648 </div>
2649 </div>
2650 <a id="ga09e129e6613329aab87c89f1108b7ed7" name="ga09e129e6613329aab87c89f1108b7ed7"></a>
2651 <h2 class="memtitle"><span class="permalink"><a href="#ga09e129e6613329aab87c89f1108b7ed7">&#9670;&#160;</a></span>__UHSAX()</h2>
2652
2653 <div class="memitem">
2654 <div class="memproto">
2655       <table class="memname">
2656         <tr>
2657           <td class="memname">uint32_t __UHSAX </td>
2658           <td>(</td>
2659           <td class="paramtype">uint32_t&#160;</td>
2660           <td class="paramname"><em>val1</em>, </td>
2661         </tr>
2662         <tr>
2663           <td class="paramkey"></td>
2664           <td></td>
2665           <td class="paramtype">uint32_t&#160;</td>
2666           <td class="paramname"><em>val2</em>&#160;</td>
2667         </tr>
2668         <tr>
2669           <td></td>
2670           <td>)</td>
2671           <td></td><td></td>
2672         </tr>
2673       </table>
2674 </div><div class="memdoc">
2675
2676 <p>Dual 16-bit unsigned subtraction and addition with halved results and exchange. </p>
2677 <p>This function enables you to exchange the halfwords of the second operand, subtract the high halfwords and add the low halfwords, halving the results.</p>
2678 <dl class="params"><dt>Parameters</dt><dd>
2679   <table class="params">
2680     <tr><td class="paramname">val1</td><td>first operand for the addition in the low halfword, and the first operand for the subtraction in the high halfword. </td></tr>
2681     <tr><td class="paramname">val2</td><td>second operand for the addition in the high halfword, and the second operand for the subtraction in the low halfword.</td></tr>
2682   </table>
2683   </dd>
2684 </dl>
2685 <dl class="section return"><dt>Returns</dt><dd><ul>
2686 <li>the halved addition of the high halfword in the second operand and the low halfword in the first operand, in the low halfword of the return value. </li>
2687 <li>the halved subtraction of the low halfword in the second operand from the high halfword in the first operand, in the high halfword of the return value.</li>
2688 </ul>
2689 </dd></dl>
2690 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = (val1[15:0]  + val2[31:16]) &gt;&gt; 1</div>
2691 <div class="line">res[31:16] = (val1[31:16] - val2[15:0] ) &gt;&gt; 1</div>
2692 </div><!-- fragment --> </dd></dl>
2693
2694 </div>
2695 </div>
2696 <a id="ga1f7545b8dc33bb97982731cb9d427a69" name="ga1f7545b8dc33bb97982731cb9d427a69"></a>
2697 <h2 class="memtitle"><span class="permalink"><a href="#ga1f7545b8dc33bb97982731cb9d427a69">&#9670;&#160;</a></span>__UHSUB16()</h2>
2698
2699 <div class="memitem">
2700 <div class="memproto">
2701       <table class="memname">
2702         <tr>
2703           <td class="memname">uint32_t __UHSUB16 </td>
2704           <td>(</td>
2705           <td class="paramtype">uint32_t&#160;</td>
2706           <td class="paramname"><em>val1</em>, </td>
2707         </tr>
2708         <tr>
2709           <td class="paramkey"></td>
2710           <td></td>
2711           <td class="paramtype">uint32_t&#160;</td>
2712           <td class="paramname"><em>val2</em>&#160;</td>
2713         </tr>
2714         <tr>
2715           <td></td>
2716           <td>)</td>
2717           <td></td><td></td>
2718         </tr>
2719       </table>
2720 </div><div class="memdoc">
2721
2722 <p>Dual 16-bit unsigned subtraction with halved results. </p>
2723 <p>This function enables you to perform two unsigned 16-bit integer subtractions, halving the results.</p>
2724 <dl class="params"><dt>Parameters</dt><dd>
2725   <table class="params">
2726     <tr><td class="paramname">val1</td><td>first two 16-bit operands. </td></tr>
2727     <tr><td class="paramname">val2</td><td>second two 16-bit operands.</td></tr>
2728   </table>
2729   </dd>
2730 </dl>
2731 <dl class="section return"><dt>Returns</dt><dd><ul>
2732 <li>the halved subtraction of the low halfword in the second operand from the low halfword in the first operand, in the low halfword of the return value. </li>
2733 <li>the halved subtraction of the high halfword in the second operand from the high halfword in the first operand, in the high halfword of the return value.</li>
2734 </ul>
2735 </dd></dl>
2736 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  - val2[15:0]   &gt;&gt; 1</div>
2737 <div class="line">res[31:16] = val1[31:16] - val2[31:16]  &gt;&gt; 1</div>
2738 </div><!-- fragment --> </dd></dl>
2739
2740 </div>
2741 </div>
2742 <a id="ga48a55df1c3e73923b73819d7c19b392d" name="ga48a55df1c3e73923b73819d7c19b392d"></a>
2743 <h2 class="memtitle"><span class="permalink"><a href="#ga48a55df1c3e73923b73819d7c19b392d">&#9670;&#160;</a></span>__UHSUB8()</h2>
2744
2745 <div class="memitem">
2746 <div class="memproto">
2747       <table class="memname">
2748         <tr>
2749           <td class="memname">uint32_t __UHSUB8 </td>
2750           <td>(</td>
2751           <td class="paramtype">uint32_t&#160;</td>
2752           <td class="paramname"><em>val1</em>, </td>
2753         </tr>
2754         <tr>
2755           <td class="paramkey"></td>
2756           <td></td>
2757           <td class="paramtype">uint32_t&#160;</td>
2758           <td class="paramname"><em>val2</em>&#160;</td>
2759         </tr>
2760         <tr>
2761           <td></td>
2762           <td>)</td>
2763           <td></td><td></td>
2764         </tr>
2765       </table>
2766 </div><div class="memdoc">
2767
2768 <p>Quad 8-bit unsigned subtraction with halved results. </p>
2769 <p>This function enables you to perform four unsigned 8-bit integer subtractions, halving the results.</p>
2770 <dl class="params"><dt>Parameters</dt><dd>
2771   <table class="params">
2772     <tr><td class="paramname">val1</td><td>first four 8-bit operands. </td></tr>
2773     <tr><td class="paramname">val2</td><td>second four 8-bit operands.</td></tr>
2774   </table>
2775   </dd>
2776 </dl>
2777 <dl class="section return"><dt>Returns</dt><dd><ul>
2778 <li>the halved subtraction of the first byte in the second operand from the first byte in the first operand, in the first bytes of the return value. </li>
2779 <li>the halved subtraction of the second byte in the second operand from the second byte in the first operand, in the second byte of the return value. </li>
2780 <li>the halved subtraction of the third byte in the second operand from the third byte in the first operand, in the third byte of the return value. </li>
2781 <li>the halved subtraction of the fourth byte in the second operand from the fourth byte in the first operand, in the fourth byte of the return value.</li>
2782 </ul>
2783 </dd></dl>
2784 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[7:0]   = val1[7:0]   - val2[7:0]    &gt;&gt; 1</div>
2785 <div class="line">res[15:8]  = val1[15:8]  - val2[15:8]   &gt;&gt; 1</div>
2786 <div class="line">res[23:16] = val1[23:16] - val2[23:16]  &gt;&gt; 1</div>
2787 <div class="line">res[31:24] = val1[31:24] - val2[31:24]  &gt;&gt; 1</div>
2788 </div><!-- fragment --> </dd></dl>
2789
2790 </div>
2791 </div>
2792 <a id="ga9e2cc5117e79578a08b25f1e89022966" name="ga9e2cc5117e79578a08b25f1e89022966"></a>
2793 <h2 class="memtitle"><span class="permalink"><a href="#ga9e2cc5117e79578a08b25f1e89022966">&#9670;&#160;</a></span>__UQADD16()</h2>
2794
2795 <div class="memitem">
2796 <div class="memproto">
2797       <table class="memname">
2798         <tr>
2799           <td class="memname">uint32_t __UQADD16 </td>
2800           <td>(</td>
2801           <td class="paramtype">uint32_t&#160;</td>
2802           <td class="paramname"><em>val1</em>, </td>
2803         </tr>
2804         <tr>
2805           <td class="paramkey"></td>
2806           <td></td>
2807           <td class="paramtype">uint32_t&#160;</td>
2808           <td class="paramname"><em>val2</em>&#160;</td>
2809         </tr>
2810         <tr>
2811           <td></td>
2812           <td>)</td>
2813           <td></td><td></td>
2814         </tr>
2815       </table>
2816 </div><div class="memdoc">
2817
2818 <p>Dual 16-bit unsigned saturating addition. </p>
2819 <p>This function enables you to perform two unsigned 16-bit integer additions, saturating the results to the 16-bit unsigned integer range 0 &lt; x &lt; 2<sup>16</sup> - 1.</p>
2820 <dl class="params"><dt>Parameters</dt><dd>
2821   <table class="params">
2822     <tr><td class="paramname">val1</td><td>first two 16-bit summands. </td></tr>
2823     <tr><td class="paramname">val2</td><td>second two 16-bit summands.</td></tr>
2824   </table>
2825   </dd>
2826 </dl>
2827 <dl class="section return"><dt>Returns</dt><dd><ul>
2828 <li>the addition of the low halfword in the first operand and the low halfword in the second operand, in the low halfword of the return value. </li>
2829 <li>the addition of the high halfword in the first operand and the high halfword in the second operand, in the high halfword of the return value.</li>
2830 </ul>
2831 </dd></dl>
2832 <dl class="section user"><dt></dt><dd>The results are saturated to the 16-bit unsigned integer range 0 &lt; x &lt; 2<sup>16</sup> - 1.</dd></dl>
2833 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  + val2[15:0]</div>
2834 <div class="line">res[31:16] = val1[31:16] + val2[31:16]</div>
2835 </div><!-- fragment --> </dd></dl>
2836
2837 </div>
2838 </div>
2839 <a id="gafa9af218db3934a692fb06fa728d8031" name="gafa9af218db3934a692fb06fa728d8031"></a>
2840 <h2 class="memtitle"><span class="permalink"><a href="#gafa9af218db3934a692fb06fa728d8031">&#9670;&#160;</a></span>__UQADD8()</h2>
2841
2842 <div class="memitem">
2843 <div class="memproto">
2844       <table class="memname">
2845         <tr>
2846           <td class="memname">uint32_t __UQADD8 </td>
2847           <td>(</td>
2848           <td class="paramtype">uint32_t&#160;</td>
2849           <td class="paramname"><em>val1</em>, </td>
2850         </tr>
2851         <tr>
2852           <td class="paramkey"></td>
2853           <td></td>
2854           <td class="paramtype">uint32_t&#160;</td>
2855           <td class="paramname"><em>val2</em>&#160;</td>
2856         </tr>
2857         <tr>
2858           <td></td>
2859           <td>)</td>
2860           <td></td><td></td>
2861         </tr>
2862       </table>
2863 </div><div class="memdoc">
2864
2865 <p>Quad 8-bit unsigned saturating addition. </p>
2866 <p>This function enables you to perform four unsigned 8-bit integer additions, saturating the results to the 8-bit unsigned integer range 0 &lt; x &lt; 2<sup>8</sup> - 1.</p>
2867 <dl class="params"><dt>Parameters</dt><dd>
2868   <table class="params">
2869     <tr><td class="paramname">val1</td><td>first four 8-bit summands. </td></tr>
2870     <tr><td class="paramname">val2</td><td>second four 8-bit summands.</td></tr>
2871   </table>
2872   </dd>
2873 </dl>
2874 <dl class="section return"><dt>Returns</dt><dd><ul>
2875 <li>the saturated addition of the first bytes in each operand, in the first byte of the return value. </li>
2876 <li>the saturated addition of the second bytes in each operand, in the second byte of the return value. </li>
2877 <li>the saturated addition of the third bytes in each operand, in the third byte of the return value. </li>
2878 <li>the saturated addition of the fourth bytes in each operand, in the fourth byte of the return value.</li>
2879 </ul>
2880 </dd></dl>
2881 <dl class="section user"><dt></dt><dd>The results are saturated to the 8-bit unsigned integer range 0 &lt; x &lt; 2<sup>8</sup> - 1.</dd></dl>
2882 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[7:0]   = val1[7:0]   + val2[7:0]</div>
2883 <div class="line">res[15:8]  = val1[15:8]  + val2[15:8]</div>
2884 <div class="line">res[23:16] = val1[23:16] + val2[23:16]</div>
2885 <div class="line">res[31:24] = val1[31:24] + val2[31:24]</div>
2886 </div><!-- fragment --> </dd></dl>
2887
2888 </div>
2889 </div>
2890 <a id="ga5eff3ae5eabcd73f3049996ca391becb" name="ga5eff3ae5eabcd73f3049996ca391becb"></a>
2891 <h2 class="memtitle"><span class="permalink"><a href="#ga5eff3ae5eabcd73f3049996ca391becb">&#9670;&#160;</a></span>__UQASX()</h2>
2892
2893 <div class="memitem">
2894 <div class="memproto">
2895       <table class="memname">
2896         <tr>
2897           <td class="memname">uint32_t __UQASX </td>
2898           <td>(</td>
2899           <td class="paramtype">uint32_t&#160;</td>
2900           <td class="paramname"><em>val1</em>, </td>
2901         </tr>
2902         <tr>
2903           <td class="paramkey"></td>
2904           <td></td>
2905           <td class="paramtype">uint32_t&#160;</td>
2906           <td class="paramname"><em>val2</em>&#160;</td>
2907         </tr>
2908         <tr>
2909           <td></td>
2910           <td>)</td>
2911           <td></td><td></td>
2912         </tr>
2913       </table>
2914 </div><div class="memdoc">
2915
2916 <p>Dual 16-bit unsigned saturating addition and subtraction with exchange. </p>
2917 <p>This function enables you to exchange the halfwords of the second operand and perform one unsigned 16-bit integer addition and one unsigned 16-bit subtraction, saturating the results to the 16-bit unsigned integer range 0 &lt;= x &lt;= 2<sup>16</sup> - 1.</p>
2918 <dl class="params"><dt>Parameters</dt><dd>
2919   <table class="params">
2920     <tr><td class="paramname">val1</td><td>first two 16-bit operands. </td></tr>
2921     <tr><td class="paramname">val2</td><td>second two 16-bit operands.</td></tr>
2922   </table>
2923   </dd>
2924 </dl>
2925 <dl class="section return"><dt>Returns</dt><dd><ul>
2926 <li>the subtraction of the high halfword in the second operand from the low halfword in the first operand, in the low halfword of the return value. </li>
2927 <li>the subtraction of the low halfword in the second operand from the high halfword in the first operand, in the high halfword of the return value.</li>
2928 </ul>
2929 </dd></dl>
2930 <dl class="section user"><dt></dt><dd>The results are saturated to the 16-bit unsigned integer range 0 &lt;= x &lt;= 2<sup>16</sup> - 1.</dd></dl>
2931 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  - val2[31:16]</div>
2932 <div class="line">res[31:16] = val1[31:16] + val2[15:0]</div>
2933 </div><!-- fragment --> </dd></dl>
2934
2935 </div>
2936 </div>
2937 <a id="gadecfdfabc328d8939d49d996f2fd4482" name="gadecfdfabc328d8939d49d996f2fd4482"></a>
2938 <h2 class="memtitle"><span class="permalink"><a href="#gadecfdfabc328d8939d49d996f2fd4482">&#9670;&#160;</a></span>__UQSAX()</h2>
2939
2940 <div class="memitem">
2941 <div class="memproto">
2942       <table class="memname">
2943         <tr>
2944           <td class="memname">uint32_t __UQSAX </td>
2945           <td>(</td>
2946           <td class="paramtype">uint32_t&#160;</td>
2947           <td class="paramname"><em>val1</em>, </td>
2948         </tr>
2949         <tr>
2950           <td class="paramkey"></td>
2951           <td></td>
2952           <td class="paramtype">uint32_t&#160;</td>
2953           <td class="paramname"><em>val2</em>&#160;</td>
2954         </tr>
2955         <tr>
2956           <td></td>
2957           <td>)</td>
2958           <td></td><td></td>
2959         </tr>
2960       </table>
2961 </div><div class="memdoc">
2962
2963 <p>Dual 16-bit unsigned saturating subtraction and addition with exchange. </p>
2964 <p>This function enables you to exchange the halfwords of the second operand and perform one unsigned 16-bit integer subtraction and one unsigned 16-bit addition, saturating the results to the 16-bit unsigned integer range 0 &lt;= x &lt;= 2<sup>16</sup> - 1.</p>
2965 <dl class="params"><dt>Parameters</dt><dd>
2966   <table class="params">
2967     <tr><td class="paramname">val1</td><td>first 16-bit operand for the addition in the low halfword, and the first 16-bit operand for the subtraction in the high halfword. </td></tr>
2968     <tr><td class="paramname">val2</td><td>second 16-bit halfword for the addition in the high halfword, and the second 16-bit halfword for the subtraction in the low halfword.</td></tr>
2969   </table>
2970   </dd>
2971 </dl>
2972 <dl class="section return"><dt>Returns</dt><dd><ul>
2973 <li>the addition of the low halfword in the first operand and the high halfword in the second operand, in the low halfword of the return value. </li>
2974 <li>the subtraction of the low halfword in the second operand from the high halfword in the first operand, in the high halfword of the return value. </li>
2975 </ul>
2976 </dd></dl>
2977 <dl class="section user"><dt></dt><dd>The results are saturated to the 16-bit unsigned integer range 0 &lt;= x &lt;= 2<sup>16</sup> - 1.</dd></dl>
2978 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  + val2[31:16]</div>
2979 <div class="line">res[31:16] = val1[31:16] - val2[15:0]</div>
2980 </div><!-- fragment --> </dd></dl>
2981
2982 </div>
2983 </div>
2984 <a id="ga5ec4e2e231d15e5c692233feb3806187" name="ga5ec4e2e231d15e5c692233feb3806187"></a>
2985 <h2 class="memtitle"><span class="permalink"><a href="#ga5ec4e2e231d15e5c692233feb3806187">&#9670;&#160;</a></span>__UQSUB16()</h2>
2986
2987 <div class="memitem">
2988 <div class="memproto">
2989       <table class="memname">
2990         <tr>
2991           <td class="memname">uint32_t __UQSUB16 </td>
2992           <td>(</td>
2993           <td class="paramtype">uint32_t&#160;</td>
2994           <td class="paramname"><em>val1</em>, </td>
2995         </tr>
2996         <tr>
2997           <td class="paramkey"></td>
2998           <td></td>
2999           <td class="paramtype">uint32_t&#160;</td>
3000           <td class="paramname"><em>val2</em>&#160;</td>
3001         </tr>
3002         <tr>
3003           <td></td>
3004           <td>)</td>
3005           <td></td><td></td>
3006         </tr>
3007       </table>
3008 </div><div class="memdoc">
3009
3010 <p>Dual 16-bit unsigned saturating subtraction. </p>
3011 <p>This function enables you to perform two unsigned 16-bit integer subtractions, saturating the results to the 16-bit unsigned integer range 0 &lt; x &lt; 2<sup>16</sup> - 1.</p>
3012 <dl class="params"><dt>Parameters</dt><dd>
3013   <table class="params">
3014     <tr><td class="paramname">val1</td><td>first two 16-bit operands for each subtraction. </td></tr>
3015     <tr><td class="paramname">val2</td><td>second two 16-bit operands for each subtraction.</td></tr>
3016   </table>
3017   </dd>
3018 </dl>
3019 <dl class="section return"><dt>Returns</dt><dd><ul>
3020 <li>the subtraction of the low halfword in the second operand from the low halfword in the first operand, in the low halfword of the return value. </li>
3021 <li>the subtraction of the high halfword in the second operand from the high halfword in the first operand, in the high halfword of the return value.</li>
3022 </ul>
3023 </dd></dl>
3024 <dl class="section user"><dt></dt><dd>The results are saturated to the 16-bit unsigned integer range 0 &lt; x &lt; 2<sup>16</sup> - 1.</dd></dl>
3025 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  - val2[15:0]</div>
3026 <div class="line">res[31:16] = val1[31:16] - val2[31:16]</div>
3027 </div><!-- fragment --> </dd></dl>
3028
3029 </div>
3030 </div>
3031 <a id="ga9736fe816aec74fe886e7fb949734eab" name="ga9736fe816aec74fe886e7fb949734eab"></a>
3032 <h2 class="memtitle"><span class="permalink"><a href="#ga9736fe816aec74fe886e7fb949734eab">&#9670;&#160;</a></span>__UQSUB8()</h2>
3033
3034 <div class="memitem">
3035 <div class="memproto">
3036       <table class="memname">
3037         <tr>
3038           <td class="memname">uint32_t __UQSUB8 </td>
3039           <td>(</td>
3040           <td class="paramtype">uint32_t&#160;</td>
3041           <td class="paramname"><em>val1</em>, </td>
3042         </tr>
3043         <tr>
3044           <td class="paramkey"></td>
3045           <td></td>
3046           <td class="paramtype">uint32_t&#160;</td>
3047           <td class="paramname"><em>val2</em>&#160;</td>
3048         </tr>
3049         <tr>
3050           <td></td>
3051           <td>)</td>
3052           <td></td><td></td>
3053         </tr>
3054       </table>
3055 </div><div class="memdoc">
3056
3057 <p>Quad 8-bit unsigned saturating subtraction. </p>
3058 <p>This function enables you to perform four unsigned 8-bit integer subtractions, saturating the results to the 8-bit unsigned integer range 0 &lt; x &lt; 2<sup>8</sup> - 1.</p>
3059 <dl class="params"><dt>Parameters</dt><dd>
3060   <table class="params">
3061     <tr><td class="paramname">val1</td><td>first four 8-bit operands. </td></tr>
3062     <tr><td class="paramname">val2</td><td>second four 8-bit operands.</td></tr>
3063   </table>
3064   </dd>
3065 </dl>
3066 <dl class="section return"><dt>Returns</dt><dd><ul>
3067 <li>the subtraction of the first byte in the second operand from the first byte in the first operand, in the first bytes of the return value. </li>
3068 <li>the subtraction of the second byte in the second operand from the second byte in the first operand, in the second byte of the return value. </li>
3069 <li>the subtraction of the third byte in the second operand from the third byte in the first operand, in the third byte of the return value. </li>
3070 <li>the subtraction of the fourth byte in the second operand from the fourth byte in the first operand, in the fourth byte of the return value.</li>
3071 </ul>
3072 </dd></dl>
3073 <dl class="section user"><dt></dt><dd>The results are saturated to the 8-bit unsigned integer range 0 &lt; x &lt; 2<sup>8</sup> - 1.</dd></dl>
3074 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[7:0]   = val1[7:0]   - val2[7:0]</div>
3075 <div class="line">res[15:8]  = val1[15:8]  - val2[15:8]</div>
3076 <div class="line">res[23:16] = val1[23:16] - val2[23:16]</div>
3077 <div class="line">res[31:24] = val1[31:24] - val2[31:24]</div>
3078 </div><!-- fragment --> </dd></dl>
3079
3080 </div>
3081 </div>
3082 <a id="gac8855c07044239ea775c8128013204f0" name="gac8855c07044239ea775c8128013204f0"></a>
3083 <h2 class="memtitle"><span class="permalink"><a href="#gac8855c07044239ea775c8128013204f0">&#9670;&#160;</a></span>__USAD8()</h2>
3084
3085 <div class="memitem">
3086 <div class="memproto">
3087       <table class="memname">
3088         <tr>
3089           <td class="memname">uint32_t __USAD8 </td>
3090           <td>(</td>
3091           <td class="paramtype">uint32_t&#160;</td>
3092           <td class="paramname"><em>val1</em>, </td>
3093         </tr>
3094         <tr>
3095           <td class="paramkey"></td>
3096           <td></td>
3097           <td class="paramtype">uint32_t&#160;</td>
3098           <td class="paramname"><em>val2</em>&#160;</td>
3099         </tr>
3100         <tr>
3101           <td></td>
3102           <td>)</td>
3103           <td></td><td></td>
3104         </tr>
3105       </table>
3106 </div><div class="memdoc">
3107
3108 <p>Unsigned sum of quad 8-bit unsigned absolute difference. </p>
3109 <p>This function enables you to perform four unsigned 8-bit subtractions, and add the absolute values of the differences together, returning the result as a single unsigned integer.</p>
3110 <dl class="params"><dt>Parameters</dt><dd>
3111   <table class="params">
3112     <tr><td class="paramname">val1</td><td>first four 8-bit operands for the subtractions. </td></tr>
3113     <tr><td class="paramname">val2</td><td>second four 8-bit operands for the subtractions.</td></tr>
3114   </table>
3115   </dd>
3116 </dl>
3117 <dl class="section return"><dt>Returns</dt><dd><ul>
3118 <li>the subtraction of the first byte in the second operand from the first byte in the first operand. </li>
3119 <li>the subtraction of the second byte in the second operand from the second byte in the first operand. </li>
3120 <li>the subtraction of the third byte in the second operand from the third byte in the first operand. </li>
3121 <li>the subtraction of the fourth byte in the second operand from the fourth byte in the first operand. </li>
3122 </ul>
3123 </dd></dl>
3124 <dl class="section user"><dt></dt><dd>The sum is returned as a single unsigned integer.</dd></dl>
3125 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">absdiff1  = val1[7:0]   - val2[7:0]</div>
3126 <div class="line">absdiff2  = val1[15:8]  - val2[15:8]</div>
3127 <div class="line">absdiff3  = val1[23:16] - val2[23:16]</div>
3128 <div class="line">absdiff4  = val1[31:24] - val2[31:24]</div>
3129 <div class="line">res[31:0] = absdiff1 + absdiff2 + absdiff3 + absdiff4</div>
3130 </div><!-- fragment --> </dd></dl>
3131
3132 </div>
3133 </div>
3134 <a id="gad032bd21f013c5d29f5fcb6b0f02bc3f" name="gad032bd21f013c5d29f5fcb6b0f02bc3f"></a>
3135 <h2 class="memtitle"><span class="permalink"><a href="#gad032bd21f013c5d29f5fcb6b0f02bc3f">&#9670;&#160;</a></span>__USADA8()</h2>
3136
3137 <div class="memitem">
3138 <div class="memproto">
3139       <table class="memname">
3140         <tr>
3141           <td class="memname">uint32_t __USADA8 </td>
3142           <td>(</td>
3143           <td class="paramtype">uint32_t&#160;</td>
3144           <td class="paramname"><em>val1</em>, </td>
3145         </tr>
3146         <tr>
3147           <td class="paramkey"></td>
3148           <td></td>
3149           <td class="paramtype">uint32_t&#160;</td>
3150           <td class="paramname"><em>val2</em>, </td>
3151         </tr>
3152         <tr>
3153           <td class="paramkey"></td>
3154           <td></td>
3155           <td class="paramtype">uint32_t&#160;</td>
3156           <td class="paramname"><em>val3</em>&#160;</td>
3157         </tr>
3158         <tr>
3159           <td></td>
3160           <td>)</td>
3161           <td></td><td></td>
3162         </tr>
3163       </table>
3164 </div><div class="memdoc">
3165
3166 <p>Unsigned sum of quad 8-bit unsigned absolute difference with 32-bit accumulate. </p>
3167 <p>This function enables you to perform four unsigned 8-bit subtractions, and add the absolute values of the differences to a 32-bit accumulate operand.</p>
3168 <dl class="params"><dt>Parameters</dt><dd>
3169   <table class="params">
3170     <tr><td class="paramname">val1</td><td>first four 8-bit operands for the subtractions. </td></tr>
3171     <tr><td class="paramname">val2</td><td>second four 8-bit operands for the subtractions. </td></tr>
3172     <tr><td class="paramname">val3</td><td>accumulation value.</td></tr>
3173   </table>
3174   </dd>
3175 </dl>
3176 <dl class="section return"><dt>Returns</dt><dd>the sum of the absolute differences of the following bytes, added to the accumulation value: <ul>
3177 <li>the subtraction of the first byte in the second operand from the first byte in the first operand. </li>
3178 <li>the subtraction of the second byte in the second operand from the second byte in the first operand. </li>
3179 <li>the subtraction of the third byte in the second operand from the third byte in the first operand. </li>
3180 <li>the subtraction of the fourth byte in the second operand from the fourth byte in the first operand.</li>
3181 </ul>
3182 </dd></dl>
3183 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">absdiff1  = val1[7:0]   - val2[7:0]</div>
3184 <div class="line">absdiff2  = val1[15:8]  - val2[15:8]</div>
3185 <div class="line">absdiff3  = val1[23:16] - val2[23:16]</div>
3186 <div class="line">absdiff4  = val1[31:24] - val2[31:24]</div>
3187 <div class="line">sum       = absdiff1 + absdiff2 + absdiff3 + absdiff4</div>
3188 <div class="line">res[31:0] = sum[31:0] + val3[31:0]</div>
3189 </div><!-- fragment --> </dd></dl>
3190
3191 </div>
3192 </div>
3193 <a id="ga967f516afff5900cf30f1a81907cdd89" name="ga967f516afff5900cf30f1a81907cdd89"></a>
3194 <h2 class="memtitle"><span class="permalink"><a href="#ga967f516afff5900cf30f1a81907cdd89">&#9670;&#160;</a></span>__USAT16()</h2>
3195
3196 <div class="memitem">
3197 <div class="memproto">
3198       <table class="memname">
3199         <tr>
3200           <td class="memname">uint32_t __USAT16 </td>
3201           <td>(</td>
3202           <td class="paramtype">uint32_t&#160;</td>
3203           <td class="paramname"><em>val1</em>, </td>
3204         </tr>
3205         <tr>
3206           <td class="paramkey"></td>
3207           <td></td>
3208           <td class="paramtype">const uint32_t&#160;</td>
3209           <td class="paramname"><em>val2</em>&#160;</td>
3210         </tr>
3211         <tr>
3212           <td></td>
3213           <td>)</td>
3214           <td></td><td></td>
3215         </tr>
3216       </table>
3217 </div><div class="memdoc">
3218
3219 <p>Q setting dual 16-bit unsigned saturate. </p>
3220 <p>This function enables you to saturate two signed 16-bit values to a selected unsigned range.<br  />
3221  The Q bit is set if either operation saturates.</p>
3222 <dl class="params"><dt>Parameters</dt><dd>
3223   <table class="params">
3224     <tr><td class="paramname">val1</td><td>two 16-bit values that are to be saturated. </td></tr>
3225     <tr><td class="paramname">val2</td><td>bit position for saturation, and must be an integral constant expression in the range 0 to 15.</td></tr>
3226   </table>
3227   </dd>
3228 </dl>
3229 <dl class="section return"><dt>Returns</dt><dd>the saturation of the two signed 16-bit values, as non-negative values. <ul>
3230 <li>the saturation of the low halfword in <em>val1</em>, saturated to the bit position specified in <em>val2</em> and returned in the low halfword of the return value. </li>
3231 <li>the saturation of the high halfword in <em>val1</em>, saturated to the bit position specified in <em>val2</em> and returned in the high halfword of the return value.</li>
3232 </ul>
3233 </dd></dl>
3234 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">Saturate halfwords in val1 to the <span class="keywordtype">unsigned</span> range specified by the bit position in val2</div>
3235 </div><!-- fragment --> </dd></dl>
3236
3237 </div>
3238 </div>
3239 <a id="ga578a082747436772c482c96d7a58e45e" name="ga578a082747436772c482c96d7a58e45e"></a>
3240 <h2 class="memtitle"><span class="permalink"><a href="#ga578a082747436772c482c96d7a58e45e">&#9670;&#160;</a></span>__USAX()</h2>
3241
3242 <div class="memitem">
3243 <div class="memproto">
3244       <table class="memname">
3245         <tr>
3246           <td class="memname">uint32_t __USAX </td>
3247           <td>(</td>
3248           <td class="paramtype">uint32_t&#160;</td>
3249           <td class="paramname"><em>val1</em>, </td>
3250         </tr>
3251         <tr>
3252           <td class="paramkey"></td>
3253           <td></td>
3254           <td class="paramtype">uint32_t&#160;</td>
3255           <td class="paramname"><em>val2</em>&#160;</td>
3256         </tr>
3257         <tr>
3258           <td></td>
3259           <td>)</td>
3260           <td></td><td></td>
3261         </tr>
3262       </table>
3263 </div><div class="memdoc">
3264
3265 <p>GE setting dual 16-bit unsigned subtract and add with exchange. </p>
3266 <p>This function enables you to exchange the halfwords of the second operand, subtract the high halfwords and add the low halfwords.<br  />
3267  The GE bits in the APSR are set according to the results.</p>
3268 <dl class="params"><dt>Parameters</dt><dd>
3269   <table class="params">
3270     <tr><td class="paramname">val1</td><td>first operand for the addition in the low halfword, and the first operand for the subtraction in the high halfword. </td></tr>
3271     <tr><td class="paramname">val2</td><td>second operand for the addition in the high halfword, and the second operand for the subtraction in the low halfword.</td></tr>
3272   </table>
3273   </dd>
3274 </dl>
3275 <dl class="section return"><dt>Returns</dt><dd><ul>
3276 <li>the addition of the low halfword in the first operand and the high halfword in the second operand, in the low halfword of the return value. </li>
3277 <li>the subtraction of the low halfword in the second operand from the high halfword in the first operand, in the high halfword of the return value. </li>
3278 </ul>
3279 </dd></dl>
3280 <dl class="section user"><dt></dt><dd>Each bit in APSR.GE is set or cleared for each byte in the return value, depending on the results of the operation. </dd></dl>
3281 <dl class="section user"><dt></dt><dd>If <em>res</em> is the return value, then: <ul>
3282 <li>if res[15:0] &gt;= 0x10000 then APSR.GE[1:0] = 11 else 00 </li>
3283 <li>if res[31:16] &gt;= 0 then APSR.GE[3:2] = 11 else 00</li>
3284 </ul>
3285 </dd></dl>
3286 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  + val2[31:16]</div>
3287 <div class="line">res[31:16] = val1[31:16] - val2[15:0]</div>
3288 </div><!-- fragment --> </dd></dl>
3289
3290 </div>
3291 </div>
3292 <a id="ga9f2b77e11fc4a77b26c36c423ed45b4e" name="ga9f2b77e11fc4a77b26c36c423ed45b4e"></a>
3293 <h2 class="memtitle"><span class="permalink"><a href="#ga9f2b77e11fc4a77b26c36c423ed45b4e">&#9670;&#160;</a></span>__USUB16()</h2>
3294
3295 <div class="memitem">
3296 <div class="memproto">
3297       <table class="memname">
3298         <tr>
3299           <td class="memname">uint32_t __USUB16 </td>
3300           <td>(</td>
3301           <td class="paramtype">uint32_t&#160;</td>
3302           <td class="paramname"><em>val1</em>, </td>
3303         </tr>
3304         <tr>
3305           <td class="paramkey"></td>
3306           <td></td>
3307           <td class="paramtype">uint32_t&#160;</td>
3308           <td class="paramname"><em>val2</em>&#160;</td>
3309         </tr>
3310         <tr>
3311           <td></td>
3312           <td>)</td>
3313           <td></td><td></td>
3314         </tr>
3315       </table>
3316 </div><div class="memdoc">
3317
3318 <p>GE setting dual 16-bit unsigned subtract. </p>
3319 <p>This function enables you to perform two 16-bit unsigned integer subtractions.<br  />
3320  The GE bits in the APSR are set according to the results.</p>
3321 <dl class="params"><dt>Parameters</dt><dd>
3322   <table class="params">
3323     <tr><td class="paramname">val1</td><td>first two 16-bit operands. </td></tr>
3324     <tr><td class="paramname">val2</td><td>second two 16-bit operands.</td></tr>
3325   </table>
3326   </dd>
3327 </dl>
3328 <dl class="section return"><dt>Returns</dt><dd><ul>
3329 <li>the subtraction of the low halfword in the second operand from the low halfword in the first operand, in the low halfword of the return value. </li>
3330 <li>the subtraction of the high halfword in the second operand from the high halfword in the first operand, in the high halfword of the return value.</li>
3331 </ul>
3332 </dd></dl>
3333 <dl class="section user"><dt></dt><dd>Each bit in APSR.GE is set or cleared for each byte in the return value, depending on the results of the operation.</dd></dl>
3334 <dl class="section user"><dt></dt><dd>If <em>res</em> is the return value, then: <ul>
3335 <li>if res[15:0] &gt;= 0 then APSR.GE[1:0] = 11 else 00 </li>
3336 <li>if res[31:16] &gt;= 0 then APSR.GE[3:2] = 11 else 00</li>
3337 </ul>
3338 </dd></dl>
3339 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = val1[15:0]  - val2[15:0]</div>
3340 <div class="line">res[31:16] = val1[31:16] - val2[31:16]</div>
3341 </div><!-- fragment --> </dd></dl>
3342
3343 </div>
3344 </div>
3345 <a id="gacb7257dc3b8e9acbd0ef0e31ff87d4b8" name="gacb7257dc3b8e9acbd0ef0e31ff87d4b8"></a>
3346 <h2 class="memtitle"><span class="permalink"><a href="#gacb7257dc3b8e9acbd0ef0e31ff87d4b8">&#9670;&#160;</a></span>__USUB8()</h2>
3347
3348 <div class="memitem">
3349 <div class="memproto">
3350       <table class="memname">
3351         <tr>
3352           <td class="memname">uint32_t __USUB8 </td>
3353           <td>(</td>
3354           <td class="paramtype">uint32_t&#160;</td>
3355           <td class="paramname"><em>val1</em>, </td>
3356         </tr>
3357         <tr>
3358           <td class="paramkey"></td>
3359           <td></td>
3360           <td class="paramtype">uint32_t&#160;</td>
3361           <td class="paramname"><em>val2</em>&#160;</td>
3362         </tr>
3363         <tr>
3364           <td></td>
3365           <td>)</td>
3366           <td></td><td></td>
3367         </tr>
3368       </table>
3369 </div><div class="memdoc">
3370
3371 <p>GE setting quad 8-bit unsigned subtract. </p>
3372 <p>This function enables you to perform four 8-bit unsigned integer subtractions. The GE bits in the APSR are set according to the results.</p>
3373 <dl class="params"><dt>Parameters</dt><dd>
3374   <table class="params">
3375     <tr><td class="paramname">val1</td><td>first four 8-bit operands. </td></tr>
3376     <tr><td class="paramname">val2</td><td>second four 8-bit operands.</td></tr>
3377   </table>
3378   </dd>
3379 </dl>
3380 <dl class="section return"><dt>Returns</dt><dd><ul>
3381 <li>the subtraction of the first byte in the second operand from the first byte in the first operand, in the first bytes of the return value. </li>
3382 <li>the subtraction of the second byte in the second operand from the second byte in the first operand, in the second byte of the return value. </li>
3383 <li>the subtraction of the third byte in the second operand from the third byte in the first operand, in the third byte of the return value. </li>
3384 <li>the subtraction of the fourth byte in the second operand from the fourth byte in the first operand, in the fourth byte of the return value.</li>
3385 </ul>
3386 </dd></dl>
3387 <dl class="section user"><dt></dt><dd>Each bit in APSR.GE is set or cleared for each byte in the return value, depending on the results of the operation.</dd></dl>
3388 <dl class="section user"><dt></dt><dd>If <em>res</em> is the return value, then: <ul>
3389 <li>if res[8:0] &gt;= 0 then APSR.GE[0] = 1 else 0 </li>
3390 <li>if res[15:8] &gt;= 0 then APSR.GE[1] = 1 else 0 </li>
3391 <li>if res[23:16] &gt;= 0 then APSR.GE[2] = 1 else 0 </li>
3392 <li>if res[31:24] &gt;= 0 then APSR.GE[3] = 1 else 0</li>
3393 </ul>
3394 </dd></dl>
3395 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[7:0]   = val1[7:0]   - val2[7:0]</div>
3396 <div class="line">res[15:8]  = val1[15:8]  - val2[15:8]</div>
3397 <div class="line">res[23:16] = val1[23:16] - val2[23:16]</div>
3398 <div class="line">res[31:24] = val1[31:24] - val2[31:24]</div>
3399 </div><!-- fragment --> </dd></dl>
3400
3401 </div>
3402 </div>
3403 <a id="gad25ce96db0f17096bbd815f4817faf09" name="gad25ce96db0f17096bbd815f4817faf09"></a>
3404 <h2 class="memtitle"><span class="permalink"><a href="#gad25ce96db0f17096bbd815f4817faf09">&#9670;&#160;</a></span>__UXTAB16()</h2>
3405
3406 <div class="memitem">
3407 <div class="memproto">
3408       <table class="memname">
3409         <tr>
3410           <td class="memname">uint32_t __UXTAB16 </td>
3411           <td>(</td>
3412           <td class="paramtype">uint32_t&#160;</td>
3413           <td class="paramname"><em>val1</em>, </td>
3414         </tr>
3415         <tr>
3416           <td class="paramkey"></td>
3417           <td></td>
3418           <td class="paramtype">uint32_t&#160;</td>
3419           <td class="paramname"><em>val2</em>&#160;</td>
3420         </tr>
3421         <tr>
3422           <td></td>
3423           <td>)</td>
3424           <td></td><td></td>
3425         </tr>
3426       </table>
3427 </div><div class="memdoc">
3428
3429 <p>Extracted 16-bit to 32-bit unsigned addition. </p>
3430 <p>This function enables you to extract two 8-bit values from one operand, zero-extend them to 16 bits each, and add the results to two 16-bit values from another operand.</p>
3431 <dl class="params"><dt>Parameters</dt><dd>
3432   <table class="params">
3433     <tr><td class="paramname">val1</td><td>value added to the zero-extended to 16-bit values. </td></tr>
3434     <tr><td class="paramname">val2</td><td>two 8-bit values to be extracted and zero-extended.</td></tr>
3435   </table>
3436   </dd>
3437 </dl>
3438 <dl class="section return"><dt>Returns</dt><dd>the 8-bit values in <em>val2</em>, zero-extended to 16-bit values and added to <em>val1</em>.</dd></dl>
3439 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = ZeroExt(val2[7:0]   to 16 bits) + val1[15:0]</div>
3440 <div class="line">res[31:16] = ZeroExt(val2[31:16] to 16 bits) + val1[31:16]</div>
3441 </div><!-- fragment --> </dd></dl>
3442
3443 </div>
3444 </div>
3445 <a id="gab41d713653b16f8d9fef44d14e397228" name="gab41d713653b16f8d9fef44d14e397228"></a>
3446 <h2 class="memtitle"><span class="permalink"><a href="#gab41d713653b16f8d9fef44d14e397228">&#9670;&#160;</a></span>__UXTB16()</h2>
3447
3448 <div class="memitem">
3449 <div class="memproto">
3450       <table class="memname">
3451         <tr>
3452           <td class="memname">uint32_t __UXTB16 </td>
3453           <td>(</td>
3454           <td class="paramtype">uint32_t&#160;</td>
3455           <td class="paramname"><em>val</em></td><td>)</td>
3456           <td></td>
3457         </tr>
3458       </table>
3459 </div><div class="memdoc">
3460
3461 <p>Dual extract 8-bits and zero-extend to 16-bits. </p>
3462 <p>This function enables you to extract two 8-bit values from an operand and zero-extend them to 16 bits each.</p>
3463 <dl class="params"><dt>Parameters</dt><dd>
3464   <table class="params">
3465     <tr><td class="paramname">val</td><td>two 8-bit values in val[7:0] and val[23:16] to be sign-extended.</td></tr>
3466   </table>
3467   </dd>
3468 </dl>
3469 <dl class="section return"><dt>Returns</dt><dd>the 8-bit values zero-extended to 16-bit values. <ul>
3470 <li>zero-extended value of val[7:0] in the low halfword of the return value. </li>
3471 <li>zero-extended value of val[23:16] in the high halfword of the return value.</li>
3472 </ul>
3473 </dd></dl>
3474 <dl class="section user"><dt>Operation:</dt><dd><div class="fragment"><div class="line">res[15:0]  = ZeroExtended(val[7:0]  )</div>
3475 <div class="line">res[31:16] = ZeroExtended(val[23:16])</div>
3476 </div><!-- fragment --> </dd></dl>
3477
3478 </div>
3479 </div>
3480 </div><!-- contents -->
3481 </div><!-- doc-content -->
3482 <!-- start footer part -->
3483 <div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
3484   <ul>
3485     <li class="footer">
3486       <script type="text/javascript">
3487         <!--
3488         writeFooter.call(this);
3489         //-->
3490       </script> 
3491     </li>
3492   </ul>
3493 </div>
3494 </body>
3495 </html>