Lines Matching refs:dtd

733 				  struct intel_sdvo_dtd *dtd)  in intel_sdvo_set_timing()  argument
735 return intel_sdvo_set_value(intel_sdvo, cmd, &dtd->part1, sizeof(dtd->part1)) && in intel_sdvo_set_timing()
736 intel_sdvo_set_value(intel_sdvo, cmd + 1, &dtd->part2, sizeof(dtd->part2)); in intel_sdvo_set_timing()
740 struct intel_sdvo_dtd *dtd) in intel_sdvo_get_timing() argument
742 return intel_sdvo_get_value(intel_sdvo, cmd, &dtd->part1, sizeof(dtd->part1)) && in intel_sdvo_get_timing()
743 intel_sdvo_get_value(intel_sdvo, cmd + 1, &dtd->part2, sizeof(dtd->part2)); in intel_sdvo_get_timing()
747 struct intel_sdvo_dtd *dtd) in intel_sdvo_set_input_timing() argument
750 SDVO_CMD_SET_INPUT_TIMINGS_PART1, dtd); in intel_sdvo_set_input_timing()
754 struct intel_sdvo_dtd *dtd) in intel_sdvo_set_output_timing() argument
757 SDVO_CMD_SET_OUTPUT_TIMINGS_PART1, dtd); in intel_sdvo_set_output_timing()
761 struct intel_sdvo_dtd *dtd) in intel_sdvo_get_input_timing() argument
764 SDVO_CMD_GET_INPUT_TIMINGS_PART1, dtd); in intel_sdvo_get_input_timing()
792 struct intel_sdvo_dtd *dtd) in intel_sdvo_get_preferred_input_timing() argument
794 BUILD_BUG_ON(sizeof(dtd->part1) != 8); in intel_sdvo_get_preferred_input_timing()
795 BUILD_BUG_ON(sizeof(dtd->part2) != 8); in intel_sdvo_get_preferred_input_timing()
797 &dtd->part1, sizeof(dtd->part1)) && in intel_sdvo_get_preferred_input_timing()
799 &dtd->part2, sizeof(dtd->part2)); in intel_sdvo_get_preferred_input_timing()
807 static void intel_sdvo_get_dtd_from_mode(struct intel_sdvo_dtd *dtd, in intel_sdvo_get_dtd_from_mode() argument
815 memset(dtd, 0, sizeof(*dtd)); in intel_sdvo_get_dtd_from_mode()
832 dtd->part1.clock = mode_clock; in intel_sdvo_get_dtd_from_mode()
834 dtd->part1.h_active = width & 0xff; in intel_sdvo_get_dtd_from_mode()
835 dtd->part1.h_blank = h_blank_len & 0xff; in intel_sdvo_get_dtd_from_mode()
836 dtd->part1.h_high = (((width >> 8) & 0xf) << 4) | in intel_sdvo_get_dtd_from_mode()
838 dtd->part1.v_active = height & 0xff; in intel_sdvo_get_dtd_from_mode()
839 dtd->part1.v_blank = v_blank_len & 0xff; in intel_sdvo_get_dtd_from_mode()
840 dtd->part1.v_high = (((height >> 8) & 0xf) << 4) | in intel_sdvo_get_dtd_from_mode()
843 dtd->part2.h_sync_off = h_sync_offset & 0xff; in intel_sdvo_get_dtd_from_mode()
844 dtd->part2.h_sync_width = h_sync_len & 0xff; in intel_sdvo_get_dtd_from_mode()
845 dtd->part2.v_sync_off_width = (v_sync_offset & 0xf) << 4 | in intel_sdvo_get_dtd_from_mode()
847 dtd->part2.sync_off_width_high = ((h_sync_offset & 0x300) >> 2) | in intel_sdvo_get_dtd_from_mode()
851 dtd->part2.dtd_flags = 0x18; in intel_sdvo_get_dtd_from_mode()
853 dtd->part2.dtd_flags |= DTD_FLAG_INTERLACE; in intel_sdvo_get_dtd_from_mode()
855 dtd->part2.dtd_flags |= DTD_FLAG_HSYNC_POSITIVE; in intel_sdvo_get_dtd_from_mode()
857 dtd->part2.dtd_flags |= DTD_FLAG_VSYNC_POSITIVE; in intel_sdvo_get_dtd_from_mode()
859 dtd->part2.v_sync_off_high = v_sync_offset & 0xc0; in intel_sdvo_get_dtd_from_mode()
863 const struct intel_sdvo_dtd *dtd) in intel_sdvo_get_mode_from_dtd() argument
867 mode.hdisplay = dtd->part1.h_active; in intel_sdvo_get_mode_from_dtd()
868 mode.hdisplay += ((dtd->part1.h_high >> 4) & 0x0f) << 8; in intel_sdvo_get_mode_from_dtd()
869 mode.hsync_start = mode.hdisplay + dtd->part2.h_sync_off; in intel_sdvo_get_mode_from_dtd()
870 mode.hsync_start += (dtd->part2.sync_off_width_high & 0xc0) << 2; in intel_sdvo_get_mode_from_dtd()
871 mode.hsync_end = mode.hsync_start + dtd->part2.h_sync_width; in intel_sdvo_get_mode_from_dtd()
872 mode.hsync_end += (dtd->part2.sync_off_width_high & 0x30) << 4; in intel_sdvo_get_mode_from_dtd()
873 mode.htotal = mode.hdisplay + dtd->part1.h_blank; in intel_sdvo_get_mode_from_dtd()
874 mode.htotal += (dtd->part1.h_high & 0xf) << 8; in intel_sdvo_get_mode_from_dtd()
876 mode.vdisplay = dtd->part1.v_active; in intel_sdvo_get_mode_from_dtd()
877 mode.vdisplay += ((dtd->part1.v_high >> 4) & 0x0f) << 8; in intel_sdvo_get_mode_from_dtd()
879 mode.vsync_start += (dtd->part2.v_sync_off_width >> 4) & 0xf; in intel_sdvo_get_mode_from_dtd()
880 mode.vsync_start += (dtd->part2.sync_off_width_high & 0x0c) << 2; in intel_sdvo_get_mode_from_dtd()
881 mode.vsync_start += dtd->part2.v_sync_off_high & 0xc0; in intel_sdvo_get_mode_from_dtd()
883 (dtd->part2.v_sync_off_width & 0xf); in intel_sdvo_get_mode_from_dtd()
884 mode.vsync_end += (dtd->part2.sync_off_width_high & 0x3) << 4; in intel_sdvo_get_mode_from_dtd()
885 mode.vtotal = mode.vdisplay + dtd->part1.v_blank; in intel_sdvo_get_mode_from_dtd()
886 mode.vtotal += (dtd->part1.v_high & 0xf) << 8; in intel_sdvo_get_mode_from_dtd()
888 mode.clock = dtd->part1.clock * 10; in intel_sdvo_get_mode_from_dtd()
890 if (dtd->part2.dtd_flags & DTD_FLAG_INTERLACE) in intel_sdvo_get_mode_from_dtd()
892 if (dtd->part2.dtd_flags & DTD_FLAG_HSYNC_POSITIVE) in intel_sdvo_get_mode_from_dtd()
896 if (dtd->part2.dtd_flags & DTD_FLAG_VSYNC_POSITIVE) in intel_sdvo_get_mode_from_dtd()
1446 struct intel_sdvo_dtd dtd; in intel_sdvo_get_config() local
1457 ret = intel_sdvo_get_input_timing(intel_sdvo, &dtd); in intel_sdvo_get_config()
1466 if (dtd.part2.dtd_flags & DTD_FLAG_HSYNC_POSITIVE) in intel_sdvo_get_config()
1471 if (dtd.part2.dtd_flags & DTD_FLAG_VSYNC_POSITIVE) in intel_sdvo_get_config()