mirror of
https://github.com/YosysHQ/yosys
synced 2025-08-22 11:07:52 +00:00
initial import
This commit is contained in:
commit
7764d0ba1d
481 changed files with 54634 additions and 0 deletions
125
tests/i2c_bench/spi_slave_model.v
Normal file
125
tests/i2c_bench/spi_slave_model.v
Normal file
|
@ -0,0 +1,125 @@
|
|||
/////////////////////////////////////////////////////////////////////
|
||||
//// ////
|
||||
//// SPI Slave Model ////
|
||||
//// ////
|
||||
//// ////
|
||||
//// Authors: Richard Herveille (richard@asics.ws) www.asics.ws ////
|
||||
//// ////
|
||||
//// http://www.opencores.org/projects/simple_spi/ ////
|
||||
//// ////
|
||||
/////////////////////////////////////////////////////////////////////
|
||||
//// ////
|
||||
//// Copyright (C) 2004 Richard Herveille ////
|
||||
//// richard@asics.ws ////
|
||||
//// ////
|
||||
//// This source file may be used and distributed without ////
|
||||
//// restriction provided that this copyright statement is not ////
|
||||
//// removed from the file and that any derivative work contains ////
|
||||
//// the original copyright notice and the associated disclaimer.////
|
||||
//// ////
|
||||
//// THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY ////
|
||||
//// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED ////
|
||||
//// TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS ////
|
||||
//// FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL THE AUTHOR ////
|
||||
//// OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, ////
|
||||
//// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES ////
|
||||
//// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE ////
|
||||
//// GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR ////
|
||||
//// BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF ////
|
||||
//// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT ////
|
||||
//// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT ////
|
||||
//// OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE ////
|
||||
//// POSSIBILITY OF SUCH DAMAGE. ////
|
||||
//// ////
|
||||
/////////////////////////////////////////////////////////////////////
|
||||
|
||||
// CVS Log
|
||||
//
|
||||
// $Id: spi_slave_model.v,v 1.1 2004-02-28 15:32:54 rherveille Exp $
|
||||
//
|
||||
// $Date: 2004-02-28 15:32:54 $
|
||||
// $Revision: 1.1 $
|
||||
// $Author: rherveille $
|
||||
// $Locker: $
|
||||
// $State: Exp $
|
||||
//
|
||||
// Change History:
|
||||
// $Log: not supported by cvs2svn $
|
||||
//
|
||||
//
|
||||
|
||||
|
||||
// Requires: Verilog2001
|
||||
|
||||
`include "timescale.v"
|
||||
|
||||
module spi_slave_model (
|
||||
input wire csn,
|
||||
input wire sc,
|
||||
input wire di,
|
||||
output wire do
|
||||
);
|
||||
|
||||
//
|
||||
// Variable declaration
|
||||
//
|
||||
wire debug = 1'b1;
|
||||
|
||||
wire cpol = 1'b0;
|
||||
wire cpha = 1'b0;
|
||||
|
||||
reg [7:0] mem [7:0]; // initiate memory
|
||||
reg [2:0] mem_adr; // memory address
|
||||
reg [7:0] mem_do; // memory data output
|
||||
|
||||
reg [7:0] sri, sro; // 8bit shift register
|
||||
|
||||
reg [2:0] bit_cnt;
|
||||
reg ld;
|
||||
|
||||
wire clk;
|
||||
|
||||
//
|
||||
// module body
|
||||
//
|
||||
|
||||
assign clk = cpol ^ cpha ^ sc;
|
||||
|
||||
// generate shift registers
|
||||
always @(posedge clk)
|
||||
sri <= #1 {sri[6:0],di};
|
||||
|
||||
always @(posedge clk)
|
||||
if (&bit_cnt)
|
||||
sro <= #1 mem[mem_adr];
|
||||
else
|
||||
sro <= #1 {sro[6:0],1'bx};
|
||||
|
||||
assign do = sro[7];
|
||||
|
||||
//generate bit-counter
|
||||
always @(posedge clk, posedge csn)
|
||||
if(csn)
|
||||
bit_cnt <= #1 3'b111;
|
||||
else
|
||||
bit_cnt <= #1 bit_cnt - 3'h1;
|
||||
|
||||
//generate access done signal
|
||||
always @(posedge clk)
|
||||
ld <= #1 ~(|bit_cnt);
|
||||
|
||||
always @(negedge clk)
|
||||
if (ld) begin
|
||||
mem[mem_adr] <= #1 sri;
|
||||
mem_adr <= #1 mem_adr + 1'b1;
|
||||
end
|
||||
|
||||
initial
|
||||
begin
|
||||
bit_cnt=3'b111;
|
||||
mem_adr = 0;
|
||||
sro = mem[mem_adr];
|
||||
end
|
||||
endmodule
|
||||
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue