[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 |