Page MenuHomeFreeBSD

efirt: When present, attempt to use EFI runtime services to shutdown
ClosedPublic

Authored by cem on Dec 11 2018, 2:23 AM.
Tags
None
Referenced Files
F133523046: D18506.id.diff
Sun, Oct 26, 9:43 AM
F133482425: D18506.id51887.diff
Sun, Oct 26, 3:06 AM
F133482424: D18506.id51885.diff
Sun, Oct 26, 3:06 AM
F133482418: D18506.id.diff
Sun, Oct 26, 3:06 AM
F133482414: D18506.id52043.diff
Sun, Oct 26, 3:06 AM
F133482407: D18506.id51846.diff
Sun, Oct 26, 3:06 AM
F133443705: D18506.diff
Sat, Oct 25, 8:28 PM
Unknown Object (File)
Sat, Oct 25, 7:04 AM
Subscribers
None

Details

Summary

Submitted by: byuu <byuu AT tutanota.com> (previous version)

Test Plan

Unlike byuu's original submission, I left efi_reset_system(void) alone for two
reasons:

  • Potential out of tree consumers (maybe Netflix?)
  • Laziness: Changing the signature requires updating efirt.9

I would be happy to switch efi_reset_system() to the enum-taking variety if
that seems better.

I made the efi_poweroff knob the default setting on EFIRT-enabled systems, but
do not feel strongly about it. We could make it off by default if you prefer.

We could similarly handle RB_REBOOT / whatever shutdown_final events with
"rt_reset" calls. Again, if you feel strongly about it, I can add that
support. I am considering adding the same functionality to the IPMI
shutdown_final event handler anyway -- we use a different IPMI reset mode than
the one in FreeBSD base tree at ISLN.

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 21507
Build 20820: arc lint + arc unit

Event Timeline

Netflix doesn't use efi_system_reset() in our version of FreeBSD. Changing the signature is likely fine.

sys/dev/efidev/efirt.c
114

Small quibble.
s/shutdown/power off/
I think that we should use the most specific term here.

465

We (NFLX) don't do anything out of tree with this.

sys/sys/efi.h
44–45

as there's more than 2, maybe having explicit values would be good. Maybe they should have been explicit all the time.

cem planned changes to this revision.Dec 11 2018, 7:58 AM
cem marked 2 inline comments as done.

Netflix doesn't use efi_system_reset() in our version of FreeBSD. Changing the signature is likely fine.

Ok, works for me.

sys/dev/efidev/efirt.c
114

Will fix

sys/sys/efi.h
44–45

I'm happy to make them explicit if you'd prefer that. They are just 0, 1, 2.

cem marked 3 inline comments as done.
  • Use explicit terminology in sysctl text.
  • Change type of efi_reset_system(9), and document in efirt.9 (which needs cleanup, but that will be left for future work).
  • Explicitly define enum efi_reset values.

efirt is unloadable; be sure to unregister our eventhandler if the module is unloaded.

This revision is now accepted and ready to land.Dec 14 2018, 7:29 PM
This revision was automatically updated to reflect the committed changes.