#include "vivid-radio-common.h"
 #include "vivid-osd.h"
 #include "vivid-ctrls.h"
+#include "vivid-cec.h"
 
 #define VIVID_CID_CUSTOM_BASE          (V4L2_CID_USER_BASE | 0xf000)
 #define VIVID_CID_BUTTON               (VIVID_CID_CUSTOM_BASE + 0)
        struct vivid_dev *dev = container_of(ctrl->handler, struct vivid_dev, ctrl_hdl_vid_out);
        struct v4l2_bt_timings *bt = &dev->dv_timings_out.bt;
        u32 display_present = 0;
-       unsigned int i, j;
+       unsigned int i, j, bus_idx;
 
        switch (ctrl->id) {
        case VIVID_CID_HAS_CROP_OUT:
                        break;
 
                dev->display_present[dev->output] = ctrl->val;
-
                for (i = 0, j = 0; i < dev->num_outputs; i++)
                        if (dev->output_type[i] == HDMI)
                                display_present |=
                                        dev->display_present[i] << j++;
 
-               __v4l2_ctrl_s_ctrl(dev->ctrl_tx_hotplug, display_present);
                __v4l2_ctrl_s_ctrl(dev->ctrl_tx_rxsense, display_present);
-               __v4l2_ctrl_s_ctrl(dev->ctrl_tx_edid_present, display_present);
+
+               if (dev->edid_blocks) {
+                       __v4l2_ctrl_s_ctrl(dev->ctrl_tx_edid_present,
+                                          display_present);
+                       __v4l2_ctrl_s_ctrl(dev->ctrl_tx_hotplug,
+                                          display_present);
+               }
+
+               bus_idx = dev->cec_output2bus_map[dev->output];
+               if (!dev->cec_tx_adap[bus_idx])
+                       break;
+
+               if (ctrl->val && dev->edid_blocks)
+                       cec_s_phys_addr(dev->cec_tx_adap[bus_idx],
+                                       dev->cec_tx_adap[bus_idx]->phys_addr,
+                                       false);
+               else
+                       cec_phys_addr_invalidate(dev->cec_tx_adap[bus_idx]);
+
                break;
        }
        return 0;
 
 {
        struct vivid_dev *dev = video_drvdata(file);
        u16 phys_addr;
-       unsigned int i;
+       u32 display_present = 0;
+       unsigned int i, j;
        int ret;
 
        memset(edid->reserved, 0, sizeof(edid->reserved));
                return -EINVAL;
        if (edid->blocks == 0) {
                dev->edid_blocks = 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;
                goto set_phys_addr;
        }
        dev->edid_blocks = edid->blocks;
        memcpy(dev->edid, edid->edid, edid->blocks * 128);
 
+       for (i = 0, j = 0; i < dev->num_outputs; i++)
+               if (dev->output_type[i] == HDMI)
+                       display_present |=
+                               dev->display_present[i] << j++;
+
+       v4l2_ctrl_s_ctrl(dev->ctrl_tx_edid_present, display_present);
+       v4l2_ctrl_s_ctrl(dev->ctrl_tx_hotplug, display_present);
+
 set_phys_addr:
        /* TODO: a proper hotplug detect cycle should be emulated here */
        cec_s_phys_addr(dev->cec_rx_adap, phys_addr, false);
 
        for (i = 0; i < MAX_OUTPUTS && dev->cec_tx_adap[i]; i++)
                cec_s_phys_addr(dev->cec_tx_adap[i],
-                               v4l2_phys_addr_for_input(phys_addr, i + 1),
+                               dev->display_present[i] ?
+                               v4l2_phys_addr_for_input(phys_addr, i + 1) :
+                               CEC_PHYS_ADDR_INVALID,
                                false);
        return 0;
 }
 
                        return -EINVAL;
                if (dev->output_type[edid->pad] != HDMI)
                        return -EINVAL;
+               if (!dev->display_present[edid->pad])
+                       return -ENODATA;
                bus_idx = dev->cec_output2bus_map[edid->pad];
                adap = dev->cec_tx_adap[bus_idx];
        }