

## 附录 语法参考

本附录提供了Verilog HDL 语言的所有语法。 ⊖

## 关键词

以下是Verilog HDL 硬件描述语言的关键词。注意,只有小写的名字才是关键词。

| begin buf bufif0 bufif1 case casex casez cmos deassign default defparam disable edge else end endcase endmodule endfunction endprimitive endspecify endtable endtask event for force forever fork function highz0 highz1 if ifnone initial inout input integer join large macromodule medium module nand negedge nmos nor not notif0 notif1 or output parameter pmos posedge primitive pullo pull1 pullup pulldown remos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while wire wor xnor xor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | always      | and          | assign     |           |           |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|------------|-----------|-----------|
| deassign default defparam disable edge else end endcase endmodule endfunction endprimitive endspecify endtable endtask event  for force forever fork function highz0 highz1 if ifnone initial inout input integer join large macromodule medium module nand negedge nmos nor not notif0 notif1 or output parameter pmos posedge primitive pull0 pull1 pullup pulldown rcmos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri1 tri1 triand trior trireg vectored wait wand weak0 weak1 while                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | begin       | buf          | bufif0     | bufif1    |           |
| edge else end endcase endmodule endfunction endprimitive endspecify endtable endtask event  for force forever fork function highz0 highz1 if ifnone initial inout input integer join large macromodule medium module nand negedge nmos nor not notif0 notif1 or output parameter pmos posedge primitive pull0 pull1 pullup pulldown remos real realtime reg release repeat rnmos rpmos prosedge rran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while while wire                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | case        | casex        | casez      | cmos      |           |
| endfunction endprimitive endspecify endtable endtask event  for force forever fork function highz0 highz1 if ifnone initial inout input integer join large macromodule medium module nand negedge nmos nor not notif0 notif1 or output parameter pmos posedge primitive pullo pullup pullup pulldown real realtime reg release repeat rnmos rpmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while while while model in the force in the specify specify weak1 while wire wor in the specify specify specify weak1 while while wor in the specify specify specify tran tranif0 tranif1 tri tri0 tri0 tri1 triand trior weak1 wand weak0 weak1 while                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | deassign    | default      | defparam   | disable   |           |
| event  for force forever fork function highz0 highz1 if ifnone initial inout input integer join large macromodule medium module nand negedge nmos nor not notif0 notif1 or output parameter pmos posedge primitive pull0 pull1 pullup pulldown rcmos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | edge        | else         | end        | endcase   | endmodule |
| for force forever fork function highz0 highz1 if ifnone initial inout input integer join large macromodule medium module nand negedge nmos nor not notif0 notif1 or output parameter pmos posedge primitive pull0 pull1 pullup pulldown remos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | endfunction | endprimitive | endspecify | endtable  | endtask   |
| highz0       highz1         if       ifnone       initial       inout       input         integer       join       Inception       Inception<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | event       |              |            |           |           |
| if inone initial inout input integer join large macromodule medium module nand negedge nmos nor not notif0 notif1 or output pullup pullup pulldown remos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri tri0 tri1 tri1 triand trior trieg vectored wait wand weak0 weak1 while module input inpu | for         | force        | forever    | fork      | function  |
| integer join large macromodule medium module nand negedge nmos nor not notif0 notif1 or output parameter pmos posedge primitive pull0 pull1 pullup pulldown rcmos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | highz0      | highz1       |            |           |           |
| join large macromodule medium module nand negedge nmos nor not notif0 notif1 or output parameter pmos posedge primitive pull0 pull1 pullup pulldown rcmos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | if          | ifnone       | initial    | inout     | input     |
| large macromodule medium module nand negedge nmos nor not notif0 notif1 or output  parameter pmos posedge primitive pull0 pull1 pullup pulldown rcmos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | integer     |              |            |           |           |
| macromodule medium module nand negedge nmos nor not notif0 notif1 or output parameter pmos posedge primitive pull0 pull1 pullup pulldown rcmos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | join        |              |            |           |           |
| nand<br>notif0negedge<br>notif1nmosnornotoroutputrealprimitivepull0pull1pulluppulldownregreleaseremosrealrealtimeregreleaserepeatrnmosrpmosrtranrtranif0rtranif1scalaredsmallspecifyspecparamstrong0strong1supply0supply1tabletasktimetrantranif0tranif1tritri0tri1triandtriortriregvectoredwaitwandweak0weak1whilewirewor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | large       |              |            |           |           |
| notif0 or output parameter pmos posedge primitive pullo pull1 pullup pulldown rcmos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | macromodule | medium       | module     |           |           |
| or output parameter pmos posedge primitive pullo pull1 pullup pulldown rcmos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | nand        | negedge      | nmos       | nor       | not       |
| parameter pmos posedge primitive pull0 pull1 pullup pulldown rcmos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | notif0      | notif1       |            |           |           |
| pull1 pullup pulldown rcmos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while wire                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | or          | output       |            |           |           |
| rcmos real realtime reg release repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while wire                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | parameter   | pmos         | posedge    | primitive | pull0     |
| repeat rnmos rpmos rtran rtranif0 rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while wire                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | pull1       | pullup       | pulldown   |           |           |
| rtranif1 scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while wire wor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | rcmos       | real         | realtime   | reg       | release   |
| scalared small specify specparam strong0 strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while wire                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | repeat      | rnmos        | rpmos      | rtran     | rtranif0  |
| strong1 supply0 supply1 table task time tran tranif0 tranif1 tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while wire wor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | rtranif1    |              |            |           |           |
| table task time tran tranif0 tranif1 tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while wire                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | scalared    | small        | specify    | specparam | strong0   |
| tranif1 tri tri0 tri1 triand trior trireg vectored wait wand weak0 weak1 while wire wor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | strong1     | supply0      | supply1    |           |           |
| trior trireg vectored wait wand weak0 weak1 while wire wor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | table       | task         | time       | tran      | tranif0   |
| vectored wait wand weak0 weak1 while wire wor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | tranif1     | tri          | tri0       | tri1      | triand    |
| wait wand weak0 weak1 while wire wor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | trior       | trireg       |            |           |           |
| wire wor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | vectored    |              |            |           |           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | wait        | wand         | weak0      | weak1     | while     |
| xnor xor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | wire        | wor          |            |           |           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | xnor        | xor          |            |           |           |

<sup>○</sup> 源自IEEE Std 1364-1995 , Copyright © 1995, IEEE, All rights reserved.



## 语法规范

下列规范应用于语法描述,规则采用巴科斯—诺尔范式(BNF)书写:

- 1) 语法规则按自左向右非终结字符的字母序组织。
- 2) 保留字、操作符和标点标记是语法的组成部分,以粗体字表示。
- 3) 非终结名字前的斜体名字的语义表示与非终结名字相关联。
- 4) 非粗体的垂直符号(|) 用于分离可替换的选项。
- 5) 非粗体的方括号([...])表示可选项。
- 6) 非粗体的大括号({...})表明某项可以重复0次或多次。
- 7) 以粗体出现的方括号、圆括号、大括号([...],(...){...},)以及其他符号(如;)表示符号是语法的组成部分。
  - 8) 起始的非终结名字为"源文本(source\_text)"
  - 9) 此语法中使用的终结名字以大写形式出现。

## 文法

always\_construct ::= always

```
statement
binary_base ::=
    'b | 'B
binary_digit ::=
    x | X | z | Z | 0 | 1
binary_number ::=
    [ size ] binary_base binary_digit { _ ! binary_digit }
binary_operator ::=
      +1-1*1/1%
    | ==|!=|==|!==|&&||||<|<=|>|>=
    | &| | | ^ | ^ | - ^ | >> | <<
      parameter_declaration
    I reg_declaration
    I integer_declaration
    | real_declaration
    I time declaration
    realtime_declaration
    l event_declaration
blocking_assignment ::=
    reg_lvalue = [ delay_or_event_control ] expression
      expression { , expression } : statement_or_null
    default [:] statement_or_null
```



