OpenCores
URL https://opencores.org/ocsvn/qaz_libs/qaz_libs/trunk

Subversion Repositories qaz_libs

[/] [qaz_libs/] [trunk/] [avalon_lib/] [sim/] [src/] [amm_bfm/] [amm_master_bfm_if.sv] - Blame information for rev 31

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 31 qaztronic
//////////////////////////////////////////////////////////////////////
2
////                                                              ////
3
//// Copyright (C) 2015 Authors and OPENCORES.ORG                 ////
4
////                                                              ////
5
//// This source file may be used and distributed without         ////
6
//// restriction provided that this copyright statement is not    ////
7
//// removed from the file and that any derivative work contains  ////
8
//// the original copyright notice and the associated disclaimer. ////
9
////                                                              ////
10
//// This source file is free software; you can redistribute it   ////
11
//// and/or modify it under the terms of the GNU Lesser General   ////
12
//// Public License as published by the Free Software Foundation; ////
13
//// either version 2.1 of the License, or (at your option) any   ////
14
//// later version.                                               ////
15
////                                                              ////
16
//// This source is distributed in the hope that it will be       ////
17
//// useful, but WITHOUT ANY WARRANTY; without even the implied   ////
18
//// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR      ////
19
//// PURPOSE.  See the GNU Lesser General Public License for more ////
20
//// details.                                                     ////
21
////                                                              ////
22
//// You should have received a copy of the GNU Lesser General    ////
23
//// Public License along with this source; if not, download it   ////
24
//// from http://www.opencores.org/lgpl.shtml                     ////
25
////                                                              ////
26
//////////////////////////////////////////////////////////////////////
27
 
28
 
29
interface
30
  amm_master_bfm_if
31
  #(
32
    A = 32, // address bus width
33
    N = 8   // data bus width in bytes
34
  )
35
  (
36
    amm_if amm_s,
37
    input reset,
38
    input clk
39
  );
40
 
41
        logic [(A-1):0]   address;
42
        logic             read;
43
        logic   [(8*N)-1:0] readdata;
44
        logic             write;
45
        logic   [(8*N)-1:0] writedata;
46
        logic   [N-1:0]     byteenable;
47
        logic             waitrequest;
48
        logic             arbiterlock;
49
        logic             readdatavalid;
50
        logic   [6:0]       burstcount;
51
        logic               resetrequest;
52
 
53
 
54
  // --------------------------------------------------------------------
55
  //
56
  default clocking cb @(posedge clk);
57
    output address;
58
    output read;
59
    input  readdata;
60
    output write;
61
    output writedata;
62
    output byteenable;
63
    input  waitrequest;
64
    output arbiterlock;
65
    input  readdatavalid;
66
    output burstcount;
67
    output resetrequest;
68
    input   reset;
69
    input   clk;
70
  endclocking
71
 
72
 
73
  // --------------------------------------------------------------------
74
  //
75
  assign amm_s.address      = address;
76
  assign amm_s.read         = read;
77
  assign readdata           = amm_s.readdata;
78
  assign amm_s.write        = write;
79
  assign amm_s.writedata    = writedata;
80
  assign amm_s.byteenable   = byteenable;
81
  assign waitrequest        = amm_s.waitrequest;
82
  assign amm_s.arbiterlock  = arbiterlock;
83
  assign readdatavalid      = amm_s.readdatavalid;
84
  assign amm_s.burstcount   = burstcount;
85
  assign amm_s.resetrequest = resetrequest;
86
 
87
 
88
  // --------------------------------------------------------------------
89
  //
90
  function void
91
    amm_default;
92
 
93
    address       = 'bx;
94
    arbiterlock   = 0;
95
    burstcount    = 'bx;
96
    byteenable    = 'bx;
97
    read          = 0;
98
    resetrequest  = 0;
99
    write         = 0;
100
    writedata     = 'bx;
101
 
102
  endfunction: amm_default
103
 
104
 
105
  // --------------------------------------------------------------------
106
  //
107
  function void
108
    init;
109
 
110
    amm_default();
111
 
112
  endfunction: init
113
 
114
 
115
  // --------------------------------------------------------------------
116
  //
117
  task
118
    zero_cycle_delay;
119
 
120
    ##0;
121
 
122
  endtask: zero_cycle_delay
123
 
124
 
125
  // --------------------------------------------------------------------
126
  //
127
  initial
128
  begin
129
 
130
    init();
131
 
132
  end
133
 
134
 
135
// --------------------------------------------------------------------
136
//
137
 
138
endinterface
139
 
140
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.