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

Subversion Repositories openmsp430

[/] [openmsp430/] [trunk/] [core/] [sim/] [rtl_sim/] [src/] [dbg_uart_cpu.v] - Blame information for rev 202

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 olivier.gi
/*===========================================================================*/
2
/* Copyright (C) 2001 Authors                                                */
3
/*                                                                           */
4
/* This source file may be used and distributed without restriction provided */
5
/* that this copyright statement is not removed from the file and that any   */
6
/* derivative work contains the original copyright notice and the associated */
7
/* disclaimer.                                                               */
8
/*                                                                           */
9
/* This source file is free software; you can redistribute it and/or modify  */
10
/* it under the terms of the GNU Lesser General Public License as published  */
11
/* by the Free Software Foundation; either version 2.1 of the License, or    */
12
/* (at your option) any later version.                                       */
13
/*                                                                           */
14
/* This source is distributed in the hope that it will be useful, but WITHOUT*/
15
/* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or     */
16
/* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public       */
17
/* License for more details.                                                 */
18
/*                                                                           */
19
/* You should have received a copy of the GNU Lesser General Public License  */
20
/* along with this source; if not, write to the Free Software Foundation,    */
21
/* Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA        */
22
/*                                                                           */
23
/*===========================================================================*/
24
/*                            DEBUG INTERFACE                                */
25
/*---------------------------------------------------------------------------*/
26
/* Test the debug interface:                                                 */
27
/*                           - CPU Control features.                         */
28 18 olivier.gi
/*                                                                           */
29
/* Author(s):                                                                */
30
/*             - Olivier Girard,    olgirard@gmail.com                       */
31
/*                                                                           */
32
/*---------------------------------------------------------------------------*/
33 19 olivier.gi
/* $Rev: 202 $                                                                */
34
/* $LastChangedBy: olivier.girard $                                          */
35
/* $LastChangedDate: 2015-07-01 23:13:32 +0200 (Wed, 01 Jul 2015) $          */
36 2 olivier.gi
/*===========================================================================*/
37
 
38
 
39
   integer my_test;
40
   integer test_var;
41
 
42 202 olivier.gi
 
43 2 olivier.gi
initial
44
   begin
45
      $display(" ===============================================");
46
      $display("|                 START SIMULATION              |");
47
      $display(" ===============================================");
48 111 olivier.gi
`ifdef DBG_EN
49 154 olivier.gi
`ifdef DBG_UART
50 106 olivier.gi
      #1 dbg_en = 1;
51 2 olivier.gi
      repeat(30) @(posedge mclk);
52
      stimulus_done = 0;
53
 
54
      // SEND UART SYNCHRONIZATION FRAME
55
      dbg_uart_tx(DBG_SYNC);
56
 
57 106 olivier.gi
   `ifdef DBG_RST_BRK_EN
58
      dbg_uart_wr(CPU_CTL,  16'h0002);  // RUN
59
   `endif
60
 
61
 
62 2 olivier.gi
      // STOP, FREEZE, ISTEP, RUN
63
      //--------------------------------------------------------
64
 
