| 
								
								
									 Jason Xu | a5f34d04f8 | Address comments | 2025-03-11 18:50:44 -04:00 |  | 
				
					
						| 
								
								
									 Jason Xu | 98eefc5d1a | Add file list support to read pass | 2025-03-07 20:44:21 -05:00 |  | 
				
					
						| 
								
								
									 N. Engelhardt | d640157ec4 | fix some cases of hdlname being added to objects with private names | 2025-01-15 15:56:42 +01:00 |  | 
				
					
						| 
								
								
									 Emil J. Tywoniak | d071489ab1 | hashlib: redo interface for flexibility | 2024-12-18 14:49:25 +01:00 |  | 
				
					
						| 
								
								
									 N. Engelhardt | 378864d33b | bound attributes: handle vhdl null ranges | 2024-12-12 11:42:39 +01:00 |  | 
				
					
						| 
								
								
									 N. Engelhardt | 03033ab6d4 | add more tests for bounds attributes, fix attributes appearing in verilog | 2024-12-11 16:11:02 +01:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 7d4aff618f | verific: Disable module existence check during static elaboration | 2024-12-06 15:59:09 +01:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 912b38eedb | verific: Handle crash when using empty box option | 2024-12-02 15:45:12 +01:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanović | 29e8812bab | Merge pull request #4724 from YosysHQ/micko/blackbox_verific verific: fix blackbox regression and add test case | 2024-11-25 15:06:54 +01:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | d6bd521487 | verific : VHDL assert DFF initial value set on Verific library patch side | 2024-11-21 13:43:26 +01:00 |  | 
				
					
						| 
								
								
									 Mike Inouye | 06e3ac4415 | Fix bug when setting Verific runtime string  flags. Signed-off-by: Mike Inouye <mikeinouye@google.com> | 2024-11-12 18:46:26 +00:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | df391f5816 | verific: fix blackbox regression and add test case | 2024-11-08 14:57:04 +01:00 |  | 
				
					
						| 
								
								
									 Emil J | caf56ca3e8 | Merge pull request #4516 from YosysHQ/emil/src-attribute-std-string-wip Represent string constants as strings | 2024-10-14 06:42:54 -07:00 |  | 
				
					
						| 
								
								
									 Emil J. Tywoniak | 785bd44da7 | rtlil: represent Const strings as std::string | 2024-10-14 06:28:12 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 8d2b63bb8a | Set VHDL assert condition initial state if fed by FF | 2024-10-11 16:32:21 +02:00 |  | 
				
					
						| 
								
								
									 Roland Coeurjoly | bdc43c6592 | Add left and right bound properties to wire. Add test. Fix printing for signed attributes
Co-authored-by: N. Engelhardt <nak@yosyshq.com>
Co-authored-by: Roland Coeurjoly <rolandcoeurjoly@gmail.com> | 2024-09-10 12:52:42 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanović | 3e14e67374 | Merge pull request #4500 from YosysHQ/micko/vhdl_mixcase VHDL is case insensitive, make sure netlist name is proper | 2024-07-29 16:44:13 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 405897a971 | Update top value that is returned back to hierarchy pass | 2024-07-29 15:50:38 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 9566709426 | Initialize extensions when verific pass is registered | 2024-07-25 11:25:17 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | c94aa719d9 | VHDL is case insensitive, make sure netlist name is proper | 2024-07-18 16:56:52 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | dfde792288 | Refactored import code | 2024-06-17 14:49:58 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 19da7f7d59 | Update makefile to make options uniform | 2024-06-17 13:29:11 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 0f3f731254 | Handle -work for vhdl, and clean messages | 2024-06-17 13:29:11 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 0a81c8e161 | Import all modules from all libraries when when needed | 2024-06-17 13:29:11 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 7c3094633d | Compile with hier_tree separate SV and VHDL as well | 2024-06-17 13:29:11 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | e2e189647f | Cleanup | 2024-06-17 13:29:11 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 7bec332b68 | SV + VHDL with RTL support | 2024-06-17 13:29:11 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 25d50bb2af | VHDL only build support | 2024-06-17 13:29:11 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 54bf9ccf06 | Add initial support for Verific without additional YosysHQ patch | 2024-06-17 13:29:11 +02:00 |  | 
				
					
						| 
								
								
									 Mike Inouye | b0ab1cf8c3 | Fix memory leak in verific file parsing. Signed-off-by: Mike Inouye <mikeinouye@google.com> | 2024-06-07 22:51:28 +00:00 |  | 
				
					
						| 
								
								
									 Ethan Mahintorabi | 82a4a87c97 | Fixes error with vector indicies of the form [2:7] [-12:7] Make sure that we correctly adjust the value to align it to a zero
indexed list with lsb = 0
Signed-off-by: Ethan Mahintorabi <ethanmoon@google.com> | 2024-05-08 20:29:47 +00:00 |  | 
				
					
						| 
								
								
									 Ethan Mahintorabi | c039da2ec1 | renames variables for more code clairty Signed-off-by: Ethan Mahintorabi <ethanmoon@google.com> | 2024-05-08 01:09:52 +00:00 |  | 
				
					
						| 
								
								
									 Ethan Mahintorabi | a2c1b268d9 | frontend: Fixes verific import around range order Test Case
