mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-09 14:50:19 +00:00
media: vivid: don't set HDMI TX controls if there are no HDMI outputs
When setting the EDID it would attempt to update two controls that are only present if there is an HDMI output configured. If there isn't any (e.g. when the vivid module is loaded with node_types=1), then calling VIDIOC_S_EDID would crash. Fix this by first checking if outputs are present. Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
This commit is contained in:
parent
e03549dd02
commit
17763960b1
@ -1554,8 +1554,10 @@ int vidioc_s_edid(struct file *file, void *_fh,
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
if (edid->blocks == 0) {
|
if (edid->blocks == 0) {
|
||||||
dev->edid_blocks = 0;
|
dev->edid_blocks = 0;
|
||||||
v4l2_ctrl_s_ctrl(dev->ctrl_tx_edid_present, 0);
|
if (dev->num_outputs) {
|
||||||
v4l2_ctrl_s_ctrl(dev->ctrl_tx_hotplug, 0);
|
v4l2_ctrl_s_ctrl(dev->ctrl_tx_edid_present, 0);
|
||||||
|
v4l2_ctrl_s_ctrl(dev->ctrl_tx_hotplug, 0);
|
||||||
|
}
|
||||||
phys_addr = CEC_PHYS_ADDR_INVALID;
|
phys_addr = CEC_PHYS_ADDR_INVALID;
|
||||||
goto set_phys_addr;
|
goto set_phys_addr;
|
||||||
}
|
}
|
||||||
@ -1579,8 +1581,10 @@ int vidioc_s_edid(struct file *file, void *_fh,
|
|||||||
display_present |=
|
display_present |=
|
||||||
dev->display_present[i] << j++;
|
dev->display_present[i] << j++;
|
||||||
|
|
||||||
v4l2_ctrl_s_ctrl(dev->ctrl_tx_edid_present, display_present);
|
if (dev->num_outputs) {
|
||||||
v4l2_ctrl_s_ctrl(dev->ctrl_tx_hotplug, display_present);
|
v4l2_ctrl_s_ctrl(dev->ctrl_tx_edid_present, display_present);
|
||||||
|
v4l2_ctrl_s_ctrl(dev->ctrl_tx_hotplug, display_present);
|
||||||
|
}
|
||||||
|
|
||||||
set_phys_addr:
|
set_phys_addr:
|
||||||
/* TODO: a proper hotplug detect cycle should be emulated here */
|
/* TODO: a proper hotplug detect cycle should be emulated here */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user