Page MenuHomeFreeBSD

bhyve: add qemu ppi emulation for tpm devices
ClosedPublic

Authored by corvink on Jun 7 2023, 12:08 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 24, 1:46 AM
Unknown Object (File)
Fri, Jan 24, 1:44 AM
Unknown Object (File)
Fri, Jan 24, 1:21 AM
Unknown Object (File)
Sun, Jan 12, 3:16 PM
Unknown Object (File)
Dec 10 2024, 6:45 PM
Unknown Object (File)
Dec 7 2024, 12:12 AM
Unknown Object (File)
Dec 4 2024, 5:30 PM
Unknown Object (File)
Nov 21 2024, 4:55 PM
Subscribers

Details

Summary

Windows requires a physical presence interface to recognize the tpm
device. Qemu has an implementation for the ppi which can reuse. Using
the qemu ppi makes it very easy because we don't have to implement new
ppi functionality into ovmf. The qemu implementation is already there.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 51954
Build 48845: arc lint + arc unit

Event Timeline

usr.sbin/bhyve/tpm_ppi_qemu.c
116

These switch statements can be replaced by calls to memcpy().

133

Same comment everywhere else.

163

mr_name is unused. There is no need to use a stack buffer for a string which is known at compile time.

200

Same bug as elsewhere, mr.name must not be a pointer to a stack buffer. Please just use a string literal.

  • use memcpy for mmio
  • remove \n from warn calls
  • add mmio registration helper

The warnx() strings do not need newlines.

usr.sbin/bhyve/tpm_ppi_qemu.c
100

If you make this a global variable, then this function isn't needed. Callers can call (un)register_mem() directly and we don't need the extra registration flag variable.

This revision is now accepted and ready to land.Aug 11 2023, 3:37 PM