mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
examples/wb_intercon: update to new APIs
This commit is contained in:
parent
6a9b59786b
commit
3143608e0a
4 changed files with 109 additions and 109 deletions
|
@ -1,10 +1,10 @@
|
||||||
from migen.fhdl import verilog
|
from migen.fhdl import verilog
|
||||||
from migen.bus import wishbone
|
from migen.bus import wishbone
|
||||||
|
|
||||||
m1 = wishbone.Master("m1")
|
m1 = wishbone.Master()
|
||||||
m2 = wishbone.Master("m2")
|
m2 = wishbone.Master()
|
||||||
s1 = wishbone.Slave("s1")
|
s1 = wishbone.Slave()
|
||||||
s2 = wishbone.Slave("s2")
|
s2 = wishbone.Slave()
|
||||||
wishbonecon0 = wishbone.InterconnectShared(
|
wishbonecon0 = wishbone.InterconnectShared(
|
||||||
[m1, m2],
|
[m1, m2],
|
||||||
[(0, s1), (1, s2)],
|
[(0, s1), (1, s2)],
|
||||||
|
|
|
@ -26,7 +26,7 @@ module master #(
|
||||||
|
|
||||||
output reg [31:0] dat_w,
|
output reg [31:0] dat_w,
|
||||||
input [31:0] dat_r,
|
input [31:0] dat_r,
|
||||||
output reg [31:0] adr,
|
output reg [29:0] adr,
|
||||||
output reg we,
|
output reg we,
|
||||||
output reg [3:0] sel,
|
output reg [3:0] sel,
|
||||||
output cyc,
|
output cyc,
|
||||||
|
@ -66,7 +66,7 @@ always @(posedge sys_clk) begin
|
||||||
active <= 1'b0;
|
active <= 1'b0;
|
||||||
end else if(~active) begin
|
end else if(~active) begin
|
||||||
if(($random % p) == 0) begin
|
if(($random % p) == 0) begin
|
||||||
adr <= (($random % 5)<< (32-2)) + id;
|
adr <= (($random % 5) << (30-2)) + id;
|
||||||
sel <= sel + 1;
|
sel <= sel + 1;
|
||||||
active <= 1'b1;
|
active <= 1'b1;
|
||||||
if(($random % 2) == 0) begin
|
if(($random % 2) == 0) begin
|
||||||
|
|
|
@ -24,7 +24,7 @@ module slave #(
|
||||||
|
|
||||||
input [31:0] dat_w,
|
input [31:0] dat_w,
|
||||||
output reg [31:0] dat_r,
|
output reg [31:0] dat_r,
|
||||||
input [31:0] adr,
|
input [29:0] adr,
|
||||||
input we,
|
input we,
|
||||||
input [3:0] sel,
|
input [3:0] sel,
|
||||||
input cyc,
|
input cyc,
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
/*
|
/*
|
||||||
* Milkymist SoC
|
* Milkymist SoC
|
||||||
* Copyright (C) 2007, 2008, 2009, 2011 Sebastien Bourdeauducq
|
* Copyright (C) 2007, 2008, 2009, 2011, 2012 Sebastien Bourdeauducq
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
@ -23,54 +23,54 @@ reg sys_clk;
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
// Wishbone master wires
|
// Wishbone master wires
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
wire [31:0] wishbone_m1_adr,
|
wire [29:0] m1_wishbone_adr,
|
||||||
wishbone_m2_adr;
|
m2_wishbone_adr;
|
||||||
|
|
||||||
wire [31:0] wishbone_m1_dat_r,
|
wire [31:0] m1_wishbone_dat_r,
|
||||||
wishbone_m1_dat_w,
|
m1_wishbone_dat_w,
|
||||||
wishbone_m2_dat_r,
|
m2_wishbone_dat_r,
|
||||||
wishbone_m2_dat_w;
|
m2_wishbone_dat_w;
|
||||||
|
|
||||||
wire [3:0] wishbone_m1_sel,
|
wire [3:0] m1_wishbone_sel,
|
||||||
wishbone_m2_sel;
|
m2_wishbone_sel;
|
||||||
|
|
||||||
wire wishbone_m1_we,
|
wire m1_wishbone_we,
|
||||||
wishbone_m2_we;
|
m2_wishbone_we;
|
||||||
|
|
||||||
wire wishbone_m1_cyc,
|
wire m1_wishbone_cyc,
|
||||||
wishbone_m2_cyc;
|
m2_wishbone_cyc;
|
||||||
|
|
||||||
wire wishbone_m1_stb,
|
wire m1_wishbone_stb,
|
||||||
wishbone_m2_stb;
|
m2_wishbone_stb;
|
||||||
|
|
||||||
wire wishbone_m1_ack,
|
wire m1_wishbone_ack,
|
||||||
wishbone_m2_ack;
|
m2_wishbone_ack;
|
||||||
|
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
// Wishbone slave wires
|
// Wishbone slave wires
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
wire [31:0] wishbone_s1_adr,
|
wire [29:0] s1_wishbone_adr,
|
||||||
wishbone_s2_adr;
|
s2_wishbone_adr;
|
||||||
|
|
||||||
wire [31:0] wishbone_s1_dat_r,
|
wire [31:0] s1_wishbone_dat_r,
|
||||||
wishbone_s1_dat_w,
|
s1_wishbone_dat_w,
|
||||||
wishbone_s2_dat_r,
|
s2_wishbone_dat_r,
|
||||||
wishbone_s2_dat_w;
|
s2_wishbone_dat_w;
|
||||||
|
|
||||||
wire [3:0] wishbone_s1_sel,
|
wire [3:0] s1_wishbone_sel,
|
||||||
wishbone_s2_sel;
|
s2_wishbone_sel;
|
||||||
|
|
||||||
wire wishbone_s1_we,
|
wire s1_wishbone_we,
|
||||||
wishbone_s2_we;
|
s2_wishbone_we;
|
||||||
|
|
||||||
wire wishbone_s1_cyc,
|
wire s1_wishbone_cyc,
|
||||||
wishbone_s2_cyc;
|
s2_wishbone_cyc;
|
||||||
|
|
||||||
wire wishbone_s1_stb,
|
wire s1_wishbone_stb,
|
||||||
wishbone_s2_stb;
|
s2_wishbone_stb;
|
||||||
|
|
||||||
wire wishbone_s1_ack,
|
wire s1_wishbone_ack,
|
||||||
wishbone_s2_ack;
|
s2_wishbone_ack;
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
// Wishbone switch
|
// Wishbone switch
|
||||||
|
@ -80,84 +80,84 @@ intercon dut(
|
||||||
.sys_rst(sys_rst),
|
.sys_rst(sys_rst),
|
||||||
|
|
||||||
// Master 0
|
// Master 0
|
||||||
.wishbone_m1_dat_o(wishbone_m1_dat_w),
|
.m1_wishbone_dat_o(m1_wishbone_dat_w),
|
||||||
.wishbone_m1_dat_i(wishbone_m1_dat_r),
|
.m1_wishbone_dat_i(m1_wishbone_dat_r),
|
||||||
.wishbone_m1_adr_o(wishbone_m1_adr),
|
.m1_wishbone_adr_o(m1_wishbone_adr),
|
||||||
.wishbone_m1_we_o(wishbone_m1_we),
|
.m1_wishbone_we_o(m1_wishbone_we),
|
||||||
.wishbone_m1_sel_o(wishbone_m1_sel),
|
.m1_wishbone_sel_o(m1_wishbone_sel),
|
||||||
.wishbone_m1_cyc_o(wishbone_m1_cyc),
|
.m1_wishbone_cyc_o(m1_wishbone_cyc),
|
||||||
.wishbone_m1_stb_o(wishbone_m1_stb),
|
.m1_wishbone_stb_o(m1_wishbone_stb),
|
||||||
.wishbone_m1_ack_i(wishbone_m1_ack),
|
.m1_wishbone_ack_i(m1_wishbone_ack),
|
||||||
// Master 1
|
// Master 1
|
||||||
.wishbone_m2_dat_o(wishbone_m2_dat_w),
|
.m2_wishbone_dat_o(m2_wishbone_dat_w),
|
||||||
.wishbone_m2_dat_i(wishbone_m2_dat_r),
|
.m2_wishbone_dat_i(m2_wishbone_dat_r),
|
||||||
.wishbone_m2_adr_o(wishbone_m2_adr),
|
.m2_wishbone_adr_o(m2_wishbone_adr),
|
||||||
.wishbone_m2_we_o(wishbone_m2_we),
|
.m2_wishbone_we_o(m2_wishbone_we),
|
||||||
.wishbone_m2_sel_o(wishbone_m2_sel),
|
.m2_wishbone_sel_o(m2_wishbone_sel),
|
||||||
.wishbone_m2_cyc_o(wishbone_m2_cyc),
|
.m2_wishbone_cyc_o(m2_wishbone_cyc),
|
||||||
.wishbone_m2_stb_o(wishbone_m2_stb),
|
.m2_wishbone_stb_o(m2_wishbone_stb),
|
||||||
.wishbone_m2_ack_i(wishbone_m2_ack),
|
.m2_wishbone_ack_i(m2_wishbone_ack),
|
||||||
|
|
||||||
// Slave 0
|
// Slave 0
|
||||||
.wishbone_s1_dat_o(wishbone_s1_dat_r),
|
.s1_wishbone_dat_o(s1_wishbone_dat_r),
|
||||||
.wishbone_s1_dat_i(wishbone_s1_dat_w),
|
.s1_wishbone_dat_i(s1_wishbone_dat_w),
|
||||||
.wishbone_s1_adr_i(wishbone_s1_adr),
|
.s1_wishbone_adr_i(s1_wishbone_adr),
|
||||||
.wishbone_s1_sel_i(wishbone_s1_sel),
|
.s1_wishbone_sel_i(s1_wishbone_sel),
|
||||||
.wishbone_s1_we_i(wishbone_s1_we),
|
.s1_wishbone_we_i(s1_wishbone_we),
|
||||||
.wishbone_s1_cyc_i(wishbone_s1_cyc),
|
.s1_wishbone_cyc_i(s1_wishbone_cyc),
|
||||||
.wishbone_s1_stb_i(wishbone_s1_stb),
|
.s1_wishbone_stb_i(s1_wishbone_stb),
|
||||||
.wishbone_s1_ack_o(wishbone_s1_ack),
|
.s1_wishbone_ack_o(s1_wishbone_ack),
|
||||||
// Slave 1
|
// Slave 1
|
||||||
.wishbone_s2_dat_o(wishbone_s2_dat_r),
|
.s2_wishbone_dat_o(s2_wishbone_dat_r),
|
||||||
.wishbone_s2_dat_i(wishbone_s2_dat_w),
|
.s2_wishbone_dat_i(s2_wishbone_dat_w),
|
||||||
.wishbone_s2_adr_i(wishbone_s2_adr),
|
.s2_wishbone_adr_i(s2_wishbone_adr),
|
||||||
.wishbone_s2_sel_i(wishbone_s2_sel),
|
.s2_wishbone_sel_i(s2_wishbone_sel),
|
||||||
.wishbone_s2_we_i(wishbone_s2_we),
|
.s2_wishbone_we_i(s2_wishbone_we),
|
||||||
.wishbone_s2_cyc_i(wishbone_s2_cyc),
|
.s2_wishbone_cyc_i(s2_wishbone_cyc),
|
||||||
.wishbone_s2_stb_i(wishbone_s2_stb),
|
.s2_wishbone_stb_i(s2_wishbone_stb),
|
||||||
.wishbone_s2_ack_o(wishbone_s2_ack)
|
.s2_wishbone_ack_o(s2_wishbone_ack)
|
||||||
);
|
);
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
// Masters
|
// Masters
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
wire wishbone_m1_end;
|
wire m1_wishbone_end;
|
||||||
master #(
|
master #(
|
||||||
.id(0)
|
.id(0)
|
||||||
) m0 (
|
) m0 (
|
||||||
.sys_clk(sys_clk),
|
.sys_clk(sys_clk),
|
||||||
.sys_rst(sys_rst),
|
.sys_rst(sys_rst),
|
||||||
|
|
||||||
.dat_w(wishbone_m1_dat_w),
|
.dat_w(m1_wishbone_dat_w),
|
||||||
.dat_r(wishbone_m1_dat_r),
|
.dat_r(m1_wishbone_dat_r),
|
||||||
.adr(wishbone_m1_adr),
|
.adr(m1_wishbone_adr),
|
||||||
.we(wishbone_m1_we),
|
.we(m1_wishbone_we),
|
||||||
.sel(wishbone_m1_sel),
|
.sel(m1_wishbone_sel),
|
||||||
.cyc(wishbone_m1_cyc),
|
.cyc(m1_wishbone_cyc),
|
||||||
.stb(wishbone_m1_stb),
|
.stb(m1_wishbone_stb),
|
||||||
.ack(wishbone_m1_ack),
|
.ack(m1_wishbone_ack),
|
||||||
|
|
||||||
.tend(wishbone_m1_end)
|
.tend(m1_wishbone_end)
|
||||||
);
|
);
|
||||||
|
|
||||||
wire wishbone_m2_end;
|
wire m2_wishbone_end;
|
||||||
master #(
|
master #(
|
||||||
.id(1)
|
.id(1)
|
||||||
) m1 (
|
) m1 (
|
||||||
.sys_clk(sys_clk),
|
.sys_clk(sys_clk),
|
||||||
.sys_rst(sys_rst),
|
.sys_rst(sys_rst),
|
||||||
|
|
||||||
.dat_w(wishbone_m2_dat_w),
|
.dat_w(m2_wishbone_dat_w),
|
||||||
.dat_r(wishbone_m2_dat_r),
|
.dat_r(m2_wishbone_dat_r),
|
||||||
.adr(wishbone_m2_adr),
|
.adr(m2_wishbone_adr),
|
||||||
.we(wishbone_m2_we),
|
.we(m2_wishbone_we),
|
||||||
.sel(wishbone_m2_sel),
|
.sel(m2_wishbone_sel),
|
||||||
.cyc(wishbone_m2_cyc),
|
.cyc(m2_wishbone_cyc),
|
||||||
.stb(wishbone_m2_stb),
|
.stb(m2_wishbone_stb),
|
||||||
.ack(wishbone_m2_ack),
|
.ack(m2_wishbone_ack),
|
||||||
|
|
||||||
.tend(wishbone_m2_end)
|
.tend(m2_wishbone_end)
|
||||||
);
|
);
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
@ -170,14 +170,14 @@ slave #(
|
||||||
.sys_clk(sys_clk),
|
.sys_clk(sys_clk),
|
||||||
.sys_rst(sys_rst),
|
.sys_rst(sys_rst),
|
||||||
|
|
||||||
.dat_w(wishbone_s1_dat_w),
|
.dat_w(s1_wishbone_dat_w),
|
||||||
.dat_r(wishbone_s1_dat_r),
|
.dat_r(s1_wishbone_dat_r),
|
||||||
.adr(wishbone_s1_adr),
|
.adr(s1_wishbone_adr),
|
||||||
.we(wishbone_s1_we),
|
.we(s1_wishbone_we),
|
||||||
.sel(wishbone_s1_sel),
|
.sel(s1_wishbone_sel),
|
||||||
.cyc(wishbone_s1_cyc),
|
.cyc(s1_wishbone_cyc),
|
||||||
.stb(wishbone_s1_stb),
|
.stb(s1_wishbone_stb),
|
||||||
.ack(wishbone_s1_ack)
|
.ack(s1_wishbone_ack)
|
||||||
);
|
);
|
||||||
|
|
||||||
slave #(
|
slave #(
|
||||||
|
@ -186,20 +186,20 @@ slave #(
|
||||||
.sys_clk(sys_clk),
|
.sys_clk(sys_clk),
|
||||||
.sys_rst(sys_rst),
|
.sys_rst(sys_rst),
|
||||||
|
|
||||||
.dat_w(wishbone_s2_dat_w),
|
.dat_w(s2_wishbone_dat_w),
|
||||||
.dat_r(wishbone_s2_dat_r),
|
.dat_r(s2_wishbone_dat_r),
|
||||||
.adr(wishbone_s2_adr),
|
.adr(s2_wishbone_adr),
|
||||||
.we(wishbone_s2_we),
|
.we(s2_wishbone_we),
|
||||||
.sel(wishbone_s2_sel),
|
.sel(s2_wishbone_sel),
|
||||||
.cyc(wishbone_s2_cyc),
|
.cyc(s2_wishbone_cyc),
|
||||||
.stb(wishbone_s2_stb),
|
.stb(s2_wishbone_stb),
|
||||||
.ack(wishbone_s2_ack)
|
.ack(s2_wishbone_ack)
|
||||||
);
|
);
|
||||||
|
|
||||||
initial sys_clk = 1'b0;
|
initial sys_clk = 1'b0;
|
||||||
always #5 sys_clk = ~sys_clk;
|
always #5 sys_clk = ~sys_clk;
|
||||||
|
|
||||||
wire all_end = wishbone_m1_end & wishbone_m2_end;
|
wire all_end = m1_wishbone_end & m2_wishbone_end;
|
||||||
|
|
||||||
always begin
|
always begin
|
||||||
$dumpfile("intercon.vcd");
|
$dumpfile("intercon.vcd");
|
||||||
|
|
Loading…
Reference in a new issue