diff --git a/src/codegen/llvm.zig b/src/codegen/llvm.zig index d11a359bb6..6c74fc8223 100644 --- a/src/codegen/llvm.zig +++ b/src/codegen/llvm.zig @@ -340,6 +340,10 @@ pub const Object = struct { llvm_module.setModuleDataLayout(target_data); + if (options.pic) llvm_module.setModulePICLevel(); + if (options.pie) llvm_module.setModulePIELevel(); + if (code_model != .Default) llvm_module.setModuleCodeModel(code_model); + return Object{ .gpa = gpa, .module = options.module.?, diff --git a/src/codegen/llvm/bindings.zig b/src/codegen/llvm/bindings.zig index b8dc3e1830..560b9544dd 100644 --- a/src/codegen/llvm/bindings.zig +++ b/src/codegen/llvm/bindings.zig @@ -310,6 +310,15 @@ pub const Module = opaque { pub const setModuleDataLayout = LLVMSetModuleDataLayout; extern fn LLVMSetModuleDataLayout(*const Module, *const TargetData) void; + pub const setModulePICLevel = ZigLLVMSetModulePICLevel; + extern fn ZigLLVMSetModulePICLevel(module: *const Module) void; + + pub const setModulePIELevel = ZigLLVMSetModulePIELevel; + extern fn ZigLLVMSetModulePIELevel(module: *const Module) void; + + pub const setModuleCodeModel = ZigLLVMSetModuleCodeModel; + extern fn ZigLLVMSetModuleCodeModel(module: *const Module, code_model: CodeModel) void; + pub const addFunction = LLVMAddFunction; extern fn LLVMAddFunction(*const Module, Name: [*:0]const u8, FunctionTy: *const Type) *const Value;