diff options
author | johannst <johannst@users.noreply.github.com> | 2024-12-13 00:18:53 +0000 |
---|---|---|
committer | johannst <johannst@users.noreply.github.com> | 2024-12-13 00:18:53 +0000 |
commit | c94a65c993f5da6a86bd1e6d23e359ba2052f836 (patch) | |
tree | 8ca23ecd01fb4cd26c958e310c3f352cc7c73d63 /src/juicebox_asm/lib.rs.html | |
parent | 741d915aed07eb4ea265d8e90cf64e8ca6552ddc (diff) | |
download | juicebox-asm-c94a65c993f5da6a86bd1e6d23e359ba2052f836.tar.gz juicebox-asm-c94a65c993f5da6a86bd1e6d23e359ba2052f836.zip |
deploy: 758f014afb8ec5c20ef2fc862fc12e80f65d3d25
Diffstat (limited to 'src/juicebox_asm/lib.rs.html')
-rw-r--r-- | src/juicebox_asm/lib.rs.html | 154 |
1 files changed, 3 insertions, 151 deletions
diff --git a/src/juicebox_asm/lib.rs.html b/src/juicebox_asm/lib.rs.html index 2b9ed8a..4b32e80 100644 --- a/src/juicebox_asm/lib.rs.html +++ b/src/juicebox_asm/lib.rs.html @@ -88,81 +88,7 @@ <a href="#87" id="87">87</a> <a href="#88" id="88">88</a> <a href="#89" id="89">89</a> -<a href="#90" id="90">90</a> -<a href="#91" id="91">91</a> -<a href="#92" id="92">92</a> -<a href="#93" id="93">93</a> -<a href="#94" id="94">94</a> -<a href="#95" id="95">95</a> -<a href="#96" id="96">96</a> -<a href="#97" id="97">97</a> -<a href="#98" id="98">98</a> -<a href="#99" id="99">99</a> -<a href="#100" id="100">100</a> -<a href="#101" id="101">101</a> -<a href="#102" id="102">102</a> -<a href="#103" id="103">103</a> -<a href="#104" id="104">104</a> -<a href="#105" id="105">105</a> -<a href="#106" id="106">106</a> -<a href="#107" id="107">107</a> -<a href="#108" id="108">108</a> -<a href="#109" id="109">109</a> -<a href="#110" id="110">110</a> -<a href="#111" id="111">111</a> -<a href="#112" id="112">112</a> -<a href="#113" id="113">113</a> -<a href="#114" id="114">114</a> -<a href="#115" id="115">115</a> -<a href="#116" id="116">116</a> -<a href="#117" id="117">117</a> -<a href="#118" id="118">118</a> -<a href="#119" id="119">119</a> -<a href="#120" id="120">120</a> -<a href="#121" id="121">121</a> -<a href="#122" id="122">122</a> -<a href="#123" id="123">123</a> -<a href="#124" id="124">124</a> -<a href="#125" id="125">125</a> -<a href="#126" id="126">126</a> -<a href="#127" id="127">127</a> -<a href="#128" id="128">128</a> -<a href="#129" id="129">129</a> -<a href="#130" id="130">130</a> -<a href="#131" id="131">131</a> -<a href="#132" id="132">132</a> -<a href="#133" id="133">133</a> -<a href="#134" id="134">134</a> -<a href="#135" id="135">135</a> -<a href="#136" id="136">136</a> -<a href="#137" id="137">137</a> -<a href="#138" id="138">138</a> -<a href="#139" id="139">139</a> -<a href="#140" id="140">140</a> -<a href="#141" id="141">141</a> -<a href="#142" id="142">142</a> -<a href="#143" id="143">143</a> -<a href="#144" id="144">144</a> -<a href="#145" id="145">145</a> -<a href="#146" id="146">146</a> -<a href="#147" id="147">147</a> -<a href="#148" id="148">148</a> -<a href="#149" id="149">149</a> -<a href="#150" id="150">150</a> -<a href="#151" id="151">151</a> -<a href="#152" id="152">152</a> -<a href="#153" id="153">153</a> -<a href="#154" id="154">154</a> -<a href="#155" id="155">155</a> -<a href="#156" id="156">156</a> -<a href="#157" id="157">157</a> -<a href="#158" id="158">158</a> -<a href="#159" id="159">159</a> -<a href="#160" id="160">160</a> -<a href="#161" id="161">161</a> -<a href="#162" id="162">162</a> -<a href="#163" id="163">163</a> -<a href="#164" id="164">164</a></pre></div><pre class="rust"><code><span class="doccomment">//! A simple `x64` jit assembler with a minimal runtime to execute emitted code for fun. +<a href="#90" id="90">90</a></pre></div><pre class="rust"><code><span class="doccomment">//! A simple `x64` jit assembler with a minimal runtime to execute emitted code for fun. //! //! The following is an fibonacci example implementation. //! ```rust @@ -240,6 +166,7 @@ </span><span class="kw">mod </span>asm; <span class="kw">mod </span>imm; <span class="kw">mod </span>label; +<span class="kw">mod </span>mem; <span class="kw">mod </span>reg; <span class="kw">mod </span>rt; @@ -248,82 +175,7 @@ <span class="kw">pub use </span>asm::Asm; <span class="kw">pub use </span>imm::{Imm16, Imm32, Imm64, Imm8}; <span class="kw">pub use </span>label::Label; +<span class="kw">pub use </span>mem::{Mem16, Mem32, Mem64, Mem8}; <span class="kw">pub use </span>reg::{Reg16, Reg32, Reg64, Reg8}; <span class="kw">pub use </span>rt::Runtime; - -<span class="doccomment">/// Type representing a memory operand. -</span><span class="attr">#[derive(Clone, Copy)] -</span><span class="kw">pub enum </span>MemOp { - <span class="doccomment">/// An indirect memory operand, eg `mov [rax], rcx`. - </span>Indirect(Reg64), - - <span class="doccomment">/// An indirect memory operand with additional displacement, eg `mov [rax + 0x10], rcx`. - </span>IndirectDisp(Reg64, i32), - - <span class="doccomment">/// An indirect memory operand in the form base + index, eg `mov [rax + rcx], rdx`. - </span>IndirectBaseIndex(Reg64, Reg64), -} - -<span class="kw">impl </span>MemOp { - <span class="doccomment">/// Get the base address register of the memory operand. - </span><span class="kw">const fn </span>base(<span class="kw-2">&</span><span class="self">self</span>) -> Reg64 { - <span class="kw">match </span><span class="self">self </span>{ - MemOp::Indirect(base) => <span class="kw-2">*</span>base, - MemOp::IndirectDisp(base, ..) => <span class="kw-2">*</span>base, - MemOp::IndirectBaseIndex(base, ..) => <span class="kw-2">*</span>base, - } - } - - <span class="doccomment">/// Get the index register of the memory operand. - </span><span class="kw">fn </span>index(<span class="kw-2">&</span><span class="self">self</span>) -> Reg64 { - <span class="comment">// Return zero index register for memory operands w/o index register. - </span><span class="kw">let </span>zero_index = Reg64::rax; - <span class="kw">use </span>reg::Reg; - <span class="macro">assert_eq!</span>(zero_index.idx(), <span class="number">0</span>); - - <span class="kw">match </span><span class="self">self </span>{ - MemOp::Indirect(..) => zero_index, - MemOp::IndirectDisp(..) => zero_index, - MemOp::IndirectBaseIndex(.., index) => <span class="kw-2">*</span>index, - } - } -} - -<span class="doccomment">/// Trait to give size hints for memory operands. -</span><span class="kw">trait </span>MemOpSized { - <span class="kw">fn </span>mem_op(<span class="kw-2">&</span><span class="self">self</span>) -> MemOp; -} - -<span class="macro">macro_rules!</span> impl_memop_sized { - ($(<span class="attr">#[<span class="macro-nonterminal">$doc</span>:meta] </span><span class="macro-nonterminal">$name</span>:ident)+) => { - $( - <span class="attr">#[<span class="macro-nonterminal">$doc</span>] - </span><span class="kw">pub struct </span><span class="macro-nonterminal">$name</span>(MemOp); - - <span class="kw">impl </span><span class="macro-nonterminal">$name </span>{ - <span class="doccomment">/// Create a memory with size hint from a raw memory operand. - </span><span class="kw">pub fn </span>from(op: MemOp) -> <span class="self">Self </span>{ - <span class="self">Self</span>(op) - } - } - - <span class="kw">impl </span>MemOpSized <span class="kw">for </span><span class="macro-nonterminal">$name </span>{ - <span class="kw">fn </span>mem_op(<span class="kw-2">&</span><span class="self">self</span>) -> MemOp { - <span class="self">self</span>.<span class="number">0 - </span>} - } - )+ - }; -} - -<span class="macro">impl_memop_sized!</span>( - <span class="doccomment">/// A memory operand with a word (8 bit) size hint. - </span>MemOp8 - <span class="doccomment">/// A memory operand with a word (16 bit) size hint. - </span>MemOp16 - <span class="doccomment">/// A memory operand with a dword (32 bit) size hint. - </span>MemOp32 - <span class="doccomment">/// A memory operand with a qword (64 bit) size hint. - </span>MemOp64 -); </code></pre></div></section></main></body></html>
\ No newline at end of file |