123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 |
- #define DSS_SUBSYS_NAME "HDMI"
- #include <linux/kernel.h>
- #include <linux/err.h>
- #include <linux/of.h>
- #include <video/omapdss.h>
- #include "hdmi.h"
- int hdmi_parse_lanes_of(struct platform_device *pdev, struct device_node *ep,
- struct hdmi_phy_data *phy)
- {
- struct property *prop;
- int r, len;
- prop = of_find_property(ep, "lanes", &len);
- if (prop) {
- u32 lanes[8];
- if (len / sizeof(u32) != ARRAY_SIZE(lanes)) {
- dev_err(&pdev->dev, "bad number of lanes\n");
- return -EINVAL;
- }
- r = of_property_read_u32_array(ep, "lanes", lanes,
- ARRAY_SIZE(lanes));
- if (r) {
- dev_err(&pdev->dev, "failed to read lane data\n");
- return r;
- }
- r = hdmi_phy_parse_lanes(phy, lanes);
- if (r) {
- dev_err(&pdev->dev, "failed to parse lane data\n");
- return r;
- }
- } else {
- static const u32 default_lanes[] = { 0, 1, 2, 3, 4, 5, 6, 7 };
- r = hdmi_phy_parse_lanes(phy, default_lanes);
- if (WARN_ON(r)) {
- dev_err(&pdev->dev, "failed to parse lane data\n");
- return r;
- }
- }
- return 0;
- }
- int hdmi_compute_acr(u32 pclk, u32 sample_freq, u32 *n, u32 *cts)
- {
- u32 deep_color;
- bool deep_color_correct = false;
- if (n == NULL || cts == NULL)
- return -EINVAL;
- /* TODO: When implemented, query deep color mode here. */
- deep_color = 100;
- /*
- * When using deep color, the default N value (as in the HDMI
- * specification) yields to an non-integer CTS. Hence, we
- * modify it while keeping the restrictions described in
- * section 7.2.1 of the HDMI 1.4a specification.
- */
- switch (sample_freq) {
- case 32000:
- case 48000:
- case 96000:
- case 192000:
- if (deep_color == 125)
- if (pclk == 27027000 || pclk == 74250000)
- deep_color_correct = true;
- if (deep_color == 150)
- if (pclk == 27027000)
- deep_color_correct = true;
- break;
- case 44100:
- case 88200:
- case 176400:
- if (deep_color == 125)
- if (pclk == 27027000)
- deep_color_correct = true;
- break;
- default:
- return -EINVAL;
- }
- if (deep_color_correct) {
- switch (sample_freq) {
- case 32000:
- *n = 8192;
- break;
- case 44100:
- *n = 12544;
- break;
- case 48000:
- *n = 8192;
- break;
- case 88200:
- *n = 25088;
- break;
- case 96000:
- *n = 16384;
- break;
- case 176400:
- *n = 50176;
- break;
- case 192000:
- *n = 32768;
- break;
- default:
- return -EINVAL;
- }
- } else {
- switch (sample_freq) {
- case 32000:
- *n = 4096;
- break;
- case 44100:
- *n = 6272;
- break;
- case 48000:
- *n = 6144;
- break;
- case 88200:
- *n = 12544;
- break;
- case 96000:
- *n = 12288;
- break;
- case 176400:
- *n = 25088;
- break;
- case 192000:
- *n = 24576;
- break;
- default:
- return -EINVAL;
- }
- }
- /* Calculate CTS. See HDMI 1.3a or 1.4a specifications */
- *cts = (pclk/1000) * (*n / 128) * deep_color / (sample_freq / 10);
- return 0;
- }
|