138 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| #! /usr/bin/vvp
 | |
| :ivl_version "11.0 (stable)";
 | |
| :ivl_delay_selection "TYPICAL";
 | |
| :vpi_time_precision + 0;
 | |
| :vpi_module "/usr/lib/x86_64-linux-gnu/ivl/system.vpi";
 | |
| :vpi_module "/usr/lib/x86_64-linux-gnu/ivl/vhdl_sys.vpi";
 | |
| :vpi_module "/usr/lib/x86_64-linux-gnu/ivl/vhdl_textio.vpi";
 | |
| :vpi_module "/usr/lib/x86_64-linux-gnu/ivl/v2005_math.vpi";
 | |
| :vpi_module "/usr/lib/x86_64-linux-gnu/ivl/va_math.vpi";
 | |
| S_0x55928b0bbf60 .scope module, "timerTB" "timerTB" 2 1;
 | |
|  .timescale 0 0;
 | |
| v0x55928b0d05d0_0 .var "clock", 0 0;
 | |
| v0x55928b0d0690_0 .net "count", 5 0, v0x55928b0d0000_0;  1 drivers
 | |
| v0x55928b0d0760_0 .var "counter", 2 0;
 | |
| v0x55928b0d0860_0 .var "gate", 0 0;
 | |
| v0x55928b0d0930_0 .var "reset", 0 0;
 | |
| v0x55928b0d0a20_0 .var "way", 0 0;
 | |
| S_0x55928b0bc0f0 .scope module, "uut" "timer" 2 9, 3 1 0, S_0x55928b0bbf60;
 | |
|  .timescale 0 0;
 | |
|     .port_info 0 /INPUT 1 "clock";
 | |
|     .port_info 1 /INPUT 1 "reset";
 | |
|     .port_info 2 /INPUT 1 "gate";
 | |
|     .port_info 3 /INPUT 3 "counter";
 | |
|     .port_info 4 /INPUT 1 "way";
 | |
|     .port_info 5 /OUTPUT 6 "count";
 | |
| v0x55928b0a8600_0 .net "clock", 0 0, v0x55928b0d05d0_0;  1 drivers
 | |
| v0x55928b0d0000_0 .var "count", 5 0;
 | |
| v0x55928b0d00e0_0 .var "countReg", 5 0;
 | |
| v0x55928b0d01a0_0 .net "counter", 2 0, v0x55928b0d0760_0;  1 drivers
 | |
| v0x55928b0d0280_0 .net "gate", 0 0, v0x55928b0d0860_0;  1 drivers
 | |
| v0x55928b0d0390_0 .net "reset", 0 0, v0x55928b0d0930_0;  1 drivers
 | |
| v0x55928b0d0450_0 .net "way", 0 0, v0x55928b0d0a20_0;  1 drivers
 | |
| E_0x55928b0b8e60 .event edge, v0x55928b0d00e0_0;
 | |
| E_0x55928b0b9330 .event posedge, v0x55928b0a8600_0;
 | |
|     .scope S_0x55928b0bc0f0;
 | |
| T_0 ;
 | |
|     %pushi/vec4 43, 0, 6;
 | |
|     %store/vec4 v0x55928b0d00e0_0, 0, 6;
 | |
|     %end;
 | |
|     .thread T_0;
 | |
|     .scope S_0x55928b0bc0f0;
 | |
| T_1 ;
 | |
|     %wait E_0x55928b0b9330;
 | |
|     %load/vec4 v0x55928b0d0390_0;
 | |
|     %flag_set/vec4 8;
 | |
|     %jmp/0xz  T_1.0, 8;
 | |
|     %pushi/vec4 0, 0, 6;
 | |
|     %assign/vec4 v0x55928b0d00e0_0, 0;
 | |
|     %jmp T_1.1;
 | |
| T_1.0 ;
 | |
|     %load/vec4 v0x55928b0d0280_0;
 | |
|     %flag_set/vec4 8;
 | |
|     %jmp/0xz  T_1.2, 8;
 | |
|     %load/vec4 v0x55928b0d0450_0;
 | |
|     %load/vec4 v0x55928b0d00e0_0;
 | |
|     %pushi/vec4 63, 0, 6;
 | |
|     %cmp/ne;
 | |
|     %flag_get/vec4 4;
 | |
