bhyve: introduce acpi_device_emul struct

It'll be easier to add new properties to the ACPI device emulation if we
have a struct which holds all device specific properties. In some future
commits the acpi_device_emul struct will be expanded to include some
device specific functions to build ACPI tables.

Reviewed by:		markj
MFC after:		1 week
Sponsored by:		Beckhoff Automation GmbH & Co. KG
Differential Revision:	https://reviews.freebsd.org/D39319
This commit is contained in:
Corvin Köhne 2022-07-22 10:00:10 +02:00
parent 54579376c0
commit acd0088c44
No known key found for this signature in database
GPG Key ID: D854DA56315E026A
3 changed files with 26 additions and 25 deletions

View File

@ -35,24 +35,23 @@ struct acpi_resource_list_entry {
* Holds information about an ACPI device.
*
* @param vm_ctx VM context the ACPI device was created in.
* @param name Name of the ACPI device.
* @param hid Hardware ID of the ACPI device.
* @param emul Device emulation struct. It contains some information like the
name of the ACPI device and some device specific functions.
* @param crs Current resources used by the ACPI device.
*/
struct acpi_device {
struct vmctx *vm_ctx;
const char *name;
const char *hid;
const struct acpi_device_emul *emul;
SLIST_HEAD(acpi_resource_list, acpi_resource_list_entry) crs;
};
int
acpi_device_create(struct acpi_device **const new_dev,
struct vmctx *const vm_ctx, const char *const name, const char *const hid)
struct vmctx *const vm_ctx, const struct acpi_device_emul *const emul)
{
if (new_dev == NULL || vm_ctx == NULL || name == NULL || hid == NULL) {
return (EINVAL);
}
assert(new_dev != NULL);
assert(vm_ctx != NULL);
assert(emul != NULL);
struct acpi_device *const dev = calloc(1, sizeof(*dev));
if (dev == NULL) {
@ -60,13 +59,8 @@ acpi_device_create(struct acpi_device **const new_dev,
}
dev->vm_ctx = vm_ctx;
dev->name = strdup(name);
dev->hid = strdup(hid);
dev->emul = emul;
SLIST_INIT(&dev->crs);
if (dev->name == NULL || dev->hid == NULL) {
acpi_device_destroy(dev);
return (ENOMEM);
}
const int error = acpi_tables_add_device(dev);
if (error) {
@ -92,9 +86,7 @@ acpi_device_destroy(struct acpi_device *const dev)
SLIST_REMOVE_HEAD(&dev->crs, chain);
free(res);
}
free(__DECONST(void *, dev->hid));
free(__DECONST(void *, dev->name));
free(dev);
}
@ -174,9 +166,9 @@ acpi_device_write_dsdt(const struct acpi_device *const dev)
dsdt_line("");
dsdt_line(" Scope (\\_SB)");
dsdt_line(" {");
dsdt_line(" Device (%s)", dev->name);
dsdt_line(" Device (%s)", dev->emul->name);
dsdt_line(" {");
dsdt_line(" Name (_HID, \"%s\")", dev->hid);
dsdt_line(" Name (_HID, \"%s\")", dev->emul->hid);
dsdt_line(" Name (_STA, 0x0F)");
dsdt_line(" Name (_CRS, ResourceTemplate ()");
dsdt_line(" {");

View File

@ -16,18 +16,22 @@ struct vmctx;
struct acpi_device;
struct acpi_device_emul {
const char *name;
const char *hid;
};
/**
* Creates an ACPI device.
*
* @param[out] new_dev Returns the newly create ACPI device.
* @param[in] vm_ctx VM context the ACPI device is created in.
* @param[in] name Name of the ACPI device. Should always be a NULL
* terminated string.
* @param[in] hid Hardware ID of the ACPI device. Should always be a NULL
* terminated string.
* @param[in] emul Device emulation struct. It contains some information
* like the name of the ACPI device and some device specific
* functions.
*/
int acpi_device_create(struct acpi_device **new_dev, struct vmctx *vm_ctx,
const char *name, const char *hid);
const struct acpi_device_emul *emul);
void acpi_device_destroy(struct acpi_device *dev);
int acpi_device_add_res_fixed_ioport(struct acpi_device *dev, UINT16 port,

View File

@ -365,6 +365,11 @@ qemu_fwcfg_add_file(const char *name, const uint32_t size, void *const data)
return (0);
}
static const struct acpi_device_emul qemu_fwcfg_acpi_device_emul = {
.name = QEMU_FWCFG_ACPI_DEVICE_NAME,
.hid = QEMU_FWCFG_ACPI_HARDWARE_ID,
};
int
qemu_fwcfg_init(struct vmctx *const ctx)
{
@ -378,7 +383,7 @@ qemu_fwcfg_init(struct vmctx *const ctx)
*/
if (strcmp(lpc_fwcfg(), "qemu") == 0) {
error = acpi_device_create(&fwcfg_sc.acpi_dev, ctx,
QEMU_FWCFG_ACPI_DEVICE_NAME, QEMU_FWCFG_ACPI_HARDWARE_ID);
&qemu_fwcfg_acpi_device_emul);
if (error) {
warnx("%s: failed to create ACPI device for QEMU FwCfg",
__func__);