mirror of
https://github.com/golang/go.git
synced 2025-12-08 06:10:04 +00:00
cmd/compile: fix irgen mis-handling invalid function declaration
In -G=3 mode, irgen use its own generated IR, which is mis-handling of bodyless function and declared function with //go:noescape pragma. Fix this by adopting the same logic in noder.funcDecl, which minor change in linkname detection. Fixes #48097 Change-Id: Ibef921c1f75e071ca61685e0cb4543f2ee5efc7f Reviewed-on: https://go-review.googlesource.com/c/go/+/346470 Trust: Cuong Manh Le <cuong.manhle.vn@gmail.com> Trust: Dan Scales <danscales@google.com> Run-TryBot: Cuong Manh Le <cuong.manhle.vn@gmail.com> TryBot-Result: Go Bot <gobot@golang.org> Reviewed-by: Cherry Mui <cherryyz@google.com> Reviewed-by: Dan Scales <danscales@google.com> Reviewed-by: Matthew Dempsky <mdempsky@google.com>
This commit is contained in:
parent
592ee433f5
commit
711e1c8224
5 changed files with 35 additions and 6 deletions
|
|
@ -272,12 +272,6 @@ Outer:
|
|||
}
|
||||
}
|
||||
|
||||
// Check for unusual case where noder2 encounters a type error that types2
|
||||
// doesn't check for (e.g. notinheap incompatibility).
|
||||
base.ExitIfErrors()
|
||||
|
||||
typecheck.DeclareUniverse()
|
||||
|
||||
for _, p := range noders {
|
||||
// Process linkname and cgo pragmas.
|
||||
p.processPragmas()
|
||||
|
|
@ -290,6 +284,22 @@ Outer:
|
|||
})
|
||||
}
|
||||
|
||||
if base.Flag.Complete {
|
||||
for _, n := range g.target.Decls {
|
||||
if fn, ok := n.(*ir.Func); ok {
|
||||
if fn.Body == nil && fn.Nname.Sym().Linkname == "" {
|
||||
base.ErrorfAt(fn.Pos(), "missing function body")
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Check for unusual case where noder2 encounters a type error that types2
|
||||
// doesn't check for (e.g. notinheap incompatibility).
|
||||
base.ExitIfErrors()
|
||||
|
||||
typecheck.DeclareUniverse()
|
||||
|
||||
// Create any needed stencils of generic functions
|
||||
g.stencil()
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue