Class: CPUSimu

Inherits:
CPU
  • Object
show all
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

Methods inherited from CPU

#connect, #controller

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_readObject

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_writeObject



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