The .pure->.naked rename (a7fe165) git-mv'd examples 1800-1803 to their
naked names but the perl content edit (abi(.pure) -> abi(.naked) in the
bodies/comments) was never re-staged, so HEAD carried the renamed files
with stale abi(.pure) bodies — which the compiler now rejects ("unknown
ABI"). The working tree had the correct .naked bodies uncommitted; this
commits them so HEAD parses + builds clean.
23 lines
1014 B
Plaintext
23 lines
1014 B
Plaintext
// Stream B1 (fibers) — `abi(.naked)` on a GENERIC function emits a correct naked
|
|
// body (regression for an adversarial-review finding).
|
|
//
|
|
// A generic function is monomorphized through a different Function-creation path
|
|
// (lower/generic.zig) than a plain decl. That path originally left `is_naked`
|
|
// unset, so a generic `abi(.naked)` instance silently shipped a FRAMED body — it
|
|
// returned 42 but leaked the prologue's stack adjustment (the exact SP-in ≠
|
|
// SP-out corruption the `.naked` ABI exists to avoid). generic.zig (and the
|
|
// sibling pack-expansion path in pack.zig) now set `is_naked` and emit the
|
|
// asm-only naked body. This pins that: the monomorphized `answer__i64` is a
|
|
// proper naked function (no frame), returning 42. aarch64-pinned (the asm body
|
|
// is per-arch); runs end-to-end on a matching host, ir-only elsewhere.
|
|
answer :: ($T: Type) -> i64 abi(.naked) {
|
|
asm volatile {
|
|
#string A
|
|
mov x0, #42
|
|
ret
|
|
A
|
|
};
|
|
}
|
|
|
|
main :: () -> i64 { return answer(i64); }
|