diff --git a/Dockerfile b/Dockerfile index b87987f97fcef..02e043bc2ec49 100644 --- a/Dockerfile +++ b/Dockerfile @@ -34,7 +34,7 @@ ENV CC=/usr/bin/clang-8 ENV CXX=/usr/bin/clang++-8 RUN wget https://github.com/llvm/llvm-project/releases/download/llvmorg-10.0.0/llvm-10.0.0.src.tar.xz RUN tar xvJf llvm-10.0.0.src.tar.xz -RUN cd llvm-10.0.0.src && mkdir build +RUN cd llvm-10.0.0.src && mkdir build WORKDIR /llvm-10.0.0.src/build RUN cmake .. -DLLVM_ENABLE_RTTI:BOOL=ON -DBUILD_SHARED_LIBS:BOOL=OFF -DCMAKE_BUILD_TYPE=Release -DLLVM_TARGETS_TO_BUILD="X86;NVPTX" -DLLVM_ENABLE_ASSERTIONS=ON RUN make -j 8 diff --git a/cmake/PythonNumpyPybind11.cmake b/cmake/PythonNumpyPybind11.cmake index 2e20ab3919464..bb3696a7f5199 100644 --- a/cmake/PythonNumpyPybind11.cmake +++ b/cmake/PythonNumpyPybind11.cmake @@ -87,4 +87,3 @@ else () endif () include_directories(${PYBIND11_INCLUDE_DIR}) - diff --git a/taichi/transforms/auto_diff.cpp b/taichi/transforms/auto_diff.cpp index 9771ca7d59085..08e9f976967f8 100644 --- a/taichi/transforms/auto_diff.cpp +++ b/taichi/transforms/auto_diff.cpp @@ -200,9 +200,18 @@ class ReplaceLocalVarWithStacks : public BasicStmtVisitor { }) .empty(); if (!load_only) { - alloc->replace_with(Stmt::make( - alloc->ret_type.data_type, - get_current_program().config.ad_stack_size)); + auto dtype = alloc->ret_type.data_type; + auto stack_alloca = Stmt::make( + dtype, alloc->get_kernel()->program.config.ad_stack_size); + auto stack_alloca_ptr = stack_alloca.get(); + + alloc->replace_with(std::move(stack_alloca)); + + // Note that unlike AllocaStmt, StackAllocaStmt does NOT have an 0 as + // initial value. Therefore here we push an initial 0 value. + auto zero = stack_alloca_ptr->insert_after_me( + Stmt::make(TypedConstant(dtype, 0))); + zero->insert_after_me(Stmt::make(stack_alloca_ptr, zero)); } }