|     %and;
 | |
|     %flag_set/vec4 8;
 | |
|     %jmp/0xz  T_1.4, 8;
 | |
|     %load/vec4 v0x55928b0d00e0_0;
 | |
|     %load/vec4 v0x55928b0d01a0_0;
 | |
|     %pad/u 6;
 | |
|     %add;
 | |
|     %assign/vec4 v0x55928b0d00e0_0, 0;
 | |
|     %jmp T_1.5;
 | |
| T_1.4 ;
 | |
|     %load/vec4 v0x55928b0d0450_0;
 | |
|     %nor/r;
 | |
|     %load/vec4 v0x55928b0d00e0_0;
 | |
|     %pushi/vec4 0, 0, 6;
 | |
|     %cmp/ne;
 | |
|     %flag_get/vec4 4;
 | |
|     %and;
 | |
|     %flag_set/vec4 8;
 | |
|     %jmp/0xz  T_1.6, 8;
 | |
|     %load/vec4 v0x55928b0d00e0_0;
 | |
|     %load/vec4 v0x55928b0d01a0_0;
 | |
|     %pad/u 6;
 | |
|     %sub;
 | |
|     %assign/vec4 v0x55928b0d00e0_0, 0;
 | |
| T_1.6 ;
 | |
| T_1.5 ;
 | |
| T_1.2 ;
 | |
| T_1.1 ;
 | |
|     %jmp T_1;
 | |
|     .thread T_1;
 | |
|     .scope S_0x55928b0bc0f0;
 | |
| T_2 ;
 | |
|     %wait E_0x55928b0b8e60;
 | |
|     %load/vec4 v0x55928b0d00e0_0;
 | |
|     %store/vec4 v0x55928b0d0000_0, 0, 6;
 | |
|     %jmp T_2;
 | |
|     .thread T_2, $push;
 | |
|     .scope S_0x55928b0bbf60;
 | |
| T_3 ;
 | |
|     %pushi/vec4 0, 0, 1;
 | |
|     %store/vec4 v0x55928b0d05d0_0, 0, 1;
 | |
| T_3.0 ;
 | |
|     %delay 5, 0;
 | |
|     %load/vec4 v0x55928b0d05d0_0;
 | |
|     %inv;
 | |
|     %store/vec4 v0x55928b0d05d0_0, 0, 1;
 | |
|     %jmp T_3.0;
 | |
|     %end;
 | |
|     .thread T_3;
 | |
|     .scope S_0x55928b0bbf60;
 | |
| T_4 ;
 | |
|     %vpi_call 2 19 "$dumpfile", "lab5t.vcd" {0 0 0};
 | |
|     %vpi_call 2 20 "$dumpvars" {0 0 0};
 | |
|     %pushi/vec4 0, 0, 1;
 | |
|     %store/vec4 v0x55928b0d0930_0, 0, 1;
 | |
|     %pushi/vec4 1, 0, 1;
 | |
|     %store/vec4 v0x55928b0d0860_0, 0, 1;
 | |
|     %pushi/vec4 2, 0, 3;
 | |
|     %store/vec4 v0x55928b0d0760_0, 0, 3;
 | |
|     %pushi/vec4 1, 0, 1;
 | |
|     %store/vec4 v0x55928b0d0a20_0, 0, 1;
 | |
|     %pushi/vec4 1, 0, 1;
 | |
|     %store/vec4 v0x55928b0d0930_0, 0, 1;
 | |
|     %pushi/vec4 1, 0, 1;
 | |
|     %store/vec4 v0x55928b0d0860_0, 0, 1;
 | |
|     %pushi/vec4 2, 0, 3;
 | |
|     %store/vec4 v0x55928b0d0760_0, 0, 3;
 | |
|     %pushi/vec4 1, 0, 1;
 | |
|     %store/vec4 v0x55928b0d0a20_0, 0, 1;
 | |
|     %delay 200, 0;
 | |
|     %vpi_call 2 25 "$finish" {0 0 0};
 | |
|     %end;
 | |
|     .thread T_4;
 | |
| # The file index is used to find the file name in the following table.
 | |
| :file_names 4;
 | |
|     "N/A";
 | |
|     "<interactive>";
 | |
|     "timerTB.v";
 | |
|     "timer.v";
 |