Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
S
sv2v
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
sv2v
Commits
a4639fa9
Commit
a4639fa9
authored
Nov 04, 2023
by
Zachary Snow
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
special case typenames when resolving pattern identifiers
parent
d5b9c1da
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
91 additions
and
5 deletions
+91
-5
CHANGELOG.md
+2
-0
src/Convert/Package.hs
+44
-5
test/core/pattern_resolve.sv
+30
-0
test/core/pattern_resolve.v
+15
-0
No files found.
CHANGELOG.md
View file @
a4639fa9
...
@@ -15,6 +15,8 @@
...
@@ -15,6 +15,8 @@
*
Fixed an issue that prevented parsing tasks and functions with
`inout`
ports
*
Fixed an issue that prevented parsing tasks and functions with
`inout`
ports
*
Fixed conflicting genvar names when inlining interfaces and modules that use
*
Fixed conflicting genvar names when inlining interfaces and modules that use
them; all genvars are now given a design-wide unique name
them; all genvars are now given a design-wide unique name
*
Fixed non-typenames (e.g., from packages or subsequent declarations)
improperly shadowing the names of
`struct`
pattern fields
*
Fixed failure to resolve typenames suffixed with dimensions in contexts
*
Fixed failure to resolve typenames suffixed with dimensions in contexts
permitting both types and expressions, e.g.,
`$bits(T[W-1:0])`
permitting both types and expressions, e.g.,
`$bits(T[W-1:0])`
*
Fixed errant constant folding of shadowed non-trivial localparams
*
Fixed errant constant folding of shadowed non-trivial localparams
...
...
src/Convert/Package.hs
View file @
a4639fa9
...
@@ -25,6 +25,7 @@ module Convert.Package
...
@@ -25,6 +25,7 @@ module Convert.Package
import
Control.Monad.State.Strict
import
Control.Monad.State.Strict
import
Control.Monad.Writer.Strict
import
Control.Monad.Writer.Strict
import
Data.Functor
((
<&>
))
import
Data.List
(
insert
,
intercalate
,
isPrefixOf
)
import
Data.List
(
insert
,
intercalate
,
isPrefixOf
)
import
Data.Maybe
(
mapMaybe
)
import
Data.Maybe
(
mapMaybe
)
import
qualified
Data.Map.Strict
as
Map
import
qualified
Data.Map.Strict
as
Map
...
@@ -261,6 +262,9 @@ explicitImport pkg ident = do
...
@@ -261,6 +262,9 @@ explicitImport pkg ident = do
++
" conflicts with prior import of "
++
" conflicts with prior import of "
++
otherPkg
++
"::"
++
ident
++
otherPkg
++
"::"
++
ident
pattern
PatternTag
::
Char
pattern
PatternTag
=
'*'
-- main logic responsible for translating packages, resolving imports and
-- main logic responsible for translating packages, resolving imports and
-- exports, and rewriting identifiers referring to package declarations
-- exports, and rewriting identifiers referring to package declarations
processItems
::
Identifier
->
Identifier
->
[
ModuleItem
]
processItems
::
Identifier
->
Identifier
->
[
ModuleItem
]
...
@@ -366,7 +370,10 @@ processItems topName packageName moduleItems = do
...
@@ -366,7 +370,10 @@ processItems topName packageName moduleItems = do
Variable
d
t
x
a
e
->
declHelp
x
$
\
x'
->
Variable
d
t
x'
a
e
Variable
d
t
x
a
e
->
declHelp
x
$
\
x'
->
Variable
d
t
x'
a
e
Net
d
n
s
t
x
a
e
->
declHelp
x
$
\
x'
->
Net
d
n
s
t
x'
a
e
Net
d
n
s
t
x
a
e
->
declHelp
x
$
\
x'
->
Net
d
n
s
t
x'
a
e
Param
p
t
x
e
->
declHelp
x
$
\
x'
->
Param
p
t
x'
e
Param
p
t
x
e
->
declHelp
x
$
\
x'
->
Param
p
t
x'
e
ParamType
p
x
t
->
declHelp
x
$
\
x'
->
ParamType
p
x'
t
ParamType
p
x
t
->
-- make this typename available for use in patterns
prefixIdent
(
PatternTag
:
x
)
>>
declHelp
x
(
\
x'
->
ParamType
p
x'
t
)
CommentDecl
c
->
return
$
CommentDecl
c
CommentDecl
c
->
return
$
CommentDecl
c
where
declHelp
x
f
=
prefixIdent
x
>>=
return
.
f
where
declHelp
x
f
=
prefixIdent
x
>>=
return
.
f
...
@@ -409,10 +416,25 @@ processItems topName packageName moduleItems = do
...
@@ -409,10 +416,25 @@ processItems topName packageName moduleItems = do
x'
<-
resolvePSIdent'
p
x
x'
<-
resolvePSIdent'
p
x
return
$
Ident
x'
return
$
Ident
x'
traverseExprM
(
Ident
x
)
=
resolveIdent
x
>>=
return
.
Ident
traverseExprM
(
Ident
x
)
=
resolveIdent
x
>>=
return
.
Ident
traverseExprM
(
Pattern
items
)
=
do
keys'
<-
mapM
keyMapper
keys
vals'
<-
mapM
traverseExprM
vals
return
$
Pattern
$
zip
keys'
vals'
where
(
keys
,
vals
)
=
unzip
items
traverseExprM
other
=
traverseExprM
other
=
traverseSinglyNestedExprsM
traverseExprM
other
traverseSinglyNestedExprsM
traverseExprM
other
>>=
traverseExprTypesM
traverseTypeM
>>=
traverseExprTypesM
traverseTypeM
-- equivalent to the special case in traverseExprIdentsM
keyMapper
(
Left
t
)
=
traverseTypeM
t
<&>
Left
keyMapper
(
Right
(
Ident
x
))
=
do
tagged'
<-
traverseExprM
$
Ident
$
PatternTag
:
x
let
Ident
x'
=
tagged'
return
$
Right
$
Ident
$
filter
(
/=
PatternTag
)
x'
keyMapper
(
Right
e
)
=
traverseExprM
e
<&>
Right
traverseLHSM
::
LHS
->
Scope
LHS
traverseLHSM
::
LHS
->
Scope
LHS
traverseLHSM
(
LHSIdent
x
)
=
resolveIdent
x
>>=
return
.
LHSIdent
traverseLHSM
(
LHSIdent
x
)
=
resolveIdent
x
>>=
return
.
LHSIdent
traverseLHSM
other
=
traverseSinglyNestedLHSsM
traverseLHSM
other
traverseLHSM
other
=
traverseSinglyNestedLHSsM
traverseLHSM
other
...
@@ -783,11 +805,28 @@ traverseIdentsM identMapper = traverseNodesM
...
@@ -783,11 +805,28 @@ traverseIdentsM identMapper = traverseNodesM
-- visits all identifiers in an expression
-- visits all identifiers in an expression
traverseExprIdentsM
::
Monad
m
=>
MapperM
m
Identifier
->
MapperM
m
Expr
traverseExprIdentsM
::
Monad
m
=>
MapperM
m
Identifier
->
MapperM
m
Expr
traverseExprIdentsM
identMapper
=
full
Mapper
traverseExprIdentsM
identMapper
=
expr
Mapper
where
where
fullMapper
=
exprMapper
>=>
traverseSinglyNestedExprsM
fullMapper
exprMapper
(
Ident
x
)
=
identMapper
x
>>=
return
.
Ident
exprMapper
(
Ident
x
)
=
identMapper
x
>>=
return
.
Ident
exprMapper
other
=
return
other
exprMapper
(
Pattern
items
)
=
do
keys'
<-
mapM
keyMapper
keys
vals'
<-
mapM
exprMapper
vals
return
$
Pattern
$
zip
keys'
vals'
where
(
keys
,
vals
)
=
unzip
items
exprMapper
other
=
traverseExprTypesM
(
traverseTypeIdentsM
identMapper
)
other
>>=
traverseSinglyNestedExprsM
exprMapper
-- Don't reorder or inject a pattern key unless it refers to a known
-- typename. TODO: This prevents referring to expressions in packages in
-- pattern keys, though this probably isn't common.
keyMapper
(
Left
t
)
=
traverseTypeIdentsM
identMapper
t
<&>
Left
keyMapper
(
Right
(
Ident
x
))
=
identMapper
(
PatternTag
:
x
)
<&>
filter
(
/=
PatternTag
)
<&>
Ident
<&>
Right
keyMapper
(
Right
e
)
=
exprMapper
e
<&>
Right
-- visits all identifiers in a type
-- visits all identifiers in a type
traverseTypeIdentsM
::
Monad
m
=>
MapperM
m
Identifier
->
MapperM
m
Type
traverseTypeIdentsM
::
Monad
m
=>
MapperM
m
Identifier
->
MapperM
m
Type
...
@@ -830,7 +869,7 @@ piNames (Task _ ident _ _) = [ident]
...
@@ -830,7 +869,7 @@ piNames (Task _ ident _ _) = [ident]
piNames
(
Decl
(
Variable
_
_
ident
_
_
))
=
[
ident
]
piNames
(
Decl
(
Variable
_
_
ident
_
_
))
=
[
ident
]
piNames
(
Decl
(
Net
_
_
_
_
ident
_
_
))
=
[
ident
]
piNames
(
Decl
(
Net
_
_
_
_
ident
_
_
))
=
[
ident
]
piNames
(
Decl
(
Param
_
_
ident
_
))
=
[
ident
]
piNames
(
Decl
(
Param
_
_
ident
_
))
=
[
ident
]
piNames
(
Decl
(
ParamType
_
ident
_
))
=
[
ident
]
piNames
(
Decl
(
ParamType
_
ident
_
))
=
[
ident
,
PatternTag
:
ident
]
piNames
(
Decl
(
CommentDecl
_
))
=
[]
piNames
(
Decl
(
CommentDecl
_
))
=
[]
piNames
item
@
DPIImport
{}
=
[
show
item
]
piNames
item
@
DPIImport
{}
=
[
show
item
]
piNames
item
@
DPIExport
{}
=
[
show
item
]
piNames
item
@
DPIExport
{}
=
[
show
item
]
...
...
test/core/pattern_resolve.sv
0 → 100644
View file @
a4639fa9
package
P
;
function
automatic
integer
F
;
F
=
'1
;
endfunction
typedef
byte
G
;
endpackage
module
top
;
typedef
struct
packed
{
integer
unsigned
X
,
Y
,
Z
;
}
T
;
parameter
T
W
=
'
{
X
:
3
,
Y
:
5
,
Z
:
7
};
localparam
Z
=
W
.
X
;
localparam
Y
=
W
.
Z
;
initial
$
display
(
W
,
W
.
X
,
W
.
Y
,
W
.
Z
,
Z
,
Y
)
;
// There is disagreement among commercial simulators on whether or not type
// names can shadow field names. sv2v allows this shadowing.
import
P
::*;
typedef
struct
packed
{
byte
E
;
shortint
F
;
integer
G
;
}
U
;
U
a
=
'
{
F
:
1
,
G
:
2
,
default
:
3
};
U
b
=
'
{
E
:
1
,
G
:
2
,
default
:
3
};
U
c
=
'
{
F
:
F
()
,
default
:
4
};
`define
DUMP
(
v
)
initial
$
display
("%
b
%
b
%
b
",
v
.
E
,
v
.
F
,
v
.
G
)
;
`DUMP
(
a
)
`DUMP
(
b
)
`DUMP
(
c
)
endmodule
test/core/pattern_resolve.v
0 → 100644
View file @
a4639fa9
module
top
;
parameter
[
95
:
0
]
W
=
{
32'd3
,
32'd5
,
32'd7
};
localparam
Z
=
W
[
95
:
64
]
;
localparam
Y
=
W
[
31
:
0
]
;
initial
$
display
(
W
,
W
[
95
:
64
]
,
W
[
63
:
32
]
,
W
[
31
:
0
]
,
Z
,
Y
)
;
reg
[
55
:
0
]
a
,
b
,
c
;
initial
begin
a
=
{
8'd2
,
16'd1
,
32'd3
};
b
=
{
8'd1
,
16'd3
,
32'd3
};
c
=
{
8'd4
,
16'hFFFF
,
32'd4
};
`define
DUMP
(
v
)
$
display
("%
b
%
b
%
b
",
v
[
55
:
48
],
v
[
47
:
32
],
v
[
31
:
0
])
;
`DUMP
(
a
)
`DUMP
(
b
)
`DUMP
(
c
)
end
endmodule
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment