root/drivers/video/fbdev/kyro/STG4000Ramdac.c

/* [<][>][^][v][top][bottom][index][help] */

DEFINITIONS

This source file includes following definitions.
  1. InitialiseRamdac
  2. DisableRamdacOutput
  3. EnableRamdacOutput

   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 
  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 */
 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 
 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 }

/* [<][>][^][v][top][bottom][index][help] */