Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
N
ngraph
Project
Project
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
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
ngraph
Commits
6291f0aa
Unverified
Commit
6291f0aa
authored
Oct 11, 2019
by
aslepko
Committed by
GitHub
Oct 11, 2019
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #3753 from NervanaSystems/nmostafa/update_mlir
Bump MLIR version
parents
27199cee
166fb921
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
33 additions
and
20 deletions
+33
-20
external_mlir.cmake
cmake/external_mlir.cmake
+2
-2
compiler.cpp
src/contrib/mlir/compiler/compiler.cpp
+28
-9
ngraph_opt.cpp
src/contrib/mlir/tools/ngraph-opt/ngraph_opt.cpp
+2
-8
dot.in.cpp
test/backend/dot.in.cpp
+1
-1
No files found.
cmake/external_mlir.cmake
View file @
6291f0aa
...
@@ -20,8 +20,8 @@ set(MLIR_LLVM_REPO_URL https://github.com/llvm/llvm-project.git)
...
@@ -20,8 +20,8 @@ set(MLIR_LLVM_REPO_URL https://github.com/llvm/llvm-project.git)
set
(
MLIR_REPO_URL https://github.com/tensorflow/mlir.git
)
set
(
MLIR_REPO_URL https://github.com/tensorflow/mlir.git
)
# Change these commit IDs to move to latest stable versions
# Change these commit IDs to move to latest stable versions
set
(
MLIR_LLVM_COMMIT_ID
4fe2732
)
set
(
MLIR_LLVM_COMMIT_ID
0845ac7331e
)
set
(
MLIR_COMMIT_ID
40fe0fe7
)
set
(
MLIR_COMMIT_ID
1f7893e0
)
# MLIR environment variables. Some of them are used by LIT tool.
# MLIR environment variables. Some of them are used by LIT tool.
set
(
MLIR_PROJECT_ROOT
${
CMAKE_CURRENT_BINARY_DIR
}
/mlir_project
)
set
(
MLIR_PROJECT_ROOT
${
CMAKE_CURRENT_BINARY_DIR
}
/mlir_project
)
...
...
src/contrib/mlir/compiler/compiler.cpp
View file @
6291f0aa
...
@@ -58,7 +58,7 @@
...
@@ -58,7 +58,7 @@
#include <llvm/Support/SourceMgr.h>
#include <llvm/Support/SourceMgr.h>
#include <llvm/Support/TargetSelect.h>
#include <llvm/Support/TargetSelect.h>
#include <llvm/Target/TargetMachine.h>
#include <llvm/Target/TargetMachine.h>
#include <mlir/Conversion/
ControlFlowToCFG/ConvertControlFlowToCFG
.h>
#include <mlir/Conversion/
LoopToStandard/ConvertLoopToStandard
.h>
#include <mlir/Conversion/StandardToLLVM/ConvertStandardToLLVM.h>
#include <mlir/Conversion/StandardToLLVM/ConvertStandardToLLVM.h>
#include <mlir/Conversion/StandardToLLVM/ConvertStandardToLLVMPass.h>
#include <mlir/Conversion/StandardToLLVM/ConvertStandardToLLVMPass.h>
#include <mlir/Dialect/LLVMIR/LLVMDialect.h>
#include <mlir/Dialect/LLVMIR/LLVMDialect.h>
...
@@ -360,7 +360,10 @@ void MLIRCompiler::lowerNgDialect()
...
@@ -360,7 +360,10 @@ void MLIRCompiler::lowerNgDialect()
// Apply any generic pass manager command line options.
// Apply any generic pass manager command line options.
mlir
::
applyPassManagerCLOptions
(
pm
);
mlir
::
applyPassManagerCLOptions
(
pm
);
pm
.
run
(
m_module
.
get
());
if
(
failed
(
pm
.
run
(
m_module
.
get
())))
{
NGRAPH_CHECK
(
false
,
"MLIR pass manager failed"
);
}
if
(
failed
(
m_module
->
verify
()))
if
(
failed
(
m_module
->
verify
()))
{
{
...
@@ -709,7 +712,11 @@ void MLIRCompiler::optimizeNgDialect()
...
@@ -709,7 +712,11 @@ void MLIRCompiler::optimizeNgDialect()
{
{
pm
.
addPass
(
mlir
::
createMemoryOptimizationPass
());
pm
.
addPass
(
mlir
::
createMemoryOptimizationPass
());
}
}
pm
.
run
(
m_module
.
get
());
if
(
failed
(
pm
.
run
(
m_module
.
get
())))
{
NGRAPH_CHECK
(
false
,
"MLIR pass manager failed"
);
}
}
}
// Binds MLIR function arguments to the proper values. This includes externally allocated tensors
// Binds MLIR function arguments to the proper values. This includes externally allocated tensors
...
@@ -729,11 +736,10 @@ void MLIRCompiler::bindArguments(std::vector<void*>& externalTensors)
...
@@ -729,11 +736,10 @@ void MLIRCompiler::bindArguments(std::vector<void*>& externalTensors)
m_externalTensors
=
&
externalTensors
;
m_externalTensors
=
&
externalTensors
;
// Create list with a type-erased double pointer for each invocation arguments.
// Create list with a type-erased double pointer for each invocation arguments.
// We currently use 'allocateMemrefArgs', which creates
a
// We currently use 'allocateMemrefArgs', which creates
the arguments list per call ABI (see
//
SmallVector<StaticFloatMemref*>. StaticFloatMemref is just a struct with the
//
comment below).
// actual pointer to the data.
//
StaticFloatMemref is just a struct with the
actual pointer to the data.
// create MemRef args
auto
expectedArguments
=
allocateMemrefArgs
();
auto
expectedArguments
=
allocateMemrefArgs
();
NGRAPH_CHECK
(
expectedArguments
.
size
(),
"Arguments can't be created"
);
NGRAPH_CHECK
(
expectedArguments
.
size
(),
"Arguments can't be created"
);
m_invokeArgs
=
std
::
move
(
expectedArguments
);
m_invokeArgs
=
std
::
move
(
expectedArguments
);
...
@@ -744,7 +750,8 @@ void MLIRCompiler::bindArguments(std::vector<void*>& externalTensors)
...
@@ -744,7 +750,8 @@ void MLIRCompiler::bindArguments(std::vector<void*>& externalTensors)
// Assign external tensor pointers to invocation arguments.
// Assign external tensor pointers to invocation arguments.
for
(
size_t
i
=
0
,
numArgs
=
m_invokeArgs
.
size
();
i
<
numArgs
;
++
i
)
for
(
size_t
i
=
0
,
numArgs
=
m_invokeArgs
.
size
();
i
<
numArgs
;
++
i
)
{
{
((
mlir
::
StaticFloatMemRef
*
)
m_invokeArgs
[
i
])
->
data
=
(
float
*
)(
*
m_externalTensors
)[
i
];
auto
*
memRefArg
=
*
(
reinterpret_cast
<
mlir
::
StaticFloatMemRef
**>
(
m_invokeArgs
[
i
]));
memRefArg
->
data
=
reinterpret_cast
<
float
*>
((
*
m_externalTensors
)[
i
]);
}
}
}
}
...
@@ -770,6 +777,8 @@ void MLIRCompiler::cleanup()
...
@@ -770,6 +777,8 @@ void MLIRCompiler::cleanup()
// Free void double pointer arguments without freeing external tensor data.
// Free void double pointer arguments without freeing external tensor data.
for
(
auto
*
arg
:
m_invokeArgs
)
for
(
auto
*
arg
:
m_invokeArgs
)
{
{
auto
*
memRefArg
=
*
(
reinterpret_cast
<
mlir
::
StaticFloatMemRef
**>
(
arg
));
free
(
memRefArg
);
free
(
arg
);
free
(
arg
);
}
}
...
@@ -780,13 +789,23 @@ void MLIRCompiler::cleanup()
...
@@ -780,13 +789,23 @@ void MLIRCompiler::cleanup()
}
}
}
}
// The current call ABI takes a single arg pointer (argPtr) pointing to a list of args.
// Each arg is a pointer to a StaticFloatMemRef which contains a data pointer
//
// The args are laid out as follows
// argPtr-> arg[0]-> StaticFloatMemRef -> <data>
// arg[1]-> StaticFloatMemRef -> <data>
// ...
SmallVector
<
void
*
,
8
>
MLIRCompiler
::
allocateMemrefArgs
()
SmallVector
<
void
*
,
8
>
MLIRCompiler
::
allocateMemrefArgs
()
{
{
SmallVector
<
void
*
,
8
>
args
;
SmallVector
<
void
*
,
8
>
args
;
for
(
auto
i
=
0
;
i
<
m_externalTensors
->
size
();
i
++
)
for
(
auto
i
=
0
;
i
<
m_externalTensors
->
size
();
i
++
)
{
{
auto
descriptor
=
allocateMemrefDescriptor
();
auto
descriptor
=
allocateMemrefDescriptor
();
args
.
push_back
(
descriptor
);
mlir
::
StaticFloatMemRef
**
arg
=
reinterpret_cast
<
mlir
::
StaticFloatMemRef
**>
(
malloc
(
sizeof
(
mlir
::
StaticFloatMemRef
*
)));
*
arg
=
descriptor
;
args
.
push_back
(
arg
);
}
}
return
args
;
return
args
;
}
}
...
...
src/contrib/mlir/tools/ngraph-opt/ngraph_opt.cpp
View file @
6291f0aa
...
@@ -61,8 +61,6 @@ static llvm::cl::opt<bool>
...
@@ -61,8 +61,6 @@ static llvm::cl::opt<bool>
llvm
::
cl
::
desc
(
"Run the verifier after each transformation pass"
),
llvm
::
cl
::
desc
(
"Run the verifier after each transformation pass"
),
llvm
::
cl
::
init
(
true
));
llvm
::
cl
::
init
(
true
));
static
std
::
vector
<
const
mlir
::
PassRegistryEntry
*>*
pass_list
;
int
main
(
int
argc
,
char
**
argv
)
int
main
(
int
argc
,
char
**
argv
)
{
{
llvm
::
InitLLVM
y
(
argc
,
argv
);
llvm
::
InitLLVM
y
(
argc
,
argv
);
...
@@ -70,11 +68,7 @@ int main(int argc, char** argv)
...
@@ -70,11 +68,7 @@ int main(int argc, char** argv)
// Register any pass manager command line options.
// Register any pass manager command line options.
mlir
::
registerPassManagerCLOptions
();
mlir
::
registerPassManagerCLOptions
();
mlir
::
PassPipelineCLParser
passPipeline
(
""
,
"Compiler passes to run"
);
// Parse pass names in main to ensure static initialization completed.
llvm
::
cl
::
list
<
const
mlir
::
PassRegistryEntry
*
,
bool
,
mlir
::
PassNameParser
>
pass_list
(
""
,
llvm
::
cl
::
desc
(
"Compiler passes to run"
));
::
pass_list
=
&
pass_list
;
llvm
::
cl
::
ParseCommandLineOptions
(
argc
,
argv
,
"nGraph MLIR modular optimizer driver
\n
"
);
llvm
::
cl
::
ParseCommandLineOptions
(
argc
,
argv
,
"nGraph MLIR modular optimizer driver
\n
"
);
// Set up the input file.
// Set up the input file.
...
@@ -87,7 +81,7 @@ int main(int argc, char** argv)
...
@@ -87,7 +81,7 @@ int main(int argc, char** argv)
return
failed
(
mlir
::
MlirOptMain
(
output
->
os
(),
return
failed
(
mlir
::
MlirOptMain
(
output
->
os
(),
std
::
move
(
file
),
std
::
move
(
file
),
pass
_list
,
pass
Pipeline
,
split_input_file
,
split_input_file
,
verify_diagnostics
,
verify_diagnostics
,
verify_passes
));
verify_passes
));
...
...
test/backend/dot.in.cpp
View file @
6291f0aa
...
@@ -254,7 +254,7 @@ NGRAPH_TEST(${BACKEND_NAME}, dot_0_0)
...
@@ -254,7 +254,7 @@ NGRAPH_TEST(${BACKEND_NAME}, dot_0_0)
EXPECT_TRUE
(
test
::
all_close_f
((
vector
<
float
>
{
0
}),
read_vector
<
float
>
(
result
)));
EXPECT_TRUE
(
test
::
all_close_f
((
vector
<
float
>
{
0
}),
read_vector
<
float
>
(
result
)));
}
}
NGRAPH_TEST
(
$
{
BACKEND_NAME
},
dot_matrix_2x0_0x2
)
NGRAPH_TEST
(
$
{
BACKEND_NAME
},
MLIR_DISABLE_TEST
(
dot_matrix_2x0_0x2
)
)
{
{
Shape
shape_a
{
2
,
0
};
Shape
shape_a
{
2
,
0
};
Shape
shape_b
{
0
,
2
};
Shape
shape_b
{
0
,
2
};
...
...
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