diff options
| -rw-r--r-- | MLKLLVMCompiler.mm | 112 | ||||
| -rw-r--r-- | MLKLexicalContext-MLKLLVMCompilation.mm | 21 | ||||
| -rw-r--r-- | Toilet Lisp.xcodeproj/project.pbxproj | 4 | ||||
| -rw-r--r-- | llvm_context.h | 27 | 
4 files changed, 94 insertions, 70 deletions
| diff --git a/MLKLLVMCompiler.mm b/MLKLLVMCompiler.mm index bb235bf..72b455b 100644 --- a/MLKLLVMCompiler.mm +++ b/MLKLLVMCompiler.mm @@ -18,9 +18,11 @@  #import "MLKCompiledClosure.h"  #import "MLKDynamicContext.h" +#import "MLKLexicalContext-MLKLLVMCompilation.h"  #import "MLKLLVMCompiler.h"  #import "MLKPackage.h"  #import "globals.h" +#import "llvm_context.h"  #import "util.h"  #import <Foundation/NSArray.h> @@ -42,7 +44,6 @@  #include <llvm/Instructions.h>  //#include <llvm/Interpreter.h>  #include <llvm/Module.h> -#include <llvm/ModuleProvider.h>  #include <llvm/PassManager.h>  #include <llvm/Support/IRBuilder.h>  #include <llvm/Target/TargetData.h> @@ -69,23 +70,17 @@ using namespace std;  static ExecutionEngine *execution_engine;  static llvm::Module *module; -#if defined(LLVM_MAJOR_VERSION) && (LLVM_MAJOR_VERSION <= 2) && (LLVM_MINOR_VERSION <= 3) -static IRBuilder builder; -#else -static IRBuilder<true, ConstantFolder> builder; -#endif +static IRBuilder<true, ConstantFolder> builder(llvm_context);  static FunctionPassManager *fpm; -static PointerType *VoidPointerTy, *PointerPointerTy; -static ModuleProvider *module_provider;  static Constant  *createGlobalStringPtr (const char *string)  {    Constant *(indices[2]); -  indices[0] = indices[1] = ConstantInt::get (Type::Int32Ty, 0); +  indices[0] = indices[1] = ConstantInt::get (Int32Ty, 0); -  Constant *str = ConstantArray::get (string); +  Constant *str = ConstantArray::get (llvm_context, string);    Constant *str2 = new GlobalVariable (str->getType(),                                         true,                                          GlobalValue::InternalLinkage, @@ -114,16 +109,12 @@ static Constant  +(void) initialize  { -  module = new llvm::Module ("MLKLLVMModule"); -  module_provider = new ExistingModuleProvider (module); - -  //execution_engine = ExecutionEngine::create (module_provider, true); -  execution_engine = ExecutionEngine::create (module_provider, false); +  module = new llvm::Module ("MLKLLVMModule", llvm_context); -  VoidPointerTy = PointerType::get(Type::Int8Ty, 0); -  PointerPointerTy = PointerType::get(VoidPointerTy, 0); +  //execution_engine = ExecutionEngine::create (module, true); +  execution_engine = ExecutionEngine::create (module, false); -  fpm = new FunctionPassManager (module_provider); +  fpm = new FunctionPassManager (module);    fpm->add (new TargetData (*execution_engine->getTargetData()));    //fpm->add (new TargetData (module));    fpm->add (createScalarReplAggregatesPass()); @@ -151,7 +142,7 @@ static Constant    Value *v = NULL;    BasicBlock *block; -  vector<const Type*> noargs (0, Type::VoidTy); +  vector<const Type*> noargs (0, VoidTy);    FunctionType *function_type = FunctionType::get (VoidPointerTy,                                                     noargs,                                                     false); @@ -166,7 +157,7 @@ static Constant                             forCompiler:self];    [self markVariablesForHeapAllocationInForm:form]; -  block = BasicBlock::Create ("entry", function); +  block = BasicBlock::Create (llvm_context, "entry", function);    builder.SetInsertPoint (block);    v = [self processForm:form]; @@ -193,7 +184,7 @@ static Constant    // FIXME: Free machine code when appropriate.  (I.e. now?  But this crashes after a LOAD.)    //execution_engine->freeMachineCodeForFunction (function);  #else -  Interpreter *i = Interpreter::create (module_provider); +  Interpreter *i = Interpreter::create (module);    lambdaForm = i->runFunction (function)->PointerVal;  #endif @@ -292,7 +283,7 @@ static Constant                 onObject:object                 withArgumentVector:argv                 name:@"" -               returnType:(Type::VoidTy)]; +               returnType:(VoidTy)];  }  +(Value *) insertMethodCall:(NSString *)messageName @@ -390,7 +381,7 @@ static Constant  {    Constant *function =      module->getOrInsertFunction ("puts", -                                 Type::Int32Ty, +                                 Int32Ty,                                   VoidPointerTy,                                   NULL); @@ -401,7 +392,7 @@ static Constant  {    Constant *function =      module->getOrInsertFunction ("printf", -                                 Type::Int32Ty, +                                 Int32Ty,                                   VoidPointerTy,                                   VoidPointerTy,                                   NULL); @@ -472,8 +463,8 @@ static Constant    Function *function = builder.GetInsertBlock()->getParent(); -  BasicBlock *loopBlock = BasicBlock::Create ("loop", function); -  BasicBlock *joinBlock = BasicBlock::Create ("after_loop"); +  BasicBlock *loopBlock = BasicBlock::Create (llvm_context, "loop", function); +  BasicBlock *joinBlock = BasicBlock::Create (llvm_context, "after_loop");    builder.CreateBr (loopBlock);    builder.SetInsertPoint (loopBlock); @@ -510,7 +501,7 @@ static Constant                                   onObject:mlkdynamiccontext];        LRETAIN (_form);  // FIXME: release -      Value *symbolV = builder.CreateIntToPtr (ConstantInt::get(Type::Int64Ty, +      Value *symbolV = builder.CreateIntToPtr (ConstantInt::get(Int64Ty,                                                                  (uint64_t)_form,                                                                  false),                                                 VoidPointerTy); @@ -579,8 +570,8 @@ static Constant        ptrdiff_t code_offset = offsetof (MLKCompiledClosure, m_code);        ptrdiff_t data_offset = offsetof (MLKCompiledClosure, m_data);  #endif -      Constant *code_offset_value = ConstantInt::get (Type::Int32Ty, code_offset, false); -      Constant *data_offset_value = ConstantInt::get (Type::Int32Ty, data_offset, false); +      Constant *code_offset_value = ConstantInt::get (Int32Ty, code_offset, false); +      Constant *data_offset_value = ConstantInt::get (Int32Ty, data_offset, false);        Value *codeptr = builder.CreateGEP (closure, code_offset_value);        Value *dataptr = builder.CreateGEP (closure, data_offset_value);        codeptr = builder.CreateBitCast (codeptr, PointerPointerTy, "closure_code_ptr"); @@ -616,7 +607,7 @@ static Constant    //GlobalVariable *endmarker = module->getGlobalVariable ("MLKEndOfArgumentsMarker", false);    //endmarker->setConstant (true);    //GlobalVariable *endmarker = new GlobalVariable (VoidPointerTy, true, GlobalValue::ExternalWeakLinkage); -  Value *endmarker = builder.CreateIntToPtr (ConstantInt::get(Type::Int64Ty, +  Value *endmarker = builder.CreateIntToPtr (ConstantInt::get(Int64Ty,                                                                (uint64_t)MLKEndOfArgumentsMarker,                                                                false),                                               VoidPointerTy); @@ -637,7 +628,8 @@ static Constant    // XXX    if ([_context functionIsInline:_head])      { -      InlineFunction (call); +      // FIXME: What to do here? +      //InlineFunction (call);      }    //[_compiler insertTrace:[NSString stringWithFormat:@"%@ done.", MLKPrintToString(_head)]]; @@ -674,19 +666,19 @@ build_simple_function_definition (MLKBodyForm *processed_form,    functionMultiValue->setName ("function_multiple_value_return_pointer");    BasicBlock *outerBlock = builder.GetInsertBlock (); -  BasicBlock *initBlock = BasicBlock::Create ("init_function", function); -  BasicBlock *loopBlock = BasicBlock::Create ("load_args"); -  BasicBlock *loopInitBlock = BasicBlock::Create ("load_args_prelude"); -  BasicBlock *joinBlock = BasicBlock::Create ("function_body"); -  BasicBlock *lambdaListNewBlock = BasicBlock::Create ("lambda_list_new"); -  BasicBlock *lambdaListUpdateBlock = BasicBlock::Create ("lambda_list_update"); +  BasicBlock *initBlock = BasicBlock::Create (llvm_context, "init_function", function); +  BasicBlock *loopBlock = BasicBlock::Create (llvm_context, "load_args"); +  BasicBlock *loopInitBlock = BasicBlock::Create (llvm_context, "load_args_prelude"); +  BasicBlock *joinBlock = BasicBlock::Create (llvm_context, "function_body"); +  BasicBlock *lambdaListNewBlock = BasicBlock::Create (llvm_context, "lambda_list_new"); +  BasicBlock *lambdaListUpdateBlock = BasicBlock::Create (llvm_context, "lambda_list_update");    // ***** HANDLE CLOSURE VARIABLES *****    builder.SetInsertPoint (outerBlock);    NSArray *freeVariables = [[processed_form freeVariables] allObjects];    closure_data = builder.CreateAlloca (VoidPointerTy, -                                       ConstantInt::get(Type::Int32Ty, +                                       ConstantInt::get(Int32Ty,                                                          (uint32_t)[freeVariables count],                                                          false));    closure_data_size = 0; @@ -697,7 +689,7 @@ build_simple_function_definition (MLKBodyForm *processed_form,        MLKSymbol *symbol = [freeVariables objectAtIndex:i];        if (![_context variableIsGlobal:symbol])          { -          Constant *position = ConstantInt::get(Type::Int32Ty, closure_data_size, false); +          Constant *position = ConstantInt::get(Int32Ty, closure_data_size, false);            // Fill in the closure data array.            builder.SetInsertPoint (outerBlock); @@ -721,16 +713,16 @@ build_simple_function_definition (MLKBodyForm *processed_form,    // ***** HANDLE ARGUMENTS *****    builder.SetInsertPoint (initBlock); -  Value *endmarker = builder.CreateIntToPtr (ConstantInt::get(Type::Int64Ty, +  Value *endmarker = builder.CreateIntToPtr (ConstantInt::get(Int64Ty,                                                                (uint64_t)MLKEndOfArgumentsMarker,                                                                false), -                                             PointerType::get(Type::Int8Ty, 0)); +                                             PointerType::get(Int8Ty, 0));    Value *ap = builder.CreateAlloca (VoidPointerTy, NULL, "ap");    Value *ap2 = builder.CreateBitCast (ap, VoidPointerTy);    builder.CreateCall (module->getOrInsertFunction ("llvm.va_start", -                                                   Type::VoidTy, +                                                   VoidTy,                                                     VoidPointerTy,                                                     NULL),                        ap2); @@ -787,7 +779,7 @@ build_simple_function_definition (MLKBodyForm *processed_form,    function->getBasicBlockList().push_back (joinBlock);    builder.CreateCall (module->getOrInsertFunction ("llvm.va_end", -                                                   Type::VoidTy, +                                                   VoidTy,                                                     VoidPointerTy,                                                     NULL),                        ap2); @@ -858,7 +850,7 @@ build_simple_function_definition (MLKBodyForm *processed_form,    vector<Value *> argv;    argv.push_back (function);    argv.push_back (builder.CreateBitCast (closure_data, VoidPointerTy)); -  argv.push_back (builder.CreateIntToPtr (ConstantInt::get(Type::Int32Ty, +  argv.push_back (builder.CreateIntToPtr (ConstantInt::get(Int32Ty,                                                             closure_data_size,                                                             false),                                            VoidPointerTy)); @@ -945,7 +937,7 @@ build_simple_function_definition (MLKBodyForm *processed_form,        vector<Value *> argv;        argv.push_back (function);        argv.push_back (builder.CreateBitCast (closure_data, VoidPointerTy)); -      argv.push_back (builder.CreateIntToPtr (ConstantInt::get(Type::Int32Ty, +      argv.push_back (builder.CreateIntToPtr (ConstantInt::get(Int32Ty,                                                                 closure_data_size,                                                                 false),                                                VoidPointerTy)); @@ -996,7 +988,7 @@ build_simple_function_definition (MLKBodyForm *processed_form,      [[NSGarbageCollector defaultCollector] disableCollectorForPointer:_quotedData];  #endif -  return builder.CreateIntToPtr (ConstantInt::get(Type::Int64Ty, +  return builder.CreateIntToPtr (ConstantInt::get(Int64Ty,                                                    (uint64_t)_quotedData,                                                    false),                                   VoidPointerTy); @@ -1017,7 +1009,7 @@ build_simple_function_definition (MLKBodyForm *processed_form,      [[NSGarbageCollector defaultCollector] disableCollectorForPointer:_form];  #endif -  return builder.CreateIntToPtr (ConstantInt::get(Type::Int64Ty, +  return builder.CreateIntToPtr (ConstantInt::get(Int64Ty,                                                    (uint64_t)_form,                                                    false),                                   VoidPointerTy); @@ -1029,9 +1021,9 @@ build_simple_function_definition (MLKBodyForm *processed_form,  -(Value *) reallyProcessForLLVMWithMultiValue:(Value *)multiValue  {    Function *function = builder.GetInsertBlock()->getParent(); -  BasicBlock *thenBlock = BasicBlock::Create ("if_then", function); -  BasicBlock *elseBlock = BasicBlock::Create ("if_else"); -  BasicBlock *joinBlock = BasicBlock::Create ("if_join"); +  BasicBlock *thenBlock = BasicBlock::Create (llvm_context, "if_then", function); +  BasicBlock *elseBlock = BasicBlock::Create (llvm_context, "if_else"); +  BasicBlock *joinBlock = BasicBlock::Create (llvm_context, "if_join");    Value *test = builder.CreateICmpNE ([_conditionForm processForLLVMWithMultiValue:NULL],                                        ConstantPointerNull::get (VoidPointerTy)); @@ -1082,7 +1074,7 @@ build_simple_function_definition (MLKBodyForm *processed_form,              [[NSGarbageCollector defaultCollector] disableCollectorForPointer:variable];  #endif -          Value *symbolV = builder.CreateIntToPtr (ConstantInt::get(Type::Int64Ty, +          Value *symbolV = builder.CreateIntToPtr (ConstantInt::get(Int64Ty,                                                                      (uint64_t)variable,                                                                      false),                                                     VoidPointerTy); @@ -1096,9 +1088,9 @@ build_simple_function_definition (MLKBodyForm *processed_form,            // Test whether the binding is non-null.  If so, set its value, else create a new one.            Function *function = builder.GetInsertBlock()->getParent(); -          BasicBlock *setBlock = BasicBlock::Create ("setq_set_existing_dynamic_binding", function); -          BasicBlock *makeNewBlock = BasicBlock::Create ("setq_make_new_dynamic_binding"); -          BasicBlock *joinBlock = BasicBlock::Create ("setq_join"); +          BasicBlock *setBlock = BasicBlock::Create (llvm_context, "setq_set_existing_dynamic_binding", function); +          BasicBlock *makeNewBlock = BasicBlock::Create (llvm_context, "setq_make_new_dynamic_binding"); +          BasicBlock *joinBlock = BasicBlock::Create (llvm_context, "setq_join");            Value *test = builder.CreateICmpNE (binding, ConstantPointerNull::get (VoidPointerTy));            //Value *value = builder.CreateAlloca (VoidPointerTy, NULL, "if_result"); @@ -1164,7 +1156,7 @@ build_simple_function_definition (MLKBodyForm *processed_form,      forSymbol:[[MLKPackage findPackage:@"COMMON-LISP"]                  intern:@"*PACKAGE*"]]; -  return builder.CreateIntToPtr (ConstantInt::get(Type::Int64Ty, +  return builder.CreateIntToPtr (ConstantInt::get(Int64Ty,                                                    (uint64_t)package,                                                    false),                                   VoidPointerTy); @@ -1188,7 +1180,7 @@ build_simple_function_definition (MLKBodyForm *processed_form,          [[NSGarbageCollector defaultCollector] disableCollectorForPointer:_functionName];  #endif -      Value *symbolV = builder.CreateIntToPtr (ConstantInt::get(Type::Int64Ty, +      Value *symbolV = builder.CreateIntToPtr (ConstantInt::get(Int64Ty,                                                                  (uint64_t)_functionName,                                                                  false),                                                 VoidPointerTy); @@ -1222,7 +1214,7 @@ build_simple_function_definition (MLKBodyForm *processed_form,  @implementation MLKMultipleValueListForm (MLKLLVMCompilation)  -(Value *) reallyProcessForLLVMWithMultiValue:(Value *)multiValue  { -  Value *endmarker = builder.CreateIntToPtr (ConstantInt::get(Type::Int64Ty, +  Value *endmarker = builder.CreateIntToPtr (ConstantInt::get(Int64Ty,                                                                (uint64_t)MLKEndOfArgumentsMarker,                                                                false),                                               VoidPointerTy); @@ -1233,9 +1225,9 @@ build_simple_function_definition (MLKBodyForm *processed_form,    Value *return_value = builder.CreateAlloca (VoidPointerTy, NULL);    Function *function = builder.GetInsertBlock()->getParent(); -  BasicBlock *singleValueBlock = BasicBlock::Create ("single_value_block", function); -  BasicBlock *multipleValueBlock = BasicBlock::Create ("multiple_value_block"); -  BasicBlock *joinBlock = BasicBlock::Create ("join_block"); +  BasicBlock *singleValueBlock = BasicBlock::Create (llvm_context, "single_value_block", function); +  BasicBlock *multipleValueBlock = BasicBlock::Create (llvm_context, "multiple_value_block"); +  BasicBlock *joinBlock = BasicBlock::Create (llvm_context, "join_block");    Value *multi_tmp_content = builder.CreateLoad (multi_tmp);    Value *isSingleValue = builder.CreateICmpEQ (multi_tmp_content, endmarker); diff --git a/MLKLexicalContext-MLKLLVMCompilation.mm b/MLKLexicalContext-MLKLLVMCompilation.mm index 936ada5..8f46a70 100644 --- a/MLKLexicalContext-MLKLLVMCompilation.mm +++ b/MLKLexicalContext-MLKLLVMCompilation.mm @@ -26,11 +26,12 @@  #include <llvm/Constants.h>  #include <llvm/DerivedTypes.h>  #include <llvm/Instructions.h> +#include <llvm/LLVMContext.h>   #include <llvm/Value.h> +#include "llvm_context.h"  using namespace llvm;  using namespace std; -  id MLKDummyUseLLVMLexicalContext = nil;  @implementation MLKLexicalContext (MLKLLVMCompilation) @@ -57,11 +58,11 @@ id MLKDummyUseLLVMLexicalContext = nil;  -(Instruction *) functionCellValueForSymbol:(id)name  { -  std::vector<const Type *> types (2, PointerType::get(PointerType::get(Type::Int8Ty, 0), 0)); -  return (new IntToPtrInst (ConstantInt::get(Type::Int64Ty, +  std::vector<const Type *> types (2, PointerType::get(PointerType::get(Int8Ty, 0), 0)); +  return (new IntToPtrInst (ConstantInt::get(Int64Ty,                                               (uint64_t)[self functionCellForSymbol:name],                                               false), -                            PointerType::get(PointerType::get(FunctionType::get(PointerType::get(Type::Int8Ty, +                            PointerType::get(PointerType::get(FunctionType::get(PointerType::get(Int8Ty,                                                                                                   0),                                                                                  types,                                                                                  true), @@ -71,27 +72,27 @@ id MLKDummyUseLLVMLexicalContext = nil;  -(Instruction *) closureDataPointerValueForSymbol:(id)name  { -  return (new IntToPtrInst (ConstantInt::get(Type::Int64Ty, +  return (new IntToPtrInst (ConstantInt::get(Int64Ty,                                               (uint64_t)[self closureDataPointerForSymbol:name],                                               false), -                            PointerType::get(PointerType::get(PointerType::get(Type::Int8Ty, 0), 0), 0))); +                            PointerType::get(PointerType::get(PointerType::get(Int8Ty, 0), 0), 0)));  }  -(Instruction *) closureDataLengthValueForSymbol:(id)name  {    // The length cell isn't really a void** but an intptr_t*. -  return (new IntToPtrInst (ConstantInt::get(Type::Int64Ty, +  return (new IntToPtrInst (ConstantInt::get(Int64Ty,                                               (uint64_t)[self closureDataLengthForSymbol:name],                                               false), -                            PointerType::get(PointerType::get(Type::Int8Ty, 0), 0))); +                            PointerType::get(PointerType::get(Int8Ty, 0), 0)));  }  -(Instruction *) globalBindingValueForSymbol:(id)name  { -  return (new IntToPtrInst (ConstantInt::get(Type::Int64Ty, +  return (new IntToPtrInst (ConstantInt::get(Int64Ty,                                               (uint64_t)[self bindingForSymbol:name],                                               false), -                            PointerType::get(Type::Int8Ty, 0))); +                            PointerType::get(Int8Ty, 0)));  }  -(Value *) bindingValueForSymbol:(id)name diff --git a/Toilet Lisp.xcodeproj/project.pbxproj b/Toilet Lisp.xcodeproj/project.pbxproj index 1c9ca0b..996080b 100644 --- a/Toilet Lisp.xcodeproj/project.pbxproj +++ b/Toilet Lisp.xcodeproj/project.pbxproj @@ -66,6 +66,7 @@  		A787138E0E4EFF8A00A7191F /* ffi.lisp in CopyFiles */ = {isa = PBXBuildFile; fileRef = A787138B0E4EFF8A00A7191F /* ffi.lisp */; };  		A787138F0E4EFF8A00A7191F /* package.lisp in CopyFiles */ = {isa = PBXBuildFile; fileRef = A787138C0E4EFF8A00A7191F /* package.lisp */; };  		A78713900E4EFF8A00A7191F /* string.lisp in CopyFiles */ = {isa = PBXBuildFile; fileRef = A787138D0E4EFF8A00A7191F /* string.lisp */; }; +		A7900BC71419687C00FB74B8 /* llvm_context.h in Headers */ = {isa = PBXBuildFile; fileRef = A7900BC61419687C00FB74B8 /* llvm_context.h */; };  		A7A833860E476CF3005D64E0 /* functions.m in Sources */ = {isa = PBXBuildFile; fileRef = A7A833800E476CF3005D64E0 /* functions.m */; };  		A7A833870E476CF3005D64E0 /* MLKBackquoteReader.m in Sources */ = {isa = PBXBuildFile; fileRef = A7A833810E476CF3005D64E0 /* MLKBackquoteReader.m */; };  		A7A833880E476CF3005D64E0 /* MLKCommaReader.m in Sources */ = {isa = PBXBuildFile; fileRef = A7A833820E476CF3005D64E0 /* MLKCommaReader.m */; }; @@ -313,6 +314,7 @@  		A787138B0E4EFF8A00A7191F /* ffi.lisp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = ffi.lisp; sourceTree = "<group>"; };  		A787138C0E4EFF8A00A7191F /* package.lisp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = package.lisp; sourceTree = "<group>"; };  		A787138D0E4EFF8A00A7191F /* string.lisp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = string.lisp; sourceTree = "<group>"; }; +		A7900BC61419687C00FB74B8 /* llvm_context.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = llvm_context.h; sourceTree = "<group>"; };  		A7A833800E476CF3005D64E0 /* functions.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = functions.m; sourceTree = "<group>"; };  		A7A833810E476CF3005D64E0 /* MLKBackquoteReader.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = MLKBackquoteReader.m; sourceTree = "<group>"; };  		A7A833820E476CF3005D64E0 /* MLKCommaReader.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = MLKCommaReader.m; sourceTree = "<group>"; }; @@ -607,6 +609,7 @@  		A7E5C48C0E2169CE00A01D81 /* Headers */ = {  			isa = PBXGroup;  			children = ( +				A7900BC61419687C00FB74B8 /* llvm_context.h */,  				A7A8628C0E6E775F00021916 /* MLKNoSuchSymbolError.h */,  				A7A8628E0E6E776000021916 /* MLKStreamError.h */,  				A7A862900E6E776000021916 /* MLKUnboundVariableError.h */, @@ -743,6 +746,7 @@  			files = (  				A745C44E0E618B2C00C43A04 /* MLKLLVMCompiler.h in Headers */,  				A745C44F0E618B2C00C43A04 /* MLKLexicalContext-MLKLLVMCompilation.h in Headers */, +				A7900BC71419687C00FB74B8 /* llvm_context.h in Headers */,  			);  			runOnlyForDeploymentPostprocessing = 0;  		}; diff --git a/llvm_context.h b/llvm_context.h new file mode 100644 index 0000000..5fce54b --- /dev/null +++ b/llvm_context.h @@ -0,0 +1,27 @@ +// +//  llvm_context.h +//  Toilet Lisp +// +//  Created by Matthias Benkard on 08.09.11. +//  Copyright 2011 __MyCompanyName__. All rights reserved. +// + +#ifndef Toilet_Lisp_llvm_context_h +#define Toilet_Lisp_llvm_context_h + +#include <llvm/DerivedTypes.h> +#include <llvm/LLVMContext.h>  +#include <llvm/Support/TypeBuilder.h> + +LLVMContext llvm_context; +//const Type* IntPtrTy = IntegerType::getInt32Ty(C); +const Type* Int8Ty = IntegerType::getInt8Ty(llvm_context); +const Type* Int16Ty = IntegerType::getInt16Ty(llvm_context); +const Type* Int32Ty = IntegerType::getInt32Ty(llvm_context); +const Type* Int64Ty = IntegerType::getInt64Ty(llvm_context); +//const Type* VoidTy = TypeBuilder<void, false>::get(llvm_context); +const Type* VoidTy = Type::getVoidTy(llvm_context); +const PointerType* VoidPointerTy = PointerType::get(Int8Ty, 0); +const PointerType* PointerPointerTy = PointerType::get(VoidPointerTy, 0); + +#endif | 