```
case_statement ::=
      case (expression) case_item { case_item } endcase
    i casez ( expression ) case_item { case_item } endcase
    casex ( expression ) case_item { case_item } endcase
charge_strength ::=
      (small)
    | (medium)
    | (large)
cmos_switch_instance ::=
    [ name_of_gate_instance ] ( output_terminal , input_terminal ,
    ncontrol_terminal, pcontrol_terminal)
cmos_switchtype ::=
    cmos | rcmos
combinational_body ::=
    table
      combinational_entry { combinational_entry }
    endtable
combinational_entry ::=
    level_input_list: output_symbol;
comment ::=
      short_comment
    i long_comment
comment_text ::=
constant_expression ::=
      constant_primary
   I unary_operator constant_primary
    constant_expression binary_operator constant_expression
    constant_expression ? constant_expression : constant_expression
    string
constant_mintypmax_expression ::=
      constant_expression
    I constant_expression : constant_expression : constant_expression
constant_primary ::=
      number
    parameter_identifier
    I constant_concatenation
    I constant_multiple_concatenation
continuous_assign ::=
    assign [ drive_strength ] [ delay3 ] list_of_net_assignments ;
controlled_timing_check_event ::=
    timing_check_event_control specify_terminal_descriptor
    [ && timing_check_condition ]
current_state ::=
    level_symbol
data_source_expression ::=
    expression
decimal_base ::=
    'd | 'D
decimal_digit ::=
```



```
0|1|2|3|4|5|6|7|8|9
decimal_number ::=
      [ sign ] unsigned_number
    I [ size ] decimal_base unsigned_number
delay2 ::=
      # delay_value
    # ( delay_value [ , delay_value ] )
delay3 ::=
      # delay_value
    # ( delay_value [ , delay_value [ , delay_value ] ] )
delay control ::=
      # delay_value
    # ( mintypmax_expression )
delay_or_event_control ::=
      delay_control
    I event_control
    I repeat (expression) event_control
delay_value ::=
      unsigned_number
    | parameter_identifier
    I constant_mintypmax_expression
description ::=
      module_declaration
    I udp_declaration
disable_statement ::=
      disable task identifier;
    i disable block_identifier;
drive_strength ::=
      (strength0, strength1)
    ( strength1 , strength0 )
    (strength0, highz1)
    (strength1, highz0)
    (highz1, strength0)
    (highz0, strength1)
edge_control_specifier ::=
    edge [ edge_descriptor [ , edge_descriptor ] ]
edge_descriptor ::=
      01
    1 10
    | 0x
    | x1
    | 1x
    | x0
edge_identifier ::=
    posedge i negedge
edge_indicator ::=
      (level_symbol level_symbol)
    | edge_symbol
edge_input_list ::=
    { level_symbol } edge_indicator { level_symbol }
```



