Each modeline has ten parameters, beginning with a label for the resolution being specified. The second parameter specifies the rate of the pixel clock in megahertz. Then follow four numbers that together specify the x-resolution (width) and related parameters, and four numbers that specify the y-resolution (height).
Or, the modeline can be split into multiple lines for greater clarity
The horizontal and vertical frequencies can be calculated by:
For interlace mode, (frame rate)=(field rate)/2, otherwise (frame rate)=(field rate).
The numbers after the width and height are used to determine the front porch, sync pulse, and back porch timings. The resulting refresh rate or frame rate of the display can be determined by dividing the pixel clock frequency by the product of the horizontal and vertical field lengths. In this case, the display is operating at 155 , 000 , 000 / ( 2048 ∗ 1263 ) = 59.92 {\displaystyle 155,000,000/(2048*1263)=59.92} Hz.
Optionally, extra parameters for controlling the polarity of the horizontal and vertical sync pulses can be added. There are also options for interlaced and double scan modes. In most situations they will not be required.
Modelines may no longer be necessary in XFree86 versions 4 and higher,1 since for many monitors and HDTVs they are now calculated by the X server at startup based on two factors:
EDID is not always completely accurate, and for some situations such as older or unusual display hardware or many HDTVs, it will be necessary to create a modeline to get the setting right. The EDID information can be obtained by using the command "startx -- -logverbose 6" and looking at /var/log/XFree86.0.log.
XFree86 Video Timings HOWTO: 2. Why This HOWTO Is Obsolete http://en.tldp.org/HOWTO/XFree86-Video-Timings-HOWTO/obsolete.html ↩