转贴:
我接触Linux有一年多了.Linux给我以优雅体面的感觉,在Linux下面工作,心情都和在MS Windows下面不一样.
但是X Window 的刷新率一直是我心中的痛.我不知道用xf86config设置了多少遍,xf86config的选择我背都背得下来,但是X Window还是有闪烁感.我想X的设置怎么这么保守.因此,我喜欢Linux的字符模式.上网只能在MS Windows下面了.前几天我痛下决心一定要把刷新率给搞定,开始看有关X的文档.原来我误会了,XF86的目标就是充分地利用硬件,哪是什么保守.是我自己不看文档.下面就是我认为最值得看的几篇文章:
/usr/X11R6/lib/X11/doc/README.Config
/usr/X11R6/lib/X11/doc/QuickStart.doc
/usr/X11R6/lib/X11/doc/VideoMode.doc
特别是最后那篇文章彻底解决了刷新率的问题.现在我就谈点体会.有什么不清楚的话,请看原文.
先介绍一些术语:
HSF:显示器的水平扫描频率,单位是kHz
VSF:垂直刷新率,单位是Hz
显卡的"dot-clock",正式名称是driving clock frequency(DCF),它表示每秒钟能
向屏幕发出的象素数,单位是MHz
RR:刷新率(refresh rate)
HR:水平分辨率
VR:垂直分辨率
frame:帧,由于显示器的扫描枪扫描到屏幕边缘的时候不可能马上回来,会有一段调
整的时间,这时候它仍在
扫描,但对我们来说是不可见的.因此帧比HRxVR略大些.
HFL:帧宽,比HR略大些,经验HFL = 1.25HR
VFL:帧长,比VR略大些,经验VFL = 1.05VR
下面就是很重要的公式:
RR = DCF/(HFL*VFL)
HFL = DCF/HSF
或 HSF = DCF/HFL
我们的问题就是:在给定分辨率和刷新率的条件下,显卡的DCF是多少?水平扫描频率(HSF)是多少,它是否超出了
显示器所能允许的最大水平扫描频率?
我们看到,在这里显卡的DCF不是问题,就是最一般的S3 Trio64V+的DCF也有135MHz,瓶颈是显示器所能允许的最大水平扫描频率.我们在启动X的时候会看到许多模式不能用,就是因为经过计算,水平扫描频率超出了显示器所能允许的最大水平扫描频率.
事情还没有完:
在XF86Config文件里,有许多这样的行:
Mode "800x600" 55.2 800 832 1064 1096 600 602 610 630
也许写成这样看得更清楚些:
Mode "800x600" 55.2 800 832 1064 1096
600 602 610 630
Mode是关键词,引号中的800x600是名称,可以随便起. 55.2就是DCF,800和600当然就是分辨率了,1096和630是帧宽和帧长(HFL,VFL).中间两个数是什么意思呢?原来它们决定了同步脉冲的开始位置和结束位置.
800 832 1064 1096 这组数可以这样理解:
水平分辨率是800,扫描枪扫到第800个象素的时候还要继续往前扫,到第832个象素的时候,发出同步脉冲,该脉冲持续一段时间,到第1064个象素的时候结束.扫描枪扫继续往前扫,到达帧宽的时候返回到最左边,扫描下一条线.
600 602 610 630是垂直方面的,也可以这样理解.这就是这组神密数字的含义.
自己从头生成一组这样的数字是挺麻烦的,我的做法是修改当前使用的模式,比如我用的是xf86config自动生成的800x600模式,但刷新率偏低. 我就找到XF86Config文件中对应的行,直接增大DCF的值,再计算一下:水平扫描频率HSF=DCF/HFL .只要水平扫描频率不超出显示器所能允许的最大水平扫描频率就行.再到X Window中用xvidtune微调一下.