1 |
40 |
leonardoar |
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
2 |
|
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
3 |
|
|
<head>
|
4 |
|
|
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
5 |
|
|
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
6 |
|
|
<title>Uart wishbone slave Documentation: E:/uart_block/hdl/iseProject/divisor.vhd Source File</title>
|
7 |
|
|
|
8 |
|
|
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
9 |
|
|
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
10 |
|
|
<link href="navtree.css" rel="stylesheet" type="text/css"/>
|
11 |
|
|
<script type="text/javascript" src="jquery.js"></script>
|
12 |
|
|
<script type="text/javascript" src="resize.js"></script>
|
13 |
|
|
<script type="text/javascript" src="navtree.js"></script>
|
14 |
|
|
<script type="text/javascript">
|
15 |
|
|
$(document).ready(initResizable);
|
16 |
|
|
</script>
|
17 |
|
|
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
18 |
|
|
<script type="text/javascript" src="search/search.js"></script>
|
19 |
|
|
<script type="text/javascript">
|
20 |
|
|
$(document).ready(function() { searchBox.OnSelectItem(0); });
|
21 |
|
|
</script>
|
22 |
|
|
|
23 |
|
|
</head>
|
24 |
|
|
<body>
|
25 |
|
|
<div id="top"><!-- do not remove this div! -->
|
26 |
|
|
|
27 |
|
|
|
28 |
|
|
<div id="titlearea">
|
29 |
|
|
<table cellspacing="0" cellpadding="0">
|
30 |
|
|
<tbody>
|
31 |
|
|
<tr style="height: 56px;">
|
32 |
|
|
|
33 |
|
|
|
34 |
|
|
<td style="padding-left: 0.5em;">
|
35 |
|
|
<div id="projectname">Uart wishbone slave Documentation
|
36 |
|
|
|
37 |
|
|
</div>
|
38 |
|
|
|
39 |
|
|
</td>
|
40 |
|
|
|
41 |
|
|
|
42 |
|
|
|
43 |
|
|
</tr>
|
44 |
|
|
</tbody>
|
45 |
|
|
</table>
|
46 |
|
|
</div>
|
47 |
|
|
|
48 |
|
|
<!-- Generated by Doxygen 1.8.0 -->
|
49 |
|
|
<script type="text/javascript">
|
50 |
|
|
var searchBox = new SearchBox("searchBox", "search",false,'Search');
|
51 |
|
|
</script>
|
52 |
|
|
<div id="navrow1" class="tabs">
|
53 |
|
|
<ul class="tablist">
|
54 |
|
|
<li><a href="index.html"><span>Main Page</span></a></li>
|
55 |
|
|
<li><a href="namespaces.html"><span>Packages</span></a></li>
|
56 |
|
|
<li><a href="annotated.html"><span>Design Unit List</span></a></li>
|
57 |
|
|
<li class="current"><a href="files.html"><span>Files</span></a></li>
|
58 |
|
|
<li>
|
59 |
|
|
<div id="MSearchBox" class="MSearchBoxInactive">
|
60 |
|
|
<span class="left">
|
61 |
|
|
<img id="MSearchSelect" src="search/mag_sel.png"
|
62 |
|
|
onmouseover="return searchBox.OnSearchSelectShow()"
|
63 |
|
|
onmouseout="return searchBox.OnSearchSelectHide()"
|
64 |
|
|
alt=""/>
|
65 |
|
|
<input type="text" id="MSearchField" value="Search" accesskey="S"
|
66 |
|
|
onfocus="searchBox.OnSearchFieldFocus(true)"
|
67 |
|
|
onblur="searchBox.OnSearchFieldFocus(false)"
|
68 |
|
|
onkeyup="searchBox.OnSearchFieldChange(event)"/>
|
69 |
|
|
</span><span class="right">
|
70 |
|
|
<a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
|
71 |
|
|
</span>
|
72 |
|
|
</div>
|
73 |
|
|
</li>
|
74 |
|
|
</ul>
|
75 |
|
|
</div>
|
76 |
|
|
<div id="navrow2" class="tabs2">
|
77 |
|
|
<ul class="tablist">
|
78 |
|
|
<li><a href="files.html"><span>File List</span></a></li>
|
79 |
|
|
</ul>
|
80 |
|
|
</div>
|
81 |
|
|
</div>
|
82 |
|
|
<div id="side-nav" class="ui-resizable side-nav-resizable">
|
83 |
|
|
<div id="nav-tree">
|
84 |
|
|
<div id="nav-tree-contents">
|
85 |
|
|
</div>
|
86 |
|
|
</div>
|
87 |
|
|
<div id="splitbar" style="-moz-user-select:none;"
|
88 |
|
|
class="ui-resizable-handle">
|
89 |
|
|
</div>
|
90 |
|
|
</div>
|
91 |
|
|
<script type="text/javascript">
|
92 |
|
|
initNavTree('divisor_8vhd.html','');
|
93 |
|
|
</script>
|
94 |
|
|
<div id="doc-content">
|
95 |
|
|
<!-- window showing the filter options -->
|
96 |
|
|
<div id="MSearchSelectWindow"
|
97 |
|
|
onmouseover="return searchBox.OnSearchSelectShow()"
|
98 |
|
|
onmouseout="return searchBox.OnSearchSelectHide()"
|
99 |
|
|
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
100 |
|
|
<a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark"> </span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark"> </span>Classes</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark"> </span>Namespaces</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark"> </span>Files</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark"> </span>Variables</a></div>
|
101 |
|
|
|
102 |
|
|
<!-- iframe showing the search results (closed by default) -->
|
103 |
|
|
<div id="MSearchResultsWindow">
|
104 |
|
|
<iframe src="javascript:void(0)" frameborder="0"
|
105 |
|
|
name="MSearchResults" id="MSearchResults">
|
106 |
|
|
</iframe>
|
107 |
|
|
</div>
|
108 |
|
|
|
109 |
|
|
<div class="header">
|
110 |
|
|
<div class="headertitle">
|
111 |
|
|
<div class="title">E:/uart_block/hdl/iseProject/divisor.vhd</div> </div>
|
112 |
|
|
</div><!--header-->
|
113 |
|
|
<div class="contents">
|
114 |
|
|
<a href="divisor_8vhd.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001
|
115 |
|
|
<a name="l00006"></a>00006 <span class="vhdlkeyword">library </span><span class="keywordflow">IEEE</span>;
|
116 |
|
|
<a name="l00007"></a>00007 <span class="vhdlkeyword">use </span>IEEE.STD_LOGIC_1164.<span class="vhdlkeyword">ALL</span>;
|
117 |
|
|
<a name="l00008"></a>00008 <span class="vhdlkeyword">use </span>IEEE.std_logic_arith.<span class="vhdlkeyword">all</span>;
|
118 |
|
|
<a name="l00009"></a>00009
|
119 |
|
|
<a name="l00011"></a><a class="code" href="classdivisor.html#ac442dca664056131bdaf5c92e4351e01">00011</a> <span class="vhdlkeyword">use </span>work.pkgDefinitions.<span class="vhdlkeyword">all</span>;
|
120 |
|
|
<a name="l00012"></a>00012
|
121 |
|
|
<a name="l00013"></a><a class="code" href="classdivisor.html">00013</a> <span class="keywordflow">entity </span><a class="code" href="classdivisor.html">divisor</a> <span class="vhdlkeyword">is</span>
|
122 |
|
|
<a name="l00014"></a><a class="code" href="classdivisor.html#a0ddd7f10f240eabbaa5f593dc724676d">00014</a> <span class="vhdlkeyword">Port</span> <span class="vhdlchar">(</span> <span class="vhdlchar"><a class="code" href="classdivisor.html#a0ddd7f10f240eabbaa5f593dc724676d" title="Reset input.">rst</a></span> <span class="vhdlchar">:</span> <span class="vhdlkeyword">in</span> <span class="comment">STD_LOGIC</span>;
|
123 |
|
|
<a name="l00015"></a><a class="code" href="classdivisor.html#afccc0679a700cd9acf53b87c41fee67a">00015</a> <span class="vhdlchar"><a class="code" href="classdivisor.html#afccc0679a700cd9acf53b87c41fee67a" title="Clock input.">clk</a></span> <span class="vhdlchar">:</span> <span class="vhdlkeyword">in</span> <span class="comment">STD_LOGIC</span>;
|
124 |
|
|
<a name="l00016"></a><a class="code" href="classdivisor.html#a72b864bee7e5df9aaa6663e15717ee2a">00016</a> <span class="vhdlchar"><a class="code" href="classdivisor.html#a72b864bee7e5df9aaa6663e15717ee2a" title="Division result (32 bits)">quotient</a></span> <span class="vhdlchar">:</span> <span class="vhdlkeyword">out</span> <span class="comment">STD_LOGIC_VECTOR</span> <span class="vhdlchar">(</span><span class="vhdlchar">(</span><span class="vhdlchar">nBitsLarge</span><span class="vhdlchar">-</span><span class="vhdllogic"></span><span class="vhdllogic">1</span><span class="vhdlchar">)</span> <span class="vhdlkeyword">downto</span> <span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">)</span>;
|
125 |
|
|
<a name="l00017"></a><a class="code" href="classdivisor.html#a2e2b27233f56bb5217044913043942fa">00017</a> <span class="vhdlchar"><a class="code" href="classdivisor.html#a2e2b27233f56bb5217044913043942fa" title="Reminder result (32 bits)">reminder</a></span> <span class="vhdlchar">:</span> <span class="vhdlkeyword">out</span> <span class="comment">STD_LOGIC_VECTOR</span> <span class="vhdlchar">(</span><span class="vhdlchar">(</span><span class="vhdlchar">nBitsLarge</span><span class="vhdlchar">-</span><span class="vhdllogic"></span><span class="vhdllogic">1</span><span class="vhdlchar">)</span> <span class="vhdlkeyword">downto</span> <span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">)</span>;
|
126 |
|
|
<a name="l00018"></a><a class="code" href="classdivisor.html#ad29d3fb6c6ea697db492c43d4a3630eb">00018</a> <span class="vhdlchar"><a class="code" href="classdivisor.html#ad29d3fb6c6ea697db492c43d4a3630eb" title="Numerator (32 bits)">numerator</a></span> <span class="vhdlchar">:</span> <span class="vhdlkeyword">in</span> <span class="comment">STD_LOGIC_VECTOR</span> <span class="vhdlchar">(</span><span class="vhdlchar">(</span><span class="vhdlchar">nBitsLarge</span><span class="vhdlchar">-</span><span class="vhdllogic"></span><span class="vhdllogic">1</span><span class="vhdlchar">)</span> <span class="vhdlkeyword">downto</span> <span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">)</span>;
|
127 |
|
|
<a name="l00019"></a><a class="code" href="classdivisor.html#a125151d21c7a62bc99907ddc72a7ebb1">00019</a> <span class="vhdlchar"><a class="code" href="classdivisor.html#a125151d21c7a62bc99907ddc72a7ebb1" title=""Divide by" number (32 bits)">divident</a></span> <span class="vhdlchar">:</span> <span class="vhdlkeyword">in</span> <span class="comment">STD_LOGIC_VECTOR</span> <span class="vhdlchar">(</span><span class="vhdlchar">(</span><span class="vhdlchar">nBitsLarge</span><span class="vhdlchar">-</span><span class="vhdllogic"></span><span class="vhdllogic">1</span><span class="vhdlchar">)</span> <span class="vhdlkeyword">downto</span> <span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">)</span>;
|
128 |
|
|
<a name="l00020"></a>00020 <span class="vhdlchar">done</span> <span class="vhdlchar">:</span> <span class="vhdlkeyword">out</span> <span class="comment">STD_LOGIC</span><span class="vhdlchar">)</span>;
|
129 |
|
|
<a name="l00021"></a>00021 <span class="vhdlkeyword">end</span> <span class="vhdlchar">divisor</span>;
|
130 |
|
|
<a name="l00022"></a>00022
|
131 |
|
|
<a name="l00025"></a><a class="code" href="classdivisor_1_1_behavioral.html">00025</a> <span class="vhdlkeyword">architecture</span> Behavioral <span class="vhdlkeyword">of</span> <a class="code" href="classdivisor.html">divisor</a> is
|
132 |
|
|
<a name="l00026"></a>00026
|
133 |
|
|
<a name="l00027"></a>00027 <span class="vhdlkeyword">begin</span>
|
134 |
|
|
<a name="l00028"></a>00028 <span class="keyword"></span>
|
135 |
|
|
<a name="l00029"></a>00029 <span class="keyword"> -- Division algorithm Q=N/D</span>
|
136 |
|
|
<a name="l00030"></a>00030 <span class="vhdlkeyword">process</span> (<a class="code" href="classdivisor.html#a0ddd7f10f240eabbaa5f593dc724676d" title="Reset input.">rst</a>, <a class="code" href="classdivisor.html#afccc0679a700cd9acf53b87c41fee67a" title="Clock input.">clk</a>, <a class="code" href="classdivisor.html#ad29d3fb6c6ea697db492c43d4a3630eb" title="Numerator (32 bits)">numerator</a>, <a class="code" href="classdivisor.html#a125151d21c7a62bc99907ddc72a7ebb1" title=""Divide by" number (32 bits)">divident</a>)
|
137 |
|
|
<a name="l00031"></a>00031 <span class="vhdlkeyword">variable</span> <span class="vhdlchar">Q</span> <span class="vhdlchar">:</span> <span class="comment">unsigned</span><span class="vhdlchar">(</span><span class="vhdlchar"><a class="code" href="classdivisor.html#a72b864bee7e5df9aaa6663e15717ee2a" title="Division result (32 bits)">quotient</a></span><span class="vhdlchar">'</span><span class="vhdlchar">length</span><span class="vhdlchar">-</span><span class="vhdllogic"></span><span class="vhdllogic">1</span> <span class="vhdlkeyword">downto</span> <span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">)</span>;
|
138 |
|
|
<a name="l00032"></a>00032 <span class="vhdlkeyword">variable</span> <span class="vhdlchar">R</span> <span class="vhdlchar">:</span> <span class="comment">unsigned</span><span class="vhdlchar">(</span><span class="vhdlchar"><a class="code" href="classdivisor.html#a2e2b27233f56bb5217044913043942fa" title="Reminder result (32 bits)">reminder</a></span><span class="vhdlchar">'</span><span class="vhdlchar">length</span><span class="vhdlchar">-</span><span class="vhdllogic"></span><span class="vhdllogic">1</span> <span class="vhdlkeyword">downto</span> <span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">)</span>;
|
139 |
|
|
<a name="l00033"></a>00033 <span class="vhdlkeyword">variable</span> <span class="vhdlchar">D</span> <span class="vhdlchar">:</span> <span class="comment">unsigned</span><span class="vhdlchar">(</span><span class="vhdlchar"><a class="code" href="classdivisor.html#a2e2b27233f56bb5217044913043942fa" title="Reminder result (32 bits)">reminder</a></span><span class="vhdlchar">'</span><span class="vhdlchar">length</span><span class="vhdlchar">-</span><span class="vhdllogic"></span><span class="vhdllogic">1</span> <span class="vhdlkeyword">downto</span> <span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">)</span>;
|
140 |
|
|
<a name="l00034"></a>00034 <span class="vhdlkeyword">variable</span> <span class="vhdlchar">N</span> <span class="vhdlchar">:</span> <span class="comment">unsigned</span><span class="vhdlchar">(</span><span class="vhdlchar"><a class="code" href="classdivisor.html#a2e2b27233f56bb5217044913043942fa" title="Reminder result (32 bits)">reminder</a></span><span class="vhdlchar">'</span><span class="vhdlchar">length</span><span class="vhdlchar">-</span><span class="vhdllogic"></span><span class="vhdllogic">1</span> <span class="vhdlkeyword">downto</span> <span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">)</span>;
|
141 |
|
|
<a name="l00035"></a>00035 <span class="vhdlkeyword">variable</span> <span class="vhdlchar">iteractions</span> <span class="vhdlchar">:</span> <span class="comment">integer</span>;
|
142 |
|
|
<a name="l00036"></a>00036 <span class="vhdlkeyword"> begin</span>
|
143 |
|
|
<a name="l00037"></a>00037 <span class="vhdlkeyword">if</span> <span class="vhdlchar">(</span><span class="vhdlchar"><a class="code" href="classdivisor.html#a0ddd7f10f240eabbaa5f593dc724676d" title="Reset input.">rst</a></span> <span class="vhdlchar">=</span> <span class="vhdlchar">'</span><span class="vhdllogic"></span><span class="vhdllogic">1</span><span class="vhdlchar">'</span><span class="vhdlchar">)</span> <span class="vhdlkeyword">then</span>
|
144 |
|
|
<a name="l00038"></a>00038 <span class="vhdlchar"><a class="code" href="classdivisor.html#a72b864bee7e5df9aaa6663e15717ee2a" title="Division result (32 bits)">quotient</a></span> <span class="vhdlchar"><=</span> <span class="vhdlchar">(</span><span class="vhdlkeyword">others</span> <span class="vhdlchar">=</span><span class="vhdlchar">></span> <span class="vhdlchar">'</span><span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">'</span><span class="vhdlchar">)</span>;
|
145 |
|
|
<a name="l00039"></a>00039 <span class="vhdlchar"><a class="code" href="classdivisor.html#a2e2b27233f56bb5217044913043942fa" title="Reminder result (32 bits)">reminder</a></span> <span class="vhdlchar"><=</span> <span class="vhdlchar">(</span><span class="vhdlkeyword">others</span> <span class="vhdlchar">=</span><span class="vhdlchar">></span> <span class="vhdlchar">'</span><span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">'</span><span class="vhdlchar">)</span>;
|
146 |
|
|
<a name="l00040"></a>00040 <span class="vhdlchar">done</span> <span class="vhdlchar"><=</span> <span class="vhdlchar">'</span><span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">'</span>;
|
147 |
|
|
<a name="l00041"></a>00041 <span class="keyword"></span>
|
148 |
|
|
<a name="l00042"></a>00042 <span class="keyword"> -- Initialize variables</span>
|
149 |
|
|
<a name="l00043"></a>00043 <span class="vhdlchar">iteractions</span> <span class="vhdlchar">:=</span> <span class="vhdlchar"><a class="code" href="classdivisor.html#a72b864bee7e5df9aaa6663e15717ee2a" title="Division result (32 bits)">quotient</a></span><span class="vhdlchar">'</span><span class="vhdlchar">length</span>;
|
150 |
|
|
<a name="l00044"></a>00044 <span class="vhdlchar">D</span> <span class="vhdlchar">:=</span> <span class="comment">unsigned</span><span class="vhdlchar">(</span><span class="vhdlchar"><a class="code" href="classdivisor.html#a125151d21c7a62bc99907ddc72a7ebb1" title=""Divide by" number (32 bits)">divident</a></span><span class="vhdlchar">)</span>;
|
151 |
|
|
<a name="l00045"></a>00045 <span class="vhdlchar">N</span> <span class="vhdlchar">:=</span> <span class="comment">unsigned</span><span class="vhdlchar">(</span><span class="vhdlchar"><a class="code" href="classdivisor.html#ad29d3fb6c6ea697db492c43d4a3630eb" title="Numerator (32 bits)">numerator</a></span><span class="vhdlchar">)</span>;<span class="keyword"></span>
|
152 |
|
|
<a name="l00046"></a>00046 <span class="keyword"> -- initialize quotient <span class="vhdlkeyword">and</span> remainder <span class="vhdlkeyword">to</span> zero</span>
|
153 |
|
|
<a name="l00047"></a>00047 <span class="vhdlchar">Q</span> <span class="vhdlchar">:=</span> <span class="vhdlchar">(</span><span class="vhdlkeyword">others</span> <span class="vhdlchar">=</span><span class="vhdlchar">></span> <span class="vhdlchar">'</span><span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">'</span><span class="vhdlchar">)</span>;
|
154 |
|
|
<a name="l00048"></a>00048 <span class="vhdlchar">R</span> <span class="vhdlchar">:=</span> <span class="vhdlchar">(</span><span class="vhdlkeyword">others</span> <span class="vhdlchar">=</span><span class="vhdlchar">></span> <span class="vhdlchar">'</span><span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">'</span><span class="vhdlchar">)</span>;
|
155 |
|
|
<a name="l00049"></a>00049 <span class="vhdlkeyword">elsif</span> <span class="vhdlchar">rising_edge</span><span class="vhdlchar">(</span><span class="vhdlchar"><a class="code" href="classdivisor.html#afccc0679a700cd9acf53b87c41fee67a" title="Clock input.">clk</a></span><span class="vhdlchar">)</span> <span class="vhdlkeyword">then</span>
|
156 |
|
|
<a name="l00050"></a>00050 <span class="vhdlkeyword">if</span> <span class="vhdlchar">iteractions</span> <span class="vhdlchar">></span> <span class="vhdllogic"></span><span class="vhdllogic">0</span> <span class="vhdlkeyword">then</span>
|
157 |
|
|
<a name="l00051"></a>00051 <span class="vhdlchar">iteractions</span> <span class="vhdlchar">:=</span> <span class="vhdlchar">iteractions</span> <span class="vhdlchar">-</span> <span class="vhdllogic"></span><span class="vhdllogic">1</span>;<span class="keyword"></span>
|
158 |
|
|
<a name="l00052"></a>00052 <span class="keyword"> -- left-shift R by </span><span class="vhdllogic">1</span> <span class="comment">bit</span>
|
159 |
|
|
<a name="l00053"></a>00053 <span class="vhdlchar">R</span> <span class="vhdlchar">:=</span> <span class="vhdlchar">(</span><span class="vhdlchar">R</span><span class="vhdlchar">(</span><span class="vhdlchar">(</span><span class="vhdlchar">R</span><span class="vhdlchar">'</span><span class="vhdlchar">HIGH</span> <span class="vhdlchar">-</span> <span class="vhdllogic"></span><span class="vhdllogic">1</span><span class="vhdlchar">)</span> <span class="vhdlkeyword">downto</span> <span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">)</span> <span class="vhdlchar">&</span> <span class="vhdlchar">'</span><span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">'</span><span class="vhdlchar">)</span>;
|
160 |
|
|
<a name="l00054"></a>00054 <span class="keyword"></span>
|
161 |
|
|
<a name="l00055"></a>00055 <span class="keyword"> --set the least-significant <span class="comment">bit</span> <span class="vhdlkeyword">of</span> R equal <span class="vhdlkeyword">to</span> <span class="comment">bit</span> i <span class="vhdlkeyword">of</span> the numerator(dividend)</span>
|
162 |
|
|
<a name="l00056"></a>00056 <span class="vhdlchar">R</span><span class="vhdlchar">(</span><span class="vhdllogic"></span><span class="vhdllogic">0</span><span class="vhdlchar">)</span> <span class="vhdlchar">:=</span> <span class="vhdlchar">N</span><span class="vhdlchar">(</span><span class="vhdlchar">iteractions</span><span class="vhdlchar">)</span>;
|
163 |
|
|
<a name="l00057"></a>00057
|
164 |
|
|
<a name="l00058"></a>00058 <span class="vhdlkeyword">if</span> <span class="vhdlchar">(</span><span class="vhdlchar">R</span> <span class="vhdlchar">>=</span> <span class="vhdlchar">D</span><span class="vhdlchar">)</span> <span class="vhdlkeyword">then</span>
|
165 |
|
|
<a name="l00059"></a>00059 <span class="vhdlchar">R</span> <span class="vhdlchar">:=</span> <span class="vhdlchar">R</span> <span class="vhdlchar">-</span> <span class="vhdlchar">D</span>;
|
166 |
|
|
<a name="l00060"></a>00060 <span class="vhdlchar">Q</span><span class="vhdlchar">(</span><span class="vhdlchar">iteractions</span><span class="vhdlchar">)</span> <span class="vhdlchar">:=</span> <span class="vhdlchar">'</span><span class="vhdllogic"></span><span class="vhdllogic">1</span><span class="vhdlchar">'</span>;
|
167 |
|
|
<a name="l00061"></a>00061 <span class="vhdlkeyword">end</span> <span class="vhdlkeyword">if</span>;
|
168 |
|
|
<a name="l00062"></a>00062 <span class="vhdlkeyword">else</span><span class="keyword"></span>
|
169 |
|
|
<a name="l00063"></a>00063 <span class="keyword"> -- We have the results here...</span>
|
170 |
|
|
<a name="l00064"></a>00064 <span class="vhdlchar">done</span> <span class="vhdlchar"><=</span> <span class="vhdlchar">'</span><span class="vhdllogic"></span><span class="vhdllogic">1</span><span class="vhdlchar">'</span>;
|
171 |
|
|
<a name="l00065"></a>00065 <span class="vhdlchar"><a class="code" href="classdivisor.html#a72b864bee7e5df9aaa6663e15717ee2a" title="Division result (32 bits)">quotient</a></span> <span class="vhdlchar"><=</span> <span class="vhdlchar">CONV_STD_LOGIC_VECTOR</span><span class="vhdlchar">(</span><span class="vhdlchar">Q</span><span class="vhdlchar">,</span><span class="vhdllogic"></span><span class="vhdllogic">32</span><span class="vhdlchar">)</span>;
|
172 |
|
|
<a name="l00066"></a>00066 <span class="vhdlchar"><a class="code" href="classdivisor.html#a2e2b27233f56bb5217044913043942fa" title="Reminder result (32 bits)">reminder</a></span> <span class="vhdlchar"><=</span> <span class="vhdlchar">CONV_STD_LOGIC_VECTOR</span><span class="vhdlchar">(</span><span class="vhdlchar">R</span><span class="vhdlchar">,</span><span class="vhdllogic"></span><span class="vhdllogic">32</span><span class="vhdlchar">)</span>;
|
173 |
|
|
<a name="l00067"></a>00067 <span class="keyword"></span>
|
174 |
|
|
<a name="l00068"></a>00068 <span class="keyword"> -- Used <span class="vhdlkeyword">to</span> avoid transparent latch (Good practise)</span>
|
175 |
|
|
<a name="l00069"></a>00069 <span class="vhdlchar">D</span> <span class="vhdlchar">:=</span> <span class="comment">unsigned</span><span class="vhdlchar">(</span><span class="vhdlchar"><a class="code" href="classdivisor.html#a125151d21c7a62bc99907ddc72a7ebb1" title=""Divide by" number (32 bits)">divident</a></span><span class="vhdlchar">)</span>;
|
176 |
|
|
<a name="l00070"></a>00070 <span class="vhdlchar">N</span> <span class="vhdlchar">:=</span> <span class="comment">unsigned</span><span class="vhdlchar">(</span><span class="vhdlchar"><a class="code" href="classdivisor.html#ad29d3fb6c6ea697db492c43d4a3630eb" title="Numerator (32 bits)">numerator</a></span><span class="vhdlchar">)</span>;
|
177 |
|
|
<a name="l00071"></a>00071 <span class="vhdlkeyword">end</span> <span class="vhdlkeyword">if</span>;
|
178 |
|
|
<a name="l00072"></a>00072 <span class="vhdlkeyword">end</span> <span class="vhdlkeyword">if</span>;
|
179 |
|
|
<a name="l00073"></a>00073 <span class="vhdlkeyword">end</span> <span class="vhdlkeyword">process</span>;
|
180 |
|
|
<a name="l00074"></a>00074
|
181 |
|
|
<a name="l00075"></a>00075 <span class="vhdlkeyword">end</span> <span class="vhdlchar">Behavioral</span>;
|
182 |
|
|
<a name="l00076"></a>00076
|
183 |
|
|
</pre></div></div><!-- contents -->
|
184 |
|
|
</div>
|
185 |
|
|
<div id="nav-path" class="navpath">
|
186 |
|
|
<ul>
|
187 |
|
|
<li class="navelem"><a class="el" href="divisor_8vhd.html">divisor.vhd</a> </li>
|
188 |
|
|
|
189 |
|
|
<li class="footer">Generated on Sat May 12 2012 22:28:05 for Uart wishbone slave Documentation by
|
190 |
|
|
<a href="http://www.doxygen.org/index.html">
|
191 |
|
|
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.0 </li>
|
192 |
|
|
</ul>
|
193 |
|
|
</div>
|
194 |
|
|
|
195 |
|
|
|
196 |
|
|
</body>
|
197 |
|
|
</html>
|