Browse Source

compiler: Workaround for runtime.boundsCheck in runtime dependencies

pull/6/head
Ayke van Laethem 7 years ago
parent
commit
16489c0df6
  1. 7
      tgo.go

7
tgo.go

@ -843,11 +843,16 @@ func (c *Compiler) parseExpr(frame *Frame, expr ssa.Value) (llvm.Value, error) {
// Bounds check. // Bounds check.
// LLVM optimizes this away in most cases. // LLVM optimizes this away in most cases.
// TODO: runtime.boundsCheck is undefined in packages imported by
// package runtime, so we have to remove it. This should be fixed.
boundsCheck := c.mod.NamedFunction("runtime.boundsCheck")
if !boundsCheck.IsNil() {
constZero := llvm.ConstInt(c.intType, 0, false) constZero := llvm.ConstInt(c.intType, 0, false)
isNegative := c.builder.CreateICmp(llvm.IntSLT, index, constZero, "") // index < 0 isNegative := c.builder.CreateICmp(llvm.IntSLT, index, constZero, "") // index < 0
isTooBig := c.builder.CreateICmp(llvm.IntSGE, index, buflen, "") // index >= len(value) isTooBig := c.builder.CreateICmp(llvm.IntSGE, index, buflen, "") // index >= len(value)
isOverflow := c.builder.CreateOr(isNegative, isTooBig, "") isOverflow := c.builder.CreateOr(isNegative, isTooBig, "")
c.builder.CreateCall(c.mod.NamedFunction("runtime.boundsCheck"), []llvm.Value{isOverflow}, "") c.builder.CreateCall(boundsCheck, []llvm.Value{isOverflow}, "")
}
indices := []llvm.Value{ indices := []llvm.Value{
llvm.ConstInt(llvm.Int32Type(), 0, false), llvm.ConstInt(llvm.Int32Type(), 0, false),

Loading…
Cancel
Save