Commit b036cda9 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'media/v6.6-3' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media

Pull media fixes from Mauro Carvalho Chehab:

 - two Kconfig build fixes under randconfig

 - pxa_camera: Fix an error handling path

 - mediatek: vcodec: Fix a NULL-access pointer

 - tegra-video: fix an infinite recursion regression

* tag 'media/v6.6-3' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media:
  media: mediatek: vcodec: Fix encoder access NULL pointer
  staging: media: tegra-video: fix infinite recursion regression
  media: pci: intel: ivsc: select V4L2_FWNODE
  media: ipu-bridge: Fix Kconfig dependencies
  media: pxa_camera: Fix an error handling path in pxa_camera_probe()
parents 5e5558f5 1146bec0
# SPDX-License-Identifier: GPL-2.0-only # SPDX-License-Identifier: GPL-2.0-only
source "drivers/media/pci/intel/ipu3/Kconfig"
source "drivers/media/pci/intel/ivsc/Kconfig"
config IPU_BRIDGE config IPU_BRIDGE
tristate tristate "Intel IPU Bridge"
depends on I2C && ACPI depends on I2C && ACPI
help help
This is a helper module for the IPU bridge, which can be The IPU bridge is a helper library for Intel IPU drivers to
used by ipu3 and other drivers. In order to handle module function on systems shipped with Windows.
dependencies, this is selected by each driver that needs it.
source "drivers/media/pci/intel/ipu3/Kconfig" Currently used by the ipu3-cio2 and atomisp drivers.
source "drivers/media/pci/intel/ivsc/Kconfig"
Supported systems include:
- Microsoft Surface models (except Surface Pro 3)
- The Lenovo Miix line (for example the 510, 520, 710 and 720)
- Dell 7285
...@@ -2,13 +2,13 @@ ...@@ -2,13 +2,13 @@
config VIDEO_IPU3_CIO2 config VIDEO_IPU3_CIO2
tristate "Intel ipu3-cio2 driver" tristate "Intel ipu3-cio2 driver"
depends on VIDEO_DEV && PCI depends on VIDEO_DEV && PCI
depends on IPU_BRIDGE || !IPU_BRIDGE
depends on ACPI || COMPILE_TEST depends on ACPI || COMPILE_TEST
depends on X86 depends on X86
select MEDIA_CONTROLLER select MEDIA_CONTROLLER
select VIDEO_V4L2_SUBDEV_API select VIDEO_V4L2_SUBDEV_API
select V4L2_FWNODE select V4L2_FWNODE
select VIDEOBUF2_DMA_SG select VIDEOBUF2_DMA_SG
select IPU_BRIDGE if CIO2_BRIDGE
help help
This is the Intel IPU3 CIO2 CSI-2 receiver unit, found in Intel This is the Intel IPU3 CIO2 CSI-2 receiver unit, found in Intel
...@@ -18,22 +18,3 @@ config VIDEO_IPU3_CIO2 ...@@ -18,22 +18,3 @@ config VIDEO_IPU3_CIO2
Say Y or M here if you have a Skylake/Kaby Lake SoC with MIPI CSI-2 Say Y or M here if you have a Skylake/Kaby Lake SoC with MIPI CSI-2
connected camera. connected camera.
The module will be called ipu3-cio2. The module will be called ipu3-cio2.
config CIO2_BRIDGE
bool "IPU3 CIO2 Sensors Bridge"
depends on VIDEO_IPU3_CIO2 && ACPI
depends on I2C
help
This extension provides an API for the ipu3-cio2 driver to create
connections to cameras that are hidden in the SSDB buffer in ACPI.
It can be used to enable support for cameras in detachable / hybrid
devices that ship with Windows.
Say Y here if your device is a detachable / hybrid laptop that comes
with Windows installed by the OEM, for example:
- Microsoft Surface models (except Surface Pro 3)
- The Lenovo Miix line (for example the 510, 520, 710 and 720)
- Dell 7285
If in doubt, say N here.
...@@ -6,7 +6,7 @@ config INTEL_VSC ...@@ -6,7 +6,7 @@ config INTEL_VSC
depends on INTEL_MEI && ACPI && VIDEO_DEV depends on INTEL_MEI && ACPI && VIDEO_DEV
select MEDIA_CONTROLLER select MEDIA_CONTROLLER
select VIDEO_V4L2_SUBDEV_API select VIDEO_V4L2_SUBDEV_API
select V4L2_ASYNC select V4L2_FWNODE
help help
This adds support for Intel Visual Sensing Controller (IVSC). This adds support for Intel Visual Sensing Controller (IVSC).
......
...@@ -2398,7 +2398,7 @@ static int pxa_camera_probe(struct platform_device *pdev) ...@@ -2398,7 +2398,7 @@ static int pxa_camera_probe(struct platform_device *pdev)
PXA_CAM_DRV_NAME, pcdev); PXA_CAM_DRV_NAME, pcdev);
if (err) { if (err) {
dev_err(&pdev->dev, "Camera interrupt register failed\n"); dev_err(&pdev->dev, "Camera interrupt register failed\n");
goto exit_v4l2_device_unregister; goto exit_deactivate;
} }
pcdev->notifier.ops = &pxa_camera_sensor_ops; pcdev->notifier.ops = &pxa_camera_sensor_ops;
......
...@@ -138,7 +138,8 @@ int vpu_enc_init(struct venc_vpu_inst *vpu) ...@@ -138,7 +138,8 @@ int vpu_enc_init(struct venc_vpu_inst *vpu)
vpu->ctx->vpu_inst = vpu; vpu->ctx->vpu_inst = vpu;
status = mtk_vcodec_fw_ipi_register(vpu->ctx->dev->fw_handler, vpu->id, status = mtk_vcodec_fw_ipi_register(vpu->ctx->dev->fw_handler, vpu->id,
vpu_enc_ipi_handler, "venc", NULL); vpu_enc_ipi_handler, "venc",
vpu->ctx->dev);
if (status) { if (status) {
mtk_venc_err(vpu->ctx, "vpu_ipi_register fail %d", status); mtk_venc_err(vpu->ctx, "vpu_ipi_register fail %d", status);
......
...@@ -12,12 +12,12 @@ menuconfig INTEL_ATOMISP ...@@ -12,12 +12,12 @@ menuconfig INTEL_ATOMISP
config VIDEO_ATOMISP config VIDEO_ATOMISP
tristate "Intel Atom Image Signal Processor Driver" tristate "Intel Atom Image Signal Processor Driver"
depends on VIDEO_DEV && INTEL_ATOMISP depends on VIDEO_DEV && INTEL_ATOMISP
depends on IPU_BRIDGE
depends on MEDIA_PCI_SUPPORT depends on MEDIA_PCI_SUPPORT
depends on PMIC_OPREGION depends on PMIC_OPREGION
depends on I2C depends on I2C
select V4L2_FWNODE select V4L2_FWNODE
select IOSF_MBI select IOSF_MBI
select IPU_BRIDGE
select VIDEOBUF2_VMALLOC select VIDEOBUF2_VMALLOC
select VIDEO_V4L2_SUBDEV_API select VIDEO_V4L2_SUBDEV_API
help help
......
...@@ -1455,17 +1455,18 @@ static int __maybe_unused vi_runtime_suspend(struct device *dev) ...@@ -1455,17 +1455,18 @@ static int __maybe_unused vi_runtime_suspend(struct device *dev)
} }
/* /*
* Graph Management * Find the entity matching a given fwnode in an v4l2_async_notifier list
*/ */
static struct tegra_vi_graph_entity * static struct tegra_vi_graph_entity *
tegra_vi_graph_find_entity(struct tegra_vi_channel *chan, tegra_vi_graph_find_entity(struct list_head *list,
const struct fwnode_handle *fwnode) const struct fwnode_handle *fwnode)
{ {
struct tegra_vi_graph_entity *entity; struct tegra_vi_graph_entity *entity;
struct v4l2_async_connection *asd; struct v4l2_async_connection *asd;
list_for_each_entry(asd, &chan->notifier.done_list, asc_entry) { list_for_each_entry(asd, list, asc_entry) {
entity = to_tegra_vi_graph_entity(asd); entity = to_tegra_vi_graph_entity(asd);
if (entity->asd.match.fwnode == fwnode) if (entity->asd.match.fwnode == fwnode)
return entity; return entity;
} }
...@@ -1532,7 +1533,8 @@ static int tegra_vi_graph_build(struct tegra_vi_channel *chan, ...@@ -1532,7 +1533,8 @@ static int tegra_vi_graph_build(struct tegra_vi_channel *chan,
} }
/* find the remote entity from notifier list */ /* find the remote entity from notifier list */
ent = tegra_vi_graph_find_entity(chan, link.remote_node); ent = tegra_vi_graph_find_entity(&chan->notifier.done_list,
link.remote_node);
if (!ent) { if (!ent) {
dev_err(vi->dev, "no entity found for %pOF\n", dev_err(vi->dev, "no entity found for %pOF\n",
to_of_node(link.remote_node)); to_of_node(link.remote_node));
...@@ -1664,7 +1666,8 @@ static int tegra_vi_graph_notify_bound(struct v4l2_async_notifier *notifier, ...@@ -1664,7 +1666,8 @@ static int tegra_vi_graph_notify_bound(struct v4l2_async_notifier *notifier,
* Locate the entity corresponding to the bound subdev and store the * Locate the entity corresponding to the bound subdev and store the
* subdev pointer. * subdev pointer.
*/ */
entity = tegra_vi_graph_find_entity(chan, subdev->fwnode); entity = tegra_vi_graph_find_entity(&chan->notifier.waiting_list,
subdev->fwnode);
if (!entity) { if (!entity) {
dev_err(vi->dev, "no entity for subdev %s\n", subdev->name); dev_err(vi->dev, "no entity for subdev %s\n", subdev->name);
return -EINVAL; return -EINVAL;
...@@ -1713,7 +1716,8 @@ static int tegra_vi_graph_parse_one(struct tegra_vi_channel *chan, ...@@ -1713,7 +1716,8 @@ static int tegra_vi_graph_parse_one(struct tegra_vi_channel *chan,
/* skip entities that are already processed */ /* skip entities that are already processed */
if (device_match_fwnode(vi->dev, remote) || if (device_match_fwnode(vi->dev, remote) ||
tegra_vi_graph_find_entity(chan, remote)) { tegra_vi_graph_find_entity(&chan->notifier.waiting_list,
remote)) {
fwnode_handle_put(remote); fwnode_handle_put(remote);
continue; continue;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment