Page MenuHomeFreeBSD

Move td_softdep_cleanup() from userret() to ast()

Authored by trasz on Sep 9 2020, 3:24 PM.



Move td_softdep_cleanup() from userret() to ast(); it's infrequent
at best. The schedule_cleanup() function already sets TDF_ASTPENDING.

Diff Detail

rS FreeBSD src repository - subversion
Automatic diff as part of commit; lint not applicable.
Automatic diff as part of commit; unit tests not applicable.

Event Timeline

trasz requested review of this revision.Sep 9 2020, 3:24 PM
198 ↗(On Diff #76814)

Leave the assert there.

198 ↗(On Diff #76814)

Wouldn't it trip at the first possibility due to ast() being called from the syscall enter assembly code some time after userret() returns?

198 ↗(On Diff #76814)

I do not understand what are you saying there.

The assert can be triggered if userret() is executed before ast is handled, or if ast() 'forgot' to handle requested su cleanup. I do not believe that the first case is possible.

Or rather, if userret() triggers that, there is a bug in your patch.

198 ↗(On Diff #76814)

Erm, are you sure about it? My understanding is that (eg) amd64_syscall() calls syscallret(), syscallret() calls userret(), and then amd64_syscall() returns; ast() gets only called afterwards.

kib added inline comments.
198 ↗(On Diff #76814)

Yes you are right. I would say that this should be fixed, but actually your series of the patches makes it not matter at all.

This revision is now accepted and ready to land.Sep 10 2020, 10:55 PM

This change looks reasonable to me as at least for amd64 every path out of the kernel appears to check TDF_ASTPENDING and calls ast() if set.