```
edge_sensitive_path_declaration ::=
      parallel_edge_sensitive_path_description = path_delay_value
    | full_edge_sensitive_path_description = path_delay_value
edge_symbol ::=
    r!R!f|F|p|P|n|N|*
enable_gate_instance ::=
    [ name_of_gate_instance ] ( output_terminal , input_terminal ,
    enable_terminal )
enable_gate_type ::=
    bufif0 | bufif1 | notif0 | notif1
enable_terminal ::=
    scalar_expression
escaped_identifier ::=
    \ { ANY_ASCII_CHARACTER_EXCEPT_WHITE_SPACE } white_space
event_control ::=
      @ event_identifier
    | @ ( event_expression )
event_declaration ::=
    event event_identifier { , event_identifier } ;
event_expression ::=
      expression
    l event_identifier
    | posedge expression
    I negedge expression
    event_expression or event_expression
event_trigger ::=
    -> event_identifier;
expression ::=
      primary
    I unary_operator primary
    expression binary_operator expression
    I expression ? expression : expression
    1 string
full_edge_sensitive_path_description ::=
    ( [ edge_identifier ] list_of_path_inputs *> list_of_path_outputs
    [ polarity_operator ] : data_source_expression )
full_path_description ::=
    ( list_of_path_inputs [ polarity_operator ] *> list_of_path_outputs )
function_call ::=
      function_identifier ( expression { , expression } )
    l name_of_system_function [ ( expression { , expression } ) ]
function declaration ::=
    function [ range_or_type ] function_identifier ;
      function_item_declaration { function_item_declaration }
      statement
    endfunction
function_item_declaration ::=
      block_item_declaration
    I input_declaration
```



```
gate_instantiation ::=
      n_input_gatetype [ drive_strength ] [ delay2 ] n_input_gate_instance
        { , n_input_gate_instance } ;
    I n_output_gatetype [ drive_strength ] [ delay2 ] n_output_gate_instance
         { , n_output_gate_instance } ;
    I enable_gatetype [ drive_strength ] [ delay3 ] enable_gate_instance
         { , enable_gate_instance } ;
    i mos_switchtype [ delay3 ] mos_switch_instance
         { , mos_switch_instance } ;
    pass_switchtype pass_switch_instance { , pass_switch_instance };
    I pass_en_switchtype [ delay3 ] pass_en_switch_instance
         { , pass_en_switch_instance };
    I cmos_switchtype [ delay3 ] cmos_switch_instance
         { , cmos_switch_instance } ;
    pullup [ pullup_strength ] pull_gate_instance { , pull_gate_instance } ;
    | pulldown | pulldown_strength | pull_gate_instance
        { , pull_gate_instance } ;
hex base ::=
    'h | 'H
hex_digit ::=
      x \mid X \mid z \mid Z
    1 0 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 1 9
    | a|b|c|d|e|f|A|B|C|D|E|F
hex number ::=
    [ size ] hex_base hex_digit { _ I hex_digit }
identifier :=
    IDENTIFIER [ { . IDENTIFIER } ]
    /* The period may not be followed or preceded by a space */
IDENTIFIER ::=
      simple_identifier
    l escaped_identifier
init_val ::=
    1'b0 | 1'b1 | 1'bx | 1'bX | 1'B0 | 1'B1 | 1'Bx | 1'BX | 1 | 0
initial construct ::=
    initial
      statement
inout_declaration ::=
    inout [ range ] list_of_port_identifiers ;
inout_terminal ::=
input_identifier ::=
       input_port_identifier
    I inout_port_identifier
input_terminal ::=
    scalar_expression
integer_declaration ::=
    integer list_of_register_identifiers;
```



