HomeFreeBSD

MFC r338337: Fix lualoader on arm64

Description

MFC r338337: Fix lualoader on arm64

Lua has a few places where it allocates a large buffer on the stack. This
is normally fine, except there are a few places where there can be multiple
frames with this buffer. This can cause a stack overflow on some arm64 SoCs.

Fix this by allocating our own stack in loader.efi large enough for these
objects. The required size has been found by tracing how the stack pointer
changes in a virtual machine and found to be no larger than 50kB. A
larger stack is allocated to reduce the likelihood of overflow from future
changes.

Details

Provenance
kevansAuthored on
Parents
rS344408: MFC various libsa fixes: r337037-r337039, r337065, r337412-r337413, r337874,
Branches
Unknown
Tags
Unknown