65
      dbg_uart_wr(CPU_STAT,  16'h00ff); // HALT
66
      dbg_uart_rd(CPU_STAT);            // READ STATUS
67
      if (dbg_uart_buf !== 16'h0000)      tb_error("====== STOP, FREEZE, ISTEP, RUN: status test 1 =====");
68
 
69
      dbg_uart_wr(CPU_CTL,  16'h0001);  // HALT
70
      repeat(10) @(posedge mclk);
71
      test_var = inst_number;
72
      repeat(50) @(posedge mclk);
73
      if (test_var !== inst_number)       tb_error("====== STOP, FREEZE, ISTEP, RUN: HALT function =====");
74 202 olivier.gi
 
75 2 olivier.gi
      dbg_uart_rd(CPU_STAT);            // READ STATUS
76
      if (dbg_uart_buf !== 16'h0001)      tb_error("====== STOP, FREEZE, ISTEP, RUN: HALT status - test 1 =====");
77
 
78
      if (dbg_freeze !== 1'b0)            tb_error("====== STOP, FREEZE, ISTEP, RUN: FREEZE value - test 1 =====");
79
      dbg_uart_wr(CPU_CTL,  16'h0010);  // FREEZE WITH BREAK
80
      repeat(10) @(posedge mclk);
81
      if (dbg_freeze !== 1'b1)            tb_error("====== STOP, FREEZE, ISTEP, RUN: FREEZE value - test 2 =====");
82
 
83 202 olivier.gi
 
84 2 olivier.gi
      test_var = r14;
85
      dbg_uart_wr(CPU_CTL,  16'h0004); // ISTEP
86
      dbg_uart_wr(CPU_CTL,  16'h0004); // ISTEP
87 95 olivier.gi
      repeat(12) @(posedge mclk);
88 2 olivier.gi
      if (test_var !== (r14+1))           tb_error("====== STOP, FREEZE, ISTEP, RUN: ISTEP test 1 =====");
89
      dbg_uart_wr(CPU_CTL,  16'h0004); // ISTEP
90
      dbg_uart_wr(CPU_CTL,  16'h0004); // ISTEP
91 95 olivier.gi
      repeat(12) @(posedge mclk);
92 2 olivier.gi
      if (test_var !== (r14+2))           tb_error("====== STOP, FREEZE, ISTEP, RUN: ISTEP test 2 =====");
93
      dbg_uart_wr(CPU_CTL,  16'h0004); // ISTEP
94
      dbg_uart_wr(CPU_CTL,  16'h0004); // ISTEP
95 95 olivier.gi
      repeat(12) @(posedge mclk);
96 2 olivier.gi
      if (test_var !== (r14+3))           tb_error("====== STOP, FREEZE, ISTEP, RUN: ISTEP test 3 =====");
97
 
98 202 olivier.gi
 
99 2 olivier.gi
      test_var = inst_number;
100
      dbg_uart_wr(CPU_CTL,  16'h0002); // RUN
101
      repeat(50) @(posedge mclk);
102
      if (test_var === inst_number)       tb_error("====== STOP, FREEZE, ISTEP, RUN: RUN function - test 1 =====");
103
      test_var = inst_number;
104
      repeat(50) @(posedge mclk);
105
      if (test_var === inst_number)       tb_error("====== STOP, FREEZE, ISTEP, RUN: RUN function - test 2 =====");
106
 
107
      dbg_uart_rd(CPU_STAT);           // READ STATUS
108
      if (dbg_uart_buf !== 16'h0000)      tb_error("====== STOP/RUN, ISTEP: HALT status - test 2 =====");
109
 
110 202 olivier.gi
 
111
 
112 2 olivier.gi
      // RESET / BREAK ON RESET
113
      //--------------------------------------------------------
114
 
115
      test_var = r14;
116
      dbg_uart_wr(CPU_CTL,  16'h0040); // RESET CPU
117
      dbg_uart_rd(CPU_STAT);           // READ STATUS
118
      if (dbg_uart_buf !== 16'h0004)      tb_error("====== RESET / BREAK ON RESET: RESET error- test 1 =====");
119 111 olivier.gi
      if (puc_rst      !== 1'b1)          tb_error("====== RESET / BREAK ON RESET: RESET error- test 2 =====");
120 2 olivier.gi
      dbg_uart_wr(CPU_CTL,  16'h0000); // RELEASE RESET
121
      dbg_uart_rd(CPU_STAT);           // READ STATUS
122
      if (dbg_uart_buf !== 16'h0004)      tb_error("====== RESET / BREAK ON RESET: RESET error- test 3 =====");
123 111 olivier.gi
      if (puc_rst      !== 1'b0)          tb_error("====== RESET / BREAK ON RESET: RESET error- test 4 =====");
124 2 olivier.gi
      if (test_var >= r14)                tb_error("====== RESET / BREAK ON RESET: RESET error- test 5 =====");
125
      dbg_uart_wr(CPU_STAT,  16'h0004); // CLEAR STATUS
126
      dbg_uart_rd(CPU_STAT);            // READ STATUS
127
      if (dbg_uart_buf !== 16'h0000)      tb_error("====== RESET / BREAK ON RESET: RESET error- test 6 =====");
128
 
129
 
130
      test_var = r14;
131
      dbg_uart_wr(CPU_CTL,  16'h0060); // RESET & BREAK ON RESET
132
      dbg_uart_rd(CPU_STAT);           // READ STATUS
133
      if (dbg_uart_buf !== 16'h0004)      tb_error("====== RESET / BREAK ON RESET: BREAK ON RESET error- test 1 =====");
134 111 olivier.gi
      if (puc_rst      !== 1'b1)          tb_error("====== RESET / BREAK ON RESET: BREAK ON RESET error- test 2 =====");
135 2 olivier.gi
      dbg_uart_wr(CPU_CTL,  16'h0020); // RELEASE RESET
136
      dbg_uart_rd(CPU_STAT);           // READ STATUS
137
      if (dbg_uart_buf !== 16'h0005)      tb_error("====== RESET / BREAK ON RESET: BREAK ON RESET error- test 3 =====");
138 111 olivier.gi
      if (puc_rst      !== 1'b0)          tb_error("====== RESET / BREAK ON RESET: BREAK ON RESET error- test 4 =====");
139 2 olivier.gi
      repeat(10) @(posedge mclk);
140
      test_var = inst_number;
141
      repeat(50) @(posedge mclk);
142
      if (test_var !== inst_number)       tb_error("====== RESET / BREAK ON RESET: BREAK ON RESET error- test 5 =====");
143
      if (r0       !== irq_vect_15)       tb_error("====== RESET / BREAK ON RESET: BREAK ON RESET error- test 6 =====");
144
 
145
      dbg_uart_wr(CPU_STAT,  16'h0004); // CLEAR STATUS
146
      dbg_uart_rd(CPU_STAT);            // READ STATUS
147
      if (dbg_uart_buf !== 16'h0001)      tb_error("====== RESET / BREAK ON RESET: BREAK ON RESET error- test 7 =====");
148
 
149
      dbg_uart_wr(CPU_CTL,  16'h0002);  // RUN
150
      dbg_uart_rd(CPU_STAT);            // READ STATUS
151
      if (dbg_uart_buf !== 16'h0000)      tb_error("====== RESET / BREAK ON RESET: BREAK ON RESET error- test 8 =====");
152
 
153 202 olivier.gi
 
154 2 olivier.gi
      // SOFTWARE BREAKPOINT
155
      //--------------------------------------------------------
156
 
157
      dbg_uart_wr(CPU_CTL,  16'h0048);  // RESET & ENABLE SOFTWARE BREAKPOINT
158
      dbg_uart_wr(CPU_CTL,  16'h0008);  // RELEASE RESET
159
      dbg_uart_rd(CPU_STAT);            // READ STATUS
160
      if (dbg_uart_buf !== 16'h000D)      tb_error("====== SOFTWARE BREAKPOINT: test 1 =====");
161 86 olivier.gi
      if (r0           !== ('h10000-`PMEM_SIZE+'h12))      tb_error("====== SOFTWARE BREAKPOINT: test 2 =====");
162 2 olivier.gi
      dbg_uart_wr(CPU_STAT,  16'h000C); // CLEAR STATUS
163
      dbg_uart_rd(CPU_STAT);            // READ STATUS
164
      if (dbg_uart_buf !== 16'h0001)      tb_error("====== SOFTWARE BREAKPOINT: test 3 =====");
165
 
166
      // Replace software breakpoint with a mov #2, r15 (opcode=0x432f)
167 86 olivier.gi
      dbg_uart_wr(MEM_ADDR, ('h10000-`PMEM_SIZE+'h12));
168 2 olivier.gi
      dbg_uart_wr(MEM_DATA, 16'h432f);
169
      dbg_uart_wr(MEM_CTL,  16'h0003);
170
 
171
      // Dummy write
172
      dbg_uart_wr(MEM_ADDR, 16'hff00);
173
      dbg_uart_wr(MEM_DATA, 16'h1234);
174
      dbg_uart_wr(MEM_CTL,  16'h0003);
175
 
176
      // RUN
177
      dbg_uart_wr(CPU_CTL,  16'h000A);
178
      repeat(20) @(posedge mclk);
179
      if (r15     !== 16'h0002)           tb_error("====== SOFTWARE BREAKPOINT: test 4 =====");
180 202 olivier.gi
 
181 2 olivier.gi
      dbg_uart_rd(CPU_STAT);            // READ STATUS
182
      if (dbg_uart_buf !== 16'h0009)      tb_error("====== SOFTWARE BREAKPOINT: test 5 =====");
183 86 olivier.gi
      if (r0           !== ('h10000-`PMEM_SIZE+'h16))      tb_error("====== SOFTWARE BREAKPOINT: test 6 =====");
184 2 olivier.gi
      dbg_uart_wr(CPU_STAT,  16'h0008); // CLEAR STATUS
185
      dbg_uart_rd(CPU_STAT);            // READ STATUS
186
      if (dbg_uart_buf !== 16'h0001)      tb_error("====== SOFTWARE BREAKPOINT: test 7 =====");
187
 
188 202 olivier.gi
 
189 2 olivier.gi
      // Replace software breakpoint with a mov #4, r15 (opcode=0x422f)
190 86 olivier.gi
      dbg_uart_wr(MEM_ADDR, ('h10000-`PMEM_SIZE+'h16));
191 2 olivier.gi
      dbg_uart_wr(MEM_DATA, 16'h422f);
192
      dbg_uart_wr(MEM_CTL,  16'h0003);
193
 
194
      // Dummy write
195
      dbg_uart_wr(MEM_ADDR, 16'hff00);
196
      dbg_uart_wr(MEM_DATA, 16'h5678);
197
      dbg_uart_wr(MEM_CTL,  16'h0003);
198 202 olivier.gi
 
199 2 olivier.gi
      // RUN
200
      dbg_uart_wr(CPU_CTL,  16'h000A);
201
      repeat(20) @(posedge mclk);
202
      if (r15     !== 16'h0004)           tb_error("====== SOFTWARE BREAKPOINT: test 8 =====");
203
 
204 202 olivier.gi
 
205 2 olivier.gi
      stimulus_done = 1;
206 111 olivier.gi
`else
207
 
208 202 olivier.gi
       tb_skip_finish("|   (serial debug interface UART not included)  |");
209 154 olivier.gi
`endif
210
`else
211 202 olivier.gi
       tb_skip_finish("|      (serial debug interface not included)    |");
212 111 olivier.gi
`endif
213 2 olivier.gi
   end

powered by: WebSVN 2.1.0

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