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.
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 175 176 |
# File 'lib/HDLRuby/hdr_samples/sw_encrypt_cpusim_bench.rb', line 126 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.
121 |
# File 'lib/HDLRuby/hdr_samples/sw_encrypt_cpusim_bench.rb', line 121 alias_method :hw_read, :read |
#hw_write ⇒ Object
122 |
# File 'lib/HDLRuby/hdr_samples/sw_encrypt_cpusim_bench.rb', line 122 alias_method :hw_write, :write |
#read(code, sig) ⇒ Object
Generates a read of signal +sig+.
181 182 183 184 |
# File 'lib/HDLRuby/hdr_samples/sw_encrypt_cpusim_bench.rb', line 181 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+.
187 188 189 190 |
# File 'lib/HDLRuby/hdr_samples/sw_encrypt_cpusim_bench.rb', line 187 def write(val,sig) # Generate the resulting SW access. return ["mem_write(,",code,",#{val},#{self.allocator.get(sig).to_s(16)})"] end |