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

Subversion Repositories dbg_interface

[/] [dbg_interface/] [trunk/] [rtl/] [verilog/] [dbg_cpu_registers.v] - Blame information for rev 158

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 100 mohor
//////////////////////////////////////////////////////////////////////
2
////                                                              ////
3
////  dbg_cpu_registers.v                                         ////
4
////                                                              ////
5
////                                                              ////
6 139 igorm
////  This file is part of the SoC Debug Interface.               ////
7 100 mohor
////  http://www.opencores.org/projects/DebugInterface/           ////
8
////                                                              ////
9
////  Author(s):                                                  ////
10
////       Igor Mohor (igorm@opencores.org)                       ////
11
////                                                              ////
12
////                                                              ////
13
////  All additional information is avaliable in the README.txt   ////
14
////  file.                                                       ////
15
////                                                              ////
16
//////////////////////////////////////////////////////////////////////
17
////                                                              ////
18
//// Copyright (C) 2000 - 2004 Authors                            ////
19
////                                                              ////
20
//// This source file may be used and distributed without         ////
21
//// restriction provided that this copyright statement is not    ////
22
//// removed from the file and that any derivative work contains  ////
23
//// the original copyright notice and the associated disclaimer. ////
24
////                                                              ////
25
//// This source file is free software; you can redistribute it   ////
26
//// and/or modify it under the terms of the GNU Lesser General   ////
27
//// Public License as published by the Free Software Foundation; ////
28
//// either version 2.1 of the License, or (at your option) any   ////
29
//// later version.                                               ////
30
////                                                              ////
31
//// This source is distributed in the hope that it will be       ////
32
//// useful, but WITHOUT ANY WARRANTY; without even the implied   ////
33
//// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR      ////
34
//// PURPOSE.  See the GNU Lesser General Public License for more ////
35
//// details.                                                     ////
36
////                                                              ////
37
//// You should have received a copy of the GNU Lesser General    ////
38
//// Public License along with this source; if not, download it   ////
39
//// from http://www.opencores.org/lgpl.shtml                     ////
40
////                                                              ////
41
//////////////////////////////////////////////////////////////////////
42
//
43
// CVS Revision History
44
//
45
// $Log: not supported by cvs2svn $
46 139 igorm
// Revision 1.5  2004/03/22 16:35:46  igorm
47
// Temp version before changing dbg interface.
48
//
49 138 igorm
// Revision 1.4  2004/01/25 14:04:18  mohor
50
// All flipflops are reset.
51
//
52 123 mohor
// Revision 1.3  2004/01/22 10:16:08  mohor
53
// cpu_stall_o activated as soon as bp occurs.
54
//
55 119 mohor
// Revision 1.2  2004/01/17 17:01:14  mohor
56
// Almost finished.
57
//
58 101 mohor
// Revision 1.1  2004/01/16 14:53:33  mohor
59
// *** empty log message ***
60 100 mohor
//
61
//
62 101 mohor
//
63 100 mohor
 
64
// synopsys translate_off
65
`include "timescale.v"
66
// synopsys translate_on
67
`include "dbg_cpu_defines.v"
68
 
69
module dbg_cpu_registers  (
70 101 mohor
                            data_i,
71
                            we_i,
72 139 igorm
                            tck_i,
73 101 mohor
                            bp_i,
74
                            rst_i,
75
                            cpu_clk_i,
76 139 igorm
                            ctrl_reg_o,
77 101 mohor
                            cpu_stall_o,
78
                            cpu_rst_o
79 100 mohor
                          );
80
 
81
 
82 139 igorm
input  [`DBG_CPU_CTRL_LEN -1:0] data_i;
83 101 mohor
input                   we_i;
84 139 igorm
input                   tck_i;
85 101 mohor
input                   bp_i;
86
input                   rst_i;
87
input                   cpu_clk_i;
88 100 mohor
 
89 139 igorm
output [`DBG_CPU_CTRL_LEN -1:0]ctrl_reg_o;
90 101 mohor
output                  cpu_stall_o;
91
output                  cpu_rst_o;
92 100 mohor
 
