1*352d2591SJean-Christophe PLAGNIOL-VILLARD /* 2*352d2591SJean-Christophe PLAGNIOL-VILLARD * (C) Copyright 2004 3*352d2591SJean-Christophe PLAGNIOL-VILLARD * Pierre Aubert, Staubli Faverges , <p.aubert@staubli.com> 4*352d2591SJean-Christophe PLAGNIOL-VILLARD * 5*352d2591SJean-Christophe PLAGNIOL-VILLARD * See file CREDITS for list of people who contributed to this 6*352d2591SJean-Christophe PLAGNIOL-VILLARD * project. 7*352d2591SJean-Christophe PLAGNIOL-VILLARD * 8*352d2591SJean-Christophe PLAGNIOL-VILLARD * This program is free software; you can redistribute it and/or 9*352d2591SJean-Christophe PLAGNIOL-VILLARD * modify it under the terms of the GNU General Public License as 10*352d2591SJean-Christophe PLAGNIOL-VILLARD * published by the Free Software Foundation; either version 2 of 11*352d2591SJean-Christophe PLAGNIOL-VILLARD * the License, or (at your option) any later version. 12*352d2591SJean-Christophe PLAGNIOL-VILLARD * 13*352d2591SJean-Christophe PLAGNIOL-VILLARD * This program is distributed in the hope that it will be useful, 14*352d2591SJean-Christophe PLAGNIOL-VILLARD * but WITHOUT ANY WARRANTY; without even the implied warranty of 15*352d2591SJean-Christophe PLAGNIOL-VILLARD * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16*352d2591SJean-Christophe PLAGNIOL-VILLARD * GNU General Public License for more details. 17*352d2591SJean-Christophe PLAGNIOL-VILLARD * 18*352d2591SJean-Christophe PLAGNIOL-VILLARD * You should have received a copy of the GNU General Public License 19*352d2591SJean-Christophe PLAGNIOL-VILLARD * along with this program; if not, write to the Free Software 20*352d2591SJean-Christophe PLAGNIOL-VILLARD * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 21*352d2591SJean-Christophe PLAGNIOL-VILLARD * MA 02111-1307 USA 22*352d2591SJean-Christophe PLAGNIOL-VILLARD */ 23*352d2591SJean-Christophe PLAGNIOL-VILLARD 24*352d2591SJean-Christophe PLAGNIOL-VILLARD /************************************************************************ 25*352d2591SJean-Christophe PLAGNIOL-VILLARD Get Parameters for the video mode: 26*352d2591SJean-Christophe PLAGNIOL-VILLARD The default video mode can be defined in CFG_DEFAULT_VIDEO_MODE. 27*352d2591SJean-Christophe PLAGNIOL-VILLARD If undefined, default video mode is set to 0x301 28*352d2591SJean-Christophe PLAGNIOL-VILLARD Parameters can be set via the variable "videomode" in the environment. 29*352d2591SJean-Christophe PLAGNIOL-VILLARD 2 diferent ways are possible: 30*352d2591SJean-Christophe PLAGNIOL-VILLARD "videomode=301" - 301 is a hexadecimal number describing the VESA 31*352d2591SJean-Christophe PLAGNIOL-VILLARD mode. Following modes are implemented: 32*352d2591SJean-Christophe PLAGNIOL-VILLARD 33*352d2591SJean-Christophe PLAGNIOL-VILLARD Colors 640x480 800x600 1024x768 1152x864 1280x1024 34*352d2591SJean-Christophe PLAGNIOL-VILLARD --------+--------------------------------------------- 35*352d2591SJean-Christophe PLAGNIOL-VILLARD 8 bits | 0x301 0x303 0x305 0x161 0x307 36*352d2591SJean-Christophe PLAGNIOL-VILLARD 15 bits | 0x310 0x313 0x316 0x162 0x319 37*352d2591SJean-Christophe PLAGNIOL-VILLARD 16 bits | 0x311 0x314 0x317 0x163 0x31A 38*352d2591SJean-Christophe PLAGNIOL-VILLARD 24 bits | 0x312 0x315 0x318 ? 0x31B 39*352d2591SJean-Christophe PLAGNIOL-VILLARD --------+--------------------------------------------- 40*352d2591SJean-Christophe PLAGNIOL-VILLARD "videomode=bootargs" 41*352d2591SJean-Christophe PLAGNIOL-VILLARD - the parameters are parsed from the bootargs. 42*352d2591SJean-Christophe PLAGNIOL-VILLARD The format is "NAME:VALUE,NAME:VALUE" etc. 43*352d2591SJean-Christophe PLAGNIOL-VILLARD Ex.: 44*352d2591SJean-Christophe PLAGNIOL-VILLARD "bootargs=video=ctfb:x:800,y:600,depth:16,pclk:25000" 45*352d2591SJean-Christophe PLAGNIOL-VILLARD Parameters not included in the list will be taken from 46*352d2591SJean-Christophe PLAGNIOL-VILLARD the default mode, which is one of the following: 47*352d2591SJean-Christophe PLAGNIOL-VILLARD mode:0 640x480x24 48*352d2591SJean-Christophe PLAGNIOL-VILLARD mode:1 800x600x16 49*352d2591SJean-Christophe PLAGNIOL-VILLARD mode:2 1024x768x8 50*352d2591SJean-Christophe PLAGNIOL-VILLARD mode:3 960x720x24 51*352d2591SJean-Christophe PLAGNIOL-VILLARD mode:4 1152x864x16 52*352d2591SJean-Christophe PLAGNIOL-VILLARD mode:5 1280x1024x8 53*352d2591SJean-Christophe PLAGNIOL-VILLARD 54*352d2591SJean-Christophe PLAGNIOL-VILLARD if "mode" is not provided within the parameter list, 55*352d2591SJean-Christophe PLAGNIOL-VILLARD mode:0 is assumed. 56*352d2591SJean-Christophe PLAGNIOL-VILLARD Following parameters are supported: 57*352d2591SJean-Christophe PLAGNIOL-VILLARD x xres = visible resolution horizontal 58*352d2591SJean-Christophe PLAGNIOL-VILLARD y yres = visible resolution vertical 59*352d2591SJean-Christophe PLAGNIOL-VILLARD pclk pixelclocks in pico sec 60*352d2591SJean-Christophe PLAGNIOL-VILLARD le left_marging time from sync to picture in pixelclocks 61*352d2591SJean-Christophe PLAGNIOL-VILLARD ri right_marging time from picture to sync in pixelclocks 62*352d2591SJean-Christophe PLAGNIOL-VILLARD up upper_margin time from sync to picture 63*352d2591SJean-Christophe PLAGNIOL-VILLARD lo lower_margin 64*352d2591SJean-Christophe PLAGNIOL-VILLARD hs hsync_len length of horizontal sync 65*352d2591SJean-Christophe PLAGNIOL-VILLARD vs vsync_len length of vertical sync 66*352d2591SJean-Christophe PLAGNIOL-VILLARD sync see FB_SYNC_* 67*352d2591SJean-Christophe PLAGNIOL-VILLARD vmode see FB_VMODE_* 68*352d2591SJean-Christophe PLAGNIOL-VILLARD depth Color depth in bits per pixel 69*352d2591SJean-Christophe PLAGNIOL-VILLARD All other parameters in the variable bootargs are ignored. 70*352d2591SJean-Christophe PLAGNIOL-VILLARD It is also possible to set the parameters direct in the 71*352d2591SJean-Christophe PLAGNIOL-VILLARD variable "videomode", or in another variable i.e. 72*352d2591SJean-Christophe PLAGNIOL-VILLARD "myvideo" and setting the variable "videomode=myvideo".. 73*352d2591SJean-Christophe PLAGNIOL-VILLARD ****************************************************************************/ 74*352d2591SJean-Christophe PLAGNIOL-VILLARD 75*352d2591SJean-Christophe PLAGNIOL-VILLARD #include <common.h> 76*352d2591SJean-Christophe PLAGNIOL-VILLARD #include "videomodes.h" 77*352d2591SJean-Christophe PLAGNIOL-VILLARD 78*352d2591SJean-Christophe PLAGNIOL-VILLARD const struct ctfb_vesa_modes vesa_modes[VESA_MODES_COUNT] = { 79*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x301, RES_MODE_640x480, 8}, 80*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x310, RES_MODE_640x480, 15}, 81*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x311, RES_MODE_640x480, 16}, 82*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x312, RES_MODE_640x480, 24}, 83*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x303, RES_MODE_800x600, 8}, 84*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x313, RES_MODE_800x600, 15}, 85*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x314, RES_MODE_800x600, 16}, 86*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x315, RES_MODE_800x600, 24}, 87*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x305, RES_MODE_1024x768, 8}, 88*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x316, RES_MODE_1024x768, 15}, 89*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x317, RES_MODE_1024x768, 16}, 90*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x318, RES_MODE_1024x768, 24}, 91*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x161, RES_MODE_1152x864, 8}, 92*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x162, RES_MODE_1152x864, 15}, 93*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x163, RES_MODE_1152x864, 16}, 94*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x307, RES_MODE_1280x1024, 8}, 95*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x319, RES_MODE_1280x1024, 15}, 96*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x31A, RES_MODE_1280x1024, 16}, 97*352d2591SJean-Christophe PLAGNIOL-VILLARD {0x31B, RES_MODE_1280x1024, 24}, 98*352d2591SJean-Christophe PLAGNIOL-VILLARD }; 99*352d2591SJean-Christophe PLAGNIOL-VILLARD const struct ctfb_res_modes res_mode_init[RES_MODES_COUNT] = { 100*352d2591SJean-Christophe PLAGNIOL-VILLARD /* x y pixclk le ri up lo hs vs s vmode */ 101*352d2591SJean-Christophe PLAGNIOL-VILLARD {640, 480, 39721, 40, 24, 32, 11, 96, 2, 0, FB_VMODE_NONINTERLACED}, 102*352d2591SJean-Christophe PLAGNIOL-VILLARD {800, 600, 27778, 64, 24, 22, 1, 72, 2, 0, FB_VMODE_NONINTERLACED}, 103*352d2591SJean-Christophe PLAGNIOL-VILLARD {1024, 768, 15384, 168, 8, 29, 3, 144, 4, 0, FB_VMODE_NONINTERLACED}, 104*352d2591SJean-Christophe PLAGNIOL-VILLARD {960, 720, 13100, 160, 40, 32, 8, 80, 4, 0, FB_VMODE_NONINTERLACED}, 105*352d2591SJean-Christophe PLAGNIOL-VILLARD {1152, 864, 12004, 200, 64, 32, 16, 80, 4, 0, FB_VMODE_NONINTERLACED}, 106*352d2591SJean-Christophe PLAGNIOL-VILLARD {1280, 1024, 9090, 200, 48, 26, 1, 184, 3, 0, FB_VMODE_NONINTERLACED}, 107*352d2591SJean-Christophe PLAGNIOL-VILLARD }; 108*352d2591SJean-Christophe PLAGNIOL-VILLARD 109*352d2591SJean-Christophe PLAGNIOL-VILLARD /************************************************************************ 110*352d2591SJean-Christophe PLAGNIOL-VILLARD * Get Parameters for the video mode: 111*352d2591SJean-Christophe PLAGNIOL-VILLARD */ 112*352d2591SJean-Christophe PLAGNIOL-VILLARD /********************************************************************* 113*352d2591SJean-Christophe PLAGNIOL-VILLARD * returns the length to the next seperator 114*352d2591SJean-Christophe PLAGNIOL-VILLARD */ 115*352d2591SJean-Christophe PLAGNIOL-VILLARD static int 116*352d2591SJean-Christophe PLAGNIOL-VILLARD video_get_param_len (char *start, char sep) 117*352d2591SJean-Christophe PLAGNIOL-VILLARD { 118*352d2591SJean-Christophe PLAGNIOL-VILLARD int i = 0; 119*352d2591SJean-Christophe PLAGNIOL-VILLARD while ((*start != 0) && (*start != sep)) { 120*352d2591SJean-Christophe PLAGNIOL-VILLARD start++; 121*352d2591SJean-Christophe PLAGNIOL-VILLARD i++; 122*352d2591SJean-Christophe PLAGNIOL-VILLARD } 123*352d2591SJean-Christophe PLAGNIOL-VILLARD return i; 124*352d2591SJean-Christophe PLAGNIOL-VILLARD } 125*352d2591SJean-Christophe PLAGNIOL-VILLARD 126*352d2591SJean-Christophe PLAGNIOL-VILLARD static int 127*352d2591SJean-Christophe PLAGNIOL-VILLARD video_search_param (char *start, char *param) 128*352d2591SJean-Christophe PLAGNIOL-VILLARD { 129*352d2591SJean-Christophe PLAGNIOL-VILLARD int len, totallen, i; 130*352d2591SJean-Christophe PLAGNIOL-VILLARD char *p = start; 131*352d2591SJean-Christophe PLAGNIOL-VILLARD len = strlen (param); 132*352d2591SJean-Christophe PLAGNIOL-VILLARD totallen = len + strlen (start); 133*352d2591SJean-Christophe PLAGNIOL-VILLARD for (i = 0; i < totallen; i++) { 134*352d2591SJean-Christophe PLAGNIOL-VILLARD if (strncmp (p++, param, len) == 0) 135*352d2591SJean-Christophe PLAGNIOL-VILLARD return (i); 136*352d2591SJean-Christophe PLAGNIOL-VILLARD } 137*352d2591SJean-Christophe PLAGNIOL-VILLARD return -1; 138*352d2591SJean-Christophe PLAGNIOL-VILLARD } 139*352d2591SJean-Christophe PLAGNIOL-VILLARD 140*352d2591SJean-Christophe PLAGNIOL-VILLARD /*************************************************************** 141*352d2591SJean-Christophe PLAGNIOL-VILLARD * Get parameter via the environment as it is done for the 142*352d2591SJean-Christophe PLAGNIOL-VILLARD * linux kernel i.e: 143*352d2591SJean-Christophe PLAGNIOL-VILLARD * video=ctfb:x:800,xv:1280,y:600,yv:1024,depth:16,mode:0,pclk:25000, 144*352d2591SJean-Christophe PLAGNIOL-VILLARD * le:56,ri:48,up:26,lo:5,hs:152,vs:2,sync:0,vmode:0,accel:0 145*352d2591SJean-Christophe PLAGNIOL-VILLARD * 146*352d2591SJean-Christophe PLAGNIOL-VILLARD * penv is a pointer to the environment, containing the string, or the name of 147*352d2591SJean-Christophe PLAGNIOL-VILLARD * another environment variable. It could even be the term "bootargs" 148*352d2591SJean-Christophe PLAGNIOL-VILLARD */ 149*352d2591SJean-Christophe PLAGNIOL-VILLARD 150*352d2591SJean-Christophe PLAGNIOL-VILLARD #define GET_OPTION(name,var) \ 151*352d2591SJean-Christophe PLAGNIOL-VILLARD if(strncmp(p,name,strlen(name))==0) { \ 152*352d2591SJean-Christophe PLAGNIOL-VILLARD val_s=p+strlen(name); \ 153*352d2591SJean-Christophe PLAGNIOL-VILLARD var=simple_strtoul(val_s, NULL, 10); \ 154*352d2591SJean-Christophe PLAGNIOL-VILLARD } 155*352d2591SJean-Christophe PLAGNIOL-VILLARD 156*352d2591SJean-Christophe PLAGNIOL-VILLARD int video_get_params (struct ctfb_res_modes *pPar, char *penv) 157*352d2591SJean-Christophe PLAGNIOL-VILLARD { 158*352d2591SJean-Christophe PLAGNIOL-VILLARD char *p, *s, *val_s; 159*352d2591SJean-Christophe PLAGNIOL-VILLARD int i = 0, t; 160*352d2591SJean-Christophe PLAGNIOL-VILLARD int bpp; 161*352d2591SJean-Christophe PLAGNIOL-VILLARD int mode; 162*352d2591SJean-Christophe PLAGNIOL-VILLARD /* first search for the environment containing the real param string */ 163*352d2591SJean-Christophe PLAGNIOL-VILLARD s = penv; 164*352d2591SJean-Christophe PLAGNIOL-VILLARD if ((p = getenv (s)) != NULL) { 165*352d2591SJean-Christophe PLAGNIOL-VILLARD s = p; 166*352d2591SJean-Christophe PLAGNIOL-VILLARD } 167*352d2591SJean-Christophe PLAGNIOL-VILLARD /* in case of the bootargs line, we have to start 168*352d2591SJean-Christophe PLAGNIOL-VILLARD * after "video=ctfb:" 169*352d2591SJean-Christophe PLAGNIOL-VILLARD */ 170*352d2591SJean-Christophe PLAGNIOL-VILLARD i = video_search_param (s, "video=ctfb:"); 171*352d2591SJean-Christophe PLAGNIOL-VILLARD if (i >= 0) { 172*352d2591SJean-Christophe PLAGNIOL-VILLARD s += i; 173*352d2591SJean-Christophe PLAGNIOL-VILLARD s += strlen ("video=ctfb:"); 174*352d2591SJean-Christophe PLAGNIOL-VILLARD } 175*352d2591SJean-Christophe PLAGNIOL-VILLARD /* search for mode as a default value */ 176*352d2591SJean-Christophe PLAGNIOL-VILLARD p = s; 177*352d2591SJean-Christophe PLAGNIOL-VILLARD t = 0; 178*352d2591SJean-Christophe PLAGNIOL-VILLARD mode = 0; /* default */ 179*352d2591SJean-Christophe PLAGNIOL-VILLARD while ((i = video_get_param_len (p, ',')) != 0) { 180*352d2591SJean-Christophe PLAGNIOL-VILLARD GET_OPTION ("mode:", mode) 181*352d2591SJean-Christophe PLAGNIOL-VILLARD p += i; 182*352d2591SJean-Christophe PLAGNIOL-VILLARD if (*p != 0) 183*352d2591SJean-Christophe PLAGNIOL-VILLARD p++; /* skip ',' */ 184*352d2591SJean-Christophe PLAGNIOL-VILLARD } 185*352d2591SJean-Christophe PLAGNIOL-VILLARD if (mode >= RES_MODES_COUNT) 186*352d2591SJean-Christophe PLAGNIOL-VILLARD mode = 0; 187*352d2591SJean-Christophe PLAGNIOL-VILLARD *pPar = res_mode_init[mode]; /* copy default values */ 188*352d2591SJean-Christophe PLAGNIOL-VILLARD bpp = 24 - ((mode % 3) * 8); 189*352d2591SJean-Christophe PLAGNIOL-VILLARD p = s; /* restart */ 190*352d2591SJean-Christophe PLAGNIOL-VILLARD while ((i = video_get_param_len (p, ',')) != 0) { 191*352d2591SJean-Christophe PLAGNIOL-VILLARD GET_OPTION ("x:", pPar->xres) 192*352d2591SJean-Christophe PLAGNIOL-VILLARD GET_OPTION ("y:", pPar->yres) 193*352d2591SJean-Christophe PLAGNIOL-VILLARD GET_OPTION ("le:", pPar->left_margin) 194*352d2591SJean-Christophe PLAGNIOL-VILLARD GET_OPTION ("ri:", pPar->right_margin) 195*352d2591SJean-Christophe PLAGNIOL-VILLARD GET_OPTION ("up:", pPar->upper_margin) 196*352d2591SJean-Christophe PLAGNIOL-VILLARD GET_OPTION ("lo:", pPar->lower_margin) 197*352d2591SJean-Christophe PLAGNIOL-VILLARD GET_OPTION ("hs:", pPar->hsync_len) 198*352d2591SJean-Christophe PLAGNIOL-VILLARD GET_OPTION ("vs:", pPar->vsync_len) 199*352d2591SJean-Christophe PLAGNIOL-VILLARD GET_OPTION ("sync:", pPar->sync) 200*352d2591SJean-Christophe PLAGNIOL-VILLARD GET_OPTION ("vmode:", pPar->vmode) 201*352d2591SJean-Christophe PLAGNIOL-VILLARD GET_OPTION ("pclk:", pPar->pixclock) 202*352d2591SJean-Christophe PLAGNIOL-VILLARD GET_OPTION ("depth:", bpp) 203*352d2591SJean-Christophe PLAGNIOL-VILLARD p += i; 204*352d2591SJean-Christophe PLAGNIOL-VILLARD if (*p != 0) 205*352d2591SJean-Christophe PLAGNIOL-VILLARD p++; /* skip ',' */ 206*352d2591SJean-Christophe PLAGNIOL-VILLARD } 207*352d2591SJean-Christophe PLAGNIOL-VILLARD return bpp; 208*352d2591SJean-Christophe PLAGNIOL-VILLARD } 209