summaryrefslogtreecommitdiffstats
path: root/clang/lib/AST/Interp/InterpStack.cpp
diff options
context:
space:
mode:
authorNandor Licker <n@ndor.email>2019-08-30 15:41:45 +0000
committerNandor Licker <n@ndor.email>2019-08-30 15:41:45 +0000
commit5c8b94a672e78d92d058f146741277228f28f9dd (patch)
treef8d0851637cb87afc6da1f0149d47d0e395e614f /clang/lib/AST/Interp/InterpStack.cpp
parent3fac668d837a92bfbabb1205027b830d709a3c42 (diff)
downloadbcm5719-llvm-5c8b94a672e78d92d058f146741277228f28f9dd.tar.gz
bcm5719-llvm-5c8b94a672e78d92d058f146741277228f28f9dd.zip
Revert [Clang Interpreter] Initial patch for the constexpr interpreter
This reverts r370476 (git commit a5590950549719d0d9ea69ed164b0c8c0f4e02e6) llvm-svn: 370481
Diffstat (limited to 'clang/lib/AST/Interp/InterpStack.cpp')
-rw-r--r--clang/lib/AST/Interp/InterpStack.cpp76
1 files changed, 0 insertions, 76 deletions
diff --git a/clang/lib/AST/Interp/InterpStack.cpp b/clang/lib/AST/Interp/InterpStack.cpp
deleted file mode 100644
index b857eea361d..00000000000
--- a/clang/lib/AST/Interp/InterpStack.cpp
+++ /dev/null
@@ -1,76 +0,0 @@
-//===--- InterpStack.cpp - Stack implementation for the VM ------*- C++ -*-===//
-//
-// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
-// See https://llvm.org/LICENSE.txt for license information.
-// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
-//
-//===----------------------------------------------------------------------===//
-
-#include "InterpStack.h"
-
-using namespace clang;
-using namespace clang::interp;
-
-InterpStack::~InterpStack() {
- clear();
-}
-
-void InterpStack::clear() {
- if (Chunk && Chunk->Next)
- free(Chunk->Next);
- if (Chunk)
- free(Chunk);
- Chunk = nullptr;
- StackSize = 0;
-}
-
-void *InterpStack::grow(size_t Size) {
- assert(Size < ChunkSize - sizeof(StackChunk) && "Object too large");
-
- if (!Chunk || sizeof(StackChunk) + Chunk->size() + Size > ChunkSize) {
- if (Chunk && Chunk->Next) {
- Chunk = Chunk->Next;
- } else {
- StackChunk *Next = new (malloc(ChunkSize)) StackChunk(Chunk);
- if (Chunk)
- Chunk->Next = Next;
- Chunk = Next;
- }
- }
-
- auto *Object = reinterpret_cast<void *>(Chunk->End);
- Chunk->End += Size;
- StackSize += Size;
- return Object;
-}
-
-void *InterpStack::peek(size_t Size) {
- assert(Chunk && "Stack is empty!");
-
- StackChunk *Ptr = Chunk;
- while (Size > Ptr->size()) {
- Size -= Ptr->size();
- Ptr = Ptr->Prev;
- assert(Ptr && "Offset too large");
- }
-
- return reinterpret_cast<void *>(Ptr->End - Size);
-}
-
-void InterpStack::shrink(size_t Size) {
- assert(Chunk && "Chunk is empty!");
-
- while (Size > Chunk->size()) {
- Size -= Chunk->size();
- if (Chunk->Next) {
- free(Chunk->Next);
- Chunk->Next = nullptr;
- }
- Chunk->End = Chunk->start();
- Chunk = Chunk->Prev;
- assert(Chunk && "Offset too large");
- }
-
- Chunk->End -= Size;
- StackSize -= Size;
-}
OpenPOWER on IntegriCloud