|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH v3 02/14] xen/asm-generic: introduce generic device.h
On 17.11.2023 13:24, Oleksii Kurochko wrote:
> --- /dev/null
> +++ b/xen/include/asm-generic/device.h
> @@ -0,0 +1,147 @@
> +/* SPDX-License-Identifier: GPL-2.0-only */
> +#ifndef __ASM_GENERIC_DEVICE_H__
> +#define __ASM_GENERIC_DEVICE_H__
> +
> +enum device_type
> +{
> +#ifdef CONFIG_HAS_DEVICE_TREE
> + DEV_DT,
> +#endif
> +
> +#ifdef HAS_PCI
CONFIG_HAS_PCI?
> + DEV_PCI,
> +#endif
> +};
> +
> +struct dev_archdata {
> + void *iommu; /* IOMMU private data */
#ifdef CONFIG_HAS_PASSTHROUGH around this field?
> +};
> +
> +/* struct device - The basic device structure */
> +struct device
> +{
> + enum device_type type;
> +#ifdef CONFIG_HAS_DEVICE_TREE
> + struct dt_device_node *of_node; /* Used by drivers imported from Linux */
> +#endif
> + struct dev_archdata archdata;
> + struct iommu_fwspec *iommu_fwspec; /* per-device IOMMU instance data */
Same here then?
> +};
> +
> +typedef struct device device_t;
> +
> +#ifdef CONFIG_HAS_DEVICE_TREE
> +#include <xen/device_tree.h>
> +#endif
> +
> +#ifdef HAS_PCI
> +#define dev_is_pci(dev) ((dev)->type == DEV_PCI)
> +#endif
> +
> +#ifdef CONFIG_HAS_DEVICE_TREE
> +#define dev_is_dt(dev) ((dev)->type == DEV_DT)
> +#endif
> +
> +enum device_class
> +{
> + DEVICE_SERIAL,
> + DEVICE_IOMMU,
> + DEVICE_IC,
What is IC here? (And thus: Is this generic enough to live here?)
> +#ifdef HAS_PCI
> + DEVICE_PCI_HOSTBRIDGE,
> +#endif
> + /* Use for error */
> + DEVICE_UNKNOWN,
> +};
> +
> +struct device_desc {
> + /* Device name */
> + const char *name;
> + /* Device class */
> + enum device_class class;
> + /* List of devices supported by this driver */
> + const struct dt_device_match *dt_match;
This and ...
> + /*
> + * Device initialization.
> + *
> + * -EAGAIN is used to indicate that device probing is deferred.
> + */
> + int (*init)(struct dt_device_node *dev, const void *data);
... this look to be DT-specific.
> +};
> +
> +#ifdef CONFIG_ACPI
> +
> +struct acpi_device_desc {
> + /* Device name */
> + const char *name;
> + /* Device class */
> + enum device_class class;
> + /* type of device supported by the driver */
> + const int class_type;
> + /* Device initialization */
> + int (*init)(const void *data);
> +};
> +
> +/**
> + * acpi_device_init - Initialize a device
> + * @class: class of the device (serial, network...)
> + * @data: specific data for initializing the device
> + *
> + * Return 0 on success.
> + */
> +int acpi_device_init(enum device_class class,
> + const void *data, int class_type);
> +
> +#endif /* CONFIG_ACPI */
> +
> +/**
> + * device_init - Initialize a device
> + * @dev: device to initialize
> + * @class: class of the device (serial, network...)
> + * @data: specific data for initializing the device
> + *
> + * Return 0 on success.
> + */
> +int device_init(struct dt_device_node *dev, enum device_class class,
> + const void *data);
As is this, simply from its first parameter's type.
> +/**
> + * device_get_type - Get the type of the device
> + * @dev: device to match
> + *
> + * Return the device type on success or DEVICE_ANY on failure
> + */
> +enum device_class device_get_class(const struct dt_device_node *dev);
> +
> +#define DT_DEVICE_START(_name, _namestr, _class) \
> +static const struct device_desc __dev_desc_##_name __used \
> +__section(".dev.info") = { \
> + .name = _namestr, \
> + .class = _class, \
> +
> +#define DT_DEVICE_END \
> +};
And all of these.
Jan
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |