[llvm] r343339 - [bindings/go] Add Go bindings for inline assembly
whitequark via llvm-commits
llvm-commits at lists.llvm.org
Fri Sep 28 09:48:47 PDT 2018
Author: whitequark
Date: Fri Sep 28 09:48:47 2018
New Revision: 343339
URL: http://llvm.org/viewvc/llvm-project?rev=343339&view=rev
Log:
[bindings/go] Add Go bindings for inline assembly
Reviewers: harlanhaskins, whitequark, pcc
Reviewed By: pcc
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D46437
Modified:
llvm/trunk/bindings/go/llvm/ir.go
Modified: llvm/trunk/bindings/go/llvm/ir.go
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/bindings/go/llvm/ir.go?rev=343339&r1=343338&r2=343339&view=diff
==============================================================================
--- llvm/trunk/bindings/go/llvm/ir.go (original)
+++ llvm/trunk/bindings/go/llvm/ir.go Fri Sep 28 09:48:47 2018
@@ -74,6 +74,7 @@ type (
IntPredicate C.LLVMIntPredicate
FloatPredicate C.LLVMRealPredicate
LandingPadClause C.LLVMLandingPadClauseTy
+ InlineAsmDialect C.LLVMInlineAsmDialect
)
func (c Context) IsNil() bool { return c.C == nil }
@@ -315,6 +316,15 @@ const (
)
//-------------------------------------------------------------------------
+// llvm.InlineAsmDialect
+//-------------------------------------------------------------------------
+
+const (
+ InlineAsmDialectATT InlineAsmDialect = C.LLVMInlineAsmDialectATT
+ InlineAsmDialectIntel InlineAsmDialect = C.LLVMInlineAsmDialectIntel
+)
+
+//-------------------------------------------------------------------------
// llvm.Context
//-------------------------------------------------------------------------
@@ -1237,6 +1247,16 @@ func (v Value) IncomingBlock(i int) (bb
return
}
+// Operations on inline assembly
+func InlineAsm(t Type, asmString, constraints string, hasSideEffects, isAlignStack bool, dialect InlineAsmDialect) (rv Value) {
+ casm := C.CString(asmString)
+ defer C.free(unsafe.Pointer(casm))
+ cconstraints := C.CString(constraints)
+ defer C.free(unsafe.Pointer(cconstraints))
+ rv.C = C.LLVMGetInlineAsm(t.C, casm, C.size_t(len(asmString)), cconstraints, C.size_t(len(constraints)), boolToLLVMBool(hasSideEffects), boolToLLVMBool(isAlignStack), C.LLVMInlineAsmDialect(dialect))
+ return
+}
+
//-------------------------------------------------------------------------
// llvm.Builder
//-------------------------------------------------------------------------
More information about the llvm-commits
mailing list