Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
T
tic
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
wenyuanbo
tic
Commits
b78f01a9
Commit
b78f01a9
authored
Sep 20, 2017
by
Tianqi Chen
Committed by
GitHub
Sep 20, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
More on source reference (#466)
parent
396c161f
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
10 additions
and
5 deletions
+10
-5
HalideIR
+1
-1
README.md
+1
-2
src/codegen/llvm/codegen_llvm.cc
+2
-0
src/pass/inject_prefetch.cc
+1
-0
src/pass/storage_flatten.cc
+2
-0
src/pass/unroll_loop.cc
+2
-1
src/pass/vectorize_loop.cc
+1
-1
No files found.
HalideIR
@
cb3c025d
Subproject commit
f3eb854595ff99f4b05a5d8034bcacea30ef045b
Subproject commit
cb3c025d5b91ab994b063a85bc935fc364d8f491
README.md
View file @
b78f01a9
...
@@ -33,7 +33,6 @@ Acknowledgement
...
@@ -33,7 +33,6 @@ Acknowledgement
---------------
---------------
We learnt a lot from the following projects when building TVM.
We learnt a lot from the following projects when building TVM.
-
[
Halide
](
https://github.com/halide/Halide
)
: TVM uses
[
HalideIR
](
https://github.com/dmlc/HalideIR
)
as data structure for
-
[
Halide
](
https://github.com/halide/Halide
)
: TVM uses
[
HalideIR
](
https://github.com/dmlc/HalideIR
)
as data structure for
arithematic simplification and low level lowering. HalideIR is derived from Halide.
arithematic simplification and low level lowering. We also learnt and adapted some part of lowering pipeline from Halide.
We also learns from Halide when implementing the lowering pipeline in TVM.
-
[
Loopy
](
https://github.com/inducer/loopy
)
: use of integer set analysis and its loop transformation primitives.
-
[
Loopy
](
https://github.com/inducer/loopy
)
: use of integer set analysis and its loop transformation primitives.
-
[
Theano
](
https://github.com/Theano/Theano
)
: the design inspiration of symbolic scan operator for recurrence.
-
[
Theano
](
https://github.com/Theano/Theano
)
: the design inspiration of symbolic scan operator for recurrence.
src/codegen/llvm/codegen_llvm.cc
View file @
b78f01a9
...
@@ -3,6 +3,7 @@
...
@@ -3,6 +3,7 @@
* \file codegen_llvm.cc
* \file codegen_llvm.cc
*/
*/
#ifdef TVM_LLVM_VERSION
#ifdef TVM_LLVM_VERSION
// Part of the code are adapted from Halide's CodeGen_LLVM
#include <tvm/runtime/device_api.h>
#include <tvm/runtime/device_api.h>
#include <tvm/runtime/c_runtime_api.h>
#include <tvm/runtime/c_runtime_api.h>
...
@@ -492,6 +493,7 @@ llvm::Value* CodeGenLLVM::CreateBufferPtr(
...
@@ -492,6 +493,7 @@ llvm::Value* CodeGenLLVM::CreateBufferPtr(
if
(
btype
!=
ptype
)
{
if
(
btype
!=
ptype
)
{
buffer
=
builder_
->
CreatePointerCast
(
buffer
,
ptype
);
buffer
=
builder_
->
CreatePointerCast
(
buffer
,
ptype
);
}
}
return
builder_
->
CreateInBoundsGEP
(
buffer
,
index
);
return
builder_
->
CreateInBoundsGEP
(
buffer
,
index
);
}
}
...
...
src/pass/inject_prefetch.cc
View file @
b78f01a9
...
@@ -2,6 +2,7 @@
...
@@ -2,6 +2,7 @@
* Copyright (c) 2017 by Contributors
* Copyright (c) 2017 by Contributors
* \file inject_prefetch.cc
* \file inject_prefetch.cc
*/
*/
// Inject prefetch op in HalideIR
#include <tvm/ir.h>
#include <tvm/ir.h>
#include <tvm/ir_mutator.h>
#include <tvm/ir_mutator.h>
#include <tvm/ir_visitor.h>
#include <tvm/ir_visitor.h>
...
...
src/pass/storage_flatten.cc
View file @
b78f01a9
...
@@ -2,6 +2,8 @@
...
@@ -2,6 +2,8 @@
* Copyright (c) 2016 by Contributors
* Copyright (c) 2016 by Contributors
* \file storage_flatten.cc
* \file storage_flatten.cc
*/
*/
// Flattens storage from multi-dimensional array to 1D
// buffer access as in Halide pipeline.
#include <tvm/ir.h>
#include <tvm/ir.h>
#include <tvm/expr.h>
#include <tvm/expr.h>
#include <tvm/operation.h>
#include <tvm/operation.h>
...
...
src/pass/unroll_loop.cc
View file @
b78f01a9
/*!
/*!
* Copyright (c) 2017 by Contributors
* Copyright (c) 2017 by Contributors
* Loop unrolling.
* Loop unrolling
as in Halide pipeline
.
* \file unroll_loop.cc
* \file unroll_loop.cc
*/
*/
// Unrolls the loop as in Halide pipeline.
#include <tvm/ir.h>
#include <tvm/ir.h>
#include <tvm/ir_pass.h>
#include <tvm/ir_pass.h>
#include <tvm/ir_mutator.h>
#include <tvm/ir_mutator.h>
...
...
src/pass/vectorize_loop.cc
View file @
b78f01a9
/*!
/*!
* Copyright (c) 2017 by Contributors
* Copyright (c) 2017 by Contributors
* Vectorize the loop
* \file vectorize_loop.cc
* \file vectorize_loop.cc
*/
*/
// Loop vectorizer as in Halide pipeline.
#include <tvm/ir.h>
#include <tvm/ir.h>
#include <tvm/ir_pass.h>
#include <tvm/ir_pass.h>
#include <tvm/ir_mutator.h>
#include <tvm/ir_mutator.h>
...
...
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