```
module packed_dimensions_range_ordering (
    input  wire [0:4-1] in,
    output wire [4-1:0] out
);
  assign out = in;
endmodule : packed_dimensions_range_ordering
module instanciates_packed_dimensions_range_ordering (
    input  wire [4-1:0] in,
    output wire [4-1:0] out
);
  packed_dimensions_range_ordering U0 (
      .in (in),
      .out(out)
  );
endmodule : instanciates_packed_dimensions_range_ordering
```
```
// with verific, does not pass formal
module instanciates_packed_dimensions_range_ordering(in, out);
  input [3:0] in;
  wire [3:0] in;
  output [3:0] out;
  wire [3:0] out;
  assign out = { in[0], in[1], in[2], in[3] };
endmodule
// with surelog, passes formal
module instanciates_packed_dimensions_range_ordering(in, out);
  input [3:0] in;
  wire [3:0] in;
  output [3:0] out;
  wire [3:0] out;
  assign out = in;
endmodule
```
Signed-off-by: Ethan Mahintorabi <ethanmoon@google.com> | 2024-05-08 01:00:06 +00:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | af94123730 | verific: expose library name as module attribute | 2024-04-15 17:01:07 +02:00 |  | 
				
					
						| 
								
								
									 N. Engelhardt | 3d5e23e585 | Merge pull request #4302 from YosysHQ/vhdl_2019 Verific support for VHDL 2019 | 2024-04-09 18:25:05 +02:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | f536de0e0e | Verific support for VHDL 2019 | 2024-03-28 13:21:55 +01:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 4367e176fb | code split and cleanup | 2024-03-19 09:15:04 +01:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 9eebc80170 | handle standard types | 2024-03-18 10:35:01 +01:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 7c09fa572e | real number handling and default to string | 2024-03-14 10:37:56 +01:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 4279cea33a | improve handling VHDL constants | 2024-03-14 10:37:56 +01:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 858eae5572 | verific_const: convert VHDL values to RTLIL consts | 2024-03-14 10:37:56 +01:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | ae7daf99f4 | Verific: Add attributes to module instantiation | 2024-02-12 09:53:47 +01:00 |  | 
				
					
						| 
								
								
									 Ethan Mahintorabi | ff578ecabd | fix formatting Signed-off-by: Ethan Mahintorabi <ethanmoon@google.com> | 2024-02-05 07:23:04 +00:00 |  | 
				
					
						| 
								
								
									 Ethan Mahintorabi | bc66dfd9ea | verific: Fixes incorrect aldff inference in verific importer The following SV module at HEAD imported with verific,
```systemverilog
    module my_module(
      input logic [4:0] a,
      input logic clk,
      input logic enable,
      output logic [4:0] z
    );
    reg [4:0] pipeline_register;
    always @(posedge clk) begin
      pipeline_register <= enable ? a : pipeline_register;
    end
    assign z = pipeline_register;
    endmodule : my_module
```
results in the following output verilog
```systemverilog
/* Generated by 0.36 */
(* top =  1  *)
(* hdlname = "my_module" *)
(* src = "/tmp/temp_directory_zTwd0l/my_input.v:2.12-2.21" *)
module my_module(clk, enable, a, z);
  wire [4:0] _0_;
  (* src = "/tmp/temp_directory_zTwd0l/my_input.v:3.25-3.26" *)
  input [4:0] a;
  wire [4:0] a;
  (* src = "/tmp/temp_directory_zTwd0l/my_input.v:4.19-4.22" *)
  input clk;
  wire clk;
  (* src = "/tmp/temp_directory_zTwd0l/my_input.v:5.19-5.25" *)
  input enable;
  wire enable;
  (* src = "/tmp/temp_directory_zTwd0l/my_input.v:6.26-6.27" *)
  output [4:0] z;
  wire [4:0] z;
  (* src = "/tmp/temp_directory_zTwd0l/my_input.v:10.12-12.8" *)
  \$aldff  #(
    .ALOAD_POLARITY(32'd1),
    .CLK_POLARITY(32'd1),
    .WIDTH(32'd5)
  ) _1_ (
    .AD(5'hxx),
    .ALOAD(1'h0),
    .CLK(clk),
    .D(_0_),
    .Q(z)
  );
  (* src = "/tmp/temp_directory_zTwd0l/my_input.v:11.28-11.58" *)
  \$mux  #(
    .WIDTH(32'd5)
  ) _2_ (
    .A(z),
    .B(a),
    .S(enable),
    .Y(_0_)
  );
endmodule
```
Yosys is incorrectly infering aldffs due to an incorrect conversion
of logical 1 and 0 SigBits.
My PR unifies the conversion of Verific::Net objects into SigBits using
Yosys' internal representation of special signals like 0,1,x,z. After
my PR these signals are correctly converted into DFFs.
Signed-off-by: Ethan Mahintorabi <ethanmoon@google.com> | 2024-02-05 07:10:25 +00:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | db1de5fe5d | verific: add option to skip simplifying complex ports | 2024-01-30 16:33:44 +01:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 1764c0ee3c | Fix verific clocking when no driver exist | 2024-01-18 08:47:04 +01:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 96fecf0716 | Revert "Add attributes to module instantiation" This reverts commit 8f207eed1b. | 2023-12-04 16:37:01 +01:00 |  | 
				
					
						| 
								
								
									 Miodrag Milanovic | 8f207eed1b | Add attributes to module instantiation | 2023-11-23 11:01:49 +01:00 |  | 
				
					
						| 
								
								
									 N. Engelhardt | 5fb1264db5 | verific: don't try to import attributes from nullptr | 2023-11-14 15:05:24 +01:00 |  | 
				
					
						| 
								
								
									 N. Engelhardt | 93a426cbbf | Merge pull request #4008 from nakengelhardt/mem_libmap_data_attr memory_libmap: look for ram_style attributes on surrounding signals | 2023-11-06 16:25:38 +01:00 |  |