radeon_dp_mst.c 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802
  1. #include <drm/drmP.h>
  2. #include <drm/drm_dp_mst_helper.h>
  3. #include <drm/drm_fb_helper.h>
  4. #include "radeon.h"
  5. #include "atom.h"
  6. #include "ni_reg.h"
  7. static struct radeon_encoder *radeon_dp_create_fake_mst_encoder(struct radeon_connector *connector);
  8. static int radeon_atom_set_enc_offset(int id)
  9. {
  10. static const int offsets[] = { EVERGREEN_CRTC0_REGISTER_OFFSET,
  11. EVERGREEN_CRTC1_REGISTER_OFFSET,
  12. EVERGREEN_CRTC2_REGISTER_OFFSET,
  13. EVERGREEN_CRTC3_REGISTER_OFFSET,
  14. EVERGREEN_CRTC4_REGISTER_OFFSET,
  15. EVERGREEN_CRTC5_REGISTER_OFFSET,
  16. 0x13830 - 0x7030 };
  17. return offsets[id];
  18. }
  19. static int radeon_dp_mst_set_be_cntl(struct radeon_encoder *primary,
  20. struct radeon_encoder_mst *mst_enc,
  21. enum radeon_hpd_id hpd, bool enable)
  22. {
  23. struct drm_device *dev = primary->base.dev;
  24. struct radeon_device *rdev = dev->dev_private;
  25. uint32_t reg;
  26. int retries = 0;
  27. uint32_t temp;
  28. reg = RREG32(NI_DIG_BE_CNTL + primary->offset);
  29. /* set MST mode */
  30. reg &= ~NI_DIG_FE_DIG_MODE(7);
  31. reg |= NI_DIG_FE_DIG_MODE(NI_DIG_MODE_DP_MST);
  32. if (enable)
  33. reg |= NI_DIG_FE_SOURCE_SELECT(1 << mst_enc->fe);
  34. else
  35. reg &= ~NI_DIG_FE_SOURCE_SELECT(1 << mst_enc->fe);
  36. reg |= NI_DIG_HPD_SELECT(hpd);
  37. DRM_DEBUG_KMS("writing 0x%08x 0x%08x\n", NI_DIG_BE_CNTL + primary->offset, reg);
  38. WREG32(NI_DIG_BE_CNTL + primary->offset, reg);
  39. if (enable) {
  40. uint32_t offset = radeon_atom_set_enc_offset(mst_enc->fe);
  41. do {
  42. temp = RREG32(NI_DIG_FE_CNTL + offset);
  43. } while ((temp & NI_DIG_SYMCLK_FE_ON) && retries++ < 10000);
  44. if (retries == 10000)
  45. DRM_ERROR("timed out waiting for FE %d %d\n", primary->offset, mst_enc->fe);
  46. }
  47. return 0;
  48. }
  49. static int radeon_dp_mst_set_stream_attrib(struct radeon_encoder *primary,
  50. int stream_number,
  51. int fe,
  52. int slots)
  53. {
  54. struct drm_device *dev = primary->base.dev;
  55. struct radeon_device *rdev = dev->dev_private;
  56. u32 temp, val;
  57. int retries = 0;
  58. int satreg, satidx;
  59. satreg = stream_number >> 1;
  60. satidx = stream_number & 1;
  61. temp = RREG32(NI_DP_MSE_SAT0 + satreg + primary->offset);
  62. val = NI_DP_MSE_SAT_SLOT_COUNT0(slots) | NI_DP_MSE_SAT_SRC0(fe);
  63. val <<= (16 * satidx);
  64. temp &= ~(0xffff << (16 * satidx));
  65. temp |= val;
  66. DRM_DEBUG_KMS("writing 0x%08x 0x%08x\n", NI_DP_MSE_SAT0 + satreg + primary->offset, temp);
  67. WREG32(NI_DP_MSE_SAT0 + satreg + primary->offset, temp);
  68. WREG32(NI_DP_MSE_SAT_UPDATE + primary->offset, 1);
  69. do {
  70. unsigned value1, value2;
  71. udelay(10);
  72. temp = RREG32(NI_DP_MSE_SAT_UPDATE + primary->offset);
  73. value1 = temp & NI_DP_MSE_SAT_UPDATE_MASK;
  74. value2 = temp & NI_DP_MSE_16_MTP_KEEPOUT;
  75. if (!value1 && !value2)
  76. break;
  77. } while (retries++ < 50);
  78. if (retries == 10000)
  79. DRM_ERROR("timed out waitin for SAT update %d\n", primary->offset);
  80. /* MTP 16 ? */
  81. return 0;
  82. }
  83. static int radeon_dp_mst_update_stream_attribs(struct radeon_connector *mst_conn,
  84. struct radeon_encoder *primary)
  85. {
  86. struct drm_device *dev = mst_conn->base.dev;
  87. struct stream_attribs new_attribs[6];
  88. int i;
  89. int idx = 0;
  90. struct radeon_connector *radeon_connector;
  91. struct drm_connector *connector;
  92. memset(new_attribs, 0, sizeof(new_attribs));
  93. list_for_each_entry(connector, &dev->mode_config.connector_list, head) {
  94. struct radeon_encoder *subenc;
  95. struct radeon_encoder_mst *mst_enc;
  96. radeon_connector = to_radeon_connector(connector);
  97. if (!radeon_connector->is_mst_connector)
  98. continue;
  99. if (radeon_connector->mst_port != mst_conn)
  100. continue;
  101. subenc = radeon_connector->mst_encoder;
  102. mst_enc = subenc->enc_priv;
  103. if (!mst_enc->enc_active)
  104. continue;
  105. new_attribs[idx].fe = mst_enc->fe;
  106. new_attribs[idx].slots = drm_dp_mst_get_vcpi_slots(&mst_conn->mst_mgr, mst_enc->port);
  107. idx++;
  108. }
  109. for (i = 0; i < idx; i++) {
  110. if (new_attribs[i].fe != mst_conn->cur_stream_attribs[i].fe ||
  111. new_attribs[i].slots != mst_conn->cur_stream_attribs[i].slots) {
  112. radeon_dp_mst_set_stream_attrib(primary, i, new_attribs[i].fe, new_attribs[i].slots);
  113. mst_conn->cur_stream_attribs[i].fe = new_attribs[i].fe;
  114. mst_conn->cur_stream_attribs[i].slots = new_attribs[i].slots;
  115. }
  116. }
  117. for (i = idx; i < mst_conn->enabled_attribs; i++) {
  118. radeon_dp_mst_set_stream_attrib(primary, i, 0, 0);
  119. mst_conn->cur_stream_attribs[i].fe = 0;
  120. mst_conn->cur_stream_attribs[i].slots = 0;
  121. }
  122. mst_conn->enabled_attribs = idx;
  123. return 0;
  124. }
  125. static int radeon_dp_mst_set_vcp_size(struct radeon_encoder *mst, s64 avg_time_slots_per_mtp)
  126. {
  127. struct drm_device *dev = mst->base.dev;
  128. struct radeon_device *rdev = dev->dev_private;
  129. struct radeon_encoder_mst *mst_enc = mst->enc_priv;
  130. uint32_t val, temp;
  131. uint32_t offset = radeon_atom_set_enc_offset(mst_enc->fe);
  132. int retries = 0;
  133. uint32_t x = drm_fixp2int(avg_time_slots_per_mtp);
  134. uint32_t y = drm_fixp2int_ceil((avg_time_slots_per_mtp - x) << 26);
  135. val = NI_DP_MSE_RATE_X(x) | NI_DP_MSE_RATE_Y(y);
  136. WREG32(NI_DP_MSE_RATE_CNTL + offset, val);
  137. do {
  138. temp = RREG32(NI_DP_MSE_RATE_UPDATE + offset);
  139. udelay(10);
  140. } while ((temp & 0x1) && (retries++ < 10000));
  141. if (retries >= 10000)
  142. DRM_ERROR("timed out wait for rate cntl %d\n", mst_enc->fe);
  143. return 0;
  144. }
  145. static int radeon_dp_mst_get_ddc_modes(struct drm_connector *connector)
  146. {
  147. struct radeon_connector *radeon_connector = to_radeon_connector(connector);
  148. struct radeon_connector *master = radeon_connector->mst_port;
  149. struct edid *edid;
  150. int ret = 0;
  151. edid = drm_dp_mst_get_edid(connector, &master->mst_mgr, radeon_connector->port);
  152. radeon_connector->edid = edid;
  153. DRM_DEBUG_KMS("edid retrieved %p\n", edid);
  154. if (radeon_connector->edid) {
  155. drm_mode_connector_update_edid_property(&radeon_connector->base, radeon_connector->edid);
  156. ret = drm_add_edid_modes(&radeon_connector->base, radeon_connector->edid);
  157. drm_edid_to_eld(&radeon_connector->base, radeon_connector->edid);
  158. return ret;
  159. }
  160. drm_mode_connector_update_edid_property(&radeon_connector->base, NULL);
  161. return ret;
  162. }
  163. static int radeon_dp_mst_get_modes(struct drm_connector *connector)
  164. {
  165. return radeon_dp_mst_get_ddc_modes(connector);
  166. }
  167. static enum drm_mode_status
  168. radeon_dp_mst_mode_valid(struct drm_connector *connector,
  169. struct drm_display_mode *mode)
  170. {
  171. /* TODO - validate mode against available PBN for link */
  172. if (mode->clock < 10000)
  173. return MODE_CLOCK_LOW;
  174. if (mode->flags & DRM_MODE_FLAG_DBLCLK)
  175. return MODE_H_ILLEGAL;
  176. return MODE_OK;
  177. }
  178. struct drm_encoder *radeon_mst_best_encoder(struct drm_connector *connector)
  179. {
  180. struct radeon_connector *radeon_connector = to_radeon_connector(connector);
  181. return &radeon_connector->mst_encoder->base;
  182. }
  183. static const struct drm_connector_helper_funcs radeon_dp_mst_connector_helper_funcs = {
  184. .get_modes = radeon_dp_mst_get_modes,
  185. .mode_valid = radeon_dp_mst_mode_valid,
  186. .best_encoder = radeon_mst_best_encoder,
  187. };
  188. static enum drm_connector_status
  189. radeon_dp_mst_detect(struct drm_connector *connector, bool force)
  190. {
  191. struct radeon_connector *radeon_connector = to_radeon_connector(connector);
  192. struct radeon_connector *master = radeon_connector->mst_port;
  193. return drm_dp_mst_detect_port(connector, &master->mst_mgr, radeon_connector->port);
  194. }
  195. static void
  196. radeon_dp_mst_connector_destroy(struct drm_connector *connector)
  197. {
  198. struct radeon_connector *radeon_connector = to_radeon_connector(connector);
  199. struct radeon_encoder *radeon_encoder = radeon_connector->mst_encoder;
  200. drm_encoder_cleanup(&radeon_encoder->base);
  201. kfree(radeon_encoder);
  202. drm_connector_cleanup(connector);
  203. kfree(radeon_connector);
  204. }
  205. static const struct drm_connector_funcs radeon_dp_mst_connector_funcs = {
  206. .dpms = drm_helper_connector_dpms,
  207. .detect = radeon_dp_mst_detect,
  208. .fill_modes = drm_helper_probe_single_connector_modes,
  209. .destroy = radeon_dp_mst_connector_destroy,
  210. };
  211. static struct drm_connector *radeon_dp_add_mst_connector(struct drm_dp_mst_topology_mgr *mgr,
  212. struct drm_dp_mst_port *port,
  213. const char *pathprop)
  214. {
  215. struct radeon_connector *master = container_of(mgr, struct radeon_connector, mst_mgr);
  216. struct drm_device *dev = master->base.dev;
  217. struct radeon_connector *radeon_connector;
  218. struct drm_connector *connector;
  219. radeon_connector = kzalloc(sizeof(*radeon_connector), GFP_KERNEL);
  220. if (!radeon_connector)
  221. return NULL;
  222. radeon_connector->is_mst_connector = true;
  223. connector = &radeon_connector->base;
  224. radeon_connector->port = port;
  225. radeon_connector->mst_port = master;
  226. DRM_DEBUG_KMS("\n");
  227. drm_connector_init(dev, connector, &radeon_dp_mst_connector_funcs, DRM_MODE_CONNECTOR_DisplayPort);
  228. drm_connector_helper_add(connector, &radeon_dp_mst_connector_helper_funcs);
  229. radeon_connector->mst_encoder = radeon_dp_create_fake_mst_encoder(master);
  230. drm_object_attach_property(&connector->base, dev->mode_config.path_property, 0);
  231. drm_object_attach_property(&connector->base, dev->mode_config.tile_property, 0);
  232. drm_mode_connector_set_path_property(connector, pathprop);
  233. return connector;
  234. }
  235. static void radeon_dp_register_mst_connector(struct drm_connector *connector)
  236. {
  237. struct drm_device *dev = connector->dev;
  238. struct radeon_device *rdev = dev->dev_private;
  239. drm_modeset_lock_all(dev);
  240. radeon_fb_add_connector(rdev, connector);
  241. drm_modeset_unlock_all(dev);
  242. drm_connector_register(connector);
  243. }
  244. static void radeon_dp_destroy_mst_connector(struct drm_dp_mst_topology_mgr *mgr,
  245. struct drm_connector *connector)
  246. {
  247. struct radeon_connector *master = container_of(mgr, struct radeon_connector, mst_mgr);
  248. struct drm_device *dev = master->base.dev;
  249. struct radeon_device *rdev = dev->dev_private;
  250. drm_connector_unregister(connector);
  251. /* need to nuke the connector */
  252. drm_modeset_lock_all(dev);
  253. /* dpms off */
  254. radeon_fb_remove_connector(rdev, connector);
  255. drm_connector_cleanup(connector);
  256. drm_modeset_unlock_all(dev);
  257. kfree(connector);
  258. DRM_DEBUG_KMS("\n");
  259. }
  260. static void radeon_dp_mst_hotplug(struct drm_dp_mst_topology_mgr *mgr)
  261. {
  262. struct radeon_connector *master = container_of(mgr, struct radeon_connector, mst_mgr);
  263. struct drm_device *dev = master->base.dev;
  264. drm_kms_helper_hotplug_event(dev);
  265. }
  266. const struct drm_dp_mst_topology_cbs mst_cbs = {
  267. .add_connector = radeon_dp_add_mst_connector,
  268. .register_connector = radeon_dp_register_mst_connector,
  269. .destroy_connector = radeon_dp_destroy_mst_connector,
  270. .hotplug = radeon_dp_mst_hotplug,
  271. };
  272. struct radeon_connector *radeon_mst_find_connector(struct drm_encoder *encoder)
  273. {
  274. struct drm_device *dev = encoder->dev;
  275. struct drm_connector *connector;
  276. list_for_each_entry(connector, &dev->mode_config.connector_list, head) {
  277. struct radeon_connector *radeon_connector = to_radeon_connector(connector);
  278. if (!connector->encoder)
  279. continue;
  280. if (!radeon_connector->is_mst_connector)
  281. continue;
  282. DRM_DEBUG_KMS("checking %p vs %p\n", connector->encoder, encoder);
  283. if (connector->encoder == encoder)
  284. return radeon_connector;
  285. }
  286. return NULL;
  287. }
  288. void radeon_dp_mst_prepare_pll(struct drm_crtc *crtc, struct drm_display_mode *mode)
  289. {
  290. struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc);
  291. struct drm_device *dev = crtc->dev;
  292. struct radeon_device *rdev = dev->dev_private;
  293. struct radeon_encoder *radeon_encoder = to_radeon_encoder(radeon_crtc->encoder);
  294. struct radeon_encoder_mst *mst_enc = radeon_encoder->enc_priv;
  295. struct radeon_connector *radeon_connector = radeon_mst_find_connector(&radeon_encoder->base);
  296. int dp_clock;
  297. struct radeon_connector_atom_dig *dig_connector = mst_enc->connector->con_priv;
  298. if (radeon_connector) {
  299. radeon_connector->pixelclock_for_modeset = mode->clock;
  300. if (radeon_connector->base.display_info.bpc)
  301. radeon_crtc->bpc = radeon_connector->base.display_info.bpc;
  302. else
  303. radeon_crtc->bpc = 8;
  304. }
  305. DRM_DEBUG_KMS("dp_clock %p %d\n", dig_connector, dig_connector->dp_clock);
  306. dp_clock = dig_connector->dp_clock;
  307. radeon_crtc->ss_enabled =
  308. radeon_atombios_get_asic_ss_info(rdev, &radeon_crtc->ss,
  309. ASIC_INTERNAL_SS_ON_DP,
  310. dp_clock);
  311. }
  312. static void
  313. radeon_mst_encoder_dpms(struct drm_encoder *encoder, int mode)
  314. {
  315. struct drm_device *dev = encoder->dev;
  316. struct radeon_device *rdev = dev->dev_private;
  317. struct radeon_encoder *radeon_encoder, *primary;
  318. struct radeon_encoder_mst *mst_enc;
  319. struct radeon_encoder_atom_dig *dig_enc;
  320. struct radeon_connector *radeon_connector;
  321. struct drm_crtc *crtc;
  322. struct radeon_crtc *radeon_crtc;
  323. int ret, slots;
  324. s64 fixed_pbn, fixed_pbn_per_slot, avg_time_slots_per_mtp;
  325. if (!ASIC_IS_DCE5(rdev)) {
  326. DRM_ERROR("got mst dpms on non-DCE5\n");
  327. return;
  328. }
  329. radeon_connector = radeon_mst_find_connector(encoder);
  330. if (!radeon_connector)
  331. return;
  332. radeon_encoder = to_radeon_encoder(encoder);
  333. mst_enc = radeon_encoder->enc_priv;
  334. primary = mst_enc->primary;
  335. dig_enc = primary->enc_priv;
  336. crtc = encoder->crtc;
  337. DRM_DEBUG_KMS("got connector %d\n", dig_enc->active_mst_links);
  338. switch (mode) {
  339. case DRM_MODE_DPMS_ON:
  340. dig_enc->active_mst_links++;
  341. radeon_crtc = to_radeon_crtc(crtc);
  342. if (dig_enc->active_mst_links == 1) {
  343. mst_enc->fe = dig_enc->dig_encoder;
  344. mst_enc->fe_from_be = true;
  345. atombios_set_mst_encoder_crtc_source(encoder, mst_enc->fe);
  346. atombios_dig_encoder_setup(&primary->base, ATOM_ENCODER_CMD_SETUP, 0);
  347. atombios_dig_transmitter_setup2(&primary->base, ATOM_TRANSMITTER_ACTION_ENABLE,
  348. 0, 0, dig_enc->dig_encoder);
  349. if (radeon_dp_needs_link_train(mst_enc->connector) ||
  350. dig_enc->active_mst_links == 1) {
  351. radeon_dp_link_train(&primary->base, &mst_enc->connector->base);
  352. }
  353. } else {
  354. mst_enc->fe = radeon_atom_pick_dig_encoder(encoder, radeon_crtc->crtc_id);
  355. if (mst_enc->fe == -1)
  356. DRM_ERROR("failed to get frontend for dig encoder\n");
  357. mst_enc->fe_from_be = false;
  358. atombios_set_mst_encoder_crtc_source(encoder, mst_enc->fe);
  359. }
  360. DRM_DEBUG_KMS("dig encoder is %d %d %d\n", dig_enc->dig_encoder,
  361. dig_enc->linkb, radeon_crtc->crtc_id);
  362. ret = drm_dp_mst_allocate_vcpi(&radeon_connector->mst_port->mst_mgr,
  363. radeon_connector->port,
  364. mst_enc->pbn, &slots);
  365. ret = drm_dp_update_payload_part1(&radeon_connector->mst_port->mst_mgr);
  366. radeon_dp_mst_set_be_cntl(primary, mst_enc,
  367. radeon_connector->mst_port->hpd.hpd, true);
  368. mst_enc->enc_active = true;
  369. radeon_dp_mst_update_stream_attribs(radeon_connector->mst_port, primary);
  370. fixed_pbn = drm_int2fixp(mst_enc->pbn);
  371. fixed_pbn_per_slot = drm_int2fixp(radeon_connector->mst_port->mst_mgr.pbn_div);
  372. avg_time_slots_per_mtp = drm_fixp_div(fixed_pbn, fixed_pbn_per_slot);
  373. radeon_dp_mst_set_vcp_size(radeon_encoder, avg_time_slots_per_mtp);
  374. atombios_dig_encoder_setup2(&primary->base, ATOM_ENCODER_CMD_DP_VIDEO_ON, 0,
  375. mst_enc->fe);
  376. ret = drm_dp_check_act_status(&radeon_connector->mst_port->mst_mgr);
  377. ret = drm_dp_update_payload_part2(&radeon_connector->mst_port->mst_mgr);
  378. break;
  379. case DRM_MODE_DPMS_STANDBY:
  380. case DRM_MODE_DPMS_SUSPEND:
  381. case DRM_MODE_DPMS_OFF:
  382. DRM_ERROR("DPMS OFF %d\n", dig_enc->active_mst_links);
  383. if (!mst_enc->enc_active)
  384. return;
  385. drm_dp_mst_reset_vcpi_slots(&radeon_connector->mst_port->mst_mgr, mst_enc->port);
  386. ret = drm_dp_update_payload_part1(&radeon_connector->mst_port->mst_mgr);
  387. drm_dp_check_act_status(&radeon_connector->mst_port->mst_mgr);
  388. /* and this can also fail */
  389. drm_dp_update_payload_part2(&radeon_connector->mst_port->mst_mgr);
  390. drm_dp_mst_deallocate_vcpi(&radeon_connector->mst_port->mst_mgr, mst_enc->port);
  391. mst_enc->enc_active = false;
  392. radeon_dp_mst_update_stream_attribs(radeon_connector->mst_port, primary);
  393. radeon_dp_mst_set_be_cntl(primary, mst_enc,
  394. radeon_connector->mst_port->hpd.hpd, false);
  395. atombios_dig_encoder_setup2(&primary->base, ATOM_ENCODER_CMD_DP_VIDEO_OFF, 0,
  396. mst_enc->fe);
  397. if (!mst_enc->fe_from_be)
  398. radeon_atom_release_dig_encoder(rdev, mst_enc->fe);
  399. mst_enc->fe_from_be = false;
  400. dig_enc->active_mst_links--;
  401. if (dig_enc->active_mst_links == 0) {
  402. /* drop link */
  403. }
  404. break;
  405. }
  406. }
  407. static bool radeon_mst_mode_fixup(struct drm_encoder *encoder,
  408. const struct drm_display_mode *mode,
  409. struct drm_display_mode *adjusted_mode)
  410. {
  411. struct radeon_encoder_mst *mst_enc;
  412. struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder);
  413. struct radeon_connector_atom_dig *dig_connector;
  414. int bpp = 24;
  415. mst_enc = radeon_encoder->enc_priv;
  416. mst_enc->pbn = drm_dp_calc_pbn_mode(adjusted_mode->clock, bpp);
  417. mst_enc->primary->active_device = mst_enc->primary->devices & mst_enc->connector->devices;
  418. DRM_DEBUG_KMS("setting active device to %08x from %08x %08x for encoder %d\n",
  419. mst_enc->primary->active_device, mst_enc->primary->devices,
  420. mst_enc->connector->devices, mst_enc->primary->base.encoder_type);
  421. drm_mode_set_crtcinfo(adjusted_mode, 0);
  422. dig_connector = mst_enc->connector->con_priv;
  423. dig_connector->dp_lane_count = drm_dp_max_lane_count(dig_connector->dpcd);
  424. dig_connector->dp_clock = drm_dp_max_link_rate(dig_connector->dpcd);
  425. DRM_DEBUG_KMS("dig clock %p %d %d\n", dig_connector,
  426. dig_connector->dp_lane_count, dig_connector->dp_clock);
  427. return true;
  428. }
  429. static void radeon_mst_encoder_prepare(struct drm_encoder *encoder)
  430. {
  431. struct radeon_connector *radeon_connector;
  432. struct radeon_encoder *radeon_encoder, *primary;
  433. struct radeon_encoder_mst *mst_enc;
  434. struct radeon_encoder_atom_dig *dig_enc;
  435. radeon_connector = radeon_mst_find_connector(encoder);
  436. if (!radeon_connector) {
  437. DRM_DEBUG_KMS("failed to find connector %p\n", encoder);
  438. return;
  439. }
  440. radeon_encoder = to_radeon_encoder(encoder);
  441. radeon_mst_encoder_dpms(encoder, DRM_MODE_DPMS_OFF);
  442. mst_enc = radeon_encoder->enc_priv;
  443. primary = mst_enc->primary;
  444. dig_enc = primary->enc_priv;
  445. mst_enc->port = radeon_connector->port;
  446. if (dig_enc->dig_encoder == -1) {
  447. dig_enc->dig_encoder = radeon_atom_pick_dig_encoder(&primary->base, -1);
  448. primary->offset = radeon_atom_set_enc_offset(dig_enc->dig_encoder);
  449. atombios_set_mst_encoder_crtc_source(encoder, dig_enc->dig_encoder);
  450. }
  451. DRM_DEBUG_KMS("%d %d\n", dig_enc->dig_encoder, primary->offset);
  452. }
  453. static void
  454. radeon_mst_encoder_mode_set(struct drm_encoder *encoder,
  455. struct drm_display_mode *mode,
  456. struct drm_display_mode *adjusted_mode)
  457. {
  458. DRM_DEBUG_KMS("\n");
  459. }
  460. static void radeon_mst_encoder_commit(struct drm_encoder *encoder)
  461. {
  462. radeon_mst_encoder_dpms(encoder, DRM_MODE_DPMS_ON);
  463. DRM_DEBUG_KMS("\n");
  464. }
  465. static const struct drm_encoder_helper_funcs radeon_mst_helper_funcs = {
  466. .dpms = radeon_mst_encoder_dpms,
  467. .mode_fixup = radeon_mst_mode_fixup,
  468. .prepare = radeon_mst_encoder_prepare,
  469. .mode_set = radeon_mst_encoder_mode_set,
  470. .commit = radeon_mst_encoder_commit,
  471. };
  472. void radeon_dp_mst_encoder_destroy(struct drm_encoder *encoder)
  473. {
  474. drm_encoder_cleanup(encoder);
  475. kfree(encoder);
  476. }
  477. static const struct drm_encoder_funcs radeon_dp_mst_enc_funcs = {
  478. .destroy = radeon_dp_mst_encoder_destroy,
  479. };
  480. static struct radeon_encoder *
  481. radeon_dp_create_fake_mst_encoder(struct radeon_connector *connector)
  482. {
  483. struct drm_device *dev = connector->base.dev;
  484. struct radeon_device *rdev = dev->dev_private;
  485. struct radeon_encoder *radeon_encoder;
  486. struct radeon_encoder_mst *mst_enc;
  487. struct drm_encoder *encoder;
  488. const struct drm_connector_helper_funcs *connector_funcs = connector->base.helper_private;
  489. struct drm_encoder *enc_master = connector_funcs->best_encoder(&connector->base);
  490. DRM_DEBUG_KMS("enc master is %p\n", enc_master);
  491. radeon_encoder = kzalloc(sizeof(*radeon_encoder), GFP_KERNEL);
  492. if (!radeon_encoder)
  493. return NULL;
  494. radeon_encoder->enc_priv = kzalloc(sizeof(*mst_enc), GFP_KERNEL);
  495. if (!radeon_encoder->enc_priv) {
  496. kfree(radeon_encoder);
  497. return NULL;
  498. }
  499. encoder = &radeon_encoder->base;
  500. switch (rdev->num_crtc) {
  501. case 1:
  502. encoder->possible_crtcs = 0x1;
  503. break;
  504. case 2:
  505. default:
  506. encoder->possible_crtcs = 0x3;
  507. break;
  508. case 4:
  509. encoder->possible_crtcs = 0xf;
  510. break;
  511. case 6:
  512. encoder->possible_crtcs = 0x3f;
  513. break;
  514. }
  515. drm_encoder_init(dev, &radeon_encoder->base, &radeon_dp_mst_enc_funcs,
  516. DRM_MODE_ENCODER_DPMST, NULL);
  517. drm_encoder_helper_add(encoder, &radeon_mst_helper_funcs);
  518. mst_enc = radeon_encoder->enc_priv;
  519. mst_enc->connector = connector;
  520. mst_enc->primary = to_radeon_encoder(enc_master);
  521. radeon_encoder->is_mst_encoder = true;
  522. return radeon_encoder;
  523. }
  524. int
  525. radeon_dp_mst_init(struct radeon_connector *radeon_connector)
  526. {
  527. struct drm_device *dev = radeon_connector->base.dev;
  528. if (!radeon_connector->ddc_bus->has_aux)
  529. return 0;
  530. radeon_connector->mst_mgr.cbs = &mst_cbs;
  531. return drm_dp_mst_topology_mgr_init(&radeon_connector->mst_mgr, dev->dev,
  532. &radeon_connector->ddc_bus->aux, 16, 6,
  533. radeon_connector->base.base.id);
  534. }
  535. int
  536. radeon_dp_mst_probe(struct radeon_connector *radeon_connector)
  537. {
  538. struct radeon_connector_atom_dig *dig_connector = radeon_connector->con_priv;
  539. struct drm_device *dev = radeon_connector->base.dev;
  540. struct radeon_device *rdev = dev->dev_private;
  541. int ret;
  542. u8 msg[1];
  543. if (!radeon_mst)
  544. return 0;
  545. if (!ASIC_IS_DCE5(rdev))
  546. return 0;
  547. if (dig_connector->dpcd[DP_DPCD_REV] < 0x12)
  548. return 0;
  549. ret = drm_dp_dpcd_read(&radeon_connector->ddc_bus->aux, DP_MSTM_CAP, msg,
  550. 1);
  551. if (ret) {
  552. if (msg[0] & DP_MST_CAP) {
  553. DRM_DEBUG_KMS("Sink is MST capable\n");
  554. dig_connector->is_mst = true;
  555. } else {
  556. DRM_DEBUG_KMS("Sink is not MST capable\n");
  557. dig_connector->is_mst = false;
  558. }
  559. }
  560. drm_dp_mst_topology_mgr_set_mst(&radeon_connector->mst_mgr,
  561. dig_connector->is_mst);
  562. return dig_connector->is_mst;
  563. }
  564. int
  565. radeon_dp_mst_check_status(struct radeon_connector *radeon_connector)
  566. {
  567. struct radeon_connector_atom_dig *dig_connector = radeon_connector->con_priv;
  568. int retry;
  569. if (dig_connector->is_mst) {
  570. u8 esi[16] = { 0 };
  571. int dret;
  572. int ret = 0;
  573. bool handled;
  574. dret = drm_dp_dpcd_read(&radeon_connector->ddc_bus->aux,
  575. DP_SINK_COUNT_ESI, esi, 8);
  576. go_again:
  577. if (dret == 8) {
  578. DRM_DEBUG_KMS("got esi %02x %02x %02x\n", esi[0], esi[1], esi[2]);
  579. ret = drm_dp_mst_hpd_irq(&radeon_connector->mst_mgr, esi, &handled);
  580. if (handled) {
  581. for (retry = 0; retry < 3; retry++) {
  582. int wret;
  583. wret = drm_dp_dpcd_write(&radeon_connector->ddc_bus->aux,
  584. DP_SINK_COUNT_ESI + 1, &esi[1], 3);
  585. if (wret == 3)
  586. break;
  587. }
  588. dret = drm_dp_dpcd_read(&radeon_connector->ddc_bus->aux,
  589. DP_SINK_COUNT_ESI, esi, 8);
  590. if (dret == 8) {
  591. DRM_DEBUG_KMS("got esi2 %02x %02x %02x\n", esi[0], esi[1], esi[2]);
  592. goto go_again;
  593. }
  594. } else
  595. ret = 0;
  596. return ret;
  597. } else {
  598. DRM_DEBUG_KMS("failed to get ESI - device may have failed %d\n", ret);
  599. dig_connector->is_mst = false;
  600. drm_dp_mst_topology_mgr_set_mst(&radeon_connector->mst_mgr,
  601. dig_connector->is_mst);
  602. /* send a hotplug event */
  603. }
  604. }
  605. return -EINVAL;
  606. }
  607. #if defined(CONFIG_DEBUG_FS)
  608. static int radeon_debugfs_mst_info(struct seq_file *m, void *data)
  609. {
  610. struct drm_info_node *node = (struct drm_info_node *)m->private;
  611. struct drm_device *dev = node->minor->dev;
  612. struct drm_connector *connector;
  613. struct radeon_connector *radeon_connector;
  614. struct radeon_connector_atom_dig *dig_connector;
  615. int i;
  616. drm_modeset_lock_all(dev);
  617. list_for_each_entry(connector, &dev->mode_config.connector_list, head) {
  618. if (connector->connector_type != DRM_MODE_CONNECTOR_DisplayPort)
  619. continue;
  620. radeon_connector = to_radeon_connector(connector);
  621. dig_connector = radeon_connector->con_priv;
  622. if (radeon_connector->is_mst_connector)
  623. continue;
  624. if (!dig_connector->is_mst)
  625. continue;
  626. drm_dp_mst_dump_topology(m, &radeon_connector->mst_mgr);
  627. for (i = 0; i < radeon_connector->enabled_attribs; i++)
  628. seq_printf(m, "attrib %d: %d %d\n", i,
  629. radeon_connector->cur_stream_attribs[i].fe,
  630. radeon_connector->cur_stream_attribs[i].slots);
  631. }
  632. drm_modeset_unlock_all(dev);
  633. return 0;
  634. }
  635. static struct drm_info_list radeon_debugfs_mst_list[] = {
  636. {"radeon_mst_info", &radeon_debugfs_mst_info, 0, NULL},
  637. };
  638. #endif
  639. int radeon_mst_debugfs_init(struct radeon_device *rdev)
  640. {
  641. #if defined(CONFIG_DEBUG_FS)
  642. return radeon_debugfs_add_files(rdev, radeon_debugfs_mst_list, 1);
  643. #endif
  644. return 0;
  645. }