Class: CPUSimu
- Defined in:
- lib/HDLRuby/hdr_samples/sw_encrypt_cpusim_bench.rb
Overview
Simulates an 8-bit data 8-bit address CPU
Instance Attribute Summary
Attributes inherited from CPU
#abus, #ack, #allocator, #clk, #dbus, #req, #rst, #rwb
Instance Method Summary collapse
-
#hw_read ⇒ Object
Read and write are overwritten, save them before.
- #hw_write ⇒ Object
-
#initialize(clk, rst) ⇒ CPUSimu
constructor
Creates a new CPU simulator.
-
#read(code, sig) ⇒ Object
Generates a read of signal +sig+.
-
#write(val, sig) ⇒ Object
Generates a write of +val+ to signal +sig+.
Methods inherited from CPU
Constructor Details
#initialize(clk, rst) ⇒ CPUSimu
Creates a new CPU simulator.
124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 |
# File 'lib/HDLRuby/hdr_samples/sw_encrypt_cpusim_bench.rb', line 124 def initialize(clk,rst) super(8,8,clk,rst) # The read and write control signals. @read_action = inner(HDLRuby.uniq_name) @write_action = inner(HDLRuby.uniq_name) @value = [8].inner(HDLRuby.uniq_name) # The CPU simulator code. this = self read_action,write_action = @read_action, @write_action value = @value par(this.posedge) do hif(this.rst) do read_action <= 0 write_action <= 0 end helse do hif(read_action) do this.hw_read(this.target,value) do read_action <= 0 end end helsif(write_action) do this.hw_write(this.target,write_value) do write_action <= 0 end end end end # The runtime code. code c: [ "unsigned char mem_read(unsigned char addr) { unsigned char res; write8(1,",@read_action,"); wait_cond8(0,",@read_action,"); return read8(",@value,"); } void mem_write(unsigned char val, unsigned char addr) { unsigned char res; write8(1,",@write_action,"); write8(val,",@value,"); wait_cond8(0,",@write_action,"); } "], h: "extern unsigned char mem_read(unsigned char addr); extern void mem_write(unsigned char val, unsigned char addr); " end |
Instance Method Details
#hw_read ⇒ Object
Read and write are overwritten, save them before.
119 |
# File 'lib/HDLRuby/hdr_samples/sw_encrypt_cpusim_bench.rb', line 119 alias_method :hw_read, :read |
#hw_write ⇒ Object
120 |
# File 'lib/HDLRuby/hdr_samples/sw_encrypt_cpusim_bench.rb', line 120 alias_method :hw_write, :write |
#read(code, sig) ⇒ Object
Generates a read of signal +sig+.
179 180 181 182 |
# File 'lib/HDLRuby/hdr_samples/sw_encrypt_cpusim_bench.rb', line 179 def read(code,sig) # Generate the resulting SW access. return ["mem_read(",code,"0x#{self.allocator.get(sig).to_s(16)})"] end |
#write(val, sig) ⇒ Object
Generates a write of +val+ to signal +sig+.
185 186 187 188 |
# File 'lib/HDLRuby/hdr_samples/sw_encrypt_cpusim_bench.rb', line 185 def write(val,sig) # Generate the resulting SW access. return ["mem_write(,",code,",#{val},#{self.allocator.get(sig).to_s(16)})"] end |