/drivers/usb/host/dwc_otg/doc/html/dwc__otg__cfi_8c-source.html
HTML | 1724 lines | 1723 code | 0 blank | 1 comment | 0 complexity | e51da8899b86c7babf080e9dc5e557cf MD5 | raw file
Possible License(s): GPL-2.0, LGPL-2.0, AGPL-1.0
Large files files are truncated, but you can click here to view the full file
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
- <html><head><meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1">
- <title>DesignWare USB 2.0 OTG Controller (DWC_otg) Device Driver: dwc_otg_cfi.c Source File</title>
- <link href="doxygen.css" rel="stylesheet" type="text/css">
- <link href="tabs.css" rel="stylesheet" type="text/css">
- </head><body>
- <!-- Generated by Doxygen 1.4.7 -->
- <div class="tabs">
- <ul>
- <li><a href="main.html"><span>Main Page</span></a></li>
- <li><a href="annotated.html"><span>Data Structures</span></a></li>
- <li id="current"><a href="files.html"><span>Files</span></a></li>
- <li><a href="pages.html"><span>Related Pages</span></a></li>
- </ul></div>
- <div class="tabs">
- <ul>
- <li><a href="files.html"><span>File List</span></a></li>
- <li><a href="globals.html"><span>Globals</span></a></li>
- </ul></div>
- <h1>dwc_otg_cfi.c</h1><a href="dwc__otg__cfi_8c.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/* ==========================================================================</span>
- <a name="l00002"></a>00002 <span class="comment"> * Synopsys HS OTG Linux Software Driver and documentation (hereinafter,</span>
- <a name="l00003"></a>00003 <span class="comment"> * "Software") is an Unsupported proprietary work of Synopsys, Inc. unless</span>
- <a name="l00004"></a>00004 <span class="comment"> * otherwise expressly agreed to in writing between Synopsys and you.</span>
- <a name="l00005"></a>00005 <span class="comment"> * </span>
- <a name="l00006"></a>00006 <span class="comment"> * The Software IS NOT an item of Licensed Software or Licensed Product under</span>
- <a name="l00007"></a>00007 <span class="comment"> * any End User Software License Agreement or Agreement for Licensed Product</span>
- <a name="l00008"></a>00008 <span class="comment"> * with Synopsys or any supplement thereto. You are permitted to use and</span>
- <a name="l00009"></a>00009 <span class="comment"> * redistribute this Software in source and binary forms, with or without</span>
- <a name="l00010"></a>00010 <span class="comment"> * modification, provided that redistributions of source code must retain this</span>
- <a name="l00011"></a>00011 <span class="comment"> * notice. You may not view, use, disclose, copy or distribute this file or</span>
- <a name="l00012"></a>00012 <span class="comment"> * any information contained herein except pursuant to this license grant from</span>
- <a name="l00013"></a>00013 <span class="comment"> * Synopsys. If you do not agree with this notice, including the disclaimer</span>
- <a name="l00014"></a>00014 <span class="comment"> * below, then you are not authorized to use the Software.</span>
- <a name="l00015"></a>00015 <span class="comment"> * </span>
- <a name="l00016"></a>00016 <span class="comment"> * THIS SOFTWARE IS BEING DISTRIBUTED BY SYNOPSYS SOLELY ON AN "AS IS" BASIS</span>
- <a name="l00017"></a>00017 <span class="comment"> * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE</span>
- <a name="l00018"></a>00018 <span class="comment"> * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE</span>
- <a name="l00019"></a>00019 <span class="comment"> * ARE HEREBY DISCLAIMED. IN NO EVENT SHALL SYNOPSYS BE LIABLE FOR ANY DIRECT,</span>
- <a name="l00020"></a>00020 <span class="comment"> * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES</span>
- <a name="l00021"></a>00021 <span class="comment"> * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR</span>
- <a name="l00022"></a>00022 <span class="comment"> * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER</span>
- <a name="l00023"></a>00023 <span class="comment"> * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT</span>
- <a name="l00024"></a>00024 <span class="comment"> * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY</span>
- <a name="l00025"></a>00025 <span class="comment"> * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH</span>
- <a name="l00026"></a>00026 <span class="comment"> * DAMAGE.</span>
- <a name="l00027"></a>00027 <span class="comment"> * ========================================================================== */</span>
- <a name="l00028"></a>00028
- <a name="l00034"></a>00034 <span class="preprocessor">#ifdef DWC_UTE_CFI</span>
- <a name="l00035"></a>00035 <span class="preprocessor"></span>
- <a name="l00036"></a>00036 <span class="preprocessor">#include "<a class="code" href="dwc__otg__pcd_8h.html">dwc_otg_pcd.h</a>"</span>
- <a name="l00037"></a>00037 <span class="preprocessor">#include "<a class="code" href="dwc__otg__cfi_8h.html">dwc_otg_cfi.h</a>"</span>
- <a name="l00038"></a>00038
- <a name="l00040"></a>00040 <span class="preprocessor">#define DWC_CONSTANT_CPU_TO_LE16(x) (x)</span>
- <a name="l00041"></a>00041 <span class="preprocessor"></span>
- <a name="l00042"></a>00042 <span class="keyword">extern</span> <a class="code" href="structdwc__otg__pcd__ep.html">dwc_otg_pcd_ep_t</a> *<a class="code" href="dwc__otg__pcd__intr_8c.html#3c351d7f51d6242296d6ea3bb1a9775c">get_ep_by_addr</a>(<a class="code" href="structdwc__otg__pcd.html">dwc_otg_pcd_t</a> * pcd, u16 wIndex);
- <a name="l00043"></a>00043
- <a name="l00044"></a>00044 <span class="keyword">static</span> <span class="keywordtype">int</span> cfi_core_features_buf(uint8_t * buf, uint16_t buflen);
- <a name="l00045"></a>00045 <span class="keyword">static</span> <span class="keywordtype">int</span> cfi_get_feature_value(uint8_t * buf, uint16_t buflen,
- <a name="l00046"></a>00046 <span class="keyword">struct</span> <a class="code" href="structdwc__otg__pcd.html">dwc_otg_pcd</a> *pcd,
- <a name="l00047"></a>00047 <span class="keyword">struct</span> <a class="code" href="structcfi__usb__ctrlrequest.html">cfi_usb_ctrlrequest</a> *ctrl_req);
- <a name="l00048"></a>00048 <span class="keyword">static</span> <span class="keywordtype">int</span> cfi_set_feature_value(<span class="keyword">struct</span> <a class="code" href="structdwc__otg__pcd.html">dwc_otg_pcd</a> *pcd);
- <a name="l00049"></a>00049 <span class="keyword">static</span> <span class="keywordtype">int</span> cfi_ep_get_sg_val(uint8_t * buf, <span class="keyword">struct</span> <a class="code" href="structdwc__otg__pcd.html">dwc_otg_pcd</a> *pcd,
- <a name="l00050"></a>00050 <span class="keyword">struct</span> <a class="code" href="structcfi__usb__ctrlrequest.html">cfi_usb_ctrlrequest</a> *req);
- <a name="l00051"></a>00051 <span class="keyword">static</span> <span class="keywordtype">int</span> cfi_ep_get_concat_val(uint8_t * buf, <span class="keyword">struct</span> <a class="code" href="structdwc__otg__pcd.html">dwc_otg_pcd</a> *pcd,
- <a name="l00052"></a>00052 <span class="keyword">struct</span> <a class="code" href="structcfi__usb__ctrlrequest.html">cfi_usb_ctrlrequest</a> *req);
- <a name="l00053"></a>00053 <span class="keyword">static</span> <span class="keywordtype">int</span> cfi_ep_get_align_val(uint8_t * buf, <span class="keyword">struct</span> <a class="code" href="structdwc__otg__pcd.html">dwc_otg_pcd</a> *pcd,
- <a name="l00054"></a>00054 <span class="keyword">struct</span> <a class="code" href="structcfi__usb__ctrlrequest.html">cfi_usb_ctrlrequest</a> *req);
- <a name="l00055"></a>00055 <span class="keyword">static</span> <span class="keywordtype">int</span> cfi_preproc_reset(<span class="keyword">struct</span> <a class="code" href="structdwc__otg__pcd.html">dwc_otg_pcd</a> *pcd,
- <a name="l00056"></a>00056 <span class="keyword">struct</span> <a class="code" href="structcfi__usb__ctrlrequest.html">cfi_usb_ctrlrequest</a> *req);
- <a name="l00057"></a>00057 <span class="keyword">static</span> <span class="keywordtype">void</span> cfi_free_ep_bs_dyn_data(<a class="code" href="structcfi__ep.html">cfi_ep_t</a> * cfiep);
- <a name="l00058"></a>00058
- <a name="l00059"></a>00059 <span class="keyword">static</span> uint16_t get_dfifo_size(<a class="code" href="structdwc__otg__core__if.html">dwc_otg_core_if_t</a> * core_if);
- <a name="l00060"></a>00060 <span class="keyword">static</span> int32_t get_rxfifo_size(<a class="code" href="structdwc__otg__core__if.html">dwc_otg_core_if_t</a> * core_if, uint16_t wValue);
- <a name="l00061"></a>00061 <span class="keyword">static</span> int32_t get_txfifo_size(<span class="keyword">struct</span> <a class="code" href="structdwc__otg__pcd.html">dwc_otg_pcd</a> *pcd, uint16_t wValue);
- <a name="l00062"></a>00062
- <a name="l00063"></a>00063 <span class="keyword">static</span> uint8_t resize_fifos(<a class="code" href="structdwc__otg__core__if.html">dwc_otg_core_if_t</a> * core_if);
- <a name="l00064"></a>00064
- <a name="l00066"></a>00066 <span class="keyword">static</span> <a class="code" href="structcfi__all__features__header.html">cfi_all_features_header_t</a> all_props_desc_header = {
- <a name="l00067"></a>00067 .wVersion = DWC_CONSTANT_CPU_TO_LE16(0x100),
- <a name="l00068"></a>00068 .wCoreID = DWC_CONSTANT_CPU_TO_LE16(<a class="code" href="dwc__cfi__common_8h.html#4b0c4a003085148bef609d81fa3c1589">CFI_CORE_ID_OTG</a>),
- <a name="l00069"></a>00069 .wNumFeatures = DWC_CONSTANT_CPU_TO_LE16(9),
- <a name="l00070"></a>00070 };
- <a name="l00071"></a>00071
- <a name="l00073"></a>00073 <span class="keyword">static</span> <a class="code" href="structcfi__feature__desc__header.html">cfi_feature_desc_header_t</a> prop_descs[] = {
- <a name="l00074"></a>00074
- <a name="l00075"></a>00075 <span class="comment">/* FT_ID_DMA_MODE */</span>
- <a name="l00076"></a>00076 {
- <a name="l00077"></a>00077 .wFeatureID = DWC_CONSTANT_CPU_TO_LE16(<a class="code" href="dwc__otg__cfi_8h.html#0e196868939f6bbf0d157868bfc90208">FT_ID_DMA_MODE</a>),
- <a name="l00078"></a>00078 .bmAttributes = <a class="code" href="dwc__cfi__common_8h.html#a4536fb9c1314c2f90a93cfcd082dbb9">CFI_FEATURE_ATTR_RW</a>,
- <a name="l00079"></a>00079 .wDataLength = DWC_CONSTANT_CPU_TO_LE16(1),
- <a name="l00080"></a>00080 },
- <a name="l00081"></a>00081
- <a name="l00082"></a>00082 <span class="comment">/* FT_ID_DMA_BUFFER_SETUP */</span>
- <a name="l00083"></a>00083 {
- <a name="l00084"></a>00084 .wFeatureID = DWC_CONSTANT_CPU_TO_LE16(<a class="code" href="dwc__otg__cfi_8h.html#98840b45640251bfafa3481260aef889">FT_ID_DMA_BUFFER_SETUP</a>),
- <a name="l00085"></a>00085 .bmAttributes = <a class="code" href="dwc__cfi__common_8h.html#a4536fb9c1314c2f90a93cfcd082dbb9">CFI_FEATURE_ATTR_RW</a>,
- <a name="l00086"></a>00086 .wDataLength = DWC_CONSTANT_CPU_TO_LE16(6),
- <a name="l00087"></a>00087 },
- <a name="l00088"></a>00088
- <a name="l00089"></a>00089 <span class="comment">/* FT_ID_DMA_BUFF_ALIGN */</span>
- <a name="l00090"></a>00090 {
- <a name="l00091"></a>00091 .wFeatureID = DWC_CONSTANT_CPU_TO_LE16(<a class="code" href="dwc__otg__cfi_8h.html#9335284cd4dae01f4bc0da7cb89d5ef4">FT_ID_DMA_BUFF_ALIGN</a>),
- <a name="l00092"></a>00092 .bmAttributes = <a class="code" href="dwc__cfi__common_8h.html#a4536fb9c1314c2f90a93cfcd082dbb9">CFI_FEATURE_ATTR_RW</a>,
- <a name="l00093"></a>00093 .wDataLength = DWC_CONSTANT_CPU_TO_LE16(2),
- <a name="l00094"></a>00094 },
- <a name="l00095"></a>00095
- <a name="l00096"></a>00096 <span class="comment">/* FT_ID_DMA_CONCAT_SETUP */</span>
- <a name="l00097"></a>00097 {
- <a name="l00098"></a>00098 .wFeatureID = DWC_CONSTANT_CPU_TO_LE16(<a class="code" href="dwc__otg__cfi_8h.html#779a11db5843dd058581d93c8232bd7c">FT_ID_DMA_CONCAT_SETUP</a>),
- <a name="l00099"></a>00099 .bmAttributes = <a class="code" href="dwc__cfi__common_8h.html#a4536fb9c1314c2f90a93cfcd082dbb9">CFI_FEATURE_ATTR_RW</a>,
- <a name="l00100"></a>00100 <span class="comment">//.wDataLength = DWC_CONSTANT_CPU_TO_LE16(6),</span>
- <a name="l00101"></a>00101 },
- <a name="l00102"></a>00102
- <a name="l00103"></a>00103 <span class="comment">/* FT_ID_DMA_CIRCULAR */</span>
- <a name="l00104"></a>00104 {
- <a name="l00105"></a>00105 .wFeatureID = DWC_CONSTANT_CPU_TO_LE16(<a class="code" href="dwc__otg__cfi_8h.html#8db5bfce321e02d42b742e9deedfa665">FT_ID_DMA_CIRCULAR</a>),
- <a name="l00106"></a>00106 .bmAttributes = <a class="code" href="dwc__cfi__common_8h.html#a4536fb9c1314c2f90a93cfcd082dbb9">CFI_FEATURE_ATTR_RW</a>,
- <a name="l00107"></a>00107 .wDataLength = DWC_CONSTANT_CPU_TO_LE16(6),
- <a name="l00108"></a>00108 },
- <a name="l00109"></a>00109
- <a name="l00110"></a>00110 <span class="comment">/* FT_ID_THRESHOLD_SETUP */</span>
- <a name="l00111"></a>00111 {
- <a name="l00112"></a>00112 .wFeatureID = DWC_CONSTANT_CPU_TO_LE16(<a class="code" href="dwc__otg__cfi_8h.html#bcc99a9e5a0b15b4212d88bd9c610647">FT_ID_THRESHOLD_SETUP</a>),
- <a name="l00113"></a>00113 .bmAttributes = <a class="code" href="dwc__cfi__common_8h.html#a4536fb9c1314c2f90a93cfcd082dbb9">CFI_FEATURE_ATTR_RW</a>,
- <a name="l00114"></a>00114 .wDataLength = DWC_CONSTANT_CPU_TO_LE16(6),
- <a name="l00115"></a>00115 },
- <a name="l00116"></a>00116
- <a name="l00117"></a>00117 <span class="comment">/* FT_ID_DFIFO_DEPTH */</span>
- <a name="l00118"></a>00118 {
- <a name="l00119"></a>00119 .wFeatureID = DWC_CONSTANT_CPU_TO_LE16(<a class="code" href="dwc__otg__cfi_8h.html#54b879727edcb06acdd11968ec60d249">FT_ID_DFIFO_DEPTH</a>),
- <a name="l00120"></a>00120 .bmAttributes = <a class="code" href="dwc__cfi__common_8h.html#45ffc2183d956983ca297033f9e527af">CFI_FEATURE_ATTR_RO</a>,
- <a name="l00121"></a>00121 .wDataLength = DWC_CONSTANT_CPU_TO_LE16(2),
- <a name="l00122"></a>00122 },
- <a name="l00123"></a>00123
- <a name="l00124"></a>00124 <span class="comment">/* FT_ID_TX_FIFO_DEPTH */</span>
- <a name="l00125"></a>00125 {
- <a name="l00126"></a>00126 .wFeatureID = DWC_CONSTANT_CPU_TO_LE16(<a class="code" href="dwc__otg__cfi_8h.html#a3a67b679a59c5279370bbf69f114cb6">FT_ID_TX_FIFO_DEPTH</a>),
- <a name="l00127"></a>00127 .bmAttributes = <a class="code" href="dwc__cfi__common_8h.html#a4536fb9c1314c2f90a93cfcd082dbb9">CFI_FEATURE_ATTR_RW</a>,
- <a name="l00128"></a>00128 .wDataLength = DWC_CONSTANT_CPU_TO_LE16(2),
- <a name="l00129"></a>00129 },
- <a name="l00130"></a>00130
- <a name="l00131"></a>00131 <span class="comment">/* FT_ID_RX_FIFO_DEPTH */</span>
- <a name="l00132"></a>00132 {
- <a name="l00133"></a>00133 .wFeatureID = DWC_CONSTANT_CPU_TO_LE16(<a class="code" href="dwc__otg__cfi_8h.html#42b7c98c105de1f9399786a3419e7e20">FT_ID_RX_FIFO_DEPTH</a>),
- <a name="l00134"></a>00134 .bmAttributes = <a class="code" href="dwc__cfi__common_8h.html#a4536fb9c1314c2f90a93cfcd082dbb9">CFI_FEATURE_ATTR_RW</a>,
- <a name="l00135"></a>00135 .wDataLength = DWC_CONSTANT_CPU_TO_LE16(2),
- <a name="l00136"></a>00136 }
- <a name="l00137"></a>00137 };
- <a name="l00138"></a>00138
- <a name="l00140"></a>00140 <a class="code" href="structcfi__string.html">cfi_string_t</a> prop_name_table[] = {
- <a name="l00141"></a>00141 {<a class="code" href="dwc__otg__cfi_8h.html#0e196868939f6bbf0d157868bfc90208">FT_ID_DMA_MODE</a>, <span class="stringliteral">"dma_mode"</span>},
- <a name="l00142"></a>00142 {<a class="code" href="dwc__otg__cfi_8h.html#98840b45640251bfafa3481260aef889">FT_ID_DMA_BUFFER_SETUP</a>, <span class="stringliteral">"buffer_setup"</span>},
- <a name="l00143"></a>00143 {<a class="code" href="dwc__otg__cfi_8h.html#9335284cd4dae01f4bc0da7cb89d5ef4">FT_ID_DMA_BUFF_ALIGN</a>, <span class="stringliteral">"buffer_align"</span>},
- <a name="l00144"></a>00144 {<a class="code" href="dwc__otg__cfi_8h.html#779a11db5843dd058581d93c8232bd7c">FT_ID_DMA_CONCAT_SETUP</a>, <span class="stringliteral">"concat_setup"</span>},
- <a name="l00145"></a>00145 {<a class="code" href="dwc__otg__cfi_8h.html#8db5bfce321e02d42b742e9deedfa665">FT_ID_DMA_CIRCULAR</a>, <span class="stringliteral">"buffer_circular"</span>},
- <a name="l00146"></a>00146 {<a class="code" href="dwc__otg__cfi_8h.html#bcc99a9e5a0b15b4212d88bd9c610647">FT_ID_THRESHOLD_SETUP</a>, <span class="stringliteral">"threshold_setup"</span>},
- <a name="l00147"></a>00147 {<a class="code" href="dwc__otg__cfi_8h.html#54b879727edcb06acdd11968ec60d249">FT_ID_DFIFO_DEPTH</a>, <span class="stringliteral">"dfifo_depth"</span>},
- <a name="l00148"></a>00148 {<a class="code" href="dwc__otg__cfi_8h.html#a3a67b679a59c5279370bbf69f114cb6">FT_ID_TX_FIFO_DEPTH</a>, <span class="stringliteral">"txfifo_depth"</span>},
- <a name="l00149"></a>00149 {<a class="code" href="dwc__otg__cfi_8h.html#42b7c98c105de1f9399786a3419e7e20">FT_ID_RX_FIFO_DEPTH</a>, <span class="stringliteral">"rxfifo_depth"</span>},
- <a name="l00150"></a>00150 {}
- <a name="l00151"></a>00151 };
- <a name="l00152"></a>00152
- <a name="l00153"></a>00153 <span class="comment">/************************************************************************/</span>
- <a name="l00154"></a>00154
- <a name="l00160"></a>00160 <span class="keyword">const</span> uint8_t *get_prop_name(uint16_t prop_id, <span class="keywordtype">int</span> *len)
- <a name="l00161"></a>00161 {
- <a name="l00162"></a>00162 <a class="code" href="structcfi__string.html">cfi_string_t</a> *pstr;
- <a name="l00163"></a>00163 *len = 0;
- <a name="l00164"></a>00164
- <a name="l00165"></a>00165 <span class="keywordflow">for</span> (pstr = prop_name_table; pstr && pstr-><a class="code" href="structcfi__string.html#c852efd76029880787738fb474dd486e">s</a>; pstr++) {
- <a name="l00166"></a>00166 <span class="keywordflow">if</span> (pstr-><a class="code" href="structcfi__string.html#dc88ed81d4ff35c7a1c837708659afea">id</a> == prop_id) {
- <a name="l00167"></a>00167 *len = DWC_STRLEN(pstr-><a class="code" href="structcfi__string.html#c852efd76029880787738fb474dd486e">s</a>);
- <a name="l00168"></a>00168 <span class="keywordflow">return</span> pstr-><a class="code" href="structcfi__string.html#c852efd76029880787738fb474dd486e">s</a>;
- <a name="l00169"></a>00169 }
- <a name="l00170"></a>00170 }
- <a name="l00171"></a>00171 <span class="keywordflow">return</span> NULL;
- <a name="l00172"></a>00172 }
- <a name="l00173"></a>00173
- <a name="l00179"></a>00179 <span class="keywordtype">int</span> cfi_setup(<span class="keyword">struct</span> <a class="code" href="structdwc__otg__pcd.html">dwc_otg_pcd</a> *pcd, <span class="keyword">struct</span> <a class="code" href="structcfi__usb__ctrlrequest.html">cfi_usb_ctrlrequest</a> *ctrl)
- <a name="l00180"></a>00180 {
- <a name="l00181"></a>00181 <span class="keywordtype">int</span> retval = 0;
- <a name="l00182"></a>00182 <a class="code" href="structdwc__otg__pcd__ep.html">dwc_otg_pcd_ep_t</a> *ep = NULL;
- <a name="l00183"></a>00183 <a class="code" href="structcfiobject.html">cfiobject_t</a> *cfi = pcd->cfi;
- <a name="l00184"></a>00184 <span class="keyword">struct </span><a class="code" href="structdwc__otg__core__if.html">dwc_otg_core_if</a> *coreif = <a class="code" href="dwc__otg__pcd_8h.html#464549f9f4484651efe25b1a03692d72">GET_CORE_IF</a>(pcd);
- <a name="l00185"></a>00185 uint16_t wLen = DWC_LE16_TO_CPU(&ctrl-><a class="code" href="structcfi__usb__ctrlrequest.html#60d71d1239e46e787f0b4c626de7c769">wLength</a>);
- <a name="l00186"></a>00186 uint16_t wValue = DWC_LE16_TO_CPU(&ctrl-><a class="code" href="structcfi__usb__ctrlrequest.html#2f236bbf9450df1a3b5204c4570d883f">wValue</a>);
- <a name="l00187"></a>00187 uint16_t wIndex = DWC_LE16_TO_CPU(&ctrl-><a class="code" href="structcfi__usb__ctrlrequest.html#984c95bd61e8d1120cd935bcbc5d7134">wIndex</a>);
- <a name="l00188"></a>00188 uint32_t regaddr = 0;
- <a name="l00189"></a>00189 uint32_t regval = 0;
- <a name="l00190"></a>00190
- <a name="l00191"></a>00191 <span class="comment">/* Save this Control Request in the CFI object. </span>
- <a name="l00192"></a>00192 <span class="comment"> * The data field will be assigned in the data stage completion CB function.</span>
- <a name="l00193"></a>00193 <span class="comment"> */</span>
- <a name="l00194"></a>00194 cfi-><a class="code" href="structcfiobject.html#a86c33aef2a521a27ca515bb7397dd34">ctrl_req</a> = *ctrl;
- <a name="l00195"></a>00195 cfi-><a class="code" href="structcfiobject.html#a86c33aef2a521a27ca515bb7397dd34">ctrl_req</a>.<a class="code" href="structcfi__usb__ctrlrequest.html#5b3865e9cb2c0fcf373b1c862a63c180">data</a> = NULL;
- <a name="l00196"></a>00196
- <a name="l00197"></a>00197 cfi-><a class="code" href="structcfiobject.html#f103d681f78c43dc92dd4a85cdbdc27c">need_gadget_att</a> = 0;
- <a name="l00198"></a>00198 cfi-><a class="code" href="structcfiobject.html#8d35a323dcd29a1c9d1a8568bd514c3b">need_status_in_complete</a> = 0;
- <a name="l00199"></a>00199
- <a name="l00200"></a>00200 <span class="keywordflow">switch</span> (ctrl-><a class="code" href="structcfi__usb__ctrlrequest.html#b3083f525fa9bb97e41364418daee3fa">bRequest</a>) {
- <a name="l00201"></a>00201 <span class="keywordflow">case</span> <a class="code" href="dwc__cfi__common_8h.html#b206fe3fb25aa96547a4bc0e47a864c6">VEN_CORE_GET_FEATURES</a>:
- <a name="l00202"></a>00202 retval = cfi_core_features_buf(cfi-><a class="code" href="structcfiobject.html#f6548b2b8fbab90656c22eb5ca857643">buf_in</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>, <a class="code" href="dwc__otg__cfi_8h.html#34582b9ef366f4c0e8ea24aa2388e829">CFI_IN_BUF_LEN</a>);
- <a name="l00203"></a>00203 <span class="keywordflow">if</span> (retval >= 0) {
- <a name="l00204"></a>00204 <span class="comment">//dump_msg(cfi->buf_in.buf, retval);</span>
- <a name="l00205"></a>00205 ep = &pcd-><a class="code" href="structdwc__otg__pcd.html#14f4f2a41d1305fdc0ec1806d119da89">ep0</a>;
- <a name="l00206"></a>00206
- <a name="l00207"></a>00207 retval = <a class="code" href="dwc__otg__cfi_8h.html#7c9949b9e692a8360832aedfa1843657">min</a>((uint16_t) retval, wLen);
- <a name="l00208"></a>00208 <span class="comment">/* Transfer this buffer to the host through the EP0-IN EP */</span>
- <a name="l00209"></a>00209 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#b40ce70422b6d105a855a8df4b33d45d">dma_addr</a> = cfi-><a class="code" href="structcfiobject.html#f6548b2b8fbab90656c22eb5ca857643">buf_in</a>.<a class="code" href="structcfi__dma__buff.html#549d40f7e33056fc5a99d51d00714d97">addr</a>;
- <a name="l00210"></a>00210 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#d0cda8ded2e5142d9a1c9c17efc5812f">start_xfer_buff</a> = cfi-><a class="code" href="structcfiobject.html#f6548b2b8fbab90656c22eb5ca857643">buf_in</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>;
- <a name="l00211"></a>00211 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#97fa9bf5c31ba734d54f70e6fe6ae8eb">xfer_buff</a> = cfi-><a class="code" href="structcfiobject.html#f6548b2b8fbab90656c22eb5ca857643">buf_in</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>;
- <a name="l00212"></a>00212 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#36d4010478ceb27479c0b12b376a7924">xfer_len</a> = retval;
- <a name="l00213"></a>00213 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#23d4871510b5bcb54fbf0674d8f122bd">xfer_count</a> = 0;
- <a name="l00214"></a>00214 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#8c6340435beba0b8c025a4677602acab">sent_zlp</a> = 0;
- <a name="l00215"></a>00215 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#5a218f200cff0491b735f43fed5176bf">total_len</a> = ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#36d4010478ceb27479c0b12b376a7924">xfer_len</a>;
- <a name="l00216"></a>00216
- <a name="l00217"></a>00217 pcd-><a class="code" href="structdwc__otg__pcd.html#2c8be11c3b9c7cd02684348eb028aeb5">ep0_pending</a> = 1;
- <a name="l00218"></a>00218 <a class="code" href="dwc__otg__cil_8c.html#ee4989b24826b2a6592535282853e556">dwc_otg_ep0_start_transfer</a>(coreif, &ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>);
- <a name="l00219"></a>00219 }
- <a name="l00220"></a>00220 retval = 0;
- <a name="l00221"></a>00221 <span class="keywordflow">break</span>;
- <a name="l00222"></a>00222
- <a name="l00223"></a>00223 <span class="keywordflow">case</span> <a class="code" href="dwc__cfi__common_8h.html#22bf207e476d086391240b18aacc0314">VEN_CORE_GET_FEATURE</a>:
- <a name="l00224"></a>00224 <a class="code" href="dwc__otg__cfi_8h.html#f121e7b686ae7277b695f7209c41135f">CFI_INFO</a>(<span class="stringliteral">"VEN_CORE_GET_FEATURE\n"</span>);
- <a name="l00225"></a>00225 retval = cfi_get_feature_value(cfi-><a class="code" href="structcfiobject.html#f6548b2b8fbab90656c22eb5ca857643">buf_in</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>, <a class="code" href="dwc__otg__cfi_8h.html#34582b9ef366f4c0e8ea24aa2388e829">CFI_IN_BUF_LEN</a>,
- <a name="l00226"></a>00226 pcd, ctrl);
- <a name="l00227"></a>00227 <span class="keywordflow">if</span> (retval >= 0) {
- <a name="l00228"></a>00228 ep = &pcd-><a class="code" href="structdwc__otg__pcd.html#14f4f2a41d1305fdc0ec1806d119da89">ep0</a>;
- <a name="l00229"></a>00229
- <a name="l00230"></a>00230 retval = <a class="code" href="dwc__otg__cfi_8h.html#7c9949b9e692a8360832aedfa1843657">min</a>((uint16_t) retval, wLen);
- <a name="l00231"></a>00231 <span class="comment">/* Transfer this buffer to the host through the EP0-IN EP */</span>
- <a name="l00232"></a>00232 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#b40ce70422b6d105a855a8df4b33d45d">dma_addr</a> = cfi-><a class="code" href="structcfiobject.html#f6548b2b8fbab90656c22eb5ca857643">buf_in</a>.<a class="code" href="structcfi__dma__buff.html#549d40f7e33056fc5a99d51d00714d97">addr</a>;
- <a name="l00233"></a>00233 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#d0cda8ded2e5142d9a1c9c17efc5812f">start_xfer_buff</a> = cfi-><a class="code" href="structcfiobject.html#f6548b2b8fbab90656c22eb5ca857643">buf_in</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>;
- <a name="l00234"></a>00234 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#97fa9bf5c31ba734d54f70e6fe6ae8eb">xfer_buff</a> = cfi-><a class="code" href="structcfiobject.html#f6548b2b8fbab90656c22eb5ca857643">buf_in</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>;
- <a name="l00235"></a>00235 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#36d4010478ceb27479c0b12b376a7924">xfer_len</a> = retval;
- <a name="l00236"></a>00236 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#23d4871510b5bcb54fbf0674d8f122bd">xfer_count</a> = 0;
- <a name="l00237"></a>00237 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#8c6340435beba0b8c025a4677602acab">sent_zlp</a> = 0;
- <a name="l00238"></a>00238 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#5a218f200cff0491b735f43fed5176bf">total_len</a> = ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#36d4010478ceb27479c0b12b376a7924">xfer_len</a>;
- <a name="l00239"></a>00239
- <a name="l00240"></a>00240 pcd-><a class="code" href="structdwc__otg__pcd.html#2c8be11c3b9c7cd02684348eb028aeb5">ep0_pending</a> = 1;
- <a name="l00241"></a>00241 <a class="code" href="dwc__otg__cil_8c.html#ee4989b24826b2a6592535282853e556">dwc_otg_ep0_start_transfer</a>(coreif, &ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>);
- <a name="l00242"></a>00242 }
- <a name="l00243"></a>00243 <a class="code" href="dwc__otg__cfi_8h.html#f121e7b686ae7277b695f7209c41135f">CFI_INFO</a>(<span class="stringliteral">"VEN_CORE_GET_FEATURE=%d\n"</span>, retval);
- <a name="l00244"></a>00244 <a class="code" href="dwc__otg__cfi_8h.html#8d8df6d136115ec977eb6bf20148547a">dump_msg</a>(cfi-><a class="code" href="structcfiobject.html#f6548b2b8fbab90656c22eb5ca857643">buf_in</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>, retval);
- <a name="l00245"></a>00245 <span class="keywordflow">break</span>;
- <a name="l00246"></a>00246
- <a name="l00247"></a>00247 <span class="keywordflow">case</span> <a class="code" href="dwc__cfi__common_8h.html#ee7fb610a7fb2437df3425e2330e9d39">VEN_CORE_SET_FEATURE</a>:
- <a name="l00248"></a>00248 <a class="code" href="dwc__otg__cfi_8h.html#f121e7b686ae7277b695f7209c41135f">CFI_INFO</a>(<span class="stringliteral">"VEN_CORE_SET_FEATURE\n"</span>);
- <a name="l00249"></a>00249 <span class="comment">/* Set up an XFER to get the data stage of the control request,</span>
- <a name="l00250"></a>00250 <span class="comment"> * which is the new value of the feature to be modified.</span>
- <a name="l00251"></a>00251 <span class="comment"> */</span>
- <a name="l00252"></a>00252 ep = &pcd-><a class="code" href="structdwc__otg__pcd.html#14f4f2a41d1305fdc0ec1806d119da89">ep0</a>;
- <a name="l00253"></a>00253 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#b882b6b7c857100ed20600e94ea37760">is_in</a> = 0;
- <a name="l00254"></a>00254 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#b40ce70422b6d105a855a8df4b33d45d">dma_addr</a> = cfi-><a class="code" href="structcfiobject.html#adaa1cd0f88e639251f8dfbd65da7935">buf_out</a>.<a class="code" href="structcfi__dma__buff.html#549d40f7e33056fc5a99d51d00714d97">addr</a>;
- <a name="l00255"></a>00255 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#d0cda8ded2e5142d9a1c9c17efc5812f">start_xfer_buff</a> = cfi-><a class="code" href="structcfiobject.html#adaa1cd0f88e639251f8dfbd65da7935">buf_out</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>;
- <a name="l00256"></a>00256 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#97fa9bf5c31ba734d54f70e6fe6ae8eb">xfer_buff</a> = cfi-><a class="code" href="structcfiobject.html#adaa1cd0f88e639251f8dfbd65da7935">buf_out</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>;
- <a name="l00257"></a>00257 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#36d4010478ceb27479c0b12b376a7924">xfer_len</a> = wLen;
- <a name="l00258"></a>00258 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#23d4871510b5bcb54fbf0674d8f122bd">xfer_count</a> = 0;
- <a name="l00259"></a>00259 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#8c6340435beba0b8c025a4677602acab">sent_zlp</a> = 0;
- <a name="l00260"></a>00260 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#5a218f200cff0491b735f43fed5176bf">total_len</a> = ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#36d4010478ceb27479c0b12b376a7924">xfer_len</a>;
- <a name="l00261"></a>00261
- <a name="l00262"></a>00262 pcd-><a class="code" href="structdwc__otg__pcd.html#2c8be11c3b9c7cd02684348eb028aeb5">ep0_pending</a> = 1;
- <a name="l00263"></a>00263 <span class="comment">/* Read the control write's data stage */</span>
- <a name="l00264"></a>00264 <a class="code" href="dwc__otg__cil_8c.html#ee4989b24826b2a6592535282853e556">dwc_otg_ep0_start_transfer</a>(coreif, &ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>);
- <a name="l00265"></a>00265 retval = 0;
- <a name="l00266"></a>00266 <span class="keywordflow">break</span>;
- <a name="l00267"></a>00267
- <a name="l00268"></a>00268 <span class="keywordflow">case</span> <a class="code" href="dwc__cfi__common_8h.html#f7551c9e324871e8258dacc4f4467846">VEN_CORE_RESET_FEATURES</a>:
- <a name="l00269"></a>00269 <a class="code" href="dwc__otg__cfi_8h.html#f121e7b686ae7277b695f7209c41135f">CFI_INFO</a>(<span class="stringliteral">"VEN_CORE_RESET_FEATURES\n"</span>);
- <a name="l00270"></a>00270 cfi-><a class="code" href="structcfiobject.html#f103d681f78c43dc92dd4a85cdbdc27c">need_gadget_att</a> = 1;
- <a name="l00271"></a>00271 cfi-><a class="code" href="structcfiobject.html#8d35a323dcd29a1c9d1a8568bd514c3b">need_status_in_complete</a> = 1;
- <a name="l00272"></a>00272 retval = cfi_preproc_reset(pcd, ctrl);
- <a name="l00273"></a>00273 <a class="code" href="dwc__otg__cfi_8h.html#f121e7b686ae7277b695f7209c41135f">CFI_INFO</a>(<span class="stringliteral">"VEN_CORE_RESET_FEATURES = (%d)\n"</span>, retval);
- <a name="l00274"></a>00274 <span class="keywordflow">break</span>;
- <a name="l00275"></a>00275
- <a name="l00276"></a>00276 <span class="keywordflow">case</span> <a class="code" href="dwc__cfi__common_8h.html#1d1302d0d167f7c9580878fbfff847d4">VEN_CORE_ACTIVATE_FEATURES</a>:
- <a name="l00277"></a>00277 <a class="code" href="dwc__otg__cfi_8h.html#f121e7b686ae7277b695f7209c41135f">CFI_INFO</a>(<span class="stringliteral">"VEN_CORE_ACTIVATE_FEATURES\n"</span>);
- <a name="l00278"></a>00278 <span class="keywordflow">break</span>;
- <a name="l00279"></a>00279
- <a name="l00280"></a>00280 <span class="keywordflow">case</span> <a class="code" href="dwc__cfi__common_8h.html#8d4bf92524d3e5fd4b4b060fc1269ec6">VEN_CORE_READ_REGISTER</a>:
- <a name="l00281"></a>00281 <a class="code" href="dwc__otg__cfi_8h.html#f121e7b686ae7277b695f7209c41135f">CFI_INFO</a>(<span class="stringliteral">"VEN_CORE_READ_REGISTER\n"</span>);
- <a name="l00282"></a>00282 <span class="comment">/* wValue optionally contains the HI WORD of the register offset and</span>
- <a name="l00283"></a>00283 <span class="comment"> * wIndex contains the LOW WORD of the register offset </span>
- <a name="l00284"></a>00284 <span class="comment"> */</span>
- <a name="l00285"></a>00285 <span class="keywordflow">if</span> (wValue == 0) {
- <a name="l00286"></a>00286 <span class="comment">/* @TODO - MAS - fix the access to the base field */</span>
- <a name="l00287"></a>00287 regaddr = 0;
- <a name="l00288"></a>00288 <span class="comment">//regaddr = (uint32_t) pcd->otg_dev->base;</span>
- <a name="l00289"></a>00289 <span class="comment">//GET_CORE_IF(pcd)->co</span>
- <a name="l00290"></a>00290 regaddr |= wIndex;
- <a name="l00291"></a>00291 } <span class="keywordflow">else</span> {
- <a name="l00292"></a>00292 regaddr = (wValue << 16) | wIndex;
- <a name="l00293"></a>00293 }
- <a name="l00294"></a>00294
- <a name="l00295"></a>00295 <span class="comment">/* Read a 32-bit value of the memory at the regaddr */</span>
- <a name="l00296"></a>00296 regval = dwc_read_reg32((uint32_t *) regaddr);
- <a name="l00297"></a>00297
- <a name="l00298"></a>00298 ep = &pcd-><a class="code" href="structdwc__otg__pcd.html#14f4f2a41d1305fdc0ec1806d119da89">ep0</a>;
- <a name="l00299"></a>00299 dwc_memcpy(cfi-><a class="code" href="structcfiobject.html#f6548b2b8fbab90656c22eb5ca857643">buf_in</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>, &regval, <span class="keyword">sizeof</span>(uint32_t));
- <a name="l00300"></a>00300 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#b882b6b7c857100ed20600e94ea37760">is_in</a> = 1;
- <a name="l00301"></a>00301 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#b40ce70422b6d105a855a8df4b33d45d">dma_addr</a> = cfi-><a class="code" href="structcfiobject.html#f6548b2b8fbab90656c22eb5ca857643">buf_in</a>.<a class="code" href="structcfi__dma__buff.html#549d40f7e33056fc5a99d51d00714d97">addr</a>;
- <a name="l00302"></a>00302 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#d0cda8ded2e5142d9a1c9c17efc5812f">start_xfer_buff</a> = cfi-><a class="code" href="structcfiobject.html#f6548b2b8fbab90656c22eb5ca857643">buf_in</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>;
- <a name="l00303"></a>00303 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#97fa9bf5c31ba734d54f70e6fe6ae8eb">xfer_buff</a> = cfi-><a class="code" href="structcfiobject.html#f6548b2b8fbab90656c22eb5ca857643">buf_in</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>;
- <a name="l00304"></a>00304 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#36d4010478ceb27479c0b12b376a7924">xfer_len</a> = wLen;
- <a name="l00305"></a>00305 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#23d4871510b5bcb54fbf0674d8f122bd">xfer_count</a> = 0;
- <a name="l00306"></a>00306 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#8c6340435beba0b8c025a4677602acab">sent_zlp</a> = 0;
- <a name="l00307"></a>00307 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#5a218f200cff0491b735f43fed5176bf">total_len</a> = ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#36d4010478ceb27479c0b12b376a7924">xfer_len</a>;
- <a name="l00308"></a>00308
- <a name="l00309"></a>00309 pcd-><a class="code" href="structdwc__otg__pcd.html#2c8be11c3b9c7cd02684348eb028aeb5">ep0_pending</a> = 1;
- <a name="l00310"></a>00310 <a class="code" href="dwc__otg__cil_8c.html#ee4989b24826b2a6592535282853e556">dwc_otg_ep0_start_transfer</a>(coreif, &ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>);
- <a name="l00311"></a>00311 cfi-><a class="code" href="structcfiobject.html#f103d681f78c43dc92dd4a85cdbdc27c">need_gadget_att</a> = 0;
- <a name="l00312"></a>00312 retval = 0;
- <a name="l00313"></a>00313 <span class="keywordflow">break</span>;
- <a name="l00314"></a>00314
- <a name="l00315"></a>00315 <span class="keywordflow">case</span> <a class="code" href="dwc__cfi__common_8h.html#d132d545f74a408b62d44a34ba51426c">VEN_CORE_WRITE_REGISTER</a>:
- <a name="l00316"></a>00316 <a class="code" href="dwc__otg__cfi_8h.html#f121e7b686ae7277b695f7209c41135f">CFI_INFO</a>(<span class="stringliteral">"VEN_CORE_WRITE_REGISTER\n"</span>);
- <a name="l00317"></a>00317 <span class="comment">/* Set up an XFER to get the data stage of the control request,</span>
- <a name="l00318"></a>00318 <span class="comment"> * which is the new value of the register to be modified.</span>
- <a name="l00319"></a>00319 <span class="comment"> */</span>
- <a name="l00320"></a>00320 ep = &pcd-><a class="code" href="structdwc__otg__pcd.html#14f4f2a41d1305fdc0ec1806d119da89">ep0</a>;
- <a name="l00321"></a>00321 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#b882b6b7c857100ed20600e94ea37760">is_in</a> = 0;
- <a name="l00322"></a>00322 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#b40ce70422b6d105a855a8df4b33d45d">dma_addr</a> = cfi-><a class="code" href="structcfiobject.html#adaa1cd0f88e639251f8dfbd65da7935">buf_out</a>.<a class="code" href="structcfi__dma__buff.html#549d40f7e33056fc5a99d51d00714d97">addr</a>;
- <a name="l00323"></a>00323 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#d0cda8ded2e5142d9a1c9c17efc5812f">start_xfer_buff</a> = cfi-><a class="code" href="structcfiobject.html#adaa1cd0f88e639251f8dfbd65da7935">buf_out</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>;
- <a name="l00324"></a>00324 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#97fa9bf5c31ba734d54f70e6fe6ae8eb">xfer_buff</a> = cfi-><a class="code" href="structcfiobject.html#adaa1cd0f88e639251f8dfbd65da7935">buf_out</a>.<a class="code" href="structcfi__dma__buff.html#474851b3123373b8b30fa3637eb81b5b">buf</a>;
- <a name="l00325"></a>00325 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#36d4010478ceb27479c0b12b376a7924">xfer_len</a> = wLen;
- <a name="l00326"></a>00326 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#23d4871510b5bcb54fbf0674d8f122bd">xfer_count</a> = 0;
- <a name="l00327"></a>00327 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#8c6340435beba0b8c025a4677602acab">sent_zlp</a> = 0;
- <a name="l00328"></a>00328 ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#5a218f200cff0491b735f43fed5176bf">total_len</a> = ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>.<a class="code" href="structdwc__ep.html#36d4010478ceb27479c0b12b376a7924">xfer_len</a>;
- <a name="l00329"></a>00329
- <a name="l00330"></a>00330 pcd-><a class="code" href="structdwc__otg__pcd.html#2c8be11c3b9c7cd02684348eb028aeb5">ep0_pending</a> = 1;
- <a name="l00331"></a>00331 <span class="comment">/* Read the control write's data stage */</span>
- <a name="l00332"></a>00332 <a class="code" href="dwc__otg__cil_8c.html#ee4989b24826b2a6592535282853e556">dwc_otg_ep0_start_transfer</a>(coreif, &ep-><a class="code" href="structdwc__otg__pcd__ep.html#6e43754ce0f3a4fe29e4d70fd58d4f8f">dwc_ep</a>);
- <a name="l00333"></a>00333 retval = 0;
- <a name="l00334"></a>00334 <span class="keywordflow">break</span>;
- <a name="l00335"></a>00335
- <a name="l00336"></a>00336 <span class="keywordflow">default</span>:
- <a name="l00337"></a>00337 retval = -DWC_E_NOT_SUPPORTED;
- <a name="l00338"></a>00338 <span class="keywordflow">break</span>;
- <a name="l00339"></a>00339 }
- <a name="l00340"></a>00340
- <a name="l00341"></a>00341 <span class="keywordflow">return</span> retval;
- <a name="l00342"></a>00342 }
- <a name="l00343"></a>00343
- <a name="l00355"></a>00355 <span class="keyword">static</span> <span class="keywordtype">int</span> cfi_core_features_buf(uint8_t * buf, uint16_t buflen)
- <a name="l00356"></a>00356 {
- <a name="l00357"></a>00357 <a class="code" href="structcfi__feature__desc__header.html">cfi_feature_desc_header_t</a> *prop_hdr = prop_descs;
- <a name="l00358"></a>00358 <a class="code" href="structcfi__feature__desc__header.html">cfi_feature_desc_header_t</a> *prop;
- <a name="l00359"></a>00359 <a class="code" href="structcfi__all__features__header.html">cfi_all_features_header_t</a> *all_props_hdr = &all_props_desc_header;
- <a name="l00360"></a>00360 <a class="code" href="structcfi__all__features__header.html">cfi_all_features_header_t</a> *tmp;
- <a name="l00361"></a>00361 uint8_t *tmpbuf = buf;
- <a name="l00362"></a>00362 <span class="keyword">const</span> uint8_t *pname = NULL;
- <a name="l00363"></a>00363 <span class="keywordtype">int</span> i, j, namelen = 0, totlen;
- <a name="l00364"></a>00364
- <a name="l00365"></a>00365 <span class="comment">/* Prepare and copy the core features into the buffer */</span>
- <a name="l00366"></a>00366 <a class="code" href="dwc__otg__cfi_8h.html#f121e7b686ae7277b695f7209c41135f">CFI_INFO</a>(<span class="stringliteral">"%s:\n"</span>, __func__);
- <a name="l00367"></a>00367
- <a name="l00368"></a>00368 tmp = (<a class="code" href="structcfi__all__features__header.html">cfi_all_features_header_t</a> *) tmpbuf;
- <a name="l00369"></a>00369 *tmp = *all_props_hdr;
- <a name="l00370"></a>00370 tmpbuf += <a class="code" href="dwc__cfi__common_8h.html#b6c1d0a310ae1d0a89437b2cf92e57ba">CFI_ALL_FEATURES_HDR_LEN</a>;
- <a name="l00371"></a>00371
- <a name="l00372"></a>00372 j = <span class="keyword">sizeof</span>(prop_descs) / <span class="keyword">sizeof</span>(<a class="code" href="structcfi__all__features__header.html">cfi_all_features_header_t</a>);
- <a name="l00373"></a>00373 <span class="keywordflow">for</span> (i = 0; i < j; i++, prop_hdr++) {
- <a name="l00374"></a>00374 pname = get_prop_name(prop_hdr-><a class="code" href="structcfi__feature__desc__header.html#f76e757383a5210368e599f872952170">wFeatureID</a>, &namelen);
- <a name="l00375"></a>00375 prop = (<a class="code" href="structcfi__feature__desc__header.html">cfi_feature_desc_header_t</a> *) tmpbuf;
- <a name="l00376"></a>00376 *prop = *prop_hdr;
- <a name="l00377"></a>00377
- <a name="l00378"></a>00378 prop-><a class="code" href="structcfi__feature__desc__header.html#4e90b7a616a2efc24937fc6d5cff1347"…
Large files files are truncated, but you can click here to view the full file