Page MenuHomeFreeBSD

sh(1): make smark a static variable instead of a local in main()
ClosedPublic

Authored by daniel_octaforge.org on Jun 3 2023, 10:44 PM.
Tags
None
Referenced Files
F107098524: D40415.diff
Fri, Jan 10, 2:24 AM
Unknown Object (File)
Sun, Jan 5, 4:05 AM
Unknown Object (File)
Wed, Dec 18, 11:33 AM
Unknown Object (File)
Nov 28 2024, 3:49 PM
Unknown Object (File)
Nov 20 2024, 5:55 PM
Unknown Object (File)
Nov 8 2024, 11:57 PM
Unknown Object (File)
Oct 27 2024, 12:05 AM
Unknown Object (File)
Sep 25 2024, 6:09 PM
Subscribers
None

Details

Summary

We are modifying it after setjmp and then accessing it after the jump, so it cannot be a local.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

I agree with the analysis, but the variables should still be defined inside main (with static) so they cannot be used outside. Some of the other functions in this file have their own smark locals that should not be mixed up with main's.

An alternative fix could be to change setstackmark and popstackmark to return/take the struct stackmark by value and make main's variables volatile. I'm not really sure that's better than just adding the static keyword though.

yes, you are right; i have changed it

This revision is now accepted and ready to land.Jun 4 2023, 8:17 PM