Initial commit of OpenSPARC T2 design and verification files.
[OpenSPARC-T2-DV] / verif / env / common / coverage / ncu / ncu_ssi_sample.vrh
CommitLineData
86530b38
AT
1// ========== Copyright Header Begin ==========================================
2//
3// OpenSPARC T2 Processor File: ncu_ssi_sample.vrh
4// Copyright (C) 1995-2007 Sun Microsystems, Inc. All Rights Reserved
5// 4150 Network Circle, Santa Clara, California 95054, U.S.A.
6//
7// * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
8//
9// This program is free software; you can redistribute it and/or modify
10// it under the terms of the GNU General Public License as published by
11// the Free Software Foundation; version 2 of the License.
12//
13// This program is distributed in the hope that it will be useful,
14// but WITHOUT ANY WARRANTY; without even the implied warranty of
15// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16// GNU General Public License for more details.
17//
18// You should have received a copy of the GNU General Public License
19// along with this program; if not, write to the Free Software
20// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21//
22// For the avoidance of doubt, and except that if any non-GPL license
23// choice is available it will apply instead, Sun elects to use only
24// the General Public License version 2 (GPLv2) at this time for any
25// software where a choice of GPL license versions is made
26// available with the language indicating that GPLv2 or any later version
27// may be used, or where a choice of which version of the GPL is applied is
28// otherwise unspecified.
29//
30// Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
31// CA 95054 USA or visit www.sun.com if you need additional information or
32// have any questions.
33//
34// ========== Copyright Header End ============================================
35sample ncu_ssi_size_sample (ncu_ssi_size)
36{
37 state SIZE0 ( 3'b000 );
38 state SIZE1 ( 3'b001 );
39 state SIZE2 ( 3'b010 );
40 state SIZE3 ( 3'b011 );
41}
42sample ncu_ssi_type_sample (ncu_ssi_type)
43{
44 state READ_REQ ( 4'b0100 );
45 state WRITE_REQ ( 4'b0101 );
46 state IFILLED_REQ ( 4'b0110 );
47}
48
49sample ncu_ssi_cpuid_sample (ncu_ssi_cpuid)
50{
51 m_state CPUID ( 0:63 ) ;
52}
53
54#ifndef FC_COVERAGE
55sample ncu_ssi_type_trans (ncu_ssi_type)
56{
57 state READ_REQ ( 4'b0100 );
58 state WRITE_REQ ( 4'b0101 );
59 state IFILLED_REQ ( 4'b0110 );
60
61 trans TYPE_TRAN0 ("READ_REQ" -> "IFILLED_REQ");
62 trans TYPE_TRAN1 ("READ_REQ" -> "WRITE_REQ");
63
64 trans TYPE_TRAN2 ("WRITE_REQ" -> "READ_REQ");
65 trans TYPE_TRAN3 ("WRITE_REQ" -> "IFILLED_REQ");
66
67 trans TYPE_TRAN4 ("IFILLED_REQ" -> "WRITE_REQ");
68 trans TYPE_TRAN5 ("IFILLED_REQ" -> "READ_REQ");
69}
70
71
72sample ncu_ssi_bufid_sample (ncu_ssi_bufid)
73{
74 m_state BUFFID (0:1);
75}
76
77
78
79
80sample ncu_ssi_b2b_sample (ncu_ssi_b2b)
81{
82 m_state B2B ( 2:5 ) ;
83}
84
85sample ncu_ssi_stall_b2b_sample (ssi_ncu_stall_b2b)
86{
87 m_state STALL ( 1:30) ;
88}
89sample ncu_ssi_pkt_gap_sample (ncu_ssi_pkt_gap)
90{
91 m_state PKT_GAP ( 1:10) ;
92}
93
94cross ncu_ssi_id_type_cross(ncu_ssi_type_sample, ncu_ssi_cpuid_sample);
95#endif