diff options
author | Hans de Goede <hdegoede@redhat.com> | 2023-07-05 23:30:03 +0200 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@kernel.org> | 2023-08-10 07:58:40 +0200 |
commit | 21fabfb1072c44be9dd88ecf6c28ae88b24281db (patch) | |
tree | 456ee0fc515b5c87004cabdc80ab88de4cf256b7 /drivers/media/pci/intel | |
parent | 998af18082fe4e318bafa090a5f0aaf3c88992d6 (diff) | |
download | lwn-21fabfb1072c44be9dd88ecf6c28ae88b24281db.tar.gz lwn-21fabfb1072c44be9dd88ecf6c28ae88b24281db.zip |
media: ipu-bridge: Move ipu-bridge.h to include/media/
Move ipu-bridge.h to include/media/, so that it can also be used by
the atomisp code.
Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com>
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
Diffstat (limited to 'drivers/media/pci/intel')
-rw-r--r-- | drivers/media/pci/intel/ipu-bridge.c | 4 | ||||
-rw-r--r-- | drivers/media/pci/intel/ipu-bridge.h | 165 | ||||
-rw-r--r-- | drivers/media/pci/intel/ipu3/ipu3-cio2.c | 3 |
3 files changed, 4 insertions, 168 deletions
diff --git a/drivers/media/pci/intel/ipu-bridge.c b/drivers/media/pci/intel/ipu-bridge.c index c9e7563ac458..994f2c0939b0 100644 --- a/drivers/media/pci/intel/ipu-bridge.c +++ b/drivers/media/pci/intel/ipu-bridge.c @@ -5,9 +5,9 @@ #include <linux/device.h> #include <linux/i2c.h> #include <linux/property.h> -#include <media/v4l2-fwnode.h> -#include "ipu-bridge.h" +#include <media/ipu-bridge.h> +#include <media/v4l2-fwnode.h> /* * Extend this array with ACPI Hardware IDs of devices known to be working diff --git a/drivers/media/pci/intel/ipu-bridge.h b/drivers/media/pci/intel/ipu-bridge.h deleted file mode 100644 index 7d84b22b2111..000000000000 --- a/drivers/media/pci/intel/ipu-bridge.h +++ /dev/null @@ -1,165 +0,0 @@ -/* SPDX-License-Identifier: GPL-2.0 */ -/* Author: Dan Scally <djrscally@gmail.com> */ -#ifndef __IPU_BRIDGE_H -#define __IPU_BRIDGE_H - -#include <linux/property.h> -#include <linux/types.h> -#include <media/v4l2-fwnode.h> - -struct i2c_client; - -#define IPU_HID "INT343E" -#define IPU_MAX_LANES 4 -#define IPU_MAX_PORTS 4 -#define MAX_NUM_LINK_FREQS 3 - -/* Values are educated guesses as we don't have a spec */ -#define IPU_SENSOR_ROTATION_NORMAL 0 -#define IPU_SENSOR_ROTATION_INVERTED 1 - -#define IPU_SENSOR_CONFIG(_HID, _NR, ...) \ - (const struct ipu_sensor_config) { \ - .hid = _HID, \ - .nr_link_freqs = _NR, \ - .link_freqs = { __VA_ARGS__ } \ - } - -#define NODE_SENSOR(_HID, _PROPS) \ - (const struct software_node) { \ - .name = _HID, \ - .properties = _PROPS, \ - } - -#define NODE_PORT(_PORT, _SENSOR_NODE) \ - (const struct software_node) { \ - .name = _PORT, \ - .parent = _SENSOR_NODE, \ - } - -#define NODE_ENDPOINT(_EP, _PORT, _PROPS) \ - (const struct software_node) { \ - .name = _EP, \ - .parent = _PORT, \ - .properties = _PROPS, \ - } - -#define NODE_VCM(_TYPE) \ - (const struct software_node) { \ - .name = _TYPE, \ - } - -enum ipu_sensor_swnodes { - SWNODE_SENSOR_HID, - SWNODE_SENSOR_PORT, - SWNODE_SENSOR_ENDPOINT, - SWNODE_IPU_PORT, - SWNODE_IPU_ENDPOINT, - /* Must be last because it is optional / maybe empty */ - SWNODE_VCM, - SWNODE_COUNT -}; - -/* Data representation as it is in ACPI SSDB buffer */ -struct ipu_sensor_ssdb { - u8 version; - u8 sku; - u8 guid_csi2[16]; - u8 devfunction; - u8 bus; - u32 dphylinkenfuses; - u32 clockdiv; - u8 link; - u8 lanes; - u32 csiparams[10]; - u32 maxlanespeed; - u8 sensorcalibfileidx; - u8 sensorcalibfileidxInMBZ[3]; - u8 romtype; - u8 vcmtype; - u8 platforminfo; - u8 platformsubinfo; - u8 flash; - u8 privacyled; - u8 degree; - u8 mipilinkdefined; - u32 mclkspeed; - u8 controllogicid; - u8 reserved1[3]; - u8 mclkport; - u8 reserved2[13]; -} __packed; - -struct ipu_property_names { - char clock_frequency[16]; - char rotation[9]; - char orientation[12]; - char bus_type[9]; - char data_lanes[11]; - char remote_endpoint[16]; - char link_frequencies[17]; -}; - -struct ipu_node_names { - char port[7]; - char endpoint[11]; - char remote_port[7]; - char vcm[16]; -}; - -struct ipu_sensor_config { - const char *hid; - const u8 nr_link_freqs; - const u64 link_freqs[MAX_NUM_LINK_FREQS]; -}; - -struct ipu_sensor { - /* append ssdb.link(u8) in "-%u" format as suffix of HID */ - char name[ACPI_ID_LEN + 4]; - struct acpi_device *adev; - struct i2c_client *vcm_i2c_client; - - /* SWNODE_COUNT + 1 for terminating NULL */ - const struct software_node *group[SWNODE_COUNT + 1]; - struct software_node swnodes[SWNODE_COUNT]; - struct ipu_node_names node_names; - - u8 link; - u8 lanes; - u32 mclkspeed; - u32 rotation; - enum v4l2_fwnode_orientation orientation; - const char *vcm_type; - - struct ipu_property_names prop_names; - struct property_entry ep_properties[5]; - struct property_entry dev_properties[5]; - struct property_entry ipu_properties[3]; - struct software_node_ref_args local_ref[1]; - struct software_node_ref_args remote_ref[1]; - struct software_node_ref_args vcm_ref[1]; -}; - -typedef int (*ipu_parse_sensor_fwnode_t)(struct acpi_device *adev, - struct ipu_sensor *sensor); - -struct ipu_bridge { - struct device *dev; - ipu_parse_sensor_fwnode_t parse_sensor_fwnode; - char ipu_node_name[ACPI_ID_LEN]; - struct software_node ipu_hid_node; - u32 data_lanes[4]; - unsigned int n_sensors; - struct ipu_sensor sensors[IPU_MAX_PORTS]; -}; - -#if IS_ENABLED(CONFIG_IPU_BRIDGE) -int ipu_bridge_init(struct device *dev, - ipu_parse_sensor_fwnode_t parse_sensor_fwnode); -int ipu_bridge_parse_ssdb(struct acpi_device *adev, struct ipu_sensor *sensor); -#else -/* Use a define to avoid the @parse_sensor_fwnode argument getting evaluated */ -#define ipu_bridge_init(dev, parse_sensor_fwnode) (0) -#endif - -#endif diff --git a/drivers/media/pci/intel/ipu3/ipu3-cio2.c b/drivers/media/pci/intel/ipu3/ipu3-cio2.c index a74eb4091f4f..9f25d7653c73 100644 --- a/drivers/media/pci/intel/ipu3/ipu3-cio2.c +++ b/drivers/media/pci/intel/ipu3/ipu3-cio2.c @@ -22,6 +22,8 @@ #include <linux/pm_runtime.h> #include <linux/property.h> #include <linux/vmalloc.h> + +#include <media/ipu-bridge.h> #include <media/v4l2-ctrls.h> #include <media/v4l2-device.h> #include <media/v4l2-event.h> @@ -29,7 +31,6 @@ #include <media/v4l2-ioctl.h> #include <media/videobuf2-dma-sg.h> -#include "../ipu-bridge.h" #include "ipu3-cio2.h" struct ipu3_cio2_fmt { |