93 139 igorm
reg                     cpu_reset;
94 100 mohor
wire             [2:1]  cpu_op_out;
95
 
96 139 igorm
reg                     stall_bp, stall_bp_csff, stall_bp_tck;
97
reg                     stall_reg, stall_reg_csff, stall_reg_cpu;
98
reg                     cpu_reset_csff;
99 101 mohor
reg                     cpu_rst_o;
100 100 mohor
 
101
 
102
 
103 119 mohor
// Breakpoint is latched and synchronized. Stall is set and latched.
104
always @ (posedge cpu_clk_i or posedge rst_i)
105 101 mohor
begin
106
  if(rst_i)
107 119 mohor
    stall_bp <= #1 1'b0;
108
  else if(bp_i)
109
    stall_bp <= #1 1'b1;
110
  else if(stall_reg_cpu)
111
    stall_bp <= #1 1'b0;
112 100 mohor
end
113
 
114
 
115 119 mohor
// Synchronizing
116 139 igorm
always @ (posedge tck_i or posedge rst_i)
117 119 mohor
begin
118
  if (rst_i)
119
    begin
120 139 igorm
      stall_bp_csff <= #1 1'b0;
121 119 mohor
      stall_bp_tck  <= #1 1'b0;
122
    end
123
  else
124
    begin
125 139 igorm
      stall_bp_csff <= #1 stall_bp;
126
      stall_bp_tck  <= #1 stall_bp_csff;
127 119 mohor
    end
128
end
129
 
130
 
131
always @ (posedge cpu_clk_i or posedge rst_i)
132
begin
133
  if (rst_i)
134
    begin
135 139 igorm
      stall_reg_csff <= #1 1'b0;
136 119 mohor
      stall_reg_cpu  <= #1 1'b0;
137
    end
138
  else
139
    begin
140 139 igorm
      stall_reg_csff <= #1 stall_reg;
141
      stall_reg_cpu  <= #1 stall_reg_csff;
142 119 mohor
    end
143
end
144
 
145
 
146
assign cpu_stall_o = bp_i | stall_bp | stall_reg_cpu;
147
 
148
 
149 139 igorm
// Writing data to the control registers (stall)
150
always @ (posedge tck_i or posedge rst_i)
151
begin
152
  if (rst_i)
153
    stall_reg <= #1 1'b0;
154
  else if (stall_bp_tck)
155
    stall_reg <= #1 1'b1;
156
  else if (we_i)
157
    stall_reg <= #1 data_i[0];
158
end
159 119 mohor
 
160 100 mohor
 
161 139 igorm
// Writing data to the control registers (reset)
162
always @ (posedge tck_i or posedge rst_i)
163 100 mohor
begin
164 123 mohor
  if (rst_i)
165 139 igorm
    cpu_reset  <= #1 1'b0;
166
  else if(we_i)
167
    cpu_reset  <= #1 data_i[1];
168 100 mohor
end
169
 
170
 
171 101 mohor
// Synchronizing signals from registers
172 119 mohor
always @ (posedge cpu_clk_i or posedge rst_i)
173 101 mohor
begin
174 119 mohor
  if (rst_i)
175
    begin
176 139 igorm
      cpu_reset_csff      <= #1 1'b0;
177 119 mohor
      cpu_rst_o           <= #1 1'b0;
178
    end
179
  else
180
    begin
181 139 igorm
      cpu_reset_csff      <= #1 cpu_reset;
182
      cpu_rst_o           <= #1 cpu_reset_csff;
183 119 mohor
    end
184 101 mohor
end
185
 
186
 
187
 
188 139 igorm
// Value for read back
189
assign ctrl_reg_o = {cpu_reset, stall_reg};
190
 
191
 
192 100 mohor
endmodule
193
 

powered by: WebSVN 2.1.0

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