aboutsummaryrefslogtreecommitdiff
path: root/test/fixedbugs/issue16948.go
blob: c98602489614bd5a18ea83fcee76d6f48a4d1e08 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
// run

// Copyright 2016 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.

// issue 16948: make sure intrinsified atomic ops won't
// confuse the scheduler.

package main

import "sync/atomic"

func main() {
	f()
}

var x int32

type T [10]int
var sink *T

func f() (t T) {
	atomic.AddInt32(&x, 1)
	g(42, 42, 42, 42, 42, &t) // use int values that is invalid pointer to smash the stack slot of return value of runtime.newobject
	return
}

//go:noinline
func g(a, b, c, d, e int, p *T) {
	var t [10000]int // a large stack frame to trigger stack growing
	_ = t
	sink = p // force p (in caller) heap allocated
}