summaryrefslogtreecommitdiff
path: root/rtl/bus/master.sv
diff options
context:
space:
mode:
authorAlejandro Soto <alejandro@34project.org>2022-09-04 16:14:37 -0600
committerAlejandro Soto <alejandro@34project.org>2022-09-04 16:14:37 -0600
commitfa3610a57e89dd667075cd8922a07a69ec433fa0 (patch)
treebaec1961a9b1dcfbfcd83cba179d2bb50f22c233 /rtl/bus/master.sv
parent9f058168d27de269df7c40f43a9070478971c4be (diff)
Add Avalon bus master
Diffstat (limited to 'rtl/bus/master.sv')
-rw-r--r--rtl/bus/master.sv58
1 files changed, 58 insertions, 0 deletions
diff --git a/rtl/bus/master.sv b/rtl/bus/master.sv
new file mode 100644
index 0000000..63ea2be
--- /dev/null
+++ b/rtl/bus/master.sv
@@ -0,0 +1,58 @@
+module bus_master
+(
+ input logic clk,
+ rst,
+
+ input logic[29:0] addr,
+ input logic start,
+ write,
+ output logic ready,
+ output logic[31:0] data_rd,
+ input logic[31:0] data_rw,
+
+ output logic[31:0] avl_address,
+ output logic avl_read,
+ avl_write,
+ input logic[31:0] avl_readdata,
+ output logic[31:0] avl_writedata,
+ input logic avl_waitrequest,
+ output logic[3:0] avl_byteenable
+);
+
+ enum {
+ REQUEST,
+ WAIT,
+ RESPONSE
+ } state;
+
+ assign data_rd = avl_readdata;
+
+ always_ff @(posedge clk) unique case(state)
+ REQUEST: if(start) begin
+ avl_address <= {addr, 2'b00};
+ avl_read <= ~write;
+ avl_write <= write;
+ avl_writedata <= data_rw;
+ end
+
+ WAIT: if(~avl_waitrequest) begin
+ ready <= 1;
+ state <= RESPONSE;
+ end
+
+ RESPONSE: begin
+ ready <= 0;
+ avl_read <= 0;
+ avl_write <= 0;
+ state <= REQUEST;
+ end
+ endcase
+
+ initial begin
+ ready <= 0;
+ avl_read <= 0;
+ avl_write <= 0;
+ state <= REQUEST;
+ end
+
+endmodule