1  /*
2   *  linux/drivers/video/kyro/STG4000Ramdac.c
3   *
4   *  Copyright (C) 2002 STMicroelectronics
5   *
6   * This file is subject to the terms and conditions of the GNU General Public
7   * License.  See the file COPYING in the main directory of this archive
8   * for more details.
9   */
10  
11  #include <linux/kernel.h>
12  #include <linux/errno.h>
13  #include <linux/types.h>
14  #include <video/kyro.h>
15  
16  #include "STG4000Reg.h"
17  #include "STG4000Interface.h"
18  
19  static u32 STG_PIXEL_BUS_WIDTH = 128;	/* 128 bit bus width      */
20  static u32 REF_CLOCK = 14318;
21  
InitialiseRamdac(volatile STG4000REG __iomem * pSTGReg,u32 displayDepth,u32 displayWidth,u32 displayHeight,s32 HSyncPolarity,s32 VSyncPolarity,u32 * pixelClock)22  int InitialiseRamdac(volatile STG4000REG __iomem * pSTGReg,
23  		     u32 displayDepth,
24  		     u32 displayWidth,
25  		     u32 displayHeight,
26  		     s32 HSyncPolarity,
27  		     s32 VSyncPolarity, u32 * pixelClock)
28  {
29  	u32 tmp = 0;
30  	u32 F = 0, R = 0, P = 0;
31  	u32 stride = 0;
32  	u32 ulPdiv = 0;
33  	u32 physicalPixelDepth = 0;
34  	/* Make sure DAC is in Reset */
35  	tmp = STG_READ_REG(SoftwareReset);
36  
37  	if (tmp & 0x1) {
38  		CLEAR_BIT(1);
39  		STG_WRITE_REG(SoftwareReset, tmp);
40  	}
41  
42  	/* Set Pixel Format */
43  	tmp = STG_READ_REG(DACPixelFormat);
44  	CLEAR_BITS_FRM_TO(0, 2);
45  
46  	/* Set LUT not used from 16bpp to 32 bpp ??? */
47  	CLEAR_BITS_FRM_TO(8, 9);
48  
49  	switch (displayDepth) {
50  	case 16:
51  		{
52  			physicalPixelDepth = 16;
53  			tmp |= _16BPP;
54  			break;
55  		}
56  	case 32:
57  		{
58  			/* Set for 32 bits per pixel */
59  			physicalPixelDepth = 32;
60  			tmp |= _32BPP;
61  			break;
62  		}
63  	default:
64  		return -EINVAL;
65  	}
66  
67  	STG_WRITE_REG(DACPixelFormat, tmp);
68  
69  	/* Workout Bus transfer bandwidth according to pixel format */
70  	ulPdiv = STG_PIXEL_BUS_WIDTH / physicalPixelDepth;
71  
72  	/* Get Screen Stride in pixels */
73  	stride = displayWidth;
74  
75  	/* Set Primary size info */
76  	tmp = STG_READ_REG(DACPrimSize);
77  	CLEAR_BITS_FRM_TO(0, 10);
78  	CLEAR_BITS_FRM_TO(12, 31);
79  	tmp |=
80  	    ((((displayHeight - 1) << 12) | (((displayWidth / ulPdiv) -
81  					      1) << 23))
82  	     | (stride / ulPdiv));
83  	STG_WRITE_REG(DACPrimSize, tmp);
84  
85  
86  	/* Set Pixel Clock */
87  	*pixelClock = ProgramClock(REF_CLOCK, *pixelClock, &F, &R, &P);
88  
89  	/* Set DAC PLL Mode */
90  	tmp = STG_READ_REG(DACPLLMode);
91  	CLEAR_BITS_FRM_TO(0, 15);
92  	/* tmp |= ((P-1) | ((F-2) << 2) | ((R-2) << 11)); */
93  	tmp |= ((P) | ((F - 2) << 2) | ((R - 2) << 11));
94  	STG_WRITE_REG(DACPLLMode, tmp);
95  
96  	/* Set Prim Address */
97  	tmp = STG_READ_REG(DACPrimAddress);
98  	CLEAR_BITS_FRM_TO(0, 20);
99  	CLEAR_BITS_FRM_TO(20, 31);
100  	STG_WRITE_REG(DACPrimAddress, tmp);
101  
102  	/* Set Cursor details with HW Cursor disabled */
103  	tmp = STG_READ_REG(DACCursorCtrl);
104  	tmp &= ~SET_BIT(31);
105  	STG_WRITE_REG(DACCursorCtrl, tmp);
106  
107  	tmp = STG_READ_REG(DACCursorAddr);
108  	CLEAR_BITS_FRM_TO(0, 20);
109  	STG_WRITE_REG(DACCursorAddr, tmp);
110  
111  	/* Set Video Window */
112  	tmp = STG_READ_REG(DACVidWinStart);
113  	CLEAR_BITS_FRM_TO(0, 10);
114  	CLEAR_BITS_FRM_TO(16, 26);
115  	STG_WRITE_REG(DACVidWinStart, tmp);
116  
117  	tmp = STG_READ_REG(DACVidWinEnd);
118  	CLEAR_BITS_FRM_TO(0, 10);
119  	CLEAR_BITS_FRM_TO(16, 26);
120  	STG_WRITE_REG(DACVidWinEnd, tmp);
121  
122  	/* Set DAC Border Color to default */
123  	tmp = STG_READ_REG(DACBorderColor);
124  	CLEAR_BITS_FRM_TO(0, 23);
125  	STG_WRITE_REG(DACBorderColor, tmp);
126  
127  	/* Set Graphics and Overlay Burst Control */
128  	STG_WRITE_REG(DACBurstCtrl, 0x0404);
129  
130  	/* Set CRC Trigger to default */
131  	tmp = STG_READ_REG(DACCrcTrigger);
132  	CLEAR_BIT(0);
133  	STG_WRITE_REG(DACCrcTrigger, tmp);
134  
135  	/* Set Video Port Control to default */
136  	tmp = STG_READ_REG(DigVidPortCtrl);
137  	CLEAR_BIT(8);
138  	CLEAR_BITS_FRM_TO(16, 27);
139  	CLEAR_BITS_FRM_TO(1, 3);
140  	CLEAR_BITS_FRM_TO(10, 11);
141  	STG_WRITE_REG(DigVidPortCtrl, tmp);
142  
143  	return 0;
144  }
145  
146  /* Ramdac control, turning output to the screen on and off */
DisableRamdacOutput(volatile STG4000REG __iomem * pSTGReg)147  void DisableRamdacOutput(volatile STG4000REG __iomem * pSTGReg)
148  {
149  	u32 tmp;
150  
151  	/* Disable DAC for Graphics Stream Control */
152  	tmp = (STG_READ_REG(DACStreamCtrl)) & ~SET_BIT(0);
153  	STG_WRITE_REG(DACStreamCtrl, tmp);
154  }
155  
EnableRamdacOutput(volatile STG4000REG __iomem * pSTGReg)156  void EnableRamdacOutput(volatile STG4000REG __iomem * pSTGReg)
157  {
158  	u32 tmp;
159  
160  	/* Enable DAC for Graphics Stream Control */
161  	tmp = (STG_READ_REG(DACStreamCtrl)) | SET_BIT(0);
162  	STG_WRITE_REG(DACStreamCtrl, tmp);
163  }
164