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
10b30d7d
Commit
10b30d7d
authored
May 01, 2021
by
Zachary Snow
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
detect infinite include loops
parent
5cc4dce0
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
60 additions
and
2 deletions
+60
-2
src/Language/SystemVerilog/Parser/Preprocess.hs
+26
-2
test/error/include_loop_1.sv
+2
-0
test/error/include_loop_2.sv
+2
-0
test/lex/include_self.sv
+30
-0
No files found.
src/Language/SystemVerilog/Parser/Preprocess.hs
View file @
10b30d7d
...
...
@@ -16,7 +16,7 @@ module Language.SystemVerilog.Parser.Preprocess
import
Control.Monad.Except
import
Control.Monad.State.Strict
import
Data.Char
(
ord
)
import
Data.List
(
dropWhileEnd
,
tails
,
isPrefixOf
,
findIndex
)
import
Data.List
(
dropWhileEnd
,
tails
,
isPrefixOf
,
findIndex
,
intercalate
)
import
Data.Maybe
(
isJust
,
fromJust
)
import
System.Directory
(
findFile
)
import
System.FilePath
(
dropFileName
)
...
...
@@ -37,6 +37,7 @@ data PP = PP
,
ppCondStack
::
[
Cond
]
-- if-else cascade state
,
ppIncludePaths
::
[
FilePath
]
-- folders to search for includes
,
ppMacroStack
::
[[(
String
,
String
)]]
-- arguments for in-progress macro expansions
,
ppIncludeStack
::
[(
FilePath
,
Env
)]
-- in-progress includes for loop detection
}
deriving
(
Eq
,
Show
)
-- keeps track of the state of an if-else cascade level
...
...
@@ -72,7 +73,7 @@ preprocess includePaths env path = do
if
path
==
"-"
then
getContents
else
loadFile
path
let
initialState
=
PP
contents
[]
(
Position
path
1
1
)
path
env
[]
includePaths
[]
let
initialState
=
PP
contents
[]
(
Position
path
1
1
)
path
env
[]
includePaths
[]
[(
path
,
env
)]
result
<-
runExceptT
$
execStateT
preprocessInput
initialState
return
$
case
result
of
Left
msg
->
Left
msg
...
...
@@ -172,6 +173,27 @@ getBuffer = do
p
<-
getPosition
return
(
x
,
p
)
-- mark the start of an include for include loop detection
pushIncludeStack
::
FilePath
->
PPS
()
pushIncludeStack
path
=
do
stack
<-
gets
ppIncludeStack
env
<-
gets
ppEnv
let
entry
=
(
path
,
env
)
let
stack'
=
entry
:
stack
if
elem
entry
stack
then
do
let
first
:
rest
=
reverse
$
map
fst
stack'
lexicalError
$
"include loop: "
++
show
first
++
" includes "
++
intercalate
", which includes "
(
map
show
rest
)
else
modify
$
\
s
->
s
{
ppIncludeStack
=
stack'
}
-- mark the end of an include for include loop detection
popIncludeStack
::
PPS
()
popIncludeStack
=
do
stack
<-
gets
ppIncludeStack
let
stack'
=
tail
stack
modify
$
\
s
->
s
{
ppIncludeStack
=
stack'
}
-- Push a condition onto the top of the preprocessor condition stack
pushCondStack
::
Cond
->
PPS
()
pushCondStack
c
=
getCondStack
>>=
setCondStack
.
(
c
:
)
...
...
@@ -713,12 +735,14 @@ handleDirective macrosOnly = do
-- find and load the included file
let
filename
=
init
$
tail
quotedFilename
includePath
<-
includeSearch
filename
pushIncludeStack
includePath
includeContent
<-
liftIO
$
loadFile
includePath
-- pre-process the included file
setFilePath
includePath
setBuffer
(
includeContent
,
Position
includePath
1
1
)
preprocessInput
-- resume processing the original file
popIncludeStack
setFilePath
fileFollow
setBuffer
bufFollow
...
...
test/error/include_loop_1.sv
0 → 100644
View file @
10b30d7d
// pattern: include loop: "include_loop_1\.sv" includes "\./include_loop_1\.sv", which includes "\./include_loop_1\.sv"
`include
"include_loop_1.sv"
test/error/include_loop_2.sv
0 → 100644
View file @
10b30d7d
// pattern: include loop: "include_loop_2\.sv" includes "\./include_loop_1\.sv", which includes "\./include_loop_1\.sv"
`include
"include_loop_1.sv"
// other file
test/lex/include_self.sv
0 → 100644
View file @
10b30d7d
`ifdef
GUARD_5
module
top
;
wire
x
;
endmodule
`elsif
GUARD_4
`define
GUARD_5
`include
"include_self.sv"
`elsif
GUARD_3
`define
GUARD_4
`include
"include_self.sv"
`elsif
GUARD_2
`define
GUARD_3
`include
"include_self.sv"
`elsif
GUARD_1
`define
GUARD_2
`include
"include_self.sv"
`elsif
GUARD_0
`define
GUARD_1
`include
"include_self.sv"
`else
`define
GUARD_0
`include
"include_self.sv"
`endif
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