1 // SPDX-License-Identifier: GPL-2.0-only
3 #include <linux/delay.h>
5 #include <drm/drm_atomic_helper.h>
6 #include <drm/drm_edid.h>
7 #include <drm/drm_managed.h>
8 #include <drm/drm_probe_helper.h>
10 #include "mgag200_drv.h"
12 void mgag200_bmc_stop_scanout(struct mga_device *mdev)
18 * 1 - The first step is to inform the BMC of an upcoming mode
19 * change. We are putting the misc<0> to output.
22 WREG8(DAC_INDEX, MGA1064_GEN_IO_CTL);
23 tmp = RREG8(DAC_DATA);
25 WREG_DAC(MGA1064_GEN_IO_CTL, tmp);
27 /* we are putting a 1 on the misc<0> line */
28 WREG8(DAC_INDEX, MGA1064_GEN_IO_DATA);
29 tmp = RREG8(DAC_DATA);
31 WREG_DAC(MGA1064_GEN_IO_DATA, tmp);
34 * 2- Second step to mask any further scan request. This is
35 * done by asserting the remfreqmsk bit (XSPAREREG<7>)
38 WREG8(DAC_INDEX, MGA1064_SPAREREG);
39 tmp = RREG8(DAC_DATA);
41 WREG_DAC(MGA1064_SPAREREG, tmp);
44 * 3a- The third step is to verify if there is an active scan.
45 * We are waiting for a 0 on remhsyncsts <XSPAREREG<0>).
48 while (!(tmp & 0x1) && iter_max) {
49 WREG8(DAC_INDEX, MGA1064_SPAREREG);
50 tmp = RREG8(DAC_DATA);
56 * 3b- This step occurs only if the remove is actually
57 * scanning. We are waiting for the end of the frame which is
58 * a 1 on remvsyncsts (XSPAREREG<1>)
62 while ((tmp & 0x2) && iter_max) {
63 WREG8(DAC_INDEX, MGA1064_SPAREREG);
64 tmp = RREG8(DAC_DATA);
71 void mgag200_bmc_start_scanout(struct mga_device *mdev)
76 WREG8(DAC_INDEX, MGA1064_REMHEADCTL2);
77 tmp = RREG8(DAC_DATA);
83 /* Deassert rstlvl2 */
85 WREG8(DAC_INDEX, MGA1064_REMHEADCTL2);
88 /* Remove mask of scan request */
89 WREG8(DAC_INDEX, MGA1064_SPAREREG);
90 tmp = RREG8(DAC_DATA);
94 /* Put back a 0 on the misc<0> line */
95 WREG8(DAC_INDEX, MGA1064_GEN_IO_DATA);
96 tmp = RREG8(DAC_DATA);
98 WREG_DAC(MGA1064_GEN_IO_DATA, tmp);