mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-24 16:34:38 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			73 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Systemverilog
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Systemverilog
		
	
	
	
	
	
| module top;
 | |
|     integer x, y, z;
 | |
|     task check;
 | |
|         input integer a, b, c;
 | |
|         assert (x == a);
 | |
|         assert (y == b);
 | |
|         assert (z == c);
 | |
|     endtask
 | |
|     always_comb begin
 | |
|         x = 0; y = 0; z = 0;
 | |
|         check(0, 0, 0);
 | |
| 
 | |
|         // post-increment/decrement statements
 | |
|         x++;
 | |
|         check(1, 0, 0);
 | |
|         (* bar *) y (* foo *) ++;
 | |
|         check(1, 1, 0);
 | |
|         z--;
 | |
|         check(1, 1, -1);
 | |
|         (* bar *) z (* foo *) --;
 | |
|         check(1, 1, -2);
 | |
| 
 | |
|         // pre-increment/decrement statements are equivalent
 | |
|         ++z;
 | |
|         check(1, 1, -1);
 | |
|         (* bar *) ++ (* foo *) z;
 | |
|         check(1, 1, 0);
 | |
|         --x;
 | |
|         check(0, 1, 0);
 | |
|         (* bar *) -- (* foo *) y;
 | |
|         check(0, 0, 0);
 | |
| 
 | |
|         // procedural pre-increment/decrement expressions
 | |
|         z = ++x;
 | |
|         check(1, 0, 1);
 | |
|         z = ++ (* foo *) x;
 | |
|         check(2, 0, 2);
 | |
|         y = --x;
 | |
|         check(1, 1, 2);
 | |
|         y = -- (* foo *) x;
 | |
| 
 | |
|         // procedural post-increment/decrement expressions
 | |
|         // TODO: support attributes on post-increment/decrement
 | |
|         check(0, 0, 2);
 | |
|         y = x++;
 | |
|         check(1, 0, 2);
 | |
|         y = x--;
 | |
|         check(0, 1, 2);
 | |
| 
 | |
|         // procedural assignment expressions
 | |
|         x = (y = (z = 99) + 1) + 1;
 | |
|         check(101, 100, 99);
 | |
|         x = (y *= 2);
 | |
|         check(200, 200, 99);
 | |
|         x = (z >>= 2) * 4;
 | |
|         check(96, 200, 24);
 | |
|         y = (z >>= 1'sb1) * 2; // shift is implicitly cast to unsigned
 | |
|         check(96, 24, 12);
 | |
| 
 | |
|         // check width of post-increment expressions
 | |
|         z = (y = 0);
 | |
|         begin
 | |
|             byte w;
 | |
|             w = 0;
 | |
|             x = {1'b1, ++w};
 | |
|             check(257, 0, 0);
 | |
|             assert (w == 1);
 | |
|             x = {2'b10, w++};
 | |
|             check(513, 0, 0);
 | |
|             assert (w == 2);
 | |
|         end
 | |
|     end
 | |
| endmodule
 |