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
3fa332b6
Commit
3fa332b6
authored
Nov 22, 2017
by
Jaikrishnan Menon
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' into mem_leaks
parents
225b12bb
ffe657df
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
18 changed files
with
122 additions
and
76 deletions
+122
-76
CMakeLists.txt
CMakeLists.txt
+8
-0
compiler.cpp
src/ngraph/codegen/compiler.cpp
+36
-30
compiler.hpp
src/ngraph/codegen/compiler.hpp
+10
-3
function.cpp
src/ngraph/function.cpp
+11
-0
function.hpp
src/ngraph/function.hpp
+4
-0
manager_state.cpp
src/ngraph/pass/manager_state.cpp
+0
-10
manager_state.hpp
src/ngraph/pass/manager_state.hpp
+0
-4
memory_layout.cpp
src/ngraph/pass/memory_layout.cpp
+3
-3
memory_layout.hpp
src/ngraph/pass/memory_layout.hpp
+2
-2
call_frame.cpp
src/ngraph/runtime/cpu/call_frame.cpp
+1
-1
call_frame.hpp
src/ngraph/runtime/cpu/call_frame.hpp
+1
-2
emitter.cpp
src/ngraph/runtime/cpu/emitter.cpp
+0
-0
emitter.hpp
src/ngraph/runtime/cpu/emitter.hpp
+0
-1
external_function.cpp
src/ngraph/runtime/cpu/external_function.cpp
+16
-16
external_function.hpp
src/ngraph/runtime/cpu/external_function.hpp
+0
-1
CMakeLists.txt
test/CMakeLists.txt
+1
-1
backend_test.in.cpp
test/backend_test.in.cpp
+27
-0
pass_memory_layout.cpp
test/pass_memory_layout.cpp
+2
-2
No files found.
CMakeLists.txt
View file @
3fa332b6
...
@@ -43,6 +43,9 @@ endif()
...
@@ -43,6 +43,9 @@ endif()
set
(
CMAKE_DISABLE_SOURCE_CHANGES ON
)
set
(
CMAKE_DISABLE_SOURCE_CHANGES ON
)
set
(
CMAKE_DISABLE_IN_SOURCE_BUILD ON
)
set
(
CMAKE_DISABLE_IN_SOURCE_BUILD ON
)
# Create compilation database compile_commands.json
set
(
CMAKE_EXPORT_COMPILE_COMMANDS ON
)
# set directory where the custom finders live
# set directory where the custom finders live
set
(
CMAKE_MODULE_PATH
${
CMAKE_MODULE_PATH
}
"
${
CMAKE_SOURCE_DIR
}
/cmake/Modules/"
)
set
(
CMAKE_MODULE_PATH
${
CMAKE_MODULE_PATH
}
"
${
CMAKE_SOURCE_DIR
}
/cmake/Modules/"
)
...
@@ -87,6 +90,11 @@ endif()
...
@@ -87,6 +90,11 @@ endif()
set
(
CMAKE_CXX_FLAGS
"
${
CMAKE_CXX_FLAGS
}
-std=c++11"
)
set
(
CMAKE_CXX_FLAGS
"
${
CMAKE_CXX_FLAGS
}
-std=c++11"
)
# set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -stdlib=libc++")
# set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -stdlib=libc++")
# Set true if CPU backend is built by default
if
(
NOT DEFINED NGRAPH_CPU_ENABLE
)
SET
(
NGRAPH_CPU_ENABLE TRUE
)
endif
()
#-----------------------------------------------------------------------------------------------
#-----------------------------------------------------------------------------------------------
# External projects install directory
# External projects install directory
#-----------------------------------------------------------------------------------------------
#-----------------------------------------------------------------------------------------------
...
...
src/ngraph/codegen/compiler.cpp
View file @
3fa332b6
...
@@ -42,6 +42,7 @@
...
@@ -42,6 +42,7 @@
#include <clang/Basic/TargetInfo.h>
#include <clang/Basic/TargetInfo.h>
#include <clang/CodeGen/CodeGenAction.h>
#include <clang/CodeGen/CodeGenAction.h>
#include <clang/Frontend/CompilerInstance.h>
#include <clang/Frontend/CompilerInstance.h>
#include <clang/Frontend/FrontendActions.h>
#include <clang/Frontend/TextDiagnosticPrinter.h>
#include <clang/Frontend/TextDiagnosticPrinter.h>
#include <llvm/Support/TargetSelect.h>
#include <llvm/Support/TargetSelect.h>
...
@@ -73,6 +74,11 @@ Compiler::~Compiler()
...
@@ -73,6 +74,11 @@ Compiler::~Compiler()
{
{
}
}
void
Compiler
::
set_precompiled_header_source
(
const
std
::
string
&
source
)
{
s_static_compiler
.
set_precompiled_header_source
(
source
);
}
std
::
unique_ptr
<
llvm
::
Module
>
Compiler
::
compile
(
const
std
::
string
&
source
)
std
::
unique_ptr
<
llvm
::
Module
>
Compiler
::
compile
(
const
std
::
string
&
source
)
{
{
lock_guard
<
mutex
>
lock
(
m_mutex
);
lock_guard
<
mutex
>
lock
(
m_mutex
);
...
@@ -88,14 +94,10 @@ static std::string GetExecutablePath(const char* Argv0)
...
@@ -88,14 +94,10 @@ static std::string GetExecutablePath(const char* Argv0)
}
}
StaticCompiler
::
StaticCompiler
()
StaticCompiler
::
StaticCompiler
()
:
m_precompiled_header
s_enable
d
(
false
)
:
m_precompiled_header
_vali
d
(
false
)
,
m_debuginfo_enabled
(
false
)
,
m_debuginfo_enabled
(
false
)
,
m_source_name
(
"code.cpp"
)
,
m_source_name
(
"code.cpp"
)
{
{
#if NGCPU_PCH
m_precompiled_headers_enabled
=
true
;
#endif
#if NGCPU_DEBUGINFO
#if NGCPU_DEBUGINFO
m_debuginfo_enabled
=
true
;
m_debuginfo_enabled
=
true
;
#endif
#endif
...
@@ -213,14 +215,6 @@ StaticCompiler::StaticCompiler()
...
@@ -213,14 +215,6 @@ StaticCompiler::StaticCompiler()
CGO
.
setDebugInfo
(
codegenoptions
::
FullDebugInfo
);
CGO
.
setDebugInfo
(
codegenoptions
::
FullDebugInfo
);
}
}
if
(
m_precompiled_headers_enabled
)
{
// Preprocessor options
auto
&
PPO
=
m_compiler
->
getInvocation
().
getPreprocessorOpts
();
PPO
.
ImplicitPCHInclude
=
"ngcpu.pch"
;
PPO
.
DisablePCHValidation
=
1
;
}
// Enable various target features
// Enable various target features
// Most of these are for Eigen
// Most of these are for Eigen
auto
&
TO
=
m_compiler
->
getInvocation
().
getTargetOpts
();
auto
&
TO
=
m_compiler
->
getInvocation
().
getTargetOpts
();
...
@@ -314,6 +308,18 @@ std::unique_ptr<llvm::Module>
...
@@ -314,6 +308,18 @@ std::unique_ptr<llvm::Module>
StaticCompiler
::
compile
(
std
::
unique_ptr
<
clang
::
CodeGenAction
>&
compiler_action
,
StaticCompiler
::
compile
(
std
::
unique_ptr
<
clang
::
CodeGenAction
>&
compiler_action
,
const
string
&
source
)
const
string
&
source
)
{
{
if
(
!
m_precompiled_header_valid
&&
m_precomiled_header_source
.
empty
()
==
false
)
{
generate_pch
(
m_precomiled_header_source
);
}
if
(
m_precompiled_header_valid
)
{
// Preprocessor options
auto
&
PPO
=
m_compiler
->
getInvocation
().
getPreprocessorOpts
();
PPO
.
ImplicitPCHInclude
=
m_pch_path
;
PPO
.
DisablePCHValidation
=
0
;
}
// Map code filename to a memoryBuffer
// Map code filename to a memoryBuffer
StringRef
source_ref
(
source
);
StringRef
source_ref
(
source
);
unique_ptr
<
MemoryBuffer
>
buffer
=
MemoryBuffer
::
getMemBufferCopy
(
source_ref
);
unique_ptr
<
MemoryBuffer
>
buffer
=
MemoryBuffer
::
getMemBufferCopy
(
source_ref
);
...
@@ -334,24 +340,24 @@ std::unique_ptr<llvm::Module>
...
@@ -334,24 +340,24 @@ std::unique_ptr<llvm::Module>
return
rc
;
return
rc
;
}
}
// std::unique_ptr<llvm::Module> StaticCompiler::generate_pch(const string& source)
void
StaticCompiler
::
generate_pch
(
const
string
&
source
)
// {
{
// // Map code filename to a memoryBuffer
m_pch_path
=
file_util
::
tmp_filename
();
// StringRef source_ref(source);
m_compiler
->
getFrontendOpts
().
OutputFile
=
m_pch_path
;
// unique_ptr<MemoryBuffer> buffer = MemoryBuffer::getMemBufferCopy(source_ref);
// m_compiler->getInvocation().getPreprocessorOpts().addRemappedFile(m_source_name, buffer.get());
// // Create and execute action
// Map code filename to a memoryBuffer
// CodeGenAction* compilerAction = new GeneratePCHAction();
StringRef
source_ref
(
source
);
// std::unique_ptr<llvm::Module> rc;
unique_ptr
<
MemoryBuffer
>
buffer
=
MemoryBuffer
::
getMemBufferCopy
(
source_ref
);
// if (m_compiler->ExecuteAction(*compilerAction) == true)
m_compiler
->
getInvocation
().
getPreprocessorOpts
().
addRemappedFile
(
m_source_name
,
buffer
.
get
());
// {
// rc = compilerAction->takeModule();
// }
// buffer.release();
// Create and execute action
clang
::
GeneratePCHAction
*
compilerAction
=
new
clang
::
GeneratePCHAction
();
if
(
m_compiler
->
ExecuteAction
(
*
compilerAction
)
==
true
)
{
m_precompiled_header_valid
=
true
;
}
// m_compiler->getInvocation().getPreprocessorOpts().clearRemappedFiles
();
buffer
.
release
();
// return rc
;
m_compiler
->
getInvocation
().
getPreprocessorOpts
().
clearRemappedFiles
()
;
//
}
}
src/ngraph/codegen/compiler.hpp
View file @
3fa332b6
...
@@ -53,6 +53,7 @@ class ngraph::codegen::Compiler
...
@@ -53,6 +53,7 @@ class ngraph::codegen::Compiler
public
:
public
:
Compiler
();
Compiler
();
~
Compiler
();
~
Compiler
();
void
set_precompiled_header_source
(
const
std
::
string
&
source
);
std
::
unique_ptr
<
llvm
::
Module
>
compile
(
const
std
::
string
&
source
);
std
::
unique_ptr
<
llvm
::
Module
>
compile
(
const
std
::
string
&
source
);
std
::
unique_ptr
<
clang
::
CodeGenAction
>&
get_compiler_action
()
{
return
compiler_action
;
}
std
::
unique_ptr
<
clang
::
CodeGenAction
>&
get_compiler_action
()
{
return
compiler_action
;
}
private
:
private
:
...
@@ -65,20 +66,26 @@ public:
...
@@ -65,20 +66,26 @@ public:
StaticCompiler
();
StaticCompiler
();
~
StaticCompiler
();
~
StaticCompiler
();
void
set_precompiled_headers_enabled
(
bool
state
)
{
m_precompiled_headers_enabled
=
state
;
}
bool
is_precompiled_headers_enabled
()
{
return
m_precompiled_headers_enabled
;
}
void
set_debuginfo_enabled
(
bool
state
)
{
m_debuginfo_enabled
=
state
;
}
void
set_debuginfo_enabled
(
bool
state
)
{
m_debuginfo_enabled
=
state
;
}
bool
is_debuginfo_enabled
()
{
return
m_debuginfo_enabled
;
}
bool
is_debuginfo_enabled
()
{
return
m_debuginfo_enabled
;
}
void
set_precompiled_header_source
(
const
std
::
string
&
source
)
{
m_precomiled_header_source
=
source
;
}
void
add_header_search_path
(
const
std
::
string
&
path
);
void
add_header_search_path
(
const
std
::
string
&
path
);
std
::
unique_ptr
<
llvm
::
Module
>
compile
(
std
::
unique_ptr
<
clang
::
CodeGenAction
>&
compiler_action
,
std
::
unique_ptr
<
llvm
::
Module
>
compile
(
std
::
unique_ptr
<
clang
::
CodeGenAction
>&
compiler_action
,
const
std
::
string
&
source
);
const
std
::
string
&
source
);
void
generate_pch
(
const
std
::
string
&
source
);
private
:
private
:
std
::
unique_ptr
<
clang
::
CompilerInstance
>
m_compiler
;
std
::
unique_ptr
<
clang
::
CompilerInstance
>
m_compiler
;
bool
m_precompiled_header
s_enable
d
;
bool
m_precompiled_header
_vali
d
;
bool
m_debuginfo_enabled
;
bool
m_debuginfo_enabled
;
std
::
string
m_source_name
;
std
::
string
m_source_name
;
std
::
vector
<
std
::
string
>
m_extra_search_path_list
;
std
::
vector
<
std
::
string
>
m_extra_search_path_list
;
std
::
string
m_pch_path
;
std
::
string
m_precomiled_header_source
;
bool
is_version_number
(
const
std
::
string
&
path
);
bool
is_version_number
(
const
std
::
string
&
path
);
void
use_cached_files
();
void
use_cached_files
();
...
...
src/ngraph/function.cpp
View file @
3fa332b6
...
@@ -31,6 +31,7 @@ Function::Function(const std::shared_ptr<Node>& result,
...
@@ -31,6 +31,7 @@ Function::Function(const std::shared_ptr<Node>& result,
,
m_name
(
name
)
,
m_name
(
name
)
,
m_result_type
(
result_type
)
,
m_result_type
(
result_type
)
,
m_ordered_ops_valid
(
false
)
,
m_ordered_ops_valid
(
false
)
,
m_temporary_pool_size
(
0
)
,
m_instance_id
(
m_next_instance_id
.
fetch_add
(
1
))
,
m_instance_id
(
m_next_instance_id
.
fetch_add
(
1
))
{
{
m_result
->
set_is_output
();
m_result
->
set_is_output
();
...
@@ -97,6 +98,16 @@ void Function::set_name(const string& name)
...
@@ -97,6 +98,16 @@ void Function::set_name(const string& name)
}
}
}
}
size_t
Function
::
get_temporary_pool_size
()
{
return
m_temporary_pool_size
;
}
void
Function
::
set_temporary_pool_size
(
size_t
size
)
{
m_temporary_pool_size
=
size
;
}
std
::
ostream
&
ngraph
::
operator
<<
(
std
::
ostream
&
out
,
const
Function
&
f
)
std
::
ostream
&
ngraph
::
operator
<<
(
std
::
ostream
&
out
,
const
Function
&
f
)
{
{
out
<<
"Function("
<<
f
.
get_name
()
<<
")"
;
out
<<
"Function("
<<
f
.
get_name
()
<<
")"
;
...
...
src/ngraph/function.hpp
View file @
3fa332b6
...
@@ -56,6 +56,9 @@ namespace ngraph
...
@@ -56,6 +56,9 @@ namespace ngraph
void
clear_ordered_ops_valid
()
{
m_ordered_ops_valid
=
false
;
}
void
clear_ordered_ops_valid
()
{
m_ordered_ops_valid
=
false
;
}
friend
std
::
ostream
&
operator
<<
(
std
::
ostream
&
,
const
Function
&
);
friend
std
::
ostream
&
operator
<<
(
std
::
ostream
&
,
const
Function
&
);
size_t
get_instance_id
()
{
return
m_instance_id
;
}
size_t
get_instance_id
()
{
return
m_instance_id
;
}
size_t
get_temporary_pool_size
();
void
set_temporary_pool_size
(
size_t
);
protected
:
protected
:
std
::
shared_ptr
<
Node
>
m_result
;
std
::
shared_ptr
<
Node
>
m_result
;
std
::
vector
<
std
::
shared_ptr
<
ngraph
::
op
::
Parameter
>>
m_parameters
;
std
::
vector
<
std
::
shared_ptr
<
ngraph
::
op
::
Parameter
>>
m_parameters
;
...
@@ -64,6 +67,7 @@ namespace ngraph
...
@@ -64,6 +67,7 @@ namespace ngraph
bool
m_ordered_ops_valid
;
bool
m_ordered_ops_valid
;
std
::
list
<
std
::
shared_ptr
<
Node
>>
m_ordered_ops
;
std
::
list
<
std
::
shared_ptr
<
Node
>>
m_ordered_ops
;
std
::
list
<
std
::
shared_ptr
<
Node
>>
m_ops
;
std
::
list
<
std
::
shared_ptr
<
Node
>>
m_ops
;
size_t
m_temporary_pool_size
;
private
:
private
:
Function
(
const
Function
&
)
=
delete
;
Function
(
const
Function
&
)
=
delete
;
...
...
src/ngraph/pass/manager_state.cpp
View file @
3fa332b6
...
@@ -27,13 +27,3 @@ const vector<shared_ptr<Function>>& ngraph::pass::ManagerState::get_functions()
...
@@ -27,13 +27,3 @@ const vector<shared_ptr<Function>>& ngraph::pass::ManagerState::get_functions()
{
{
return
m_function_list
;
return
m_function_list
;
}
}
size_t
ngraph
::
pass
::
ManagerState
::
get_temporary_pool_size
()
{
return
m_temporary_pool_size
;
}
void
ngraph
::
pass
::
ManagerState
::
set_temporary_pool_size
(
size_t
size
)
{
m_temporary_pool_size
=
size
;
}
src/ngraph/pass/manager_state.hpp
View file @
3fa332b6
...
@@ -39,10 +39,6 @@ public:
...
@@ -39,10 +39,6 @@ public:
m_function_list
.
insert
(
m_function_list
.
begin
(),
collection
.
begin
(),
collection
.
end
());
m_function_list
.
insert
(
m_function_list
.
begin
(),
collection
.
begin
(),
collection
.
end
());
}
}
size_t
get_temporary_pool_size
();
void
set_temporary_pool_size
(
size_t
);
private
:
private
:
size_t
m_temporary_pool_size
=
0
;
std
::
vector
<
std
::
shared_ptr
<
Function
>>
m_function_list
;
std
::
vector
<
std
::
shared_ptr
<
Function
>>
m_function_list
;
};
};
src/ngraph/pass/memory_layout.cpp
View file @
3fa332b6
...
@@ -31,10 +31,10 @@ pass::MemoryLayout::MemoryLayout(size_t alignment)
...
@@ -31,10 +31,10 @@ pass::MemoryLayout::MemoryLayout(size_t alignment)
{
{
}
}
bool
pass
::
MemoryLayout
::
run_on_
call_graph
(
std
::
list
<
std
::
shared_ptr
<
Node
>>&
node_list
)
bool
pass
::
MemoryLayout
::
run_on_
function
(
std
::
shared_ptr
<
ngraph
::
Function
>
function
)
{
{
MemoryManager
mm
(
m_alignment
);
MemoryManager
mm
(
m_alignment
);
for
(
shared_ptr
<
Node
>
node
:
node_list
)
for
(
shared_ptr
<
Node
>
node
:
function
->
get_ordered_ops
()
)
{
{
for
(
Tensor
*
tensor
:
node
->
liveness_new_list
)
for
(
Tensor
*
tensor
:
node
->
liveness_new_list
)
{
{
...
@@ -46,7 +46,7 @@ bool pass::MemoryLayout::run_on_call_graph(std::list<std::shared_ptr<Node>>& nod
...
@@ -46,7 +46,7 @@ bool pass::MemoryLayout::run_on_call_graph(std::list<std::shared_ptr<Node>>& nod
mm
.
free
(
tensor
->
get_pool_offset
());
mm
.
free
(
tensor
->
get_pool_offset
());
}
}
}
}
get_state
().
set_temporary_pool_size
(
mm
.
max_allocated
());
function
->
set_temporary_pool_size
(
mm
.
max_allocated
());
return
false
;
return
false
;
}
}
...
...
src/ngraph/pass/memory_layout.hpp
View file @
3fa332b6
...
@@ -30,11 +30,11 @@ namespace ngraph
...
@@ -30,11 +30,11 @@ namespace ngraph
}
}
}
}
class
ngraph
::
pass
::
MemoryLayout
:
public
CallGraph
Pass
class
ngraph
::
pass
::
MemoryLayout
:
public
Function
Pass
{
{
public
:
public
:
MemoryLayout
(
size_t
alignment
=
1
);
MemoryLayout
(
size_t
alignment
=
1
);
virtual
bool
run_on_call_graph
(
std
::
list
<
std
::
shared_ptr
<
Node
>>&
)
override
;
bool
run_on_function
(
std
::
shared_ptr
<
ngraph
::
Function
>
)
override
;
private
:
private
:
size_t
m_alignment
;
size_t
m_alignment
;
...
...
src/ngraph/runtime/cpu/call_frame.cpp
View file @
3fa332b6
...
@@ -47,7 +47,7 @@ void CallFrame::tensor_call(
...
@@ -47,7 +47,7 @@ void CallFrame::tensor_call(
}
}
// Invoke compiled computation
// Invoke compiled computation
m_compiled_function
(
inputs
,
outputs
);
m_compiled_function
(
inputs
.
data
(),
outputs
.
data
()
);
}
}
void
CallFrame
::
operator
()(
const
std
::
vector
<
std
::
shared_ptr
<
ngraph
::
runtime
::
Value
>>&
arguments
,
void
CallFrame
::
operator
()(
const
std
::
vector
<
std
::
shared_ptr
<
ngraph
::
runtime
::
Value
>>&
arguments
,
...
...
src/ngraph/runtime/cpu/call_frame.hpp
View file @
3fa332b6
...
@@ -33,8 +33,7 @@ namespace ngraph
...
@@ -33,8 +33,7 @@ namespace ngraph
class
CallFrame
;
class
CallFrame
;
class
ExternalFunction
;
class
ExternalFunction
;
using
EntryPoint_t
=
void
(
const
std
::
vector
<
void
*>&
inputs
,
using
EntryPoint_t
=
void
(
void
**
inputs
,
void
**
outputs
);
const
std
::
vector
<
void
*>&
outputs
);
using
EntryPoint
=
std
::
function
<
EntryPoint_t
>
;
using
EntryPoint
=
std
::
function
<
EntryPoint_t
>
;
...
...
src/ngraph/runtime/cpu/emitter.cpp
View file @
3fa332b6
This diff is collapsed.
Click to expand it.
src/ngraph/runtime/cpu/emitter.hpp
View file @
3fa332b6
...
@@ -24,7 +24,6 @@
...
@@ -24,7 +24,6 @@
#define EMITTER_DECL(E) \
#define EMITTER_DECL(E) \
E(const ngraph::Node* n, \
E(const ngraph::Node* n, \
ExternalFunction* ef, \
const std::vector<TensorViewInfo>& inputs, \
const std::vector<TensorViewInfo>& inputs, \
const std::vector<TensorViewInfo>& outputs)
const std::vector<TensorViewInfo>& outputs)
...
...
src/ngraph/runtime/cpu/external_function.cpp
View file @
3fa332b6
...
@@ -183,15 +183,9 @@ void ExternalFunction::compile()
...
@@ -183,15 +183,9 @@ void ExternalFunction::compile()
Emitter
emitter
;
Emitter
emitter
;
codegen
::
CodeWriter
&
TU
=
emitter
.
get_code_writer
();
codegen
::
CodeWriter
&
TU
=
emitter
.
get_code_writer
();
// The "dso_handle" symbol below is required by __cxa_atexit()
// which is enabled because the JIT uses it as the default mechanism
// to register cleanup handlers. We use it, and not atexit(), because
// atexit() happens too late, when the JIT is no longer alive
TU
+=
TU
+=
R"(// Generated by the NGraph CPU backend
R"(// Generated by the NGraph CPU backend
#include <cmath>
#include <cmath>
#include <vector>
#include <Eigen/Dense>
#include <Eigen/Dense>
...
@@ -201,24 +195,27 @@ void ExternalFunction::compile()
...
@@ -201,24 +195,27 @@ void ExternalFunction::compile()
using namespace ngraph::runtime::cpu::eigen;
using namespace ngraph::runtime::cpu::eigen;
void *__dso_handle = 0;
)"
;
)"
;
string
pch_header_source
=
TU
.
get_code
();
// The "dso_handle" symbol is required by __cxa_atexit()
// which is enabled because the JIT uses it as the default mechanism
// to register cleanup handlers. We use it, and not atexit(), because
// atexit() happens too late, when the JIT is no longer alive
TU
<<
"void *__dso_handle = 0;
\n\n
"
;
TU
<<
"// Declare all functions
\n
"
;
TU
<<
"// Declare all functions
\n
"
;
for
(
shared_ptr
<
Function
>
f
:
pass_manager
.
get_state
().
get_functions
())
for
(
shared_ptr
<
Function
>
f
:
pass_manager
.
get_state
().
get_functions
())
{
{
TU
<<
"extern
\"
C
\"
void "
<<
f
->
get_name
()
<<
"(
\n
"
;
TU
<<
"extern
\"
C
\"
void "
<<
f
->
get_name
()
<<
"(void** inputs, void** outputs);
\n
"
;
TU
<<
" const std::vector<void*>& inputs,
\n
"
;
TU
<<
" const std::vector<void*>& outputs);
\n
"
;
}
}
TU
<<
"
\n
"
;
TU
<<
"
\n
"
;
for
(
shared_ptr
<
Function
>
current_function
:
pass_manager
.
get_state
().
get_functions
())
for
(
shared_ptr
<
Function
>
current_function
:
pass_manager
.
get_state
().
get_functions
())
{
{
TU
<<
"extern
\"
C
\"
void "
<<
current_function
->
get_name
()
<<
"(
\n
"
;
TU
<<
"extern
\"
C
\"
void "
<<
current_function
->
get_name
();
TU
<<
" const std::vector<void*>& inputs,
\n
"
;
TU
<<
"(void** inputs, void** outputs)
\n
"
;
TU
<<
" const std::vector<void*>& outputs)
\n
"
;
TU
<<
"{
\n
"
;
TU
<<
"{
\n
"
;
TU
.
indent
++
;
TU
.
indent
++
;
...
@@ -233,7 +230,7 @@ void *__dso_handle = 0;
...
@@ -233,7 +230,7 @@ void *__dso_handle = 0;
}
}
if
(
temporaries_used
)
if
(
temporaries_used
)
{
{
size_t
temp_pool_size
=
pass_manager
.
get_state
().
get_temporary_pool_size
();
size_t
temp_pool_size
=
current_function
->
get_temporary_pool_size
();
TU
<<
"// Allocate the memory pool
\n
"
;
TU
<<
"// Allocate the memory pool
\n
"
;
TU
<<
"ngraph::runtime::AlignedBuffer memory_handler("
<<
temp_pool_size
<<
", "
TU
<<
"ngraph::runtime::AlignedBuffer memory_handler("
<<
temp_pool_size
<<
", "
<<
ngraph
::
runtime
::
cpu
::
alignment
<<
");
\n
"
;
<<
ngraph
::
runtime
::
cpu
::
alignment
<<
");
\n
"
;
...
@@ -303,7 +300,7 @@ void *__dso_handle = 0;
...
@@ -303,7 +300,7 @@ void *__dso_handle = 0;
auto
tv
=
output
.
get_tensor_view
();
auto
tv
=
output
.
get_tensor_view
();
out
.
push_back
({
0
,
tv
});
out
.
push_back
({
0
,
tv
});
}
}
handler
->
second
(
&
emitter
,
node
.
get
(),
this
,
in
,
out
);
handler
->
second
(
&
emitter
,
node
.
get
(),
in
,
out
);
}
}
TU
.
indent
--
;
TU
.
indent
--
;
...
@@ -325,7 +322,10 @@ void *__dso_handle = 0;
...
@@ -325,7 +322,10 @@ void *__dso_handle = 0;
compiler
.
reset
(
new
codegen
::
Compiler
());
compiler
.
reset
(
new
codegen
::
Compiler
());
execution_engine
.
reset
(
new
codegen
::
ExecutionEngine
());
execution_engine
.
reset
(
new
codegen
::
ExecutionEngine
());
compiler
->
set_precompiled_header_source
(
pch_header_source
);
auto
llvm_module
=
compiler
->
compile
(
code
);
auto
llvm_module
=
compiler
->
compile
(
code
);
if
(
llvm_module
==
nullptr
)
if
(
llvm_module
==
nullptr
)
{
{
throw
runtime_error
(
"function failed to compile"
);
throw
runtime_error
(
"function failed to compile"
);
...
...
src/ngraph/runtime/cpu/external_function.hpp
View file @
3fa332b6
...
@@ -39,7 +39,6 @@ namespace ngraph
...
@@ -39,7 +39,6 @@ namespace ngraph
using
OpFunction
=
std
::
function
<
void
(
Emitter
*
,
using
OpFunction
=
std
::
function
<
void
(
Emitter
*
,
const
ngraph
::
Node
*
,
const
ngraph
::
Node
*
,
ExternalFunction
*
,
const
std
::
vector
<
TensorViewInfo
>&
inputs
,
const
std
::
vector
<
TensorViewInfo
>&
inputs
,
const
std
::
vector
<
TensorViewInfo
>&
outputs
)
>
;
const
std
::
vector
<
TensorViewInfo
>&
outputs
)
>
;
...
...
test/CMakeLists.txt
View file @
3fa332b6
...
@@ -57,7 +57,7 @@ if(MKLDNN_INCLUDE_DIR)
...
@@ -57,7 +57,7 @@ if(MKLDNN_INCLUDE_DIR)
set
(
SRC
${
SRC
}
mkldnn.cpp
)
set
(
SRC
${
SRC
}
mkldnn.cpp
)
endif
()
endif
()
if
(
LLVM_INCLUDE_DIR
)
if
(
NGRAPH_CPU_ENABLE AND
LLVM_INCLUDE_DIR
)
include_directories
(
SYSTEM
${
LLVM_INCLUDE_DIR
}
)
include_directories
(
SYSTEM
${
LLVM_INCLUDE_DIR
}
)
link_directories
(
${
LLVM_LIB_DIR
}
)
link_directories
(
${
LLVM_LIB_DIR
}
)
set
(
SRC
${
SRC
}
codegen.cpp
)
set
(
SRC
${
SRC
}
codegen.cpp
)
...
...
test/backend_test.in.cpp
View file @
3fa332b6
...
@@ -2708,3 +2708,30 @@ TEST(${BACKEND_NAME}, sign)
...
@@ -2708,3 +2708,30 @@ TEST(${BACKEND_NAME}, sign)
(
*
cf
)({
a
},
{
result
});
(
*
cf
)({
a
},
{
result
});
ASSERT_EQ
((
vector
<
float
>
{
1
,
-
1
,
0
,
-
1
,
1
,
0
}),
result
->
get_vector
<
float
>
());
ASSERT_EQ
((
vector
<
float
>
{
1
,
-
1
,
0
,
-
1
,
1
,
0
}),
result
->
get_vector
<
float
>
());
}
}
TEST
(
$
{
BACKEND_NAME
},
constant_equality_bool
)
{
auto
shape
=
Shape
{
4
};
// auto A = make_shared<op::Parameter>(element::Bool::element_type(), shape);
// auto B = make_shared<op::Parameter>(element::Bool::element_type(), shape);
// auto result_type = make_shared<TensorViewType>(element::Bool::element_type(), shape);
// auto f = make_shared<Function>(make_shared<op::Equal>(A, B), result_type, op::Parameters{A, B});
auto
a
=
runtime
::
make_tensor
<
element
::
Bool
>
(
shape
,
{
true
,
false
,
true
,
false
});
auto
A
=
make_shared
<
op
::
ParameterizedConstant
<
element
::
Bool
>>
(
shape
,
a
);
auto
b
=
runtime
::
make_tensor
<
element
::
Bool
>
(
shape
,
{
true
,
true
,
true
,
true
});
auto
B
=
make_shared
<
op
::
ParameterizedConstant
<
element
::
Bool
>>
(
shape
,
b
);
auto
rt
=
make_shared
<
TensorViewType
>
(
element
::
Bool
::
element_type
(),
shape
);
auto
f
=
make_shared
<
Function
>
(
make_shared
<
op
::
Equal
>
(
A
,
B
),
rt
,
op
::
Parameters
{});
auto
manager
=
runtime
::
Manager
::
get
(
"${BACKEND_NAME}"
);
auto
external
=
manager
->
compile
(
f
);
auto
backend
=
manager
->
allocate_backend
();
auto
cf
=
backend
->
make_call_frame
(
external
);
// Create some tensors for input/output
auto
result
=
backend
->
make_primary_tensor_view
(
element
::
Bool
::
element_type
(),
shape
);
(
*
cf
)({},
{
result
});
ASSERT_EQ
((
vector
<
char
>
{
true
,
false
,
true
,
false
}),
result
->
get_vector
<
char
>
());
}
test/pass_memory_layout.cpp
View file @
3fa332b6
...
@@ -215,7 +215,7 @@ TEST(memory_layout, basic)
...
@@ -215,7 +215,7 @@ TEST(memory_layout, basic)
auto
graph
=
make_test_graph
();
auto
graph
=
make_test_graph
();
pass_manager
.
run_passes
(
graph
);
pass_manager
.
run_passes
(
graph
);
auto
sorted
=
graph
->
get_ordered_ops
();
auto
sorted
=
graph
->
get_ordered_ops
();
size_t
temporary_pool_size
=
pass_manager
.
get_state
().
get_temporary_pool_size
();
size_t
temporary_pool_size
=
graph
->
get_temporary_pool_size
();
EXPECT_EQ
(
12
,
temporary_pool_size
);
EXPECT_EQ
(
12
,
temporary_pool_size
);
}
}
...
@@ -235,6 +235,6 @@ TEST(memory_layout, constant)
...
@@ -235,6 +235,6 @@ TEST(memory_layout, constant)
pass_manager
.
run_passes
(
f
);
pass_manager
.
run_passes
(
f
);
auto
sorted
=
f
->
get_ordered_ops
();
auto
sorted
=
f
->
get_ordered_ops
();
size_t
temporary_pool_size
=
pass_manager
.
get_state
().
get_temporary_pool_size
();
size_t
temporary_pool_size
=
f
->
get_temporary_pool_size
();
EXPECT_EQ
(
0
,
temporary_pool_size
);
EXPECT_EQ
(
0
,
temporary_pool_size
);
}
}
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