```
level_input_list ::=
     level_symbol { level_symbol }
level_symbol ::=
     0 | 1 | x | X | ? | b | B
limit_value ::=
     constant_mintypmax_expression
list_of_module_connections ::=
       ordered_port_connection { , ordered_port_connection }
     named_port_connection { , named_port_connection }
list_of_net_assignments ::=
     net_assignment { , net_assignment }
list_of_net_decl_assignments ::=
     net_decl_assignment { , net_decl_assignment }
list_of_net_identifiers ::=
    net_identifier { , net_identifier }
list_of_param_assignments ::=
    param_assignment { , param_assignment }
list_of_path_delay expressions ::=
       t_path_delay_expression
    trise_path_delay_expression, tfall_path_delay_expression
    trise_path_delay_expression , tfall_path_delay_expression ,
         tz_path_delay_expression
    t01_path_delay_expression, t10_path_delay_expression,
         t0z_path_delay_expression, tz1_path_delay_expression,
         t1z_path_delay_expression, tz0_path_delay_expression
    1 t01_path_delay_expression, t10_path_delay_expression,
         t0z_path_delay_expression, tz1_path_delay_expression,
         t1z\_path\_delay\_expression , tz0\_path\_delay\_expression ,
         t0x_path_delay_expression, tx1_path_delay_expression,
         t1x_path_delay_expression, tx0_path_delay_expression,
         txz_path_delay_expression, tzx_path_delay_expression
list_of_path_inputs ::=
    specify_input_terminal_descriptor { , specify_input_terminal_descriptor }
list_of_path_outputs ::=
    specify_output_terminal_descriptor { , specify_output_terminal_descriptor }
list_of_port_identifiers ::=
    port_identifer { , port_identifier }
list_of_ports ::=
    (port { , port } )
list of real identifiers ::=
    real_identifier { , real_identifier }
list_of_register_identifiers ::=
    register_name { , register_name }
list_of_specparam_assignments ::=
    specparam_assignment { , specparam_assignment }
long comment ::=
    /* comment_text */
loop statement ::=
       forever statement
```



```
I repeat (expression) statement
    I while (expression) statement
    I for ( reg_assignment ; expression ; reg_assignment ) statement
mintypmax_expression ::=
      expression
    expression: expression: expression
module declaration ::=
    module_keyword module_identifier [ list_of_ports ];
      { module item }
    endmodule
module instance ::=
    name_of_instance ([list_of_module_connections])
module_instantiation ::=
    module_identifier [ parameter_value_assignment ] module_instance
      { , module_instance } ;
module_item ::=
      module_item_declaration
    I parameter_override
    I continuous_assign
    I gate_instantiation
    I udp_instantiation
    | module_instantiation
    | specify_block
    | initial_construct
    | always_construct
module_item_declaration ::=
      parameter_declaration
    I input_declaration
    I output_declaration
    I inout_declaration
    I net_declaration
    I reg declaration
    integer_declaration
    I real_declaration
    I time_declaration
    realtime declaration
    I event_declaration
    I task declaration
    I function_declaration
module_keyword ::=
    module | macromodule
mos_switch_instance ::=
    [ name_of_gate_instance ] ( output_terminal , input_terminal ,
      enable_terminal)
mos_switchtype ::=
    nmos | pmos | rnmos | rpmos
multiple_concatenation ::=
    { expression { expression { , expression } } }
n_input_gate_instance ::=
    [ name_of_gate_instance ] ( output_terminal , input_terminal
      { , input_terminal } )
```

```
net_assignment ::=
    net_lvalue = expression
net_decl_assignment ::=
    net_identifier = expression
net_declaration ::=
      net_type [ vectored | scalared ] [ range ] [ delay3 ] list_of_net_identifiers ;
    trireg [ vectored | scalared ] [ charge_strength ] [ range ] [ delay3 ]
         list_of_net_identifiers;
    i net_type [ vectored | scalared ] [ drive_strength ] [ range ] [ delay3 ]
         list_of_net_decl_assignments;
net_lvalue ::=
      net_identifier
    | net_identifier [ expression ]
    l net_identifier [ msb_constant_expression : lsb_constant_expression ]
    | net_concatenation
net_type ::=
    wire | tri | tri1 | supply0 | wand | triand | tri0 | supply1 | wor | trior
next_state ::=
     output_symbol | -
non_blocking_assignment ::=
     reg_lvalue <= [ delay_or_event_control ] expression
notify_register ::=
     register_identifier
number ::=
       decimal_number
     | octal_number
     I binary_number
     | hex_number
     I real_number
octal_base ::=
```



