1 <!-- HTML header for doxygen 1.8.20-->
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">
5 <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
6 <meta http-equiv="X-UA-Compatible" content="IE=9"/>
7 <meta name="generator" content="Doxygen 1.9.4"/>
8 <meta name="viewport" content="width=device-width, initial-scale=1"/>
9 <title>Raspberry Pi Pico SDK: hardware_interp</title>
10 <!-- <link href="tabs.css" rel="stylesheet" type="text/css"/> -->
11 <script type="text/javascript" src="jquery.js"></script>
12 <script type="text/javascript" src="dynsections.js"></script>
13 <link href="navtree.css" rel="stylesheet" type="text/css"/>
14 <script type="text/javascript" src="resize.js"></script>
15 <script type="text/javascript" src="navtreedata.js"></script>
16 <script type="text/javascript" src="navtree.js"></script>
17 <link href="search/search.css" rel="stylesheet" type="text/css"/>
18 <script type="text/javascript" src="search/searchdata.js"></script>
19 <script type="text/javascript" src="search/search.js"></script>
20 <link href="https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500&display=swap" rel="stylesheet">
21 <link href="doxygen.css" rel="stylesheet" type="text/css" />
22 <link href="normalise.css" rel="stylesheet" type="text/css"/>
23 <link href="main.css" rel="stylesheet" type="text/css"/>
24 <link href="styles.css" rel="stylesheet" type="text/css"/>
27 <div class="navigation-mobile">
28 <div class="logo--mobile">
29 <a href="/"><img src="logo-mobile.svg" alt="Raspberry Pi"></a>
31 <div class="navigation-toggle">
32 <span class="line-1"></span>
36 <span class="line-3"></span>
39 <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
41 <a href="index.html"> <img src="logo.svg" alt="Raspberry Pi"></a>
42 <span style="display: inline-block; margin-top: 10px;">
46 <div class="navigation-footer">
47 <img src="logo-mobile.svg" alt="Raspberry Pi">
48 <a href="https://www.raspberrypi.com/" target="_blank">By Raspberry Pi Ltd</a>
50 <!-- <div class="search">
52 <input type="search" name="search" id="search" placeholder="Search">
53 <input type="submit" value="Search">
56 <!-- Generated by Doxygen 1.9.4 -->
57 <script type="text/javascript">
58 /* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
59 var searchBox = new SearchBox("searchBox", "search",'Search','.html');
62 <script type="text/javascript" src="menudata.js"></script>
63 <script type="text/javascript" src="menu.js"></script>
64 <script type="text/javascript">
65 /* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
67 initMenu('',true,false,'search.php','Search');
68 $(document).ready(function() { init_search(); });
72 <div id="main-nav"></div>
74 <div id="side-nav" class="ui-resizable side-nav-resizable">
76 <div id="nav-tree-contents">
77 <div id="nav-sync" class="sync"></div>
80 <div id="splitbar" style="-moz-user-select:none;"
81 class="ui-resizable-handle">
84 <script type="text/javascript">
85 /* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
86 $(document).ready(function(){initNavTree('group__hardware__interp.html',''); initResizable(); });
89 <div id="doc-content">
90 <!-- window showing the filter options -->
91 <div id="MSearchSelectWindow"
92 onmouseover="return searchBox.OnSearchSelectShow()"
93 onmouseout="return searchBox.OnSearchSelectHide()"
94 onkeydown="return searchBox.OnSearchSelectKey(event)">
97 <!-- iframe showing the search results (closed by default) -->
98 <div id="MSearchResultsWindow">
99 <iframe src="javascript:void(0)" frameborder="0"
100 name="MSearchResults" id="MSearchResults">
105 <div class="summary">
106 <a href="#groups">Modules</a> |
107 <a href="#func-members">Functions</a> </div>
108 <div class="headertitle"><div class="title">hardware_interp<div class="ingroups"><a class="el" href="group__hardware.html">Hardware APIs</a></div></div></div>
110 <div class="contents">
112 <p>Hardware Interpolator API.
113 <a href="#details">More...</a></p>
114 <table class="memberdecls">
115 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="groups" name="groups"></a>
116 Modules</h2></td></tr>
117 <tr class="memitem:group__interp__config"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="group__interp__config.html">interp_config</a></td></tr>
118 <tr class="memdesc:group__interp__config"><td class="mdescLeft"> </td><td class="mdescRight">Interpolator configuration. <br /></td></tr>
119 <tr class="separator:"><td class="memSeparator" colspan="2"> </td></tr>
120 </table><table class="memberdecls">
121 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a>
122 Functions</h2></td></tr>
123 <tr class="memitem:ga4bf868768cfc42e621211d9dea8cc9bf"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#ga4bf868768cfc42e621211d9dea8cc9bf">interp_claim_lane</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane)</td></tr>
124 <tr class="memdesc:ga4bf868768cfc42e621211d9dea8cc9bf"><td class="mdescLeft"> </td><td class="mdescRight">Claim the interpolator lane specified. <a href="group__hardware__interp.html#ga4bf868768cfc42e621211d9dea8cc9bf">More...</a><br /></td></tr>
125 <tr class="separator:ga4bf868768cfc42e621211d9dea8cc9bf"><td class="memSeparator" colspan="2"> </td></tr>
126 <tr class="memitem:ga7da3e2eec0075ae39bf648b6a3b6feb9"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#ga7da3e2eec0075ae39bf648b6a3b6feb9">interp_claim_lane_mask</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane_mask)</td></tr>
127 <tr class="memdesc:ga7da3e2eec0075ae39bf648b6a3b6feb9"><td class="mdescLeft"> </td><td class="mdescRight">Claim the interpolator lanes specified in the mask. <a href="group__hardware__interp.html#ga7da3e2eec0075ae39bf648b6a3b6feb9">More...</a><br /></td></tr>
128 <tr class="separator:ga7da3e2eec0075ae39bf648b6a3b6feb9"><td class="memSeparator" colspan="2"> </td></tr>
129 <tr class="memitem:ga47d82417be5f875a1060384eada84147"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#ga47d82417be5f875a1060384eada84147">interp_unclaim_lane</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane)</td></tr>
130 <tr class="memdesc:ga47d82417be5f875a1060384eada84147"><td class="mdescLeft"> </td><td class="mdescRight">Release a previously claimed interpolator lane. <a href="group__hardware__interp.html#ga47d82417be5f875a1060384eada84147">More...</a><br /></td></tr>
131 <tr class="separator:ga47d82417be5f875a1060384eada84147"><td class="memSeparator" colspan="2"> </td></tr>
132 <tr class="memitem:gaf5bfa88632de76db56f01e3f22d705e0"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#gaf5bfa88632de76db56f01e3f22d705e0">interp_lane_is_claimed</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane)</td></tr>
133 <tr class="memdesc:gaf5bfa88632de76db56f01e3f22d705e0"><td class="mdescLeft"> </td><td class="mdescRight">Determine if an interpolator lane is claimed. <a href="group__hardware__interp.html#gaf5bfa88632de76db56f01e3f22d705e0">More...</a><br /></td></tr>
134 <tr class="separator:gaf5bfa88632de76db56f01e3f22d705e0"><td class="memSeparator" colspan="2"> </td></tr>
135 <tr class="memitem:ga8b6dfe0f72bb43788ff10d25d6b17403"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#ga8b6dfe0f72bb43788ff10d25d6b17403">interp_unclaim_lane_mask</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane_mask)</td></tr>
136 <tr class="memdesc:ga8b6dfe0f72bb43788ff10d25d6b17403"><td class="mdescLeft"> </td><td class="mdescRight">Release previously claimed interpolator lanes. <a href="group__hardware__interp.html#ga8b6dfe0f72bb43788ff10d25d6b17403">More...</a><br /></td></tr>
137 <tr class="separator:ga8b6dfe0f72bb43788ff10d25d6b17403"><td class="memSeparator" colspan="2"> </td></tr>
138 <tr class="memitem:ga839a103a740e190e7dc1b1313afb11a3"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#ga839a103a740e190e7dc1b1313afb11a3">interp_set_force_bits</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane, uint bits)</td></tr>
139 <tr class="memdesc:ga839a103a740e190e7dc1b1313afb11a3"><td class="mdescLeft"> </td><td class="mdescRight">Directly set the force bits on a specified lane. <a href="group__hardware__interp.html#ga839a103a740e190e7dc1b1313afb11a3">More...</a><br /></td></tr>
140 <tr class="separator:ga839a103a740e190e7dc1b1313afb11a3"><td class="memSeparator" colspan="2"> </td></tr>
141 <tr class="memitem:ga87a06576cf02918ed74f15415b1517f2"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#ga87a06576cf02918ed74f15415b1517f2">interp_save</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, <a class="el" href="structinterp__hw__save__t.html">interp_hw_save_t</a> *saver)</td></tr>
142 <tr class="memdesc:ga87a06576cf02918ed74f15415b1517f2"><td class="mdescLeft"> </td><td class="mdescRight">Save the specified interpolator state. <a href="group__hardware__interp.html#ga87a06576cf02918ed74f15415b1517f2">More...</a><br /></td></tr>
143 <tr class="separator:ga87a06576cf02918ed74f15415b1517f2"><td class="memSeparator" colspan="2"> </td></tr>
144 <tr class="memitem:ga35e7824263e623c7e2d54a74b2631c61"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#ga35e7824263e623c7e2d54a74b2631c61">interp_restore</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, <a class="el" href="structinterp__hw__save__t.html">interp_hw_save_t</a> *saver)</td></tr>
145 <tr class="memdesc:ga35e7824263e623c7e2d54a74b2631c61"><td class="mdescLeft"> </td><td class="mdescRight">Restore an interpolator state. <a href="group__hardware__interp.html#ga35e7824263e623c7e2d54a74b2631c61">More...</a><br /></td></tr>
146 <tr class="separator:ga35e7824263e623c7e2d54a74b2631c61"><td class="memSeparator" colspan="2"> </td></tr>
147 <tr class="memitem:gaa213d0a845f57c719593fa8be01482f1"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#gaa213d0a845f57c719593fa8be01482f1">interp_set_base</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane, uint32_t val)</td></tr>
148 <tr class="memdesc:gaa213d0a845f57c719593fa8be01482f1"><td class="mdescLeft"> </td><td class="mdescRight">Sets the interpolator base register by lane. <a href="group__hardware__interp.html#gaa213d0a845f57c719593fa8be01482f1">More...</a><br /></td></tr>
149 <tr class="separator:gaa213d0a845f57c719593fa8be01482f1"><td class="memSeparator" colspan="2"> </td></tr>
150 <tr class="memitem:ga1d89466df907cb1515b639813ee34837"><td class="memItemLeft" align="right" valign="top">static uint32_t </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#ga1d89466df907cb1515b639813ee34837">interp_get_base</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane)</td></tr>
151 <tr class="memdesc:ga1d89466df907cb1515b639813ee34837"><td class="mdescLeft"> </td><td class="mdescRight">Gets the content of interpolator base register by lane. <a href="group__hardware__interp.html#ga1d89466df907cb1515b639813ee34837">More...</a><br /></td></tr>
152 <tr class="separator:ga1d89466df907cb1515b639813ee34837"><td class="memSeparator" colspan="2"> </td></tr>
153 <tr class="memitem:ga25479c3fa9137c52fc22c1c9a796ab93"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#ga25479c3fa9137c52fc22c1c9a796ab93">interp_set_base_both</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint32_t val)</td></tr>
154 <tr class="memdesc:ga25479c3fa9137c52fc22c1c9a796ab93"><td class="mdescLeft"> </td><td class="mdescRight">Sets the interpolator base registers simultaneously. <a href="group__hardware__interp.html#ga25479c3fa9137c52fc22c1c9a796ab93">More...</a><br /></td></tr>
155 <tr class="separator:ga25479c3fa9137c52fc22c1c9a796ab93"><td class="memSeparator" colspan="2"> </td></tr>
156 <tr class="memitem:gae544ffb8c39587a43e69e3644f6da5d2"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#gae544ffb8c39587a43e69e3644f6da5d2">interp_set_accumulator</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane, uint32_t val)</td></tr>
157 <tr class="memdesc:gae544ffb8c39587a43e69e3644f6da5d2"><td class="mdescLeft"> </td><td class="mdescRight">Sets the interpolator accumulator register by lane. <a href="group__hardware__interp.html#gae544ffb8c39587a43e69e3644f6da5d2">More...</a><br /></td></tr>
158 <tr class="separator:gae544ffb8c39587a43e69e3644f6da5d2"><td class="memSeparator" colspan="2"> </td></tr>
159 <tr class="memitem:gaae77d8dbe417020c1d707b05b6a164ae"><td class="memItemLeft" align="right" valign="top">static uint32_t </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#gaae77d8dbe417020c1d707b05b6a164ae">interp_get_accumulator</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane)</td></tr>
160 <tr class="memdesc:gaae77d8dbe417020c1d707b05b6a164ae"><td class="mdescLeft"> </td><td class="mdescRight">Gets the content of the interpolator accumulator register by lane. <a href="group__hardware__interp.html#gaae77d8dbe417020c1d707b05b6a164ae">More...</a><br /></td></tr>
161 <tr class="separator:gaae77d8dbe417020c1d707b05b6a164ae"><td class="memSeparator" colspan="2"> </td></tr>
162 <tr class="memitem:gaf831284340273ce3eb6b11974424dc1b"><td class="memItemLeft" align="right" valign="top">static uint32_t </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#gaf831284340273ce3eb6b11974424dc1b">interp_pop_lane_result</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane)</td></tr>
163 <tr class="memdesc:gaf831284340273ce3eb6b11974424dc1b"><td class="mdescLeft"> </td><td class="mdescRight">Read lane result, and write lane results to both accumulators to update the interpolator. <a href="group__hardware__interp.html#gaf831284340273ce3eb6b11974424dc1b">More...</a><br /></td></tr>
164 <tr class="separator:gaf831284340273ce3eb6b11974424dc1b"><td class="memSeparator" colspan="2"> </td></tr>
165 <tr class="memitem:gafc04844f6c02d3f942f8ee95fca144ef"><td class="memItemLeft" align="right" valign="top">static uint32_t </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#gafc04844f6c02d3f942f8ee95fca144ef">interp_peek_lane_result</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane)</td></tr>
166 <tr class="memdesc:gafc04844f6c02d3f942f8ee95fca144ef"><td class="mdescLeft"> </td><td class="mdescRight">Read lane result. <a href="group__hardware__interp.html#gafc04844f6c02d3f942f8ee95fca144ef">More...</a><br /></td></tr>
167 <tr class="separator:gafc04844f6c02d3f942f8ee95fca144ef"><td class="memSeparator" colspan="2"> </td></tr>
168 <tr class="memitem:gab438b641a65e536f3bcec411596988a2"><td class="memItemLeft" align="right" valign="top">static uint32_t </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#gab438b641a65e536f3bcec411596988a2">interp_pop_full_result</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp)</td></tr>
169 <tr class="memdesc:gab438b641a65e536f3bcec411596988a2"><td class="mdescLeft"> </td><td class="mdescRight">Read lane result, and write lane results to both accumulators to update the interpolator. <a href="group__hardware__interp.html#gab438b641a65e536f3bcec411596988a2">More...</a><br /></td></tr>
170 <tr class="separator:gab438b641a65e536f3bcec411596988a2"><td class="memSeparator" colspan="2"> </td></tr>
171 <tr class="memitem:gaadc9a108c4c4c0255062b56967c157cc"><td class="memItemLeft" align="right" valign="top">static uint32_t </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#gaadc9a108c4c4c0255062b56967c157cc">interp_peek_full_result</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp)</td></tr>
172 <tr class="memdesc:gaadc9a108c4c4c0255062b56967c157cc"><td class="mdescLeft"> </td><td class="mdescRight">Read lane result. <a href="group__hardware__interp.html#gaadc9a108c4c4c0255062b56967c157cc">More...</a><br /></td></tr>
173 <tr class="separator:gaadc9a108c4c4c0255062b56967c157cc"><td class="memSeparator" colspan="2"> </td></tr>
174 <tr class="memitem:gae90bdfe6d73365cf3bed859ca288f928"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#gae90bdfe6d73365cf3bed859ca288f928">interp_add_accumulater</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane, uint32_t val)</td></tr>
175 <tr class="memdesc:gae90bdfe6d73365cf3bed859ca288f928"><td class="mdescLeft"> </td><td class="mdescRight">Add to accumulator. <a href="group__hardware__interp.html#gae90bdfe6d73365cf3bed859ca288f928">More...</a><br /></td></tr>
176 <tr class="separator:gae90bdfe6d73365cf3bed859ca288f928"><td class="memSeparator" colspan="2"> </td></tr>
177 <tr class="memitem:ga20a0a099084a94e006e68f555685421a"><td class="memItemLeft" align="right" valign="top">static uint32_t </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__interp.html#ga20a0a099084a94e006e68f555685421a">interp_get_raw</a> (<a class="el" href="structinterp__hw__t.html">interp_hw_t</a> *interp, uint lane)</td></tr>
178 <tr class="memdesc:ga20a0a099084a94e006e68f555685421a"><td class="mdescLeft"> </td><td class="mdescRight">Get raw lane value. <a href="group__hardware__interp.html#ga20a0a099084a94e006e68f555685421a">More...</a><br /></td></tr>
179 <tr class="separator:ga20a0a099084a94e006e68f555685421a"><td class="memSeparator" colspan="2"> </td></tr>
181 <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
182 <p >Hardware Interpolator API. </p>
183 <p >Each core is equipped with two interpolators (INTERP0 and INTERP1) which can be used to accelerate tasks by combining certain pre-configured simple operations into a single processor cycle. Intended for cases where the pre-configured operation is repeated a large number of times, this results in code which uses both fewer CPU cycles and fewer CPU registers in the time critical sections of the code.</p>
184 <p >The interpolators are used heavily to accelerate audio operations within the SDK, but their flexible configuration make it possible to optimise many other tasks such as quantization and dithering, table lookup address generation, affine texture mapping, decompression and linear feedback.</p>
185 <p >Please refer to the appropriate RP-series microcontroller datasheet for more information on the HW interpolators and how they work. </p>
186 <h2 class="groupheader">Function Documentation</h2>
187 <a id="gae90bdfe6d73365cf3bed859ca288f928" name="gae90bdfe6d73365cf3bed859ca288f928"></a>
188 <h2 class="memtitle"><span class="permalink"><a href="#gae90bdfe6d73365cf3bed859ca288f928">◆ </a></span>interp_add_accumulater()</h2>
190 <div class="memitem">
191 <div class="memproto">
192 <table class="mlabels">
194 <td class="mlabels-left">
195 <table class="memname">
197 <td class="memname">static void interp_add_accumulater </td>
199 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
200 <td class="paramname"><em>interp</em>, </td>
203 <td class="paramkey"></td>
205 <td class="paramtype">uint </td>
206 <td class="paramname"><em>lane</em>, </td>
209 <td class="paramkey"></td>
211 <td class="paramtype">uint32_t </td>
212 <td class="paramname"><em>val</em> </td>
221 <td class="mlabels-right">
222 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
225 </div><div class="memdoc">
227 <p>Add to accumulator. </p>
228 <p >Atomically add the specified value to the accumulator on the specified lane</p>
229 <dl class="params"><dt>Parameters</dt><dd>
230 <table class="params">
231 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
232 <tr><td class="paramname">lane</td><td>The lane number, 0 or 1 </td></tr>
233 <tr><td class="paramname">val</td><td>Value to add </td></tr>
240 <a id="ga4bf868768cfc42e621211d9dea8cc9bf" name="ga4bf868768cfc42e621211d9dea8cc9bf"></a>
241 <h2 class="memtitle"><span class="permalink"><a href="#ga4bf868768cfc42e621211d9dea8cc9bf">◆ </a></span>interp_claim_lane()</h2>
243 <div class="memitem">
244 <div class="memproto">
245 <table class="memname">
247 <td class="memname">void interp_claim_lane </td>
249 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
250 <td class="paramname"><em>interp</em>, </td>
253 <td class="paramkey"></td>
255 <td class="paramtype">uint </td>
256 <td class="paramname"><em>lane</em> </td>
264 </div><div class="memdoc">
266 <p>Claim the interpolator lane specified. </p>
267 <p >Use this function to claim exclusive access to the specified interpolator lane.</p>
268 <p >This function will panic if the lane is already claimed.</p>
269 <dl class="params"><dt>Parameters</dt><dd>
270 <table class="params">
271 <tr><td class="paramname">interp</td><td>Interpolator on which to claim a lane. interp0 or interp1 </td></tr>
272 <tr><td class="paramname">lane</td><td>The lane number, 0 or 1. </td></tr>
279 <a id="ga7da3e2eec0075ae39bf648b6a3b6feb9" name="ga7da3e2eec0075ae39bf648b6a3b6feb9"></a>
280 <h2 class="memtitle"><span class="permalink"><a href="#ga7da3e2eec0075ae39bf648b6a3b6feb9">◆ </a></span>interp_claim_lane_mask()</h2>
282 <div class="memitem">
283 <div class="memproto">
284 <table class="memname">
286 <td class="memname">void interp_claim_lane_mask </td>
288 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
289 <td class="paramname"><em>interp</em>, </td>
292 <td class="paramkey"></td>
294 <td class="paramtype">uint </td>
295 <td class="paramname"><em>lane_mask</em> </td>
303 </div><div class="memdoc">
305 <p>Claim the interpolator lanes specified in the mask. </p>
306 <dl class="params"><dt>Parameters</dt><dd>
307 <table class="params">
308 <tr><td class="paramname">interp</td><td>Interpolator on which to claim lanes. interp0 or interp1 </td></tr>
309 <tr><td class="paramname">lane_mask</td><td>Bit pattern of lanes to claim (only bits 0 and 1 are valid) </td></tr>
316 <a id="gaae77d8dbe417020c1d707b05b6a164ae" name="gaae77d8dbe417020c1d707b05b6a164ae"></a>
317 <h2 class="memtitle"><span class="permalink"><a href="#gaae77d8dbe417020c1d707b05b6a164ae">◆ </a></span>interp_get_accumulator()</h2>
319 <div class="memitem">
320 <div class="memproto">
321 <table class="mlabels">
323 <td class="mlabels-left">
324 <table class="memname">
326 <td class="memname">static uint32_t interp_get_accumulator </td>
328 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
329 <td class="paramname"><em>interp</em>, </td>
332 <td class="paramkey"></td>
334 <td class="paramtype">uint </td>
335 <td class="paramname"><em>lane</em> </td>
344 <td class="mlabels-right">
345 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
348 </div><div class="memdoc">
350 <p>Gets the content of the interpolator accumulator register by lane. </p>
351 <dl class="params"><dt>Parameters</dt><dd>
352 <table class="params">
353 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
354 <tr><td class="paramname">lane</td><td>The lane number, 0 or 1 </td></tr>
358 <dl class="section return"><dt>Returns</dt><dd>The current content of the register </dd></dl>
362 <a id="ga1d89466df907cb1515b639813ee34837" name="ga1d89466df907cb1515b639813ee34837"></a>
363 <h2 class="memtitle"><span class="permalink"><a href="#ga1d89466df907cb1515b639813ee34837">◆ </a></span>interp_get_base()</h2>
365 <div class="memitem">
366 <div class="memproto">
367 <table class="mlabels">
369 <td class="mlabels-left">
370 <table class="memname">
372 <td class="memname">static uint32_t interp_get_base </td>
374 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
375 <td class="paramname"><em>interp</em>, </td>
378 <td class="paramkey"></td>
380 <td class="paramtype">uint </td>
381 <td class="paramname"><em>lane</em> </td>
390 <td class="mlabels-right">
391 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
394 </div><div class="memdoc">
396 <p>Gets the content of interpolator base register by lane. </p>
397 <dl class="params"><dt>Parameters</dt><dd>
398 <table class="params">
399 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
400 <tr><td class="paramname">lane</td><td>The lane number, 0 or 1 or 2 </td></tr>
404 <dl class="section return"><dt>Returns</dt><dd>The current content of the lane base register </dd></dl>
408 <a id="ga20a0a099084a94e006e68f555685421a" name="ga20a0a099084a94e006e68f555685421a"></a>
409 <h2 class="memtitle"><span class="permalink"><a href="#ga20a0a099084a94e006e68f555685421a">◆ </a></span>interp_get_raw()</h2>
411 <div class="memitem">
412 <div class="memproto">
413 <table class="mlabels">
415 <td class="mlabels-left">
416 <table class="memname">
418 <td class="memname">static uint32_t interp_get_raw </td>
420 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
421 <td class="paramname"><em>interp</em>, </td>
424 <td class="paramkey"></td>
426 <td class="paramtype">uint </td>
427 <td class="paramname"><em>lane</em> </td>
436 <td class="mlabels-right">
437 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
440 </div><div class="memdoc">
442 <p>Get raw lane value. </p>
443 <p >Returns the raw shift and mask value from the specified lane, BASE0 is NOT added</p>
444 <dl class="params"><dt>Parameters</dt><dd>
445 <table class="params">
446 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
447 <tr><td class="paramname">lane</td><td>The lane number, 0 or 1 </td></tr>
451 <dl class="section return"><dt>Returns</dt><dd>The raw shift/mask value </dd></dl>
455 <a id="gaf5bfa88632de76db56f01e3f22d705e0" name="gaf5bfa88632de76db56f01e3f22d705e0"></a>
456 <h2 class="memtitle"><span class="permalink"><a href="#gaf5bfa88632de76db56f01e3f22d705e0">◆ </a></span>interp_lane_is_claimed()</h2>
458 <div class="memitem">
459 <div class="memproto">
460 <table class="memname">
462 <td class="memname">bool interp_lane_is_claimed </td>
464 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
465 <td class="paramname"><em>interp</em>, </td>
468 <td class="paramkey"></td>
470 <td class="paramtype">uint </td>
471 <td class="paramname"><em>lane</em> </td>
479 </div><div class="memdoc">
481 <p>Determine if an interpolator lane is claimed. </p>
482 <dl class="params"><dt>Parameters</dt><dd>
483 <table class="params">
484 <tr><td class="paramname">interp</td><td>Interpolator whose lane to check </td></tr>
485 <tr><td class="paramname">lane</td><td>The lane number, 0 or 1 </td></tr>
489 <dl class="section return"><dt>Returns</dt><dd>true if claimed, false otherwise </dd></dl>
490 <dl class="section see"><dt>See also</dt><dd><a class="el" href="group__hardware__interp.html#ga4bf868768cfc42e621211d9dea8cc9bf" title="Claim the interpolator lane specified.">interp_claim_lane</a> </dd>
492 <a class="el" href="group__hardware__interp.html#ga7da3e2eec0075ae39bf648b6a3b6feb9" title="Claim the interpolator lanes specified in the mask.">interp_claim_lane_mask</a> </dd></dl>
496 <a id="gaadc9a108c4c4c0255062b56967c157cc" name="gaadc9a108c4c4c0255062b56967c157cc"></a>
497 <h2 class="memtitle"><span class="permalink"><a href="#gaadc9a108c4c4c0255062b56967c157cc">◆ </a></span>interp_peek_full_result()</h2>
499 <div class="memitem">
500 <div class="memproto">
501 <table class="mlabels">
503 <td class="mlabels-left">
504 <table class="memname">
506 <td class="memname">static uint32_t interp_peek_full_result </td>
508 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
509 <td class="paramname"><em>interp</em></td><td>)</td>
514 <td class="mlabels-right">
515 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
518 </div><div class="memdoc">
520 <p>Read lane result. </p>
521 <dl class="params"><dt>Parameters</dt><dd>
522 <table class="params">
523 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
527 <dl class="section return"><dt>Returns</dt><dd>The content of the FULL register </dd></dl>
531 <a id="gafc04844f6c02d3f942f8ee95fca144ef" name="gafc04844f6c02d3f942f8ee95fca144ef"></a>
532 <h2 class="memtitle"><span class="permalink"><a href="#gafc04844f6c02d3f942f8ee95fca144ef">◆ </a></span>interp_peek_lane_result()</h2>
534 <div class="memitem">
535 <div class="memproto">
536 <table class="mlabels">
538 <td class="mlabels-left">
539 <table class="memname">
541 <td class="memname">static uint32_t interp_peek_lane_result </td>
543 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
544 <td class="paramname"><em>interp</em>, </td>
547 <td class="paramkey"></td>
549 <td class="paramtype">uint </td>
550 <td class="paramname"><em>lane</em> </td>
559 <td class="mlabels-right">
560 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
563 </div><div class="memdoc">
565 <p>Read lane result. </p>
566 <dl class="params"><dt>Parameters</dt><dd>
567 <table class="params">
568 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
569 <tr><td class="paramname">lane</td><td>The lane number, 0 or 1 </td></tr>
573 <dl class="section return"><dt>Returns</dt><dd>The content of the lane result register </dd></dl>
577 <a id="gab438b641a65e536f3bcec411596988a2" name="gab438b641a65e536f3bcec411596988a2"></a>
578 <h2 class="memtitle"><span class="permalink"><a href="#gab438b641a65e536f3bcec411596988a2">◆ </a></span>interp_pop_full_result()</h2>
580 <div class="memitem">
581 <div class="memproto">
582 <table class="mlabels">
584 <td class="mlabels-left">
585 <table class="memname">
587 <td class="memname">static uint32_t interp_pop_full_result </td>
589 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
590 <td class="paramname"><em>interp</em></td><td>)</td>
595 <td class="mlabels-right">
596 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
599 </div><div class="memdoc">
601 <p>Read lane result, and write lane results to both accumulators to update the interpolator. </p>
602 <dl class="params"><dt>Parameters</dt><dd>
603 <table class="params">
604 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
608 <dl class="section return"><dt>Returns</dt><dd>The content of the FULL register </dd></dl>
612 <a id="gaf831284340273ce3eb6b11974424dc1b" name="gaf831284340273ce3eb6b11974424dc1b"></a>
613 <h2 class="memtitle"><span class="permalink"><a href="#gaf831284340273ce3eb6b11974424dc1b">◆ </a></span>interp_pop_lane_result()</h2>
615 <div class="memitem">
616 <div class="memproto">
617 <table class="mlabels">
619 <td class="mlabels-left">
620 <table class="memname">
622 <td class="memname">static uint32_t interp_pop_lane_result </td>
624 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
625 <td class="paramname"><em>interp</em>, </td>
628 <td class="paramkey"></td>
630 <td class="paramtype">uint </td>
631 <td class="paramname"><em>lane</em> </td>
640 <td class="mlabels-right">
641 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
644 </div><div class="memdoc">
646 <p>Read lane result, and write lane results to both accumulators to update the interpolator. </p>
647 <dl class="params"><dt>Parameters</dt><dd>
648 <table class="params">
649 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
650 <tr><td class="paramname">lane</td><td>The lane number, 0 or 1 </td></tr>
654 <dl class="section return"><dt>Returns</dt><dd>The content of the lane result register </dd></dl>
658 <a id="ga35e7824263e623c7e2d54a74b2631c61" name="ga35e7824263e623c7e2d54a74b2631c61"></a>
659 <h2 class="memtitle"><span class="permalink"><a href="#ga35e7824263e623c7e2d54a74b2631c61">◆ </a></span>interp_restore()</h2>
661 <div class="memitem">
662 <div class="memproto">
663 <table class="memname">
665 <td class="memname">void interp_restore </td>
667 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
668 <td class="paramname"><em>interp</em>, </td>
671 <td class="paramkey"></td>
673 <td class="paramtype"><a class="el" href="structinterp__hw__save__t.html">interp_hw_save_t</a> * </td>
674 <td class="paramname"><em>saver</em> </td>
682 </div><div class="memdoc">
684 <p>Restore an interpolator state. </p>
685 <dl class="params"><dt>Parameters</dt><dd>
686 <table class="params">
687 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
688 <tr><td class="paramname">saver</td><td>Pointer to save structure to reapply to the specified interpolator </td></tr>
695 <a id="ga87a06576cf02918ed74f15415b1517f2" name="ga87a06576cf02918ed74f15415b1517f2"></a>
696 <h2 class="memtitle"><span class="permalink"><a href="#ga87a06576cf02918ed74f15415b1517f2">◆ </a></span>interp_save()</h2>
698 <div class="memitem">
699 <div class="memproto">
700 <table class="memname">
702 <td class="memname">void interp_save </td>
704 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
705 <td class="paramname"><em>interp</em>, </td>
708 <td class="paramkey"></td>
710 <td class="paramtype"><a class="el" href="structinterp__hw__save__t.html">interp_hw_save_t</a> * </td>
711 <td class="paramname"><em>saver</em> </td>
719 </div><div class="memdoc">
721 <p>Save the specified interpolator state. </p>
722 <p >Can be used to save state if you need an interpolator for another purpose, state can then be recovered afterwards and continue from that point</p>
723 <dl class="params"><dt>Parameters</dt><dd>
724 <table class="params">
725 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
726 <tr><td class="paramname">saver</td><td>Pointer to the save structure to fill in </td></tr>
733 <a id="gae544ffb8c39587a43e69e3644f6da5d2" name="gae544ffb8c39587a43e69e3644f6da5d2"></a>
734 <h2 class="memtitle"><span class="permalink"><a href="#gae544ffb8c39587a43e69e3644f6da5d2">◆ </a></span>interp_set_accumulator()</h2>
736 <div class="memitem">
737 <div class="memproto">
738 <table class="mlabels">
740 <td class="mlabels-left">
741 <table class="memname">
743 <td class="memname">static void interp_set_accumulator </td>
745 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
746 <td class="paramname"><em>interp</em>, </td>
749 <td class="paramkey"></td>
751 <td class="paramtype">uint </td>
752 <td class="paramname"><em>lane</em>, </td>
755 <td class="paramkey"></td>
757 <td class="paramtype">uint32_t </td>
758 <td class="paramname"><em>val</em> </td>
767 <td class="mlabels-right">
768 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
771 </div><div class="memdoc">
773 <p>Sets the interpolator accumulator register by lane. </p>
774 <dl class="params"><dt>Parameters</dt><dd>
775 <table class="params">
776 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
777 <tr><td class="paramname">lane</td><td>The lane number, 0 or 1 </td></tr>
778 <tr><td class="paramname">val</td><td>The value to apply to the register </td></tr>
785 <a id="gaa213d0a845f57c719593fa8be01482f1" name="gaa213d0a845f57c719593fa8be01482f1"></a>
786 <h2 class="memtitle"><span class="permalink"><a href="#gaa213d0a845f57c719593fa8be01482f1">◆ </a></span>interp_set_base()</h2>
788 <div class="memitem">
789 <div class="memproto">
790 <table class="mlabels">
792 <td class="mlabels-left">
793 <table class="memname">
795 <td class="memname">static void interp_set_base </td>
797 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
798 <td class="paramname"><em>interp</em>, </td>
801 <td class="paramkey"></td>
803 <td class="paramtype">uint </td>
804 <td class="paramname"><em>lane</em>, </td>
807 <td class="paramkey"></td>
809 <td class="paramtype">uint32_t </td>
810 <td class="paramname"><em>val</em> </td>
819 <td class="mlabels-right">
820 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
823 </div><div class="memdoc">
825 <p>Sets the interpolator base register by lane. </p>
826 <dl class="params"><dt>Parameters</dt><dd>
827 <table class="params">
828 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
829 <tr><td class="paramname">lane</td><td>The lane number, 0 or 1 or 2 </td></tr>
830 <tr><td class="paramname">val</td><td>The value to apply to the register </td></tr>
837 <a id="ga25479c3fa9137c52fc22c1c9a796ab93" name="ga25479c3fa9137c52fc22c1c9a796ab93"></a>
838 <h2 class="memtitle"><span class="permalink"><a href="#ga25479c3fa9137c52fc22c1c9a796ab93">◆ </a></span>interp_set_base_both()</h2>
840 <div class="memitem">
841 <div class="memproto">
842 <table class="mlabels">
844 <td class="mlabels-left">
845 <table class="memname">
847 <td class="memname">static void interp_set_base_both </td>
849 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
850 <td class="paramname"><em>interp</em>, </td>
853 <td class="paramkey"></td>
855 <td class="paramtype">uint32_t </td>
856 <td class="paramname"><em>val</em> </td>
865 <td class="mlabels-right">
866 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
869 </div><div class="memdoc">
871 <p>Sets the interpolator base registers simultaneously. </p>
872 <p >The lower 16 bits go to BASE0, upper bits to BASE1 simultaneously. Each half is sign-extended to 32 bits if that lane’s SIGNED flag is set.</p>
873 <dl class="params"><dt>Parameters</dt><dd>
874 <table class="params">
875 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
876 <tr><td class="paramname">val</td><td>The value to apply to the register </td></tr>
883 <a id="ga839a103a740e190e7dc1b1313afb11a3" name="ga839a103a740e190e7dc1b1313afb11a3"></a>
884 <h2 class="memtitle"><span class="permalink"><a href="#ga839a103a740e190e7dc1b1313afb11a3">◆ </a></span>interp_set_force_bits()</h2>
886 <div class="memitem">
887 <div class="memproto">
888 <table class="mlabels">
890 <td class="mlabels-left">
891 <table class="memname">
893 <td class="memname">static void interp_set_force_bits </td>
895 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
896 <td class="paramname"><em>interp</em>, </td>
899 <td class="paramkey"></td>
901 <td class="paramtype">uint </td>
902 <td class="paramname"><em>lane</em>, </td>
905 <td class="paramkey"></td>
907 <td class="paramtype">uint </td>
908 <td class="paramname"><em>bits</em> </td>
917 <td class="mlabels-right">
918 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
921 </div><div class="memdoc">
923 <p>Directly set the force bits on a specified lane. </p>
924 <p >These bits are ORed into bits 29:28 of the lane result presented to the processor on the bus. There is no effect on the internal 32-bit datapath.</p>
925 <p >Useful for using a lane to generate sequence of pointers into flash or SRAM, saving a subsequent OR or add operation.</p>
926 <dl class="params"><dt>Parameters</dt><dd>
927 <table class="params">
928 <tr><td class="paramname">interp</td><td>Interpolator instance, interp0 or interp1. </td></tr>
929 <tr><td class="paramname">lane</td><td>The lane to set </td></tr>
930 <tr><td class="paramname">bits</td><td>The bits to set (bits 0 and 1, value range 0-3) </td></tr>
937 <a id="ga47d82417be5f875a1060384eada84147" name="ga47d82417be5f875a1060384eada84147"></a>
938 <h2 class="memtitle"><span class="permalink"><a href="#ga47d82417be5f875a1060384eada84147">◆ </a></span>interp_unclaim_lane()</h2>
940 <div class="memitem">
941 <div class="memproto">
942 <table class="memname">
944 <td class="memname">void interp_unclaim_lane </td>
946 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
947 <td class="paramname"><em>interp</em>, </td>
950 <td class="paramkey"></td>
952 <td class="paramtype">uint </td>
953 <td class="paramname"><em>lane</em> </td>
961 </div><div class="memdoc">
963 <p>Release a previously claimed interpolator lane. </p>
964 <dl class="params"><dt>Parameters</dt><dd>
965 <table class="params">
966 <tr><td class="paramname">interp</td><td>Interpolator on which to release a lane. interp0 or interp1 </td></tr>
967 <tr><td class="paramname">lane</td><td>The lane number, 0 or 1 </td></tr>
974 <a id="ga8b6dfe0f72bb43788ff10d25d6b17403" name="ga8b6dfe0f72bb43788ff10d25d6b17403"></a>
975 <h2 class="memtitle"><span class="permalink"><a href="#ga8b6dfe0f72bb43788ff10d25d6b17403">◆ </a></span>interp_unclaim_lane_mask()</h2>
977 <div class="memitem">
978 <div class="memproto">
979 <table class="memname">
981 <td class="memname">void interp_unclaim_lane_mask </td>
983 <td class="paramtype"><a class="el" href="structinterp__hw__t.html">interp_hw_t</a> * </td>
984 <td class="paramname"><em>interp</em>, </td>
987 <td class="paramkey"></td>
989 <td class="paramtype">uint </td>
990 <td class="paramname"><em>lane_mask</em> </td>
998 </div><div class="memdoc">
1000 <p>Release previously claimed interpolator lanes. </p>
1001 <dl class="section see"><dt>See also</dt><dd><a class="el" href="group__hardware__interp.html#ga7da3e2eec0075ae39bf648b6a3b6feb9" title="Claim the interpolator lanes specified in the mask.">interp_claim_lane_mask</a></dd></dl>
1002 <dl class="params"><dt>Parameters</dt><dd>
1003 <table class="params">
1004 <tr><td class="paramname">interp</td><td>Interpolator on which to release lanes. interp0 or interp1 </td></tr>
1005 <tr><td class="paramname">lane_mask</td><td>Bit pattern of lanes to unclaim (only bits 0 and 1 are valid) </td></tr>
1012 </div><!-- contents -->
1013 </div><!-- doc-content -->
1015 <script src="main.js"></script>