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
66989b04
Commit
66989b04
authored
Sep 09, 2019
by
Zachary Snow
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
language support for parameter type bindings
parent
d11e898e
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
60 additions
and
17 deletions
+60
-17
src/Convert/Struct.hs
+1
-0
src/Convert/Traverse.hs
+7
-1
src/Language/SystemVerilog/AST/Expr.hs
+7
-2
src/Language/SystemVerilog/AST/ModuleItem.hs
+16
-3
src/Language/SystemVerilog/AST/Type.hs
+2
-1
src/Language/SystemVerilog/Parser/Parse.y
+26
-9
src/Language/SystemVerilog/Parser/ParseDecl.hs
+1
-1
No files found.
src/Convert/Struct.hs
View file @
66989b04
...
@@ -445,6 +445,7 @@ convertAsgn structs types (lhs, expr) =
...
@@ -445,6 +445,7 @@ convertAsgn structs types (lhs, expr) =
where
where
items'
=
map
mapItem
items
items'
=
map
mapItem
items
mapItem
(
mx
,
e
)
=
(
mx
,
snd
$
convertSubExpr
e
)
mapItem
(
mx
,
e
)
=
(
mx
,
snd
$
convertSubExpr
e
)
convertSubExpr
Nil
=
(
Implicit
Unspecified
[]
,
Nil
)
-- lookup the range of a field in its unstructured type
-- lookup the range of a field in its unstructured type
lookupUnstructRange
::
TypeFunc
->
Identifier
->
Range
lookupUnstructRange
::
TypeFunc
->
Identifier
->
Range
...
...
src/Convert/Traverse.hs
View file @
66989b04
...
@@ -464,6 +464,7 @@ traverseNestedExprsM mapper = exprMapper
...
@@ -464,6 +464,7 @@ traverseNestedExprsM mapper = exprMapper
let
names
=
map
fst
l
let
names
=
map
fst
l
exprs
<-
mapM
exprMapper
$
map
snd
l
exprs
<-
mapM
exprMapper
$
map
snd
l
return
$
Pattern
$
zip
names
exprs
return
$
Pattern
$
zip
names
exprs
em
(
Nil
)
=
return
Nil
exprMapperHelpers
::
Monad
m
=>
MapperM
m
Expr
->
exprMapperHelpers
::
Monad
m
=>
MapperM
m
Expr
->
(
MapperM
m
Range
,
MapperM
m
(
Maybe
Expr
),
MapperM
m
Decl
,
MapperM
m
LHS
,
MapperM
m
Type
)
(
MapperM
m
Range
,
MapperM
m
(
Maybe
Expr
),
MapperM
m
Decl
,
MapperM
m
LHS
,
MapperM
m
Type
)
...
@@ -524,6 +525,11 @@ traverseExprsM' strat exprMapper = moduleItemMapper
...
@@ -524,6 +525,11 @@ traverseExprsM' strat exprMapper = moduleItemMapper
portBindingMapper
(
p
,
me
)
=
portBindingMapper
(
p
,
me
)
=
maybeExprMapper
me
>>=
\
me'
->
return
(
p
,
me'
)
maybeExprMapper
me
>>=
\
me'
->
return
(
p
,
me'
)
paramBindingMapper
(
p
,
Left
t
)
=
typeMapper
t
>>=
\
t'
->
return
(
p
,
Left
t'
)
paramBindingMapper
(
p
,
Right
e
)
=
exprMapper
e
>>=
\
e'
->
return
(
p
,
Right
e'
)
moduleItemMapper
(
MIAttr
attr
mi
)
=
moduleItemMapper
(
MIAttr
attr
mi
)
=
-- note: we exclude expressions in attributes from conversion
-- note: we exclude expressions in attributes from conversion
return
$
MIAttr
attr
mi
return
$
MIAttr
attr
mi
...
@@ -567,7 +573,7 @@ traverseExprsM' strat exprMapper = moduleItemMapper
...
@@ -567,7 +573,7 @@ traverseExprsM' strat exprMapper = moduleItemMapper
else
return
stmts
else
return
stmts
return
$
MIPackageItem
$
Task
lifetime
f
decls'
stmts'
return
$
MIPackageItem
$
Task
lifetime
f
decls'
stmts'
moduleItemMapper
(
Instance
m
p
x
r
l
)
=
do
moduleItemMapper
(
Instance
m
p
x
r
l
)
=
do
p'
<-
mapM
p
ort
BindingMapper
p
p'
<-
mapM
p
aram
BindingMapper
p
l'
<-
mapM
portBindingMapper
l
l'
<-
mapM
portBindingMapper
l
r'
<-
mapM
rangeMapper
r
r'
<-
mapM
rangeMapper
r
return
$
Instance
m
p'
x
r'
l'
return
$
Instance
m
p'
x
r'
l'
...
...
src/Language/SystemVerilog/AST/Expr.hs
View file @
66989b04
...
@@ -8,6 +8,7 @@
...
@@ -8,6 +8,7 @@
module
Language.SystemVerilog.AST.Expr
module
Language.SystemVerilog.AST.Expr
(
Expr
(
..
)
(
Expr
(
..
)
,
Range
,
Range
,
TypeOrExpr
,
Args
(
..
)
,
Args
(
..
)
,
PartSelectMode
(
..
)
,
PartSelectMode
(
..
)
,
showAssignment
,
showAssignment
...
@@ -30,6 +31,8 @@ import {-# SOURCE #-} Language.SystemVerilog.AST.Type
...
@@ -30,6 +31,8 @@ import {-# SOURCE #-} Language.SystemVerilog.AST.Type
type
Range
=
(
Expr
,
Expr
)
type
Range
=
(
Expr
,
Expr
)
type
TypeOrExpr
=
Either
Type
Expr
data
Expr
data
Expr
=
String
String
=
String
String
|
Number
String
|
Number
String
...
@@ -44,13 +47,15 @@ data Expr
...
@@ -44,13 +47,15 @@ data Expr
|
UniOp
UniOp
Expr
|
UniOp
UniOp
Expr
|
BinOp
BinOp
Expr
Expr
|
BinOp
BinOp
Expr
Expr
|
Mux
Expr
Expr
Expr
|
Mux
Expr
Expr
Expr
|
Cast
(
Either
Type
Expr
)
Expr
|
Cast
TypeOrExpr
Expr
|
Bits
(
Either
Type
Expr
)
|
Bits
TypeOrExpr
|
Dot
Expr
Identifier
|
Dot
Expr
Identifier
|
Pattern
[(
Maybe
Identifier
,
Expr
)]
|
Pattern
[(
Maybe
Identifier
,
Expr
)]
|
Nil
deriving
(
Eq
,
Ord
)
deriving
(
Eq
,
Ord
)
instance
Show
Expr
where
instance
Show
Expr
where
show
(
Nil
)
=
""
show
(
Number
str
)
=
str
show
(
Number
str
)
=
str
show
(
Ident
str
)
=
str
show
(
Ident
str
)
=
str
show
(
PSIdent
x
y
)
=
printf
"%s::%s"
x
y
show
(
PSIdent
x
y
)
=
printf
"%s::%s"
x
y
...
...
src/Language/SystemVerilog/AST/ModuleItem.hs
View file @
66989b04
...
@@ -8,6 +8,7 @@
...
@@ -8,6 +8,7 @@
module
Language.SystemVerilog.AST.ModuleItem
module
Language.SystemVerilog.AST.ModuleItem
(
ModuleItem
(
..
)
(
ModuleItem
(
..
)
,
PortBinding
,
PortBinding
,
ParamBinding
,
ModportDecl
,
ModportDecl
,
AlwaysKW
(
..
)
,
AlwaysKW
(
..
)
,
NInputGateKW
(
..
)
,
NInputGateKW
(
..
)
...
@@ -16,6 +17,7 @@ module Language.SystemVerilog.AST.ModuleItem
...
@@ -16,6 +17,7 @@ module Language.SystemVerilog.AST.ModuleItem
import
Data.List
(
intercalate
)
import
Data.List
(
intercalate
)
import
Data.Maybe
(
maybe
,
fromJust
,
isJust
)
import
Data.Maybe
(
maybe
,
fromJust
,
isJust
)
import
Data.Either
(
either
)
import
Text.Printf
(
printf
)
import
Text.Printf
(
printf
)
import
Language.SystemVerilog.AST.ShowHelp
import
Language.SystemVerilog.AST.ShowHelp
...
@@ -23,7 +25,7 @@ import Language.SystemVerilog.AST.ShowHelp
...
@@ -23,7 +25,7 @@ import Language.SystemVerilog.AST.ShowHelp
import
Language.SystemVerilog.AST.Attr
(
Attr
)
import
Language.SystemVerilog.AST.Attr
(
Attr
)
import
Language.SystemVerilog.AST.Decl
(
Direction
)
import
Language.SystemVerilog.AST.Decl
(
Direction
)
import
Language.SystemVerilog.AST.Description
(
PackageItem
)
import
Language.SystemVerilog.AST.Description
(
PackageItem
)
import
Language.SystemVerilog.AST.Expr
(
Expr
(
Ident
),
Range
,
showRanges
)
import
Language.SystemVerilog.AST.Expr
(
Expr
(
Ident
,
Nil
),
Range
,
TypeOrExpr
,
showRanges
)
import
Language.SystemVerilog.AST.GenItem
(
GenItem
)
import
Language.SystemVerilog.AST.GenItem
(
GenItem
)
import
Language.SystemVerilog.AST.LHS
(
LHS
)
import
Language.SystemVerilog.AST.LHS
(
LHS
)
import
Language.SystemVerilog.AST.Stmt
(
Stmt
,
AssertionItem
)
import
Language.SystemVerilog.AST.Stmt
(
Stmt
,
AssertionItem
)
...
@@ -34,7 +36,7 @@ data ModuleItem
...
@@ -34,7 +36,7 @@ data ModuleItem
|
AlwaysC
AlwaysKW
Stmt
|
AlwaysC
AlwaysKW
Stmt
|
Assign
(
Maybe
Expr
)
LHS
Expr
|
Assign
(
Maybe
Expr
)
LHS
Expr
|
Defparam
LHS
Expr
|
Defparam
LHS
Expr
|
Instance
Identifier
[
P
ort
Binding
]
Identifier
(
Maybe
Range
)
[
PortBinding
]
|
Instance
Identifier
[
P
aram
Binding
]
Identifier
(
Maybe
Range
)
[
PortBinding
]
|
Genvar
Identifier
|
Genvar
Identifier
|
Generate
[
GenItem
]
|
Generate
[
GenItem
]
|
Modport
Identifier
[
ModportDecl
]
|
Modport
Identifier
[
ModportDecl
]
...
@@ -66,7 +68,7 @@ instance Show ModuleItem where
...
@@ -66,7 +68,7 @@ instance Show ModuleItem where
show
(
Instance
m
params
i
r
ports
)
=
show
(
Instance
m
params
i
r
ports
)
=
if
null
params
if
null
params
then
printf
"%s %s%s%s;"
m
i
rStr
(
showPorts
ports
)
then
printf
"%s %s%s%s;"
m
i
rStr
(
showPorts
ports
)
else
printf
"%s #%s %s%s%s;"
m
(
showP
ort
s
params
)
i
rStr
(
showPorts
ports
)
else
printf
"%s #%s %s%s%s;"
m
(
showP
aram
s
params
)
i
rStr
(
showPorts
ports
)
where
rStr
=
maybe
""
(
\
a
->
showRanges
[
a
]
++
" "
)
r
where
rStr
=
maybe
""
(
\
a
->
showRanges
[
a
]
++
" "
)
r
showPorts
::
[
PortBinding
]
->
String
showPorts
::
[
PortBinding
]
->
String
...
@@ -79,6 +81,15 @@ showPort (i, arg) =
...
@@ -79,6 +81,15 @@ showPort (i, arg) =
then
show
(
fromJust
arg
)
then
show
(
fromJust
arg
)
else
printf
".%s(%s)"
i
(
if
isJust
arg
then
show
$
fromJust
arg
else
""
)
else
printf
".%s(%s)"
i
(
if
isJust
arg
then
show
$
fromJust
arg
else
""
)
showParams
::
[
ParamBinding
]
->
String
showParams
params
=
indentedParenList
$
map
showParam
params
showParam
::
ParamBinding
->
String
showParam
(
"*"
,
Right
Nil
)
=
".*"
showParam
(
i
,
arg
)
=
printf
fmt
i
(
either
show
show
arg
)
where
fmt
=
if
i
==
""
then
"%s%s"
else
".%s(%s)"
showModportDecl
::
ModportDecl
->
String
showModportDecl
::
ModportDecl
->
String
showModportDecl
(
dir
,
ident
,
me
)
=
showModportDecl
(
dir
,
ident
,
me
)
=
if
me
==
Just
(
Ident
ident
)
if
me
==
Just
(
Ident
ident
)
...
@@ -87,6 +98,8 @@ showModportDecl (dir, ident, me) =
...
@@ -87,6 +98,8 @@ showModportDecl (dir, ident, me) =
type
PortBinding
=
(
Identifier
,
Maybe
Expr
)
type
PortBinding
=
(
Identifier
,
Maybe
Expr
)
type
ParamBinding
=
(
Identifier
,
TypeOrExpr
)
type
ModportDecl
=
(
Direction
,
Identifier
,
Maybe
Expr
)
type
ModportDecl
=
(
Direction
,
Identifier
,
Maybe
Expr
)
data
AlwaysKW
data
AlwaysKW
...
...
src/Language/SystemVerilog/AST/Type.hs
View file @
66989b04
...
@@ -95,7 +95,8 @@ nullRange :: Type -> ([Range] -> Type)
...
@@ -95,7 +95,8 @@ nullRange :: Type -> ([Range] -> Type)
nullRange
t
[]
=
t
nullRange
t
[]
=
t
nullRange
t
[(
Number
"0"
,
Number
"0"
)]
=
t
nullRange
t
[(
Number
"0"
,
Number
"0"
)]
=
t
nullRange
t
other
=
nullRange
t
other
=
error
$
"non vector type "
++
show
t
++
" cannot have a range"
error
$
"non vector type "
++
show
t
++
" cannot have a range: "
++
show
other
data
Signing
data
Signing
=
Unspecified
=
Unspecified
...
...
src/Language/SystemVerilog/Parser/Parse.y
View file @
66989b04
...
@@ -556,7 +556,7 @@ DeclTokens(delim) :: { [DeclToken] }
...
@@ -556,7 +556,7 @@ DeclTokens(delim) :: { [DeclToken] }
DeclToken :: { DeclToken }
DeclToken :: { DeclToken }
: DeclOrStmtToken { $1 }
: DeclOrStmtToken { $1 }
| ParameterBindings { DTParams $1 }
| ParameterBindings { DTParams $1 }
|
ModuleInstantiation
{ DTInstance $1 }
|
PortBindings
{ DTInstance $1 }
DeclOrStmtTokens(delim) :: { [DeclToken] }
DeclOrStmtTokens(delim) :: { [DeclToken] }
: DeclOrStmtToken delim { [$1] }
: DeclOrStmtToken delim { [$1] }
...
@@ -766,9 +766,6 @@ Lifetime :: { Lifetime }
...
@@ -766,9 +766,6 @@ Lifetime :: { Lifetime }
: "static" { Static }
: "static" { Static }
| "automatic" { Automatic }
| "automatic" { Automatic }
ModuleInstantiation :: { [PortBinding] }
: "(" Bindings ")" { $2 }
TFItems :: { [Decl] }
TFItems :: { [Decl] }
: "(" DeclTokens(")") ";" { parseDTsAsDecls $2 }
: "(" DeclTokens(")") ";" { parseDTsAsDecls $2 }
| "(" ")" ";" { [] }
| "(" ")" ";" { [] }
...
@@ -819,6 +816,28 @@ LHSs :: { [LHS] }
...
@@ -819,6 +816,28 @@ LHSs :: { [LHS] }
: LHS { [$1] }
: LHS { [$1] }
| LHSs "," LHS { $1 ++ [$3] }
| LHSs "," LHS { $1 ++ [$3] }
PortBindings :: { [PortBinding] }
: "(" ")" { [] }
| "(" PortBindingsInside ")" { $2 }
PortBindingsInside :: { [PortBinding] }
: PortBinding { [$1] }
| PortBinding "," PortBindingsInside { $1 : $3}
PortBinding :: { PortBinding }
: "." Identifier "(" opt(Expr) ")" { ($2, $4) }
| "." Identifier { ($2, Just $ Ident $2) }
| Expr { ("", Just $1) }
| ".*" { ("*", Nothing) }
ParameterBindings :: { [ParamBinding] }
: "#" "(" ParamBindingsInside ")" { $3 }
ParamBindingsInside :: { [ParamBinding] }
: ParamBinding { [$1] }
| ParamBinding "," ParamBindingsInside { $1 : $3}
ParamBinding :: { ParamBinding }
: "." Identifier "(" TypeOrExpr ")" { ($2, $4) }
| "." Identifier "(" ")" { ($2, Right Nil) }
| TypeOrExpr { ("", $1) }
Bindings :: { [(Identifier, Maybe Expr)] }
Bindings :: { [(Identifier, Maybe Expr)] }
: {- empty -} { [] }
: {- empty -} { [] }
| BindingsNonEmpty { $1 }
| BindingsNonEmpty { $1 }
...
@@ -831,9 +850,6 @@ Binding :: { (Identifier, Maybe Expr) }
...
@@ -831,9 +850,6 @@ Binding :: { (Identifier, Maybe Expr) }
| Expr { ("", Just $1) }
| Expr { ("", Just $1) }
| ".*" { ("*", Nothing) }
| ".*" { ("*", Nothing) }
ParameterBindings :: { [(Identifier, Maybe Expr)] }
: "#" "(" BindingsNonEmpty ")" { $3 }
Stmts :: { [Stmt] }
Stmts :: { [Stmt] }
: {- empty -} { [] }
: {- empty -} { [] }
| Stmts Stmt { $1 ++ [$2] }
| Stmts Stmt { $1 ++ [$2] }
...
@@ -987,16 +1003,17 @@ Exprs :: { [Expr] }
...
@@ -987,16 +1003,17 @@ Exprs :: { [Expr] }
: Expr { [$1] }
: Expr { [$1] }
| Exprs "," Expr { $1 ++ [$3] }
| Exprs "," Expr { $1 ++ [$3] }
BitsArg :: { Either Type
Expr }
TypeOrExpr :: { TypeOr
Expr }
: TypeNonIdent { Left $1 }
: TypeNonIdent { Left $1 }
| Expr { Right $1 }
| Expr { Right $1 }
Expr :: { Expr }
Expr :: { Expr }
: "(" Expr ")" { $2 }
: "(" Expr ")" { $2 }
| String { String $1 }
| String { String $1 }
| Number { Number $1 }
| Number { Number $1 }
| Identifier "(" CallArgs ")" { Call (Nothing) $1 $3 }
| Identifier "(" CallArgs ")" { Call (Nothing) $1 $3 }
| Identifier "::" Identifier "(" CallArgs ")" { Call (Just $1) $3 $5 }
| Identifier "::" Identifier "(" CallArgs ")" { Call (Just $1) $3 $5 }
| "$bits"
"(" BitsArg
")" { Bits $3 }
| "$bits"
"(" TypeOrExpr
")" { Bits $3 }
| Identifier { Ident $1 }
| Identifier { Ident $1 }
| Identifier "::" Identifier { PSIdent $1 $3 }
| Identifier "::" Identifier { PSIdent $1 $3 }
| Expr PartSelect { Range $1 (fst $2) (snd $2) }
| Expr PartSelect { Range $1 (fst $2) (snd $2) }
...
...
src/Language/SystemVerilog/Parser/ParseDecl.hs
View file @
66989b04
...
@@ -53,7 +53,7 @@ data DeclToken
...
@@ -53,7 +53,7 @@ data DeclToken
|
DTPSIdent
Identifier
Identifier
|
DTPSIdent
Identifier
Identifier
|
DTDir
Direction
|
DTDir
Direction
|
DTType
(
Signing
->
[
Range
]
->
Type
)
|
DTType
(
Signing
->
[
Range
]
->
Type
)
|
DTParams
[
P
ort
Binding
]
|
DTParams
[
P
aram
Binding
]
|
DTInstance
[
PortBinding
]
|
DTInstance
[
PortBinding
]
|
DTBit
Expr
|
DTBit
Expr
|
DTConcat
[
LHS
]
|
DTConcat
[
LHS
]
...
...
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