cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

STG4000Ramdac.c (3931B)


      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
     19static u32 STG_PIXEL_BUS_WIDTH = 128;	/* 128 bit bus width      */
     20static u32 REF_CLOCK = 14318;
     21
     22int 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 */
    147void 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
    156void 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}