```
'o | 'O
 octal_digit ::=
     x | X | z | Z | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7
 octal_number ::=
     [ size ] octal_base octal_digit { _ l octal_digit }
 ordered_port_connection ::=
     [ expression ]
 output_declaration ::=
     output [ range ] list_of_port_identifiers;
 output_identifier ::=
        output_port_identifier
      inout_port_identifier
 output_symbol ::=
     0 | 1 | x | X
 output_terminal ::=
       terminal_identifier
     terminal_identifier [ constant_expression ]
par block ::=
     fork
       [:block_identifier
         { block_item_declaration } ]
       { statement }
     join
parallel_edge_sensitive_path_description ::=
     ([edge_identifier] specify_input_terminal_descriptor =>
       specify_output_terminal_descriptor [ polarity_operator ]:
       data_source_expression)
parallel_path_description ::=
     ( specify_input_terminal_descriptor [ polarity_operator ] =>
       specify_output_terminal_descriptor)
param_assignment ::=
     parameter_identifier = constant_expression
parameter_declaration ::=
     parameter list_of_param_assignments;
parameter_override ::=
     defparam list_of_param_assignments;
parameter_value_assignment ::=
    #(expression { , expression } )
pass_en_switchtype ::=
    tranif0 | tranif1 | rtranif1 | rtranif0
pass_en_switch_instance ::=
    [ name_of_gate_instance ] ( inout_terminal , inout_terminal ,
       enable_terminal)
pass_switch_instance ::=
    [ name_of_gate_instance ] ( inout_terminal , inout_terminal )
pass_switchtype ::=
    tran | rtran
path_declaration ::=
```

```
path_delay_value ::=
      list_of_path_delay_expressions
    ( list_of_path_delay_expressions )
pcontrol_terminal ::=
    scalar_expression
polarity_operator ::=
    +1-
port ::=
      [ port_expression ]
    . port_identifier ([port_expression])
port_expression ::=
      port_reference
    | { port_reference { , port_reference } }
port_reference ::=
      port_identifier
    port_identifier [ constant_expression ]
    | port_identifier [ msb_constant_expression : lsb_constant_expression ]
primary ::=
      number
    I identifier
    | identifier [expression]
    identifier [ msb_constant_expression : lsb_constant_expression ]
    concatenation
    | multiple_concatenation
    | function_call
    I (mintypmax_expression)
procedural_continuous_assignment ::=
      assign reg_assignment;
    i deassign reg_lvalue;
    l force reg_assignment;
    l force net_assignment;
    I release reg_lvalue;
    | release net_lvalue;
procedural_timing_control_statement ::=
    delay_or_event_control statement_or_null
pull_gate_instance ::=
    [ name_of_gate_instance ] ( output_terminal )
pulldown_strength ::=
      (strength0, strength1)
    | (strength1, strength0)
    (strength0)
pullup_strength ::=
      (strength0, strength1)
    (strength1, strength0)
    (strength1)
```



```
pulse_control_specparam ::=
      PATHPULSE$ = ( reject_limit_value [ , error_limit_value ] );
    PATHPULSE$specify_input_terminal_descriptor /*no space; continue*/
      $specify output terminal_descriptor = ( reject_limit_value
      [, error_limit_value]);
range ::=
    [ msb_constant_expression : lsb_constant_expression ]
range_or_type ::=
    range | integer | real | realtime | time
real_declaration ::=
    real list_of_real_identifiers;
real_number ::=
      [ sign ] unsigned_number . unsigned_number
    I [ sign ] unsigned_number [ . unsigned_number ] e [ sign ]
        unsigned_number
    [ sign ] unsigned_number [ . unsigned_number ] E [ sign ]
        unsigned_number
realtime_declaration ::=
    realtime list_of_real_identifiers;
reg_assignment ::=
    reg_lvalue = expression
rea declaration ::=
    reg [ range ] list_of_register_identifiers ;
reg_lvalue ::=
      reg_identifier
    | rea identifier [expression]
    | reg_identifier [ msb_constant_expression : lsb_constant_expression ]
    I reg_concatenation
register_name ::=
      register_identifier
    l memory_identifier [ upper_limit_constant_expression :
         lower limit constant_expression ]
scalar_constant ::=
    1'b0 | 1'b1 | 1'B0 | 1'B1 | 'b0 | 'b1 | 'B0 | 'B1 | 1 | 0
scalar_timing_check_condition ::=
       expression
    ~ expression
    | expression == scalar_constant
    | expression === scalar_constant
    | expression != scalar_constant
    | expression !== scalar_constant
seq_block ::=
    begin
       [: block_identifier
         { block_item_declaration } ]
       { statement }
     end
seq_input_list ::=
     level_input_list | edge_input_list
sequential_body ::=
```



