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
24a79ffe
Commit
24a79ffe
authored
Jun 02, 2021
by
Zachary Snow
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
support multi-dimensional modports
parent
e0e29634
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
47 additions
and
13 deletions
+47
-13
src/Convert/Interface.hs
+7
-5
src/Convert/UnpackedArray.hs
+8
-8
test/basic/interface_delay_2.sv
+18
-0
test/basic/interface_delay_2.v
+14
-0
No files found.
src/Convert/Interface.hs
View file @
24a79ffe
...
...
@@ -302,12 +302,12 @@ convertDescription parts (Part attrs extern Module lifetime name ports items) =
collectDecl
_
=
return
()
extractModportInfo
::
Type
->
Maybe
(
Identifier
,
Identifier
)
extractModportInfo
(
InterfaceT
""
""
[]
)
=
Just
(
""
,
""
)
extractModportInfo
(
InterfaceT
interfaceName
modportName
[]
)
=
extractModportInfo
(
InterfaceT
""
""
_
)
=
Just
(
""
,
""
)
extractModportInfo
(
InterfaceT
interfaceName
modportName
_
)
=
if
isInterface
interfaceName
then
Just
(
interfaceName
,
modportName
)
else
Nothing
extractModportInfo
(
Alias
interfaceName
[]
)
=
extractModportInfo
(
Alias
interfaceName
_
)
=
if
isInterface
interfaceName
then
Just
(
interfaceName
,
""
)
else
Nothing
...
...
@@ -496,15 +496,17 @@ inlineInstance global ranges modportBindings items partName
Variable
d
t
x
a
e
else
if
makeBindingBaseExpr
modportE
==
Nothing
then
CommentDecl
$
"removed modport instance "
++
x
else
if
null
a
then
else
if
null
modportDims
then
localparam
(
modportBaseName
x
)
bindingBaseExpr
else
localparam
(
modportBaseName
x
)
$
BinOp
Sub
bindingBaseExpr
(
sliceLo
NonIndexed
$
head
a
)
BinOp
Sub
bindingBaseExpr
(
sliceLo
NonIndexed
modportDim
)
where
maybeModportBinding
=
lookup
x
modportBindings
Just
(
_
,
modportE
)
=
maybeModportBinding
bindingBaseExpr
=
Ident
$
bindingBaseName
++
x
modportDims
=
a
++
snd
(
typeRanges
t
)
[
modportDim
]
=
modportDims
removeModportInstance
other
=
other
...
...
src/Convert/UnpackedArray.hs
View file @
24a79ffe
...
...
@@ -29,25 +29,25 @@ convert :: [AST] -> [AST]
convert
=
map
$
traverseDescriptions
convertDescription
convertDescription
::
Description
->
Description
convertDescription
(
description
@
(
Part
_
_
Module
_
_
_
_
))
=
convertDescription
(
description
@
(
Part
_
_
Module
_
_
ports
_
))
=
evalState
(
operation
description
)
Set
.
empty
where
operation
=
partScoperT
traverseDeclM
traverseModuleItemM
noop
traverseStmtM
>=>
operation
=
partScoperT
(
traverseDeclM
ports
)
traverseModuleItemM
noop
traverseStmtM
>=>
partScoperT
rewriteDeclM
noop
noop
noop
noop
=
return
convertDescription
other
=
other
-- tracks multi-dimensional unpacked array declarations
traverseDeclM
::
Decl
->
ST
Decl
traverseDeclM
(
decl
@
(
Variable
_
_
_
[]
_
))
=
return
decl
traverseDeclM
(
decl
@
(
Variable
dir
_
x
_
e
))
=
do
traverseDeclM
::
[
Identifier
]
->
Decl
->
ST
Decl
traverseDeclM
_
(
decl
@
(
Variable
_
_
_
[]
_
))
=
return
decl
traverseDeclM
ports
(
decl
@
(
Variable
_
_
x
_
e
))
=
do
insertElem
x
decl
if
dir
/=
Local
||
e
/=
Nil
if
elem
x
ports
||
e
/=
Nil
then
flatUsageM
x
else
return
()
return
decl
traverseDeclM
other
=
return
other
traverseDeclM
_
other
=
return
other
-- pack decls marked for packing
rewriteDeclM
::
Decl
->
ST
Decl
...
...
test/basic/interface_delay_2.sv
0 → 100644
View file @
24a79ffe
interface
Interface
;
logic
[
0
:
1
][
0
:
2
]
arr
;
endinterface
module
Module
(
intf
)
;
Interface
intf
[
3
:
3
][
1
:
2
]
;
assign
intf
[
3
][
2
]
.
arr
[
1
]
=
1
;
assign
intf
[
3
][
2
]
.
arr
[
0
][
0
]
=
0
;
initial
$
display
(
"2: %b"
,
intf
[
3
][
2
]
.
arr
)
;
endmodule
module
top
;
Interface
intf
[
1
:
1
][
1
:
2
]
()
;
Module
mod
(
intf
)
;
assign
intf
[
1
][
1
]
.
arr
[
1
]
=
6
;
assign
intf
[
1
][
1
]
.
arr
[
0
][
0
]
=
1
;
initial
$
display
(
"1: %b"
,
intf
[
1
][
1
]
.
arr
)
;
endmodule
test/basic/interface_delay_2.v
0 → 100644
View file @
24a79ffe
module
top
;
if
(
1
)
begin
:
intf1
wire
[
0
:
1
][
0
:
2
]
arr
;
end
if
(
1
)
begin
:
intf2
wire
[
0
:
1
][
0
:
2
]
arr
;
end
assign
intf2
.
arr
[
1
]
=
1
;
assign
intf2
.
arr
[
0
][
0
]
=
0
;
initial
$
display
(
"2: %b"
,
intf2
.
arr
)
;
assign
intf1
.
arr
[
1
]
=
6
;
assign
intf1
.
arr
[
0
][
0
]
=
1
;
initial
$
display
(
"1: %b"
,
intf1
.
arr
)
;
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