Lines Matching full:vic
1547 * HDMI 1.4 4k modes. Index using the VIC.
4172 static __always_inline const struct drm_display_mode *cea_mode_for_vic(u8 vic) in cea_mode_for_vic() argument
4177 if (vic >= 1 && vic < 1 + ARRAY_SIZE(edid_cea_modes_1)) in cea_mode_for_vic()
4178 return &edid_cea_modes_1[vic - 1]; in cea_mode_for_vic()
4179 if (vic >= 193 && vic < 193 + ARRAY_SIZE(edid_cea_modes_193)) in cea_mode_for_vic()
4180 return &edid_cea_modes_193[vic - 193]; in cea_mode_for_vic()
4189 static u8 cea_next_vic(u8 vic) in cea_next_vic() argument
4191 if (++vic == 1 + ARRAY_SIZE(edid_cea_modes_1)) in cea_next_vic()
4192 vic = 193; in cea_next_vic()
4193 return vic; in cea_next_vic()
4222 cea_mode_alternate_timings(u8 vic, struct drm_display_mode *mode) in cea_mode_alternate_timings() argument
4242 if (((vic == 8 || vic == 9 || in cea_mode_alternate_timings()
4243 vic == 12 || vic == 13) && mode->vtotal < 263) || in cea_mode_alternate_timings()
4244 ((vic == 23 || vic == 24 || in cea_mode_alternate_timings()
4245 vic == 27 || vic == 28) && mode->vtotal < 314)) { in cea_mode_alternate_timings()
4260 u8 vic; in drm_match_cea_mode_clock_tolerance() local
4268 for (vic = 1; vic < cea_num_vics(); vic = cea_next_vic(vic)) { in drm_match_cea_mode_clock_tolerance()
4272 drm_mode_init(&cea_mode, cea_mode_for_vic(vic)); in drm_match_cea_mode_clock_tolerance()
4284 return vic; in drm_match_cea_mode_clock_tolerance()
4285 } while (cea_mode_alternate_timings(vic, &cea_mode)); in drm_match_cea_mode_clock_tolerance()
4295 * Return: The CEA Video ID (VIC) of the mode or 0 if it isn't a CEA-861
4301 u8 vic; in drm_match_cea_mode() local
4309 for (vic = 1; vic < cea_num_vics(); vic = cea_next_vic(vic)) { in drm_match_cea_mode()
4313 drm_mode_init(&cea_mode, cea_mode_for_vic(vic)); in drm_match_cea_mode()
4325 return vic; in drm_match_cea_mode()
4326 } while (cea_mode_alternate_timings(vic, &cea_mode)); in drm_match_cea_mode()
4333 static bool drm_valid_cea_vic(u8 vic) in drm_valid_cea_vic() argument
4335 return cea_mode_for_vic(vic) != NULL; in drm_valid_cea_vic()
4367 u8 vic; in drm_match_hdmi_mode_clock_tolerance() local
4375 for (vic = 1; vic < ARRAY_SIZE(edid_4k_modes); vic++) { in drm_match_hdmi_mode_clock_tolerance()
4376 const struct drm_display_mode *hdmi_mode = &edid_4k_modes[vic]; in drm_match_hdmi_mode_clock_tolerance()
4388 return vic; in drm_match_hdmi_mode_clock_tolerance()
4400 * Returns the HDMI Video ID (VIC) of the mode or 0 if it isn't one.
4405 u8 vic; in drm_match_hdmi_mode() local
4413 for (vic = 1; vic < ARRAY_SIZE(edid_4k_modes); vic++) { in drm_match_hdmi_mode()
4414 const struct drm_display_mode *hdmi_mode = &edid_4k_modes[vic]; in drm_match_hdmi_mode()
4424 return vic; in drm_match_hdmi_mode()
4429 static bool drm_valid_hdmi_vic(u8 vic) in drm_valid_hdmi_vic() argument
4431 return vic > 0 && vic < ARRAY_SIZE(edid_4k_modes); in drm_valid_hdmi_vic()
4453 u8 vic = drm_match_cea_mode(mode); in add_alternate_cea_modes() local
4456 if (drm_valid_cea_vic(vic)) { in add_alternate_cea_modes()
4457 cea_mode = cea_mode_for_vic(vic); in add_alternate_cea_modes()
4460 vic = drm_match_hdmi_mode(mode); in add_alternate_cea_modes()
4461 if (drm_valid_hdmi_vic(vic)) { in add_alternate_cea_modes()
4462 cea_mode = &edid_4k_modes[vic]; in add_alternate_cea_modes()
4508 /* 0-6 bit vic, 7th bit native mode indicator */ in svd_to_vic()
4516 * Return a display mode for the 0-based vic_index'th VIC across all CTA VDBs in
4548 u8 vic = svd_to_vic(svds[i]); in do_y420vdb_modes() local
4551 if (!drm_valid_cea_vic(vic)) in do_y420vdb_modes()
4554 newmode = drm_mode_duplicate(dev, cea_mode_for_vic(vic)); in do_y420vdb_modes()
4565 * drm_display_mode_from_cea_vic() - return a mode for CEA VIC
4567 * @video_code: CEA VIC of the mode
4569 * Creates a new mode matching the specified CEA VIC.
4678 static int add_hdmi_mode(struct drm_connector *connector, u8 vic) in add_hdmi_mode() argument
4683 if (!drm_valid_hdmi_vic(vic)) { in add_hdmi_mode()
4684 drm_err(connector->dev, "[CONNECTOR:%d:%s] Unknown HDMI VIC: %d\n", in add_hdmi_mode()
4685 connector->base.id, connector->name, vic); in add_hdmi_mode()
4689 newmode = drm_mode_duplicate(dev, &edid_4k_modes[vic]); in add_hdmi_mode()
4797 u8 vic; in do_hdmi_vsdb_modes() local
4799 vic = db[9 + offset + i]; in do_hdmi_vsdb_modes()
4800 modes += add_hdmi_mode(connector, vic); in do_hdmi_vsdb_modes()
5290 u8 vic; in fixup_detailed_cea_mode_clock() local
5297 vic = drm_match_cea_mode_clock_tolerance(mode, 5); in fixup_detailed_cea_mode_clock()
5298 if (drm_valid_cea_vic(vic)) { in fixup_detailed_cea_mode_clock()
5300 cea_mode = cea_mode_for_vic(vic); in fixup_detailed_cea_mode_clock()
5304 vic = drm_match_hdmi_mode_clock_tolerance(mode, 5); in fixup_detailed_cea_mode_clock()
5305 if (drm_valid_hdmi_vic(vic)) { in fixup_detailed_cea_mode_clock()
5307 cea_mode = &edid_4k_modes[vic]; in fixup_detailed_cea_mode_clock()
5325 "[CONNECTOR:%d:%s] detailed mode matches %s VIC %d, adjusting clock %d -> %d\n", in fixup_detailed_cea_mode_clock()
5327 type, vic, mode->clock, clock); in fixup_detailed_cea_mode_clock()
5872 /* All CEA modes other than VIC 1 use limited quantization range. */ in drm_default_rgb_quant_range()
5900 u8 vic = svd_to_vic(svds[i]); in parse_cta_vdb() local
5902 if (!drm_valid_cea_vic(vic)) in parse_cta_vdb()
5903 vic = 0; in parse_cta_vdb()
5905 info->vics[vic_index++] = vic; in parse_cta_vdb()
5912 * Translate the y420cmdb_map based on VIC indexes to y420_cmdb_modes indexed
5922 u8 vic = info->vics[i]; in update_cta_y420cmdb() local
5924 if (vic && y420cmdb_map & BIT_ULL(i)) in update_cta_y420cmdb()
5925 bitmap_set(hdmi->y420_cmdb_modes, vic, 1); in update_cta_y420cmdb()
5929 static bool cta_vdb_has_vic(const struct drm_connector *connector, u8 vic) in cta_vdb_has_vic() argument
5934 if (!vic || !info->vics) in cta_vdb_has_vic()
5938 if (info->vics[i] == vic) in cta_vdb_has_vic()
5955 u8 vic = svd_to_vic(svds[i]); in parse_cta_y420vdb() local
5957 if (!drm_valid_cea_vic(vic)) in parse_cta_y420vdb()
5960 bitmap_set(hdmi->y420_vdb_modes, vic, 1); in parse_cta_y420vdb()
7037 /* No HDMI VIC when signalling 3D video format */ in drm_mode_hdmi_vic()
7049 * we should send its VIC in vendor infoframes, else send the in drm_mode_cea_vic()
7050 * VIC in AVI infoframes. Lets check if this mode is present in in drm_mode_cea_vic()
7063 * HDMI 1.4 (CTA-861-D) VIC range: [1..64]
7064 * HDMI 2.0 (CTA-861-F) VIC range: [1..107]
7066 * If the sink lists the VIC in CTA VDB, assume it's fine, regardless of HDMI
7069 static u8 vic_for_avi_infoframe(const struct drm_connector *connector, u8 vic) in vic_for_avi_infoframe() argument
7071 if (!is_hdmi2_sink(connector) && vic > 64 && in vic_for_avi_infoframe()
7072 !cta_vdb_has_vic(connector, vic)) in vic_for_avi_infoframe()
7075 return vic; in vic_for_avi_infoframe()
7093 u8 vic, hdmi_vic; in drm_hdmi_avi_infoframe_from_display_mode() local
7103 vic = drm_mode_cea_vic(connector, mode); in drm_hdmi_avi_infoframe_from_display_mode()
7122 if (vic) in drm_hdmi_avi_infoframe_from_display_mode()
7123 picture_aspect = drm_get_cea_aspect_ratio(vic); in drm_hdmi_avi_infoframe_from_display_mode()
7131 * we can only satisfy it by specifying the right VIC. in drm_hdmi_avi_infoframe_from_display_mode()
7134 if (vic) { in drm_hdmi_avi_infoframe_from_display_mode()
7135 if (picture_aspect != drm_get_cea_aspect_ratio(vic)) in drm_hdmi_avi_infoframe_from_display_mode()
7147 frame->video_code = vic_for_avi_infoframe(connector, vic); in drm_hdmi_avi_infoframe_from_display_mode()
7276 * (ie.vic==0 and s3d_struct==0) we will still send it if we in drm_hdmi_vendor_infoframe_from_display_mode()
7283 frame->vic = drm_mode_hdmi_vic(connector, mode); in drm_hdmi_vendor_infoframe_from_display_mode()