0001
0002
0003
0004
0005
0006 #define pr_fmt(fmt) "[drm-dp] %s: " fmt, __func__
0007
0008 #include <linux/delay.h>
0009 #include <linux/iopoll.h>
0010 #include <linux/phy/phy.h>
0011 #include <linux/phy/phy-dp.h>
0012 #include <linux/rational.h>
0013 #include <drm/display/drm_dp_helper.h>
0014 #include <drm/drm_print.h>
0015
0016 #include "dp_catalog.h"
0017 #include "dp_reg.h"
0018
0019 #define POLLING_SLEEP_US 1000
0020 #define POLLING_TIMEOUT_US 10000
0021
0022 #define SCRAMBLER_RESET_COUNT_VALUE 0xFC
0023
0024 #define DP_INTERRUPT_STATUS_ACK_SHIFT 1
0025 #define DP_INTERRUPT_STATUS_MASK_SHIFT 2
0026
0027 #define DP_INTF_CONFIG_DATABUS_WIDEN BIT(4)
0028
0029 #define DP_INTERRUPT_STATUS1 \
0030 (DP_INTR_AUX_I2C_DONE| \
0031 DP_INTR_WRONG_ADDR | DP_INTR_TIMEOUT | \
0032 DP_INTR_NACK_DEFER | DP_INTR_WRONG_DATA_CNT | \
0033 DP_INTR_I2C_NACK | DP_INTR_I2C_DEFER | \
0034 DP_INTR_PLL_UNLOCKED | DP_INTR_AUX_ERROR)
0035
0036 #define DP_INTERRUPT_STATUS1_ACK \
0037 (DP_INTERRUPT_STATUS1 << DP_INTERRUPT_STATUS_ACK_SHIFT)
0038 #define DP_INTERRUPT_STATUS1_MASK \
0039 (DP_INTERRUPT_STATUS1 << DP_INTERRUPT_STATUS_MASK_SHIFT)
0040
0041 #define DP_INTERRUPT_STATUS2 \
0042 (DP_INTR_READY_FOR_VIDEO | DP_INTR_IDLE_PATTERN_SENT | \
0043 DP_INTR_FRAME_END | DP_INTR_CRC_UPDATED)
0044
0045 #define DP_INTERRUPT_STATUS2_ACK \
0046 (DP_INTERRUPT_STATUS2 << DP_INTERRUPT_STATUS_ACK_SHIFT)
0047 #define DP_INTERRUPT_STATUS2_MASK \
0048 (DP_INTERRUPT_STATUS2 << DP_INTERRUPT_STATUS_MASK_SHIFT)
0049
0050 struct dp_catalog_private {
0051 struct device *dev;
0052 struct drm_device *drm_dev;
0053 struct dp_io *io;
0054 u32 (*audio_map)[DP_AUDIO_SDP_HEADER_MAX];
0055 struct dp_catalog dp_catalog;
0056 u8 aux_lut_cfg_index[PHY_AUX_CFG_MAX];
0057 };
0058
0059 void dp_catalog_snapshot(struct dp_catalog *dp_catalog, struct msm_disp_state *disp_state)
0060 {
0061 struct dp_catalog_private *catalog = container_of(dp_catalog,
0062 struct dp_catalog_private, dp_catalog);
0063 struct dss_io_data *dss = &catalog->io->dp_controller;
0064
0065 msm_disp_snapshot_add_block(disp_state, dss->ahb.len, dss->ahb.base, "dp_ahb");
0066 msm_disp_snapshot_add_block(disp_state, dss->aux.len, dss->aux.base, "dp_aux");
0067 msm_disp_snapshot_add_block(disp_state, dss->link.len, dss->link.base, "dp_link");
0068 msm_disp_snapshot_add_block(disp_state, dss->p0.len, dss->p0.base, "dp_p0");
0069 }
0070
0071 static inline u32 dp_read_aux(struct dp_catalog_private *catalog, u32 offset)
0072 {
0073 return readl_relaxed(catalog->io->dp_controller.aux.base + offset);
0074 }
0075
0076 static inline void dp_write_aux(struct dp_catalog_private *catalog,
0077 u32 offset, u32 data)
0078 {
0079
0080
0081
0082
0083 writel(data, catalog->io->dp_controller.aux.base + offset);
0084 }
0085
0086 static inline u32 dp_read_ahb(const struct dp_catalog_private *catalog, u32 offset)
0087 {
0088 return readl_relaxed(catalog->io->dp_controller.ahb.base + offset);
0089 }
0090
0091 static inline void dp_write_ahb(struct dp_catalog_private *catalog,
0092 u32 offset, u32 data)
0093 {
0094
0095
0096
0097
0098 writel(data, catalog->io->dp_controller.ahb.base + offset);
0099 }
0100
0101 static inline void dp_write_p0(struct dp_catalog_private *catalog,
0102 u32 offset, u32 data)
0103 {
0104
0105
0106
0107
0108 writel(data, catalog->io->dp_controller.p0.base + offset);
0109 }
0110
0111 static inline u32 dp_read_p0(struct dp_catalog_private *catalog,
0112 u32 offset)
0113 {
0114
0115
0116
0117
0118 return readl_relaxed(catalog->io->dp_controller.p0.base + offset);
0119 }
0120
0121 static inline u32 dp_read_link(struct dp_catalog_private *catalog, u32 offset)
0122 {
0123 return readl_relaxed(catalog->io->dp_controller.link.base + offset);
0124 }
0125
0126 static inline void dp_write_link(struct dp_catalog_private *catalog,
0127 u32 offset, u32 data)
0128 {
0129
0130
0131
0132
0133 writel(data, catalog->io->dp_controller.link.base + offset);
0134 }
0135
0136
0137 u32 dp_catalog_aux_read_data(struct dp_catalog *dp_catalog)
0138 {
0139 struct dp_catalog_private *catalog = container_of(dp_catalog,
0140 struct dp_catalog_private, dp_catalog);
0141
0142 return dp_read_aux(catalog, REG_DP_AUX_DATA);
0143 }
0144
0145 int dp_catalog_aux_write_data(struct dp_catalog *dp_catalog)
0146 {
0147 struct dp_catalog_private *catalog = container_of(dp_catalog,
0148 struct dp_catalog_private, dp_catalog);
0149
0150 dp_write_aux(catalog, REG_DP_AUX_DATA, dp_catalog->aux_data);
0151 return 0;
0152 }
0153
0154 int dp_catalog_aux_write_trans(struct dp_catalog *dp_catalog)
0155 {
0156 struct dp_catalog_private *catalog = container_of(dp_catalog,
0157 struct dp_catalog_private, dp_catalog);
0158
0159 dp_write_aux(catalog, REG_DP_AUX_TRANS_CTRL, dp_catalog->aux_data);
0160 return 0;
0161 }
0162
0163 int dp_catalog_aux_clear_trans(struct dp_catalog *dp_catalog, bool read)
0164 {
0165 u32 data;
0166 struct dp_catalog_private *catalog = container_of(dp_catalog,
0167 struct dp_catalog_private, dp_catalog);
0168
0169 if (read) {
0170 data = dp_read_aux(catalog, REG_DP_AUX_TRANS_CTRL);
0171 data &= ~DP_AUX_TRANS_CTRL_GO;
0172 dp_write_aux(catalog, REG_DP_AUX_TRANS_CTRL, data);
0173 } else {
0174 dp_write_aux(catalog, REG_DP_AUX_TRANS_CTRL, 0);
0175 }
0176 return 0;
0177 }
0178
0179 int dp_catalog_aux_clear_hw_interrupts(struct dp_catalog *dp_catalog)
0180 {
0181 struct dp_catalog_private *catalog = container_of(dp_catalog,
0182 struct dp_catalog_private, dp_catalog);
0183
0184 dp_read_aux(catalog, REG_DP_PHY_AUX_INTERRUPT_STATUS);
0185 dp_write_aux(catalog, REG_DP_PHY_AUX_INTERRUPT_CLEAR, 0x1f);
0186 dp_write_aux(catalog, REG_DP_PHY_AUX_INTERRUPT_CLEAR, 0x9f);
0187 dp_write_aux(catalog, REG_DP_PHY_AUX_INTERRUPT_CLEAR, 0);
0188 return 0;
0189 }
0190
0191
0192
0193
0194
0195
0196
0197
0198
0199
0200
0201
0202
0203 void dp_catalog_aux_reset(struct dp_catalog *dp_catalog)
0204 {
0205 u32 aux_ctrl;
0206 struct dp_catalog_private *catalog = container_of(dp_catalog,
0207 struct dp_catalog_private, dp_catalog);
0208
0209 aux_ctrl = dp_read_aux(catalog, REG_DP_AUX_CTRL);
0210
0211 aux_ctrl |= DP_AUX_CTRL_RESET;
0212 dp_write_aux(catalog, REG_DP_AUX_CTRL, aux_ctrl);
0213 usleep_range(1000, 1100);
0214
0215 aux_ctrl &= ~DP_AUX_CTRL_RESET;
0216 dp_write_aux(catalog, REG_DP_AUX_CTRL, aux_ctrl);
0217 }
0218
0219 void dp_catalog_aux_enable(struct dp_catalog *dp_catalog, bool enable)
0220 {
0221 u32 aux_ctrl;
0222 struct dp_catalog_private *catalog = container_of(dp_catalog,
0223 struct dp_catalog_private, dp_catalog);
0224
0225 aux_ctrl = dp_read_aux(catalog, REG_DP_AUX_CTRL);
0226
0227 if (enable) {
0228 dp_write_aux(catalog, REG_DP_TIMEOUT_COUNT, 0xffff);
0229 dp_write_aux(catalog, REG_DP_AUX_LIMITS, 0xffff);
0230 aux_ctrl |= DP_AUX_CTRL_ENABLE;
0231 } else {
0232 aux_ctrl &= ~DP_AUX_CTRL_ENABLE;
0233 }
0234
0235 dp_write_aux(catalog, REG_DP_AUX_CTRL, aux_ctrl);
0236 }
0237
0238 void dp_catalog_aux_update_cfg(struct dp_catalog *dp_catalog)
0239 {
0240 struct dp_catalog_private *catalog = container_of(dp_catalog,
0241 struct dp_catalog_private, dp_catalog);
0242 struct dp_io *dp_io = catalog->io;
0243 struct phy *phy = dp_io->phy;
0244
0245 phy_calibrate(phy);
0246 }
0247
0248 int dp_catalog_aux_wait_for_hpd_connect_state(struct dp_catalog *dp_catalog)
0249 {
0250 u32 state;
0251 struct dp_catalog_private *catalog = container_of(dp_catalog,
0252 struct dp_catalog_private, dp_catalog);
0253
0254
0255 return readl_poll_timeout(catalog->io->dp_controller.aux.base +
0256 REG_DP_DP_HPD_INT_STATUS,
0257 state, state & DP_DP_HPD_STATE_STATUS_CONNECTED,
0258 2000, 500000);
0259 }
0260
0261 static void dump_regs(void __iomem *base, int len)
0262 {
0263 int i;
0264 u32 x0, x4, x8, xc;
0265 u32 addr_off = 0;
0266
0267 len = DIV_ROUND_UP(len, 16);
0268 for (i = 0; i < len; i++) {
0269 x0 = readl_relaxed(base + addr_off);
0270 x4 = readl_relaxed(base + addr_off + 0x04);
0271 x8 = readl_relaxed(base + addr_off + 0x08);
0272 xc = readl_relaxed(base + addr_off + 0x0c);
0273
0274 pr_info("%08x: %08x %08x %08x %08x", addr_off, x0, x4, x8, xc);
0275 addr_off += 16;
0276 }
0277 }
0278
0279 void dp_catalog_dump_regs(struct dp_catalog *dp_catalog)
0280 {
0281 struct dp_catalog_private *catalog = container_of(dp_catalog,
0282 struct dp_catalog_private, dp_catalog);
0283 struct dss_io_data *io = &catalog->io->dp_controller;
0284
0285 pr_info("AHB regs\n");
0286 dump_regs(io->ahb.base, io->ahb.len);
0287
0288 pr_info("AUXCLK regs\n");
0289 dump_regs(io->aux.base, io->aux.len);
0290
0291 pr_info("LCLK regs\n");
0292 dump_regs(io->link.base, io->link.len);
0293
0294 pr_info("P0CLK regs\n");
0295 dump_regs(io->p0.base, io->p0.len);
0296 }
0297
0298 u32 dp_catalog_aux_get_irq(struct dp_catalog *dp_catalog)
0299 {
0300 struct dp_catalog_private *catalog = container_of(dp_catalog,
0301 struct dp_catalog_private, dp_catalog);
0302 u32 intr, intr_ack;
0303
0304 intr = dp_read_ahb(catalog, REG_DP_INTR_STATUS);
0305 intr &= ~DP_INTERRUPT_STATUS1_MASK;
0306 intr_ack = (intr & DP_INTERRUPT_STATUS1)
0307 << DP_INTERRUPT_STATUS_ACK_SHIFT;
0308 dp_write_ahb(catalog, REG_DP_INTR_STATUS, intr_ack |
0309 DP_INTERRUPT_STATUS1_MASK);
0310
0311 return intr;
0312
0313 }
0314
0315
0316 void dp_catalog_ctrl_update_transfer_unit(struct dp_catalog *dp_catalog,
0317 u32 dp_tu, u32 valid_boundary,
0318 u32 valid_boundary2)
0319 {
0320 struct dp_catalog_private *catalog = container_of(dp_catalog,
0321 struct dp_catalog_private, dp_catalog);
0322
0323 dp_write_link(catalog, REG_DP_VALID_BOUNDARY, valid_boundary);
0324 dp_write_link(catalog, REG_DP_TU, dp_tu);
0325 dp_write_link(catalog, REG_DP_VALID_BOUNDARY_2, valid_boundary2);
0326 }
0327
0328 void dp_catalog_ctrl_state_ctrl(struct dp_catalog *dp_catalog, u32 state)
0329 {
0330 struct dp_catalog_private *catalog = container_of(dp_catalog,
0331 struct dp_catalog_private, dp_catalog);
0332
0333 dp_write_link(catalog, REG_DP_STATE_CTRL, state);
0334 }
0335
0336 void dp_catalog_ctrl_config_ctrl(struct dp_catalog *dp_catalog, u32 cfg)
0337 {
0338 struct dp_catalog_private *catalog = container_of(dp_catalog,
0339 struct dp_catalog_private, dp_catalog);
0340
0341 drm_dbg_dp(catalog->drm_dev, "DP_CONFIGURATION_CTRL=0x%x\n", cfg);
0342
0343 dp_write_link(catalog, REG_DP_CONFIGURATION_CTRL, cfg);
0344 }
0345
0346 void dp_catalog_ctrl_lane_mapping(struct dp_catalog *dp_catalog)
0347 {
0348 struct dp_catalog_private *catalog = container_of(dp_catalog,
0349 struct dp_catalog_private, dp_catalog);
0350 u32 ln_0 = 0, ln_1 = 1, ln_2 = 2, ln_3 = 3;
0351 u32 ln_mapping;
0352
0353 ln_mapping = ln_0 << LANE0_MAPPING_SHIFT;
0354 ln_mapping |= ln_1 << LANE1_MAPPING_SHIFT;
0355 ln_mapping |= ln_2 << LANE2_MAPPING_SHIFT;
0356 ln_mapping |= ln_3 << LANE3_MAPPING_SHIFT;
0357
0358 dp_write_link(catalog, REG_DP_LOGICAL2PHYSICAL_LANE_MAPPING,
0359 ln_mapping);
0360 }
0361
0362 void dp_catalog_ctrl_mainlink_ctrl(struct dp_catalog *dp_catalog,
0363 bool enable)
0364 {
0365 u32 mainlink_ctrl;
0366 struct dp_catalog_private *catalog = container_of(dp_catalog,
0367 struct dp_catalog_private, dp_catalog);
0368
0369 drm_dbg_dp(catalog->drm_dev, "enable=%d\n", enable);
0370 if (enable) {
0371
0372
0373
0374
0375 mainlink_ctrl = dp_read_link(catalog, REG_DP_MAINLINK_CTRL);
0376
0377 mainlink_ctrl &= ~(DP_MAINLINK_CTRL_RESET |
0378 DP_MAINLINK_CTRL_ENABLE);
0379 dp_write_link(catalog, REG_DP_MAINLINK_CTRL, mainlink_ctrl);
0380
0381 mainlink_ctrl |= DP_MAINLINK_CTRL_RESET;
0382 dp_write_link(catalog, REG_DP_MAINLINK_CTRL, mainlink_ctrl);
0383
0384 mainlink_ctrl &= ~DP_MAINLINK_CTRL_RESET;
0385 dp_write_link(catalog, REG_DP_MAINLINK_CTRL, mainlink_ctrl);
0386
0387 mainlink_ctrl |= (DP_MAINLINK_CTRL_ENABLE |
0388 DP_MAINLINK_FB_BOUNDARY_SEL);
0389 dp_write_link(catalog, REG_DP_MAINLINK_CTRL, mainlink_ctrl);
0390 } else {
0391 mainlink_ctrl = dp_read_link(catalog, REG_DP_MAINLINK_CTRL);
0392 mainlink_ctrl &= ~DP_MAINLINK_CTRL_ENABLE;
0393 dp_write_link(catalog, REG_DP_MAINLINK_CTRL, mainlink_ctrl);
0394 }
0395 }
0396
0397 void dp_catalog_ctrl_config_misc(struct dp_catalog *dp_catalog,
0398 u32 colorimetry_cfg,
0399 u32 test_bits_depth)
0400 {
0401 u32 misc_val;
0402 struct dp_catalog_private *catalog = container_of(dp_catalog,
0403 struct dp_catalog_private, dp_catalog);
0404
0405 misc_val = dp_read_link(catalog, REG_DP_MISC1_MISC0);
0406
0407
0408 misc_val &= ~(0x07 << DP_MISC0_TEST_BITS_DEPTH_SHIFT);
0409 misc_val |= colorimetry_cfg << DP_MISC0_COLORIMETRY_CFG_SHIFT;
0410 misc_val |= test_bits_depth << DP_MISC0_TEST_BITS_DEPTH_SHIFT;
0411
0412 misc_val |= DP_MISC0_SYNCHRONOUS_CLK;
0413
0414 drm_dbg_dp(catalog->drm_dev, "misc settings = 0x%x\n", misc_val);
0415 dp_write_link(catalog, REG_DP_MISC1_MISC0, misc_val);
0416 }
0417
0418 void dp_catalog_ctrl_config_msa(struct dp_catalog *dp_catalog,
0419 u32 rate, u32 stream_rate_khz,
0420 bool fixed_nvid)
0421 {
0422 u32 pixel_m, pixel_n;
0423 u32 mvid, nvid, pixel_div = 0, dispcc_input_rate;
0424 u32 const nvid_fixed = DP_LINK_CONSTANT_N_VALUE;
0425 u32 const link_rate_hbr2 = 540000;
0426 u32 const link_rate_hbr3 = 810000;
0427 unsigned long den, num;
0428
0429 struct dp_catalog_private *catalog = container_of(dp_catalog,
0430 struct dp_catalog_private, dp_catalog);
0431
0432 if (rate == link_rate_hbr3)
0433 pixel_div = 6;
0434 else if (rate == 1620000 || rate == 270000)
0435 pixel_div = 2;
0436 else if (rate == link_rate_hbr2)
0437 pixel_div = 4;
0438 else
0439 DRM_ERROR("Invalid pixel mux divider\n");
0440
0441 dispcc_input_rate = (rate * 10) / pixel_div;
0442
0443 rational_best_approximation(dispcc_input_rate, stream_rate_khz,
0444 (unsigned long)(1 << 16) - 1,
0445 (unsigned long)(1 << 16) - 1, &den, &num);
0446
0447 den = ~(den - num);
0448 den = den & 0xFFFF;
0449 pixel_m = num;
0450 pixel_n = den;
0451
0452 mvid = (pixel_m & 0xFFFF) * 5;
0453 nvid = (0xFFFF & (~pixel_n)) + (pixel_m & 0xFFFF);
0454
0455 if (nvid < nvid_fixed) {
0456 u32 temp;
0457
0458 temp = (nvid_fixed / nvid) * nvid;
0459 mvid = (nvid_fixed / nvid) * mvid;
0460 nvid = temp;
0461 }
0462
0463 if (link_rate_hbr2 == rate)
0464 nvid *= 2;
0465
0466 if (link_rate_hbr3 == rate)
0467 nvid *= 3;
0468
0469 drm_dbg_dp(catalog->drm_dev, "mvid=0x%x, nvid=0x%x\n", mvid, nvid);
0470 dp_write_link(catalog, REG_DP_SOFTWARE_MVID, mvid);
0471 dp_write_link(catalog, REG_DP_SOFTWARE_NVID, nvid);
0472 dp_write_p0(catalog, MMSS_DP_DSC_DTO, 0x0);
0473 }
0474
0475 int dp_catalog_ctrl_set_pattern_state_bit(struct dp_catalog *dp_catalog,
0476 u32 state_bit)
0477 {
0478 int bit, ret;
0479 u32 data;
0480 struct dp_catalog_private *catalog = container_of(dp_catalog,
0481 struct dp_catalog_private, dp_catalog);
0482
0483 bit = BIT(state_bit - 1);
0484 drm_dbg_dp(catalog->drm_dev, "hw: bit=%d train=%d\n", bit, state_bit);
0485 dp_catalog_ctrl_state_ctrl(dp_catalog, bit);
0486
0487 bit = BIT(state_bit - 1) << DP_MAINLINK_READY_LINK_TRAINING_SHIFT;
0488
0489
0490 ret = readx_poll_timeout(readl, catalog->io->dp_controller.link.base +
0491 REG_DP_MAINLINK_READY,
0492 data, data & bit,
0493 POLLING_SLEEP_US, POLLING_TIMEOUT_US);
0494 if (ret < 0) {
0495 DRM_ERROR("set state_bit for link_train=%d failed\n", state_bit);
0496 return ret;
0497 }
0498 return 0;
0499 }
0500
0501
0502
0503
0504
0505
0506
0507
0508
0509 u32 dp_catalog_hw_revision(const struct dp_catalog *dp_catalog)
0510 {
0511 const struct dp_catalog_private *catalog = container_of(dp_catalog,
0512 struct dp_catalog_private, dp_catalog);
0513
0514 return dp_read_ahb(catalog, REG_DP_HW_VERSION);
0515 }
0516
0517
0518
0519
0520
0521
0522
0523
0524
0525
0526
0527
0528
0529 void dp_catalog_ctrl_reset(struct dp_catalog *dp_catalog)
0530 {
0531 u32 sw_reset;
0532 struct dp_catalog_private *catalog = container_of(dp_catalog,
0533 struct dp_catalog_private, dp_catalog);
0534
0535 sw_reset = dp_read_ahb(catalog, REG_DP_SW_RESET);
0536
0537 sw_reset |= DP_SW_RESET;
0538 dp_write_ahb(catalog, REG_DP_SW_RESET, sw_reset);
0539 usleep_range(1000, 1100);
0540
0541 sw_reset &= ~DP_SW_RESET;
0542 dp_write_ahb(catalog, REG_DP_SW_RESET, sw_reset);
0543 }
0544
0545 bool dp_catalog_ctrl_mainlink_ready(struct dp_catalog *dp_catalog)
0546 {
0547 u32 data;
0548 int ret;
0549 struct dp_catalog_private *catalog = container_of(dp_catalog,
0550 struct dp_catalog_private, dp_catalog);
0551
0552
0553 ret = readl_poll_timeout(catalog->io->dp_controller.link.base +
0554 REG_DP_MAINLINK_READY,
0555 data, data & DP_MAINLINK_READY_FOR_VIDEO,
0556 POLLING_SLEEP_US, POLLING_TIMEOUT_US);
0557 if (ret < 0) {
0558 DRM_ERROR("mainlink not ready\n");
0559 return false;
0560 }
0561
0562 return true;
0563 }
0564
0565 void dp_catalog_ctrl_enable_irq(struct dp_catalog *dp_catalog,
0566 bool enable)
0567 {
0568 struct dp_catalog_private *catalog = container_of(dp_catalog,
0569 struct dp_catalog_private, dp_catalog);
0570
0571 if (enable) {
0572 dp_write_ahb(catalog, REG_DP_INTR_STATUS,
0573 DP_INTERRUPT_STATUS1_MASK);
0574 dp_write_ahb(catalog, REG_DP_INTR_STATUS2,
0575 DP_INTERRUPT_STATUS2_MASK);
0576 } else {
0577 dp_write_ahb(catalog, REG_DP_INTR_STATUS, 0x00);
0578 dp_write_ahb(catalog, REG_DP_INTR_STATUS2, 0x00);
0579 }
0580 }
0581
0582 void dp_catalog_hpd_config_intr(struct dp_catalog *dp_catalog,
0583 u32 intr_mask, bool en)
0584 {
0585 struct dp_catalog_private *catalog = container_of(dp_catalog,
0586 struct dp_catalog_private, dp_catalog);
0587
0588 u32 config = dp_read_aux(catalog, REG_DP_DP_HPD_INT_MASK);
0589
0590 config = (en ? config | intr_mask : config & ~intr_mask);
0591
0592 drm_dbg_dp(catalog->drm_dev, "intr_mask=%#x config=%#x\n",
0593 intr_mask, config);
0594 dp_write_aux(catalog, REG_DP_DP_HPD_INT_MASK,
0595 config & DP_DP_HPD_INT_MASK);
0596 }
0597
0598 void dp_catalog_ctrl_hpd_config(struct dp_catalog *dp_catalog)
0599 {
0600 struct dp_catalog_private *catalog = container_of(dp_catalog,
0601 struct dp_catalog_private, dp_catalog);
0602
0603 u32 reftimer = dp_read_aux(catalog, REG_DP_DP_HPD_REFTIMER);
0604
0605
0606 reftimer |= DP_DP_HPD_REFTIMER_ENABLE;
0607 dp_write_aux(catalog, REG_DP_DP_HPD_REFTIMER, reftimer);
0608
0609
0610 dp_write_aux(catalog, REG_DP_DP_HPD_CTRL, DP_DP_HPD_CTRL_HPD_EN);
0611 }
0612
0613 u32 dp_catalog_link_is_connected(struct dp_catalog *dp_catalog)
0614 {
0615 struct dp_catalog_private *catalog = container_of(dp_catalog,
0616 struct dp_catalog_private, dp_catalog);
0617 u32 status;
0618
0619 status = dp_read_aux(catalog, REG_DP_DP_HPD_INT_STATUS);
0620 drm_dbg_dp(catalog->drm_dev, "aux status: %#x\n", status);
0621 status >>= DP_DP_HPD_STATE_STATUS_BITS_SHIFT;
0622 status &= DP_DP_HPD_STATE_STATUS_BITS_MASK;
0623
0624 return status;
0625 }
0626
0627 u32 dp_catalog_hpd_get_intr_status(struct dp_catalog *dp_catalog)
0628 {
0629 struct dp_catalog_private *catalog = container_of(dp_catalog,
0630 struct dp_catalog_private, dp_catalog);
0631 int isr, mask;
0632
0633 isr = dp_read_aux(catalog, REG_DP_DP_HPD_INT_STATUS);
0634 dp_write_aux(catalog, REG_DP_DP_HPD_INT_ACK,
0635 (isr & DP_DP_HPD_INT_MASK));
0636 mask = dp_read_aux(catalog, REG_DP_DP_HPD_INT_MASK);
0637
0638
0639
0640
0641
0642
0643
0644
0645 return isr & (mask | ~DP_DP_HPD_INT_MASK);
0646 }
0647
0648 int dp_catalog_ctrl_get_interrupt(struct dp_catalog *dp_catalog)
0649 {
0650 struct dp_catalog_private *catalog = container_of(dp_catalog,
0651 struct dp_catalog_private, dp_catalog);
0652 u32 intr, intr_ack;
0653
0654 intr = dp_read_ahb(catalog, REG_DP_INTR_STATUS2);
0655 intr &= ~DP_INTERRUPT_STATUS2_MASK;
0656 intr_ack = (intr & DP_INTERRUPT_STATUS2)
0657 << DP_INTERRUPT_STATUS_ACK_SHIFT;
0658 dp_write_ahb(catalog, REG_DP_INTR_STATUS2,
0659 intr_ack | DP_INTERRUPT_STATUS2_MASK);
0660
0661 return intr;
0662 }
0663
0664 void dp_catalog_ctrl_phy_reset(struct dp_catalog *dp_catalog)
0665 {
0666 struct dp_catalog_private *catalog = container_of(dp_catalog,
0667 struct dp_catalog_private, dp_catalog);
0668
0669 dp_write_ahb(catalog, REG_DP_PHY_CTRL,
0670 DP_PHY_CTRL_SW_RESET | DP_PHY_CTRL_SW_RESET_PLL);
0671 usleep_range(1000, 1100);
0672 dp_write_ahb(catalog, REG_DP_PHY_CTRL, 0x0);
0673 }
0674
0675 int dp_catalog_ctrl_update_vx_px(struct dp_catalog *dp_catalog,
0676 u8 v_level, u8 p_level)
0677 {
0678 struct dp_catalog_private *catalog = container_of(dp_catalog,
0679 struct dp_catalog_private, dp_catalog);
0680 struct dp_io *dp_io = catalog->io;
0681 struct phy *phy = dp_io->phy;
0682 struct phy_configure_opts_dp *opts_dp = &dp_io->phy_opts.dp;
0683
0684
0685 opts_dp->voltage[0] = v_level;
0686 opts_dp->pre[0] = p_level;
0687 opts_dp->set_voltages = 1;
0688 phy_configure(phy, &dp_io->phy_opts);
0689 opts_dp->set_voltages = 0;
0690
0691 return 0;
0692 }
0693
0694 void dp_catalog_ctrl_send_phy_pattern(struct dp_catalog *dp_catalog,
0695 u32 pattern)
0696 {
0697 struct dp_catalog_private *catalog = container_of(dp_catalog,
0698 struct dp_catalog_private, dp_catalog);
0699 u32 value = 0x0;
0700
0701
0702 dp_write_link(catalog, REG_DP_STATE_CTRL, 0x0);
0703
0704 drm_dbg_dp(catalog->drm_dev, "pattern: %#x\n", pattern);
0705 switch (pattern) {
0706 case DP_PHY_TEST_PATTERN_D10_2:
0707 dp_write_link(catalog, REG_DP_STATE_CTRL,
0708 DP_STATE_CTRL_LINK_TRAINING_PATTERN1);
0709 break;
0710 case DP_PHY_TEST_PATTERN_ERROR_COUNT:
0711 value &= ~(1 << 16);
0712 dp_write_link(catalog, REG_DP_HBR2_COMPLIANCE_SCRAMBLER_RESET,
0713 value);
0714 value |= SCRAMBLER_RESET_COUNT_VALUE;
0715 dp_write_link(catalog, REG_DP_HBR2_COMPLIANCE_SCRAMBLER_RESET,
0716 value);
0717 dp_write_link(catalog, REG_DP_MAINLINK_LEVELS,
0718 DP_MAINLINK_SAFE_TO_EXIT_LEVEL_2);
0719 dp_write_link(catalog, REG_DP_STATE_CTRL,
0720 DP_STATE_CTRL_LINK_SYMBOL_ERR_MEASURE);
0721 break;
0722 case DP_PHY_TEST_PATTERN_PRBS7:
0723 dp_write_link(catalog, REG_DP_STATE_CTRL,
0724 DP_STATE_CTRL_LINK_PRBS7);
0725 break;
0726 case DP_PHY_TEST_PATTERN_80BIT_CUSTOM:
0727 dp_write_link(catalog, REG_DP_STATE_CTRL,
0728 DP_STATE_CTRL_LINK_TEST_CUSTOM_PATTERN);
0729
0730 dp_write_link(catalog, REG_DP_TEST_80BIT_CUSTOM_PATTERN_REG0,
0731 0x3E0F83E0);
0732
0733 dp_write_link(catalog, REG_DP_TEST_80BIT_CUSTOM_PATTERN_REG1,
0734 0x0F83E0F8);
0735
0736 dp_write_link(catalog, REG_DP_TEST_80BIT_CUSTOM_PATTERN_REG2,
0737 0x0000F83E);
0738 break;
0739 case DP_PHY_TEST_PATTERN_CP2520:
0740 value = dp_read_link(catalog, REG_DP_MAINLINK_CTRL);
0741 value &= ~DP_MAINLINK_CTRL_SW_BYPASS_SCRAMBLER;
0742 dp_write_link(catalog, REG_DP_MAINLINK_CTRL, value);
0743
0744 value = DP_HBR2_ERM_PATTERN;
0745 dp_write_link(catalog, REG_DP_HBR2_COMPLIANCE_SCRAMBLER_RESET,
0746 value);
0747 value |= SCRAMBLER_RESET_COUNT_VALUE;
0748 dp_write_link(catalog, REG_DP_HBR2_COMPLIANCE_SCRAMBLER_RESET,
0749 value);
0750 dp_write_link(catalog, REG_DP_MAINLINK_LEVELS,
0751 DP_MAINLINK_SAFE_TO_EXIT_LEVEL_2);
0752 dp_write_link(catalog, REG_DP_STATE_CTRL,
0753 DP_STATE_CTRL_LINK_SYMBOL_ERR_MEASURE);
0754 value = dp_read_link(catalog, REG_DP_MAINLINK_CTRL);
0755 value |= DP_MAINLINK_CTRL_ENABLE;
0756 dp_write_link(catalog, REG_DP_MAINLINK_CTRL, value);
0757 break;
0758 case DP_PHY_TEST_PATTERN_SEL_MASK:
0759 dp_write_link(catalog, REG_DP_MAINLINK_CTRL,
0760 DP_MAINLINK_CTRL_ENABLE);
0761 dp_write_link(catalog, REG_DP_STATE_CTRL,
0762 DP_STATE_CTRL_LINK_TRAINING_PATTERN4);
0763 break;
0764 default:
0765 drm_dbg_dp(catalog->drm_dev,
0766 "No valid test pattern requested: %#x\n", pattern);
0767 break;
0768 }
0769 }
0770
0771 u32 dp_catalog_ctrl_read_phy_pattern(struct dp_catalog *dp_catalog)
0772 {
0773 struct dp_catalog_private *catalog = container_of(dp_catalog,
0774 struct dp_catalog_private, dp_catalog);
0775
0776 return dp_read_link(catalog, REG_DP_MAINLINK_READY);
0777 }
0778
0779
0780 int dp_catalog_panel_timing_cfg(struct dp_catalog *dp_catalog)
0781 {
0782 struct dp_catalog_private *catalog = container_of(dp_catalog,
0783 struct dp_catalog_private, dp_catalog);
0784 u32 reg;
0785
0786 dp_write_link(catalog, REG_DP_TOTAL_HOR_VER,
0787 dp_catalog->total);
0788 dp_write_link(catalog, REG_DP_START_HOR_VER_FROM_SYNC,
0789 dp_catalog->sync_start);
0790 dp_write_link(catalog, REG_DP_HSYNC_VSYNC_WIDTH_POLARITY,
0791 dp_catalog->width_blanking);
0792 dp_write_link(catalog, REG_DP_ACTIVE_HOR_VER, dp_catalog->dp_active);
0793
0794 reg = dp_read_p0(catalog, MMSS_DP_INTF_CONFIG);
0795
0796 if (dp_catalog->wide_bus_en)
0797 reg |= DP_INTF_CONFIG_DATABUS_WIDEN;
0798 else
0799 reg &= ~DP_INTF_CONFIG_DATABUS_WIDEN;
0800
0801
0802 DRM_DEBUG_DP("wide_bus_en=%d reg=%#x\n", dp_catalog->wide_bus_en, reg);
0803
0804 dp_write_p0(catalog, MMSS_DP_INTF_CONFIG, reg);
0805 return 0;
0806 }
0807
0808 void dp_catalog_panel_tpg_enable(struct dp_catalog *dp_catalog,
0809 struct drm_display_mode *drm_mode)
0810 {
0811 struct dp_catalog_private *catalog = container_of(dp_catalog,
0812 struct dp_catalog_private, dp_catalog);
0813 u32 hsync_period, vsync_period;
0814 u32 display_v_start, display_v_end;
0815 u32 hsync_start_x, hsync_end_x;
0816 u32 v_sync_width;
0817 u32 hsync_ctl;
0818 u32 display_hctl;
0819
0820
0821 hsync_period = drm_mode->htotal;
0822 vsync_period = drm_mode->vtotal;
0823
0824 display_v_start = ((drm_mode->vtotal - drm_mode->vsync_start) *
0825 hsync_period);
0826 display_v_end = ((vsync_period - (drm_mode->vsync_start -
0827 drm_mode->vdisplay))
0828 * hsync_period) - 1;
0829
0830 display_v_start += drm_mode->htotal - drm_mode->hsync_start;
0831 display_v_end -= (drm_mode->hsync_start - drm_mode->hdisplay);
0832
0833 hsync_start_x = drm_mode->htotal - drm_mode->hsync_start;
0834 hsync_end_x = hsync_period - (drm_mode->hsync_start -
0835 drm_mode->hdisplay) - 1;
0836
0837 v_sync_width = drm_mode->vsync_end - drm_mode->vsync_start;
0838
0839 hsync_ctl = (hsync_period << 16) |
0840 (drm_mode->hsync_end - drm_mode->hsync_start);
0841 display_hctl = (hsync_end_x << 16) | hsync_start_x;
0842
0843
0844 dp_write_p0(catalog, MMSS_DP_INTF_CONFIG, 0x0);
0845 dp_write_p0(catalog, MMSS_DP_INTF_HSYNC_CTL, hsync_ctl);
0846 dp_write_p0(catalog, MMSS_DP_INTF_VSYNC_PERIOD_F0, vsync_period *
0847 hsync_period);
0848 dp_write_p0(catalog, MMSS_DP_INTF_VSYNC_PULSE_WIDTH_F0, v_sync_width *
0849 hsync_period);
0850 dp_write_p0(catalog, MMSS_DP_INTF_VSYNC_PERIOD_F1, 0);
0851 dp_write_p0(catalog, MMSS_DP_INTF_VSYNC_PULSE_WIDTH_F1, 0);
0852 dp_write_p0(catalog, MMSS_DP_INTF_DISPLAY_HCTL, display_hctl);
0853 dp_write_p0(catalog, MMSS_DP_INTF_ACTIVE_HCTL, 0);
0854 dp_write_p0(catalog, MMSS_INTF_DISPLAY_V_START_F0, display_v_start);
0855 dp_write_p0(catalog, MMSS_DP_INTF_DISPLAY_V_END_F0, display_v_end);
0856 dp_write_p0(catalog, MMSS_INTF_DISPLAY_V_START_F1, 0);
0857 dp_write_p0(catalog, MMSS_DP_INTF_DISPLAY_V_END_F1, 0);
0858 dp_write_p0(catalog, MMSS_DP_INTF_ACTIVE_V_START_F0, 0);
0859 dp_write_p0(catalog, MMSS_DP_INTF_ACTIVE_V_END_F0, 0);
0860 dp_write_p0(catalog, MMSS_DP_INTF_ACTIVE_V_START_F1, 0);
0861 dp_write_p0(catalog, MMSS_DP_INTF_ACTIVE_V_END_F1, 0);
0862 dp_write_p0(catalog, MMSS_DP_INTF_POLARITY_CTL, 0);
0863
0864 dp_write_p0(catalog, MMSS_DP_TPG_MAIN_CONTROL,
0865 DP_TPG_CHECKERED_RECT_PATTERN);
0866 dp_write_p0(catalog, MMSS_DP_TPG_VIDEO_CONFIG,
0867 DP_TPG_VIDEO_CONFIG_BPP_8BIT |
0868 DP_TPG_VIDEO_CONFIG_RGB);
0869 dp_write_p0(catalog, MMSS_DP_BIST_ENABLE,
0870 DP_BIST_ENABLE_DPBIST_EN);
0871 dp_write_p0(catalog, MMSS_DP_TIMING_ENGINE_EN,
0872 DP_TIMING_ENGINE_EN_EN);
0873 drm_dbg_dp(catalog->drm_dev, "%s: enabled tpg\n", __func__);
0874 }
0875
0876 void dp_catalog_panel_tpg_disable(struct dp_catalog *dp_catalog)
0877 {
0878 struct dp_catalog_private *catalog = container_of(dp_catalog,
0879 struct dp_catalog_private, dp_catalog);
0880
0881 dp_write_p0(catalog, MMSS_DP_TPG_MAIN_CONTROL, 0x0);
0882 dp_write_p0(catalog, MMSS_DP_BIST_ENABLE, 0x0);
0883 dp_write_p0(catalog, MMSS_DP_TIMING_ENGINE_EN, 0x0);
0884 }
0885
0886 struct dp_catalog *dp_catalog_get(struct device *dev, struct dp_io *io)
0887 {
0888 struct dp_catalog_private *catalog;
0889
0890 if (!io) {
0891 DRM_ERROR("invalid input\n");
0892 return ERR_PTR(-EINVAL);
0893 }
0894
0895 catalog = devm_kzalloc(dev, sizeof(*catalog), GFP_KERNEL);
0896 if (!catalog)
0897 return ERR_PTR(-ENOMEM);
0898
0899 catalog->dev = dev;
0900 catalog->io = io;
0901
0902 return &catalog->dp_catalog;
0903 }
0904
0905 void dp_catalog_audio_get_header(struct dp_catalog *dp_catalog)
0906 {
0907 struct dp_catalog_private *catalog;
0908 u32 (*sdp_map)[DP_AUDIO_SDP_HEADER_MAX];
0909 enum dp_catalog_audio_sdp_type sdp;
0910 enum dp_catalog_audio_header_type header;
0911
0912 if (!dp_catalog)
0913 return;
0914
0915 catalog = container_of(dp_catalog,
0916 struct dp_catalog_private, dp_catalog);
0917
0918 sdp_map = catalog->audio_map;
0919 sdp = dp_catalog->sdp_type;
0920 header = dp_catalog->sdp_header;
0921
0922 dp_catalog->audio_data = dp_read_link(catalog,
0923 sdp_map[sdp][header]);
0924 }
0925
0926 void dp_catalog_audio_set_header(struct dp_catalog *dp_catalog)
0927 {
0928 struct dp_catalog_private *catalog;
0929 u32 (*sdp_map)[DP_AUDIO_SDP_HEADER_MAX];
0930 enum dp_catalog_audio_sdp_type sdp;
0931 enum dp_catalog_audio_header_type header;
0932 u32 data;
0933
0934 if (!dp_catalog)
0935 return;
0936
0937 catalog = container_of(dp_catalog,
0938 struct dp_catalog_private, dp_catalog);
0939
0940 sdp_map = catalog->audio_map;
0941 sdp = dp_catalog->sdp_type;
0942 header = dp_catalog->sdp_header;
0943 data = dp_catalog->audio_data;
0944
0945 dp_write_link(catalog, sdp_map[sdp][header], data);
0946 }
0947
0948 void dp_catalog_audio_config_acr(struct dp_catalog *dp_catalog)
0949 {
0950 struct dp_catalog_private *catalog;
0951 u32 acr_ctrl, select;
0952
0953 if (!dp_catalog)
0954 return;
0955
0956 catalog = container_of(dp_catalog,
0957 struct dp_catalog_private, dp_catalog);
0958
0959 select = dp_catalog->audio_data;
0960 acr_ctrl = select << 4 | BIT(31) | BIT(8) | BIT(14);
0961
0962 drm_dbg_dp(catalog->drm_dev, "select: %#x, acr_ctrl: %#x\n",
0963 select, acr_ctrl);
0964
0965 dp_write_link(catalog, MMSS_DP_AUDIO_ACR_CTRL, acr_ctrl);
0966 }
0967
0968 void dp_catalog_audio_enable(struct dp_catalog *dp_catalog)
0969 {
0970 struct dp_catalog_private *catalog;
0971 bool enable;
0972 u32 audio_ctrl;
0973
0974 if (!dp_catalog)
0975 return;
0976
0977 catalog = container_of(dp_catalog,
0978 struct dp_catalog_private, dp_catalog);
0979
0980 enable = !!dp_catalog->audio_data;
0981 audio_ctrl = dp_read_link(catalog, MMSS_DP_AUDIO_CFG);
0982
0983 if (enable)
0984 audio_ctrl |= BIT(0);
0985 else
0986 audio_ctrl &= ~BIT(0);
0987
0988 drm_dbg_dp(catalog->drm_dev, "dp_audio_cfg = 0x%x\n", audio_ctrl);
0989
0990 dp_write_link(catalog, MMSS_DP_AUDIO_CFG, audio_ctrl);
0991
0992 wmb();
0993 }
0994
0995 void dp_catalog_audio_config_sdp(struct dp_catalog *dp_catalog)
0996 {
0997 struct dp_catalog_private *catalog;
0998 u32 sdp_cfg = 0;
0999 u32 sdp_cfg2 = 0;
1000
1001 if (!dp_catalog)
1002 return;
1003
1004 catalog = container_of(dp_catalog,
1005 struct dp_catalog_private, dp_catalog);
1006
1007 sdp_cfg = dp_read_link(catalog, MMSS_DP_SDP_CFG);
1008
1009 sdp_cfg |= BIT(1);
1010
1011 sdp_cfg |= BIT(2);
1012
1013 sdp_cfg |= BIT(5);
1014
1015 sdp_cfg |= BIT(6);
1016
1017 sdp_cfg |= BIT(20);
1018
1019 drm_dbg_dp(catalog->drm_dev, "sdp_cfg = 0x%x\n", sdp_cfg);
1020
1021 dp_write_link(catalog, MMSS_DP_SDP_CFG, sdp_cfg);
1022
1023 sdp_cfg2 = dp_read_link(catalog, MMSS_DP_SDP_CFG2);
1024
1025 sdp_cfg2 &= ~BIT(0);
1026
1027 sdp_cfg2 &= ~BIT(1);
1028
1029 drm_dbg_dp(catalog->drm_dev, "sdp_cfg2 = 0x%x\n", sdp_cfg2);
1030
1031 dp_write_link(catalog, MMSS_DP_SDP_CFG2, sdp_cfg2);
1032 }
1033
1034 void dp_catalog_audio_init(struct dp_catalog *dp_catalog)
1035 {
1036 struct dp_catalog_private *catalog;
1037
1038 static u32 sdp_map[][DP_AUDIO_SDP_HEADER_MAX] = {
1039 {
1040 MMSS_DP_AUDIO_STREAM_0,
1041 MMSS_DP_AUDIO_STREAM_1,
1042 MMSS_DP_AUDIO_STREAM_1,
1043 },
1044 {
1045 MMSS_DP_AUDIO_TIMESTAMP_0,
1046 MMSS_DP_AUDIO_TIMESTAMP_1,
1047 MMSS_DP_AUDIO_TIMESTAMP_1,
1048 },
1049 {
1050 MMSS_DP_AUDIO_INFOFRAME_0,
1051 MMSS_DP_AUDIO_INFOFRAME_1,
1052 MMSS_DP_AUDIO_INFOFRAME_1,
1053 },
1054 {
1055 MMSS_DP_AUDIO_COPYMANAGEMENT_0,
1056 MMSS_DP_AUDIO_COPYMANAGEMENT_1,
1057 MMSS_DP_AUDIO_COPYMANAGEMENT_1,
1058 },
1059 {
1060 MMSS_DP_AUDIO_ISRC_0,
1061 MMSS_DP_AUDIO_ISRC_1,
1062 MMSS_DP_AUDIO_ISRC_1,
1063 },
1064 };
1065
1066 if (!dp_catalog)
1067 return;
1068
1069 catalog = container_of(dp_catalog,
1070 struct dp_catalog_private, dp_catalog);
1071
1072 catalog->audio_map = sdp_map;
1073 }
1074
1075 void dp_catalog_audio_sfe_level(struct dp_catalog *dp_catalog)
1076 {
1077 struct dp_catalog_private *catalog;
1078 u32 mainlink_levels, safe_to_exit_level;
1079
1080 if (!dp_catalog)
1081 return;
1082
1083 catalog = container_of(dp_catalog,
1084 struct dp_catalog_private, dp_catalog);
1085
1086 safe_to_exit_level = dp_catalog->audio_data;
1087 mainlink_levels = dp_read_link(catalog, REG_DP_MAINLINK_LEVELS);
1088 mainlink_levels &= 0xFE0;
1089 mainlink_levels |= safe_to_exit_level;
1090
1091 drm_dbg_dp(catalog->drm_dev,
1092 "mainlink_level = 0x%x, safe_to_exit_level = 0x%x\n",
1093 mainlink_levels, safe_to_exit_level);
1094
1095 dp_write_link(catalog, REG_DP_MAINLINK_LEVELS, mainlink_levels);
1096 }