```
[ udp_initial_statement ]
    table
      sequential_entry
      { sequential_entry }
    endtable
sequential_entry ::=
    seq_input_list : current_state : next_state ;
short comment ::=
    // comment_text \n
sign ::=
    +1-
simple_identifier ::=
    [a-zA-Z][a-zA-Z_$0-9]
simple_path_declaration ::=
      parallel_path_description = path_delay_value
    I full_path_description = path_delay_value
size ::=
    unsigned_number
source_text ::=
    { description }
specify_block ::=
     specify
       { specify_item }
     endspecify
specify_input_terminal_descriptor ::=
       input_identifier
     I input_identifier [ constant_expression ]
     l input_identifier [ msb_constant_expression : lsb_constant_expression ]
specify_item ::=
      specparam_declaration
     I path_declaration
     I system_timing_check
specify_output_terminal_descriptor ::=
       output_identifier
    l output_identifier [ constant_expression ]
    output_identifier [ msb_constant_expression : lsb_constant_expression ]
specify_terminal_descriptor ::=
       specify_input_terminal_descriptor
    I specify_output_terminal_descriptor
specparam_assignment ::=
       specparam_identifier = constant_expression
    l pulse_control_specparam
specparam_declaration ::=
    specparam list_of_specparam_assignments;
state_dependent_path_declaration ::=
       if ( conditional_expression ) simple_path_declaration
    if (conditional_expression) edge_sensitive_path_declaration
    I ifnone simple_path_declaration
statement ::=
```



```
blocking_assignment;
    l non_blocking_assignment;
    procedural continuous assignment;
    I procedural_timing_control_statement
    I conditional statement
    I case_statement
    | loop_statement
    | wait_statement
    I disable_statement
    I event_trigger
    | seq_block
    I par_block
    I task enable
    | system_task_enable
statement_or_null ::=
    statement |;
strength0 ::=
    supply0 | strong0 | pull0 | weak0
strenath1 ::=
    supply1 | strong1 | pull1 | weak1
string ::=
    "{ ANY_ASCII_CHARACTERS_EXCEPT_NEWLINE } "
                   I path_declaration
system_task_name ::=
    $identifier
    /* The $ cannot be followed by a space */
system_timing_check ::=
      $setup (timing_check_event, timing_check_event, timing_check_limit
         [, notify_register]);
    1 $hold (timing_check_event, timing_check_event, timing_check_limit
         [, notify_register]);
    | Speriod (controlled_timing_check_event, timing_check_limit)
         [, notify_register]);
    | Swidth (controlled_timing_check_event, timing_check_limit,
         constant_expression [ , notify_register ] );
    | $skew (timing_check_event, timing_check_event, timing_check_limit
         [, notify_register]);
    | $recovery (controlled_timing_check_event, timing_check_event,
         timing_check_limit[, notify_tegister]);
    | $setuphold (timing_check_event , timing_check_event ,
         timing_check_limit, timing_check_limit[, notify_register]);
task_declaration ::=
    task task_identifier;
      { task_item_declaration }
       statement or null
    endtask
task_enable ::=
    task_identifier [ ( expression { , expression } ) ];
task_item_declaration ::=
       block item declaration
    input_declaration
```



10. Open Verilog International, OVI Standard Delay File (SDF) Format Manual.