Page MenuHomeFreeBSD

Round TF_SIZE up to the stack alignment (16-bytes).
ClosedPublic

Authored by brooks on Sep 4 2020, 5:58 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Mar 17, 1:41 AM
Unknown Object (File)
Mon, Mar 16, 6:26 PM
Unknown Object (File)
Thu, Mar 12, 11:50 AM
Unknown Object (File)
Thu, Mar 12, 5:36 AM
Unknown Object (File)
Wed, Mar 11, 10:33 PM
Unknown Object (File)
Wed, Mar 11, 11:13 AM
Unknown Object (File)
Wed, Mar 11, 2:00 AM
Unknown Object (File)
Sat, Mar 7, 2:12 PM
Subscribers

Details

Summary

The kernel adjusts the stack by TF_SIZE and the RISC-V ABI requires
that it remain 16-byte aligned.

Test Plan

works on CheriBSD

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

brooks requested review of this revision.Sep 4 2020, 5:58 PM
brooks created this revision.
mhorne added inline comments.
sys/riscv/riscv/genassym.c
90 ↗(On Diff #76655)

It seems to me that STACKALIGNBYTES should really just be 16.

This revision is now accepted and ready to land.Sep 4 2020, 6:43 PM
sys/riscv/riscv/genassym.c
90 ↗(On Diff #76655)

I like this documents what we're doing. I didn't use STACKALIGNBYTES in the D26327 because in CheriBSD our roundup2 isn't assembly friendly (we use a type-preserving builtin).

This revision was automatically updated to reflect the committed changes.