media: ov5640: Add Omnivision OV5640 support
[linux-2.6.git] / drivers / video / modedb.c
index 1da2f84..34048e2 100644 (file)
@@ -12,9 +12,9 @@
  */
 
 #include <linux/module.h>
-#include <linux/tty.h>
+#include <linux/slab.h>
 #include <linux/fb.h>
-#include <linux/sched.h>
+#include <linux/kernel.h>
 
 #undef DEBUG
 
     ((v).xres == (x) && (v).yres == (y))
 
 #ifdef DEBUG
-#define DPRINTK(fmt, args...)  printk("modedb %s: " fmt, __FUNCTION__ , ## args)
+#define DPRINTK(fmt, args...)  printk("modedb %s: " fmt, __func__ , ## args)
 #else
 #define DPRINTK(fmt, args...)
 #endif
 
-const char *global_mode_option;
+const char *fb_mode_option;
+EXPORT_SYMBOL_GPL(fb_mode_option);
 
-    /*
-     *  Standard video mode definitions (taken from XFree86)
-     */
-
-#define DEFAULT_MODEDB_INDEX   0
+/*
+ *  Standard video mode definitions (taken from XFree86)
+ */
 
 static const struct fb_videomode modedb[] = {
-    {
+
        /* 640x400 @ 70 Hz, 31.5 kHz hsync */
-       NULL, 70, 640, 400, 39721, 40, 24, 39, 9, 96, 2,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 70, 640, 400, 39721, 40, 24, 39, 9, 96, 2, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 640x480 @ 60 Hz, 31.5 kHz hsync */
-       NULL, 60, 640, 480, 39721, 40, 24, 32, 11, 96, 2,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 60, 640, 480, 39721, 40, 24, 32, 11, 96, 2,     0,
+               FB_VMODE_NONINTERLACED },
+
        /* 800x600 @ 56 Hz, 35.15 kHz hsync */
-       NULL, 56, 800, 600, 27777, 128, 24, 22, 1, 72, 2,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 56, 800, 600, 27777, 128, 24, 22, 1, 72, 2,     0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1024x768 @ 87 Hz interlaced, 35.5 kHz hsync */
-       NULL, 87, 1024, 768, 22271, 56, 24, 33, 8, 160, 8,
-       0, FB_VMODE_INTERLACED
-    }, {
+       { NULL, 87, 1024, 768, 22271, 56, 24, 33, 8, 160, 8, 0,
+               FB_VMODE_INTERLACED },
+
        /* 640x400 @ 85 Hz, 37.86 kHz hsync */
-       NULL, 85, 640, 400, 31746, 96, 32, 41, 1, 64, 3,
-       FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 85, 640, 400, 31746, 96, 32, 41, 1, 64, 3,
+               FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED },
+
        /* 640x480 @ 72 Hz, 36.5 kHz hsync */
-       NULL, 72, 640, 480, 31746, 144, 40, 30, 8, 40, 3,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 72, 640, 480, 31746, 144, 40, 30, 8, 40, 3, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 640x480 @ 75 Hz, 37.50 kHz hsync */
-       NULL, 75, 640, 480, 31746, 120, 16, 16, 1, 64, 3,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 75, 640, 480, 31746, 120, 16, 16, 1, 64, 3,     0,
+               FB_VMODE_NONINTERLACED },
+
        /* 800x600 @ 60 Hz, 37.8 kHz hsync */
-       NULL, 60, 800, 600, 25000, 88, 40, 23, 1, 128, 4,
-       FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 60, 800, 600, 25000, 88, 40, 23, 1, 128, 4,
+               FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+               FB_VMODE_NONINTERLACED },
+
        /* 640x480 @ 85 Hz, 43.27 kHz hsync */
-       NULL, 85, 640, 480, 27777, 80, 56, 25, 1, 56, 3,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 85, 640, 480, 27777, 80, 56, 25, 1, 56, 3, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1152x864 @ 89 Hz interlaced, 44 kHz hsync */
-       NULL, 69, 1152, 864, 15384, 96, 16, 110, 1, 216, 10,
-       0, FB_VMODE_INTERLACED
-    }, {
+       { NULL, 89, 1152, 864, 15384, 96, 16, 110, 1, 216, 10, 0,
+               FB_VMODE_INTERLACED },
        /* 800x600 @ 72 Hz, 48.0 kHz hsync */
-       NULL, 72, 800, 600, 20000, 64, 56, 23, 37, 120, 6,
-       FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 72, 800, 600, 20000, 64, 56, 23, 37, 120, 6,
+               FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+               FB_VMODE_NONINTERLACED },
+
        /* 1024x768 @ 60 Hz, 48.4 kHz hsync */
-       NULL, 60, 1024, 768, 15384, 168, 8, 29, 3, 144, 6,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 60, 1024, 768, 15384, 168, 8, 29, 3, 144, 6, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 640x480 @ 100 Hz, 53.01 kHz hsync */
-       NULL, 100, 640, 480, 21834, 96, 32, 36, 8, 96, 6,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 100, 640, 480, 21834, 96, 32, 36, 8, 96, 6,     0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1152x864 @ 60 Hz, 53.5 kHz hsync */
-       NULL, 60, 1152, 864, 11123, 208, 64, 16, 4, 256, 8,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 60, 1152, 864, 11123, 208, 64, 16, 4, 256, 8, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 800x600 @ 85 Hz, 55.84 kHz hsync */
-       NULL, 85, 800, 600, 16460, 160, 64, 36, 16, 64, 5,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 85, 800, 600, 16460, 160, 64, 36, 16, 64, 5, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1024x768 @ 70 Hz, 56.5 kHz hsync */
-       NULL, 70, 1024, 768, 13333, 144, 24, 29, 3, 136, 6,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 70, 1024, 768, 13333, 144, 24, 29, 3, 136, 6, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1280x1024 @ 87 Hz interlaced, 51 kHz hsync */
-       NULL, 87, 1280, 1024, 12500, 56, 16, 128, 1, 216, 12,
-       0, FB_VMODE_INTERLACED
-    }, {
+       { NULL, 87, 1280, 1024, 12500, 56, 16, 128, 1, 216, 12, 0,
+               FB_VMODE_INTERLACED },
+
        /* 800x600 @ 100 Hz, 64.02 kHz hsync */
-       NULL, 100, 800, 600, 14357, 160, 64, 30, 4, 64, 6,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 100, 800, 600, 14357, 160, 64, 30, 4, 64, 6, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1024x768 @ 76 Hz, 62.5 kHz hsync */
-       NULL, 76, 1024, 768, 11764, 208, 8, 36, 16, 120, 3,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 76, 1024, 768, 11764, 208, 8, 36, 16, 120, 3, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1152x864 @ 70 Hz, 62.4 kHz hsync */
-       NULL, 70, 1152, 864, 10869, 106, 56, 20, 1, 160, 10,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 70, 1152, 864, 10869, 106, 56, 20, 1, 160, 10, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1280x1024 @ 61 Hz, 64.2 kHz hsync */
-       NULL, 61, 1280, 1024, 9090, 200, 48, 26, 1, 184, 3,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 61, 1280, 1024, 9090, 200, 48, 26, 1, 184, 3, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1400x1050 @ 60Hz, 63.9 kHz hsync */
-       NULL, 68, 1400, 1050, 9259, 136, 40, 13, 1, 112, 3,
-       0, FB_VMODE_NONINTERLACED       
-    }, {
+       { NULL, 60, 1400, 1050, 9259, 136, 40, 13, 1, 112, 3, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1400x1050 @ 75,107 Hz, 82,392 kHz +hsync +vsync*/
-       NULL, 75, 1400, 1050, 9271, 120, 56, 13, 0, 112, 3,
-       FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 75, 1400, 1050, 7190, 120, 56, 23, 10, 112, 13,
+               FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+               FB_VMODE_NONINTERLACED },
+
        /* 1400x1050 @ 60 Hz, ? kHz +hsync +vsync*/
-        NULL, 60, 1400, 1050, 9259, 128, 40, 12, 0, 112, 3,
-       FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 60, 1400, 1050, 9259, 128, 40, 12, 0, 112, 3,
+               FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+               FB_VMODE_NONINTERLACED },
+
        /* 1024x768 @ 85 Hz, 70.24 kHz hsync */
-       NULL, 85, 1024, 768, 10111, 192, 32, 34, 14, 160, 6,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 85, 1024, 768, 10111, 192, 32, 34, 14, 160, 6, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1152x864 @ 78 Hz, 70.8 kHz hsync */
-       NULL, 78, 1152, 864, 9090, 228, 88, 32, 0, 84, 12,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 78, 1152, 864, 9090, 228, 88, 32, 0, 84, 12, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1280x1024 @ 70 Hz, 74.59 kHz hsync */
-       NULL, 70, 1280, 1024, 7905, 224, 32, 28, 8, 160, 8,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 70, 1280, 1024, 7905, 224, 32, 28, 8, 160, 8, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1600x1200 @ 60Hz, 75.00 kHz hsync */
-       NULL, 60, 1600, 1200, 6172, 304, 64, 46, 1, 192, 3,
-       FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 60, 1600, 1200, 6172, 304, 64, 46, 1, 192, 3,
+               FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+               FB_VMODE_NONINTERLACED },
+
        /* 1152x864 @ 84 Hz, 76.0 kHz hsync */
-       NULL, 84, 1152, 864, 7407, 184, 312, 32, 0, 128, 12,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 84, 1152, 864, 7407, 184, 312, 32, 0, 128, 12, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1280x1024 @ 74 Hz, 78.85 kHz hsync */
-       NULL, 74, 1280, 1024, 7407, 256, 32, 34, 3, 144, 3,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 74, 1280, 1024, 7407, 256, 32, 34, 3, 144, 3, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1024x768 @ 100Hz, 80.21 kHz hsync */
-       NULL, 100, 1024, 768, 8658, 192, 32, 21, 3, 192, 10,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 100, 1024, 768, 8658, 192, 32, 21, 3, 192, 10, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1280x1024 @ 76 Hz, 81.13 kHz hsync */
-       NULL, 76, 1280, 1024, 7407, 248, 32, 34, 3, 104, 3,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 76, 1280, 1024, 7407, 248, 32, 34, 3, 104, 3, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1600x1200 @ 70 Hz, 87.50 kHz hsync */
-       NULL, 70, 1600, 1200, 5291, 304, 64, 46, 1, 192, 3,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 70, 1600, 1200, 5291, 304, 64, 46, 1, 192, 3, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1152x864 @ 100 Hz, 89.62 kHz hsync */
-       NULL, 100, 1152, 864, 7264, 224, 32, 17, 2, 128, 19,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 100, 1152, 864, 7264, 224, 32, 17, 2, 128, 19, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1280x1024 @ 85 Hz, 91.15 kHz hsync */
-       NULL, 85, 1280, 1024, 6349, 224, 64, 44, 1, 160, 3,
-       FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 85, 1280, 1024, 6349, 224, 64, 44, 1, 160, 3,
+               FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+               FB_VMODE_NONINTERLACED },
+
        /* 1600x1200 @ 75 Hz, 93.75 kHz hsync */
-       NULL, 75, 1600, 1200, 4938, 304, 64, 46, 1, 192, 3,
-       FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 75, 1600, 1200, 4938, 304, 64, 46, 1, 192, 3,
+               FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+               FB_VMODE_NONINTERLACED },
+
+       /* 1680x1050 @ 60 Hz, 65.191 kHz hsync */
+       { NULL, 60, 1680, 1050, 6848, 280, 104, 30, 3, 176, 6,
+               FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+               FB_VMODE_NONINTERLACED },
+
        /* 1600x1200 @ 85 Hz, 105.77 kHz hsync */
-       NULL, 85, 1600, 1200, 4545, 272, 16, 37, 4, 192, 3,
-       FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 85, 1600, 1200, 4545, 272, 16, 37, 4, 192, 3,
+               FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+               FB_VMODE_NONINTERLACED },
+
        /* 1280x1024 @ 100 Hz, 107.16 kHz hsync */
-       NULL, 100, 1280, 1024, 5502, 256, 32, 26, 7, 128, 15,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 100, 1280, 1024, 5502, 256, 32, 26, 7, 128, 15, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 1800x1440 @ 64Hz, 96.15 kHz hsync  */
-       NULL, 64, 1800, 1440, 4347, 304, 96, 46, 1, 192, 3,
-       FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 64, 1800, 1440, 4347, 304, 96, 46, 1, 192, 3,
+               FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+               FB_VMODE_NONINTERLACED },
+
        /* 1800x1440 @ 70Hz, 104.52 kHz hsync  */
-       NULL, 70, 1800, 1440, 4000, 304, 96, 46, 1, 192, 3,
-       FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 70, 1800, 1440, 4000, 304, 96, 46, 1, 192, 3,
+               FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+               FB_VMODE_NONINTERLACED },
+
        /* 512x384 @ 78 Hz, 31.50 kHz hsync */
-       NULL, 78, 512, 384, 49603, 48, 16, 16, 1, 64, 3,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 78, 512, 384, 49603, 48, 16, 16, 1, 64, 3, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 512x384 @ 85 Hz, 34.38 kHz hsync */
-       NULL, 85, 512, 384, 45454, 48, 16, 16, 1, 64, 3,
-       0, FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 85, 512, 384, 45454, 48, 16, 16, 1, 64, 3, 0,
+               FB_VMODE_NONINTERLACED },
+
        /* 320x200 @ 70 Hz, 31.5 kHz hsync, 8:5 aspect ratio */
-       NULL, 70, 320, 200, 79440, 16, 16, 20, 4, 48, 1,
-       0, FB_VMODE_DOUBLE
-    }, {
+       { NULL, 70, 320, 200, 79440, 16, 16, 20, 4, 48, 1, 0,
+               FB_VMODE_DOUBLE },
+
        /* 320x240 @ 60 Hz, 31.5 kHz hsync, 4:3 aspect ratio */
-       NULL, 60, 320, 240, 79440, 16, 16, 16, 5, 48, 1,
-       0, FB_VMODE_DOUBLE
-    }, {
+       { NULL, 60, 320, 240, 79440, 16, 16, 16, 5, 48, 1, 0,
+               FB_VMODE_DOUBLE },
+
        /* 320x240 @ 72 Hz, 36.5 kHz hsync */
-       NULL, 72, 320, 240, 63492, 16, 16, 16, 4, 48, 2,
-       0, FB_VMODE_DOUBLE
-    }, {
+       { NULL, 72, 320, 240, 63492, 16, 16, 16, 4, 48, 2, 0,
+               FB_VMODE_DOUBLE },
+
        /* 400x300 @ 56 Hz, 35.2 kHz hsync, 4:3 aspect ratio */
-       NULL, 56, 400, 300, 55555, 64, 16, 10, 1, 32, 1,
-       0, FB_VMODE_DOUBLE
-    }, {
+       { NULL, 56, 400, 300, 55555, 64, 16, 10, 1, 32, 1, 0,
+               FB_VMODE_DOUBLE },
+
        /* 400x300 @ 60 Hz, 37.8 kHz hsync */
-       NULL, 60, 400, 300, 50000, 48, 16, 11, 1, 64, 2,
-       0, FB_VMODE_DOUBLE
-    }, {
+       { NULL, 60, 400, 300, 50000, 48, 16, 11, 1, 64, 2, 0,
+               FB_VMODE_DOUBLE },
+
        /* 400x300 @ 72 Hz, 48.0 kHz hsync */
-       NULL, 72, 400, 300, 40000, 32, 24, 11, 19, 64, 3,
-       0, FB_VMODE_DOUBLE
-    }, {
+       { NULL, 72, 400, 300, 40000, 32, 24, 11, 19, 64, 3,     0,
+               FB_VMODE_DOUBLE },
+
        /* 480x300 @ 56 Hz, 35.2 kHz hsync, 8:5 aspect ratio */
-       NULL, 56, 480, 300, 46176, 80, 16, 10, 1, 40, 1,
-       0, FB_VMODE_DOUBLE
-    }, {
+       { NULL, 56, 480, 300, 46176, 80, 16, 10, 1, 40, 1, 0,
+               FB_VMODE_DOUBLE },
+
        /* 480x300 @ 60 Hz, 37.8 kHz hsync */
-       NULL, 60, 480, 300, 41858, 56, 16, 11, 1, 80, 2,
-       0, FB_VMODE_DOUBLE
-    }, {
+       { NULL, 60, 480, 300, 41858, 56, 16, 11, 1, 80, 2, 0,
+               FB_VMODE_DOUBLE },
+
        /* 480x300 @ 63 Hz, 39.6 kHz hsync */
-       NULL, 63, 480, 300, 40000, 56, 16, 11, 1, 80, 2,
-       0, FB_VMODE_DOUBLE
-    }, {
+       { NULL, 63, 480, 300, 40000, 56, 16, 11, 1, 80, 2, 0,
+               FB_VMODE_DOUBLE },
+
        /* 480x300 @ 72 Hz, 48.0 kHz hsync */
-       NULL, 72, 480, 300, 33386, 40, 24, 11, 19, 80, 3,
-       0, FB_VMODE_DOUBLE
-    }, {
+       { NULL, 72, 480, 300, 33386, 40, 24, 11, 19, 80, 3, 0,
+               FB_VMODE_DOUBLE },
+
        /* 1920x1200 @ 60 Hz, 74.5 Khz hsync */
-       NULL, 60, 1920, 1200, 5177, 128, 336, 1, 38, 208, 3,
-       FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
-       FB_VMODE_NONINTERLACED
-    }, {
+       { NULL, 60, 1920, 1200, 5177, 128, 336, 1, 38, 208, 3,
+               FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+               FB_VMODE_NONINTERLACED },
+
        /* 1152x768, 60 Hz, PowerBook G4 Titanium I and II */
-       NULL, 60, 1152, 768, 15386, 158, 26, 29, 3, 136, 6,
-       FB_SYNC_HOR_HIGH_ACT|FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED
-    },
+       { NULL, 60, 1152, 768, 14047, 158, 26, 29, 3, 136, 6,
+               FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+               FB_VMODE_NONINTERLACED },
+
+       /* 1366x768, 60 Hz, 47.403 kHz hsync, WXGA 16:9 aspect ratio */
+       { NULL, 60, 1366, 768, 13806, 120, 10, 14, 3, 32, 5, 0,
+               FB_VMODE_NONINTERLACED },
+
+       /* 1280x800, 60 Hz, 47.403 kHz hsync, WXGA 16:10 aspect ratio */
+       { NULL, 60, 1280, 800, 12048, 200, 64, 24, 1, 136, 3, 0,
+               FB_VMODE_NONINTERLACED },
+
+       /* 720x576i @ 50 Hz, 15.625 kHz hsync (PAL RGB) */
+       { NULL, 50, 720, 576, 74074, 64, 16, 39, 5, 64, 5, 0,
+               FB_VMODE_INTERLACED },
+
+       /* 800x520i @ 50 Hz, 15.625 kHz hsync (PAL RGB) */
+       { NULL, 50, 800, 520, 58823, 144, 64, 72, 28, 80, 5, 0,
+               FB_VMODE_INTERLACED },
+
+       /* 864x480 @ 60 Hz, 35.15 kHz hsync */
+       { NULL, 60, 864, 480, 27777, 1, 1, 1, 1, 0, 0,
+               0, FB_VMODE_NONINTERLACED },
 };
 
 #ifdef CONFIG_FB_MODE_HELPERS
-const struct fb_videomode vesa_modes[] = {
+const struct fb_videomode cea_modes[CEA_MODEDB_SIZE] = {
+       {},
+       /* 1: 640x480p @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 640, .yres = 480, .pixclock = 39721,
+        .left_margin = 48, .right_margin = 16,
+        .upper_margin = 33, .lower_margin = 1,
+        .hsync_len = 96, .vsync_len = 2,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 2: 720x480p @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 720, .yres = 480, .pixclock = 37037,
+        .left_margin = 60, .right_margin = 16,
+        .upper_margin = 30, .lower_margin = 9,
+        .hsync_len = 62, .vsync_len = 6,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 3: 720x480p @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 720, .yres = 480, .pixclock = 37037,
+        .left_margin = 60, .right_margin = 16,
+        .upper_margin = 30, .lower_margin = 9,
+        .hsync_len = 62, .vsync_len = 6,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 4: 1280x720p @ 59.94Hz/60Hz */
+       {.refresh = 60, .xres = 1280, .yres = 720, .pixclock = 13468,
+        .left_margin = 220, .right_margin = 110,
+        .upper_margin = 20, .lower_margin = 5,
+        .hsync_len = 40, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 5: 1920x1080i @ 59.94Hz/60Hz */
+       {.refresh = 60, .xres = 1920, .yres = 1080, .pixclock = 13468,
+        .left_margin = 148, .right_margin = 88,
+        .upper_margin = 15, .lower_margin = 2,
+        .hsync_len = 44, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 6: 720(1440)x480i @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 1440, .yres = 480, .pixclock = 37037,
+        .left_margin = 114, .right_margin = 38,
+        .upper_margin = 15, .lower_margin = 4,
+        .hsync_len = 124, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 7: 720(1440)x480i @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 1440, .yres = 480, .pixclock = 37037,
+        .left_margin = 114, .right_margin = 38,
+        .upper_margin = 15, .lower_margin = 4,
+        .hsync_len = 124, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 8: 720(1440)x240p @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 1440, .yres = 240, .pixclock = 37037,
+        .left_margin = 114, .right_margin = 38,
+        .upper_margin = 15, .lower_margin = 5,
+        .hsync_len = 124, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 9: 720(1440)x240p @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 1440, .yres = 240, .pixclock = 37037,
+        .left_margin = 114, .right_margin = 38,
+        .upper_margin = 15, .lower_margin = 5,
+        .hsync_len = 124, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 10: 2880x480i @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 2880, .yres = 480, .pixclock = 18518,
+        .left_margin = 228, .right_margin = 76,
+        .upper_margin = 15, .lower_margin = 4,
+        .hsync_len = 248, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 11: 2880x480i @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 2880, .yres = 480, .pixclock = 18518,
+        .left_margin = 228, .right_margin = 76,
+        .upper_margin = 15, .lower_margin = 4,
+        .hsync_len = 248, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 12: 2880x240p @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 2880, .yres = 240, .pixclock = 18518,
+        .left_margin = 228, .right_margin = 76,
+        .upper_margin = 15, .lower_margin = 5,
+        .hsync_len = 248, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 13: 2880x240p @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 2880, .yres = 240, .pixclock = 18518,
+        .left_margin = 228, .right_margin = 76,
+        .upper_margin = 15, .lower_margin = 5,
+        .hsync_len = 248, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 14: 1440x480p @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 1440, .yres = 480, .pixclock = 18518,
+        .left_margin = 120, .right_margin = 32,
+        .upper_margin = 30, .lower_margin = 9,
+        .hsync_len = 124, .vsync_len = 6,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 15: 1440x480p @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 1440, .yres = 480, .pixclock = 18518,
+        .left_margin = 120, .right_margin = 32,
+        .upper_margin = 30, .lower_margin = 9,
+        .hsync_len = 124, .vsync_len = 6,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 16: 1920x1080p @ 59.94Hz/60Hz */
+       {.refresh = 60, .xres = 1920, .yres = 1080, .pixclock = 6734,
+        .left_margin = 148, .right_margin = 88,
+        .upper_margin = 36, .lower_margin = 4,
+        .hsync_len = 44, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 17: 720x576p @ 50Hz */
+       {.refresh = 50, .xres = 720, .yres = 576, .pixclock = 37037,
+        .left_margin = 68, .right_margin = 12,
+        .upper_margin = 39, .lower_margin = 5,
+        .hsync_len = 64, .vsync_len = 5,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 18: 720x576p @ 50Hz */
+       {.refresh = 50, .xres = 720, .yres = 576, .pixclock = 37037,
+        .left_margin = 68, .right_margin = 12,
+        .upper_margin = 39, .lower_margin = 5,
+        .hsync_len = 64, .vsync_len = 5,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 19: 1280x720p @ 50Hz */
+       {.refresh = 50, .xres = 1280, .yres = 720, .pixclock = 13468,
+        .left_margin = 220, .right_margin = 440,
+        .upper_margin = 20, .lower_margin = 5,
+        .hsync_len = 40, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 20: 1920x1080i @ 50Hz */
+       {.refresh = 50, .xres = 1920, .yres = 1080, .pixclock = 13468,
+        .left_margin = 148, .right_margin = 528,
+        .upper_margin = 15, .lower_margin = 2,
+        .hsync_len = 44, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 21: 720(1440)x576i @ 50Hz */
+       {.refresh = 50, .xres = 1440, .yres = 576, .pixclock = 37037,
+        .left_margin = 138, .right_margin = 24,
+        .upper_margin = 19, .lower_margin = 2,
+        .hsync_len = 126, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 22: 720(1440)x576i @ 50Hz */
+       {.refresh = 50, .xres = 1440, .yres = 576, .pixclock = 37037,
+        .left_margin = 138, .right_margin = 24,
+        .upper_margin = 19, .lower_margin = 2,
+        .hsync_len = 126, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 23: 720(1440)x288p @ 50Hz */
+       {.refresh = 49, .xres = 1440, .yres = 288, .pixclock = 37037,
+        .left_margin = 138, .right_margin = 24,
+        .upper_margin = 19, .lower_margin = 4,
+        .hsync_len = 126, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 24: 720(1440)x288p @ 50Hz */
+       {.refresh = 49, .xres = 1440, .yres = 288, .pixclock = 37037,
+        .left_margin = 138, .right_margin = 24,
+        .upper_margin = 19, .lower_margin = 4,
+        .hsync_len = 126, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 25: 2880x576i @ 50Hz */
+       {.refresh = 50, .xres = 2880, .yres = 576, .pixclock = 18518,
+        .left_margin = 276, .right_margin = 48,
+        .upper_margin = 19, .lower_margin = 2,
+        .hsync_len = 252, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 26: 2880x576i @ 50Hz */
+       {.refresh = 50, .xres = 2880, .yres = 576, .pixclock = 18518,
+        .left_margin = 276, .right_margin = 48,
+        .upper_margin = 19, .lower_margin = 2,
+        .hsync_len = 252, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 27: 2880x288p @ 50Hz */
+       {.refresh = 49, .xres = 2880, .yres = 288, .pixclock = 18518,
+        .left_margin = 276, .right_margin = 48,
+        .upper_margin = 19, .lower_margin = 4,
+        .hsync_len = 252, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 28: 2880x288p @ 50Hz */
+       {.refresh = 49, .xres = 2880, .yres = 288, .pixclock = 18518,
+        .left_margin = 276, .right_margin = 48,
+        .upper_margin = 19, .lower_margin = 4,
+        .hsync_len = 252, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 29: 1440x576p @ 50Hz */
+       {.refresh = 50, .xres = 1440, .yres = 576, .pixclock = 18518,
+        .left_margin = 136, .right_margin = 24,
+        .upper_margin = 39, .lower_margin = 5,
+        .hsync_len = 128, .vsync_len = 5,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 30: 1440x576p @ 50Hz */
+       {.refresh = 50, .xres = 1440, .yres = 576, .pixclock = 18518,
+        .left_margin = 136, .right_margin = 24,
+        .upper_margin = 39, .lower_margin = 5,
+        .hsync_len = 128, .vsync_len = 5,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 31: 1920x1080p @ 50Hz */
+       {.refresh = 50, .xres = 1920, .yres = 1080, .pixclock = 6734,
+        .left_margin = 148, .right_margin = 528,
+        .upper_margin = 36, .lower_margin = 4,
+        .hsync_len = 44, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 32: 1920x1080p @ 23.97Hz/24Hz */
+       {.refresh = 24, .xres = 1920, .yres = 1080, .pixclock = 13468,
+        .left_margin = 148, .right_margin = 638,
+        .upper_margin = 36, .lower_margin = 4,
+        .hsync_len = 44, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 33: 1920x1080p @ 25Hz */
+       {.refresh = 25, .xres = 1920, .yres = 1080, .pixclock = 13468,
+        .left_margin = 148, .right_margin = 528,
+        .upper_margin = 36, .lower_margin = 4,
+        .hsync_len = 44, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 34: 1920x1080p @ 29.97Hz/30Hz */
+       {.refresh = 30, .xres = 1920, .yres = 1080, .pixclock = 13468,
+        .left_margin = 148, .right_margin = 88,
+        .upper_margin = 36, .lower_margin = 4,
+        .hsync_len = 44, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 35: 2880x480p @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 2880, .yres = 480, .pixclock = 9259,
+        .left_margin = 240, .right_margin = 64,
+        .upper_margin = 30, .lower_margin = 9,
+        .hsync_len = 248, .vsync_len = 6,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 36: 2880x480p @ 59.94Hz/60Hz */
+       {.refresh = 59, .xres = 2880, .yres = 480, .pixclock = 9259,
+        .left_margin = 240, .right_margin = 64,
+        .upper_margin = 30, .lower_margin = 9,
+        .hsync_len = 248, .vsync_len = 6,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 37: 2880x576p @ 50Hz */
+       {.refresh = 50, .xres = 2880, .yres = 576, .pixclock = 9259,
+        .left_margin = 272, .right_margin = 48,
+        .upper_margin = 39, .lower_margin = 5,
+        .hsync_len = 256, .vsync_len = 5,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 38: 2880x576p @ 50Hz */
+       {.refresh = 50, .xres = 2880, .yres = 576, .pixclock = 9259,
+        .left_margin = 272, .right_margin = 48,
+        .upper_margin = 39, .lower_margin = 5,
+        .hsync_len = 256, .vsync_len = 5,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 39: 1920x1080i @ 50Hz */
+       {.refresh = 50, .xres = 1920, .yres = 1080, .pixclock = 13888,
+        .left_margin = 184, .right_margin = 32,
+        .upper_margin = 57, .lower_margin = 2,
+        .hsync_len = 168, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 40: 1920x1080i @ 100Hz */
+       {.refresh = 100, .xres = 1920, .yres = 1080, .pixclock = 6734,
+        .left_margin = 148, .right_margin = 528,
+        .upper_margin = 15, .lower_margin = 2,
+        .hsync_len = 44, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 41: 1280x720p @ 100Hz */
+       {.refresh = 100, .xres = 1280, .yres = 720, .pixclock = 6734,
+        .left_margin = 220, .right_margin = 440,
+        .upper_margin = 20, .lower_margin = 5,
+        .hsync_len = 40, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 42: 720x576p @ 100Hz */
+       {.refresh = 100, .xres = 720, .yres = 576, .pixclock = 18518,
+        .left_margin = 68, .right_margin = 12,
+        .upper_margin = 39, .lower_margin = 5,
+        .hsync_len = 64, .vsync_len = 5,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 43: 720x576p @ 100Hz */
+       {.refresh = 100, .xres = 720, .yres = 576, .pixclock = 18518,
+        .left_margin = 68, .right_margin = 12,
+        .upper_margin = 39, .lower_margin = 5,
+        .hsync_len = 64, .vsync_len = 5,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 44: 720(1440)x576i @ 100Hz */
+       {.refresh = 100, .xres = 1440, .yres = 576, .pixclock = 18518,
+        .left_margin = 138, .right_margin = 24,
+        .upper_margin = 19, .lower_margin = 2,
+        .hsync_len = 126, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 45: 720(1440)x576i @ 100Hz */
+       {.refresh = 100, .xres = 1440, .yres = 576, .pixclock = 18518,
+        .left_margin = 138, .right_margin = 24,
+        .upper_margin = 19, .lower_margin = 2,
+        .hsync_len = 126, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 46: 1920x1080i @ 119.88/120Hz */
+       {.refresh = 120, .xres = 1920, .yres = 1080, .pixclock = 6734,
+        .left_margin = 148, .right_margin = 88,
+        .upper_margin = 15, .lower_margin = 2,
+        .hsync_len = 44, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 47: 1280x720p @ 119.88/120Hz */
+       {.refresh = 120, .xres = 1280, .yres = 720, .pixclock = 6734,
+        .left_margin = 220, .right_margin = 110,
+        .upper_margin = 20, .lower_margin = 5,
+        .hsync_len = 40, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 48: 720x480p @ 119.88/120Hz */
+       {.refresh = 119, .xres = 720, .yres = 480, .pixclock = 18518,
+        .left_margin = 60, .right_margin = 16,
+        .upper_margin = 30, .lower_margin = 9,
+        .hsync_len = 62, .vsync_len = 6,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 49: 720x480p @ 119.88/120Hz */
+       {.refresh = 119, .xres = 720, .yres = 480, .pixclock = 18518,
+        .left_margin = 60, .right_margin = 16,
+        .upper_margin = 30, .lower_margin = 9,
+        .hsync_len = 62, .vsync_len = 6,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 50: 720(1440)x480i @ 119.88/120Hz */
+       {.refresh = 119, .xres = 1440, .yres = 480, .pixclock = 18518,
+        .left_margin = 114, .right_margin = 38,
+        .upper_margin = 15, .lower_margin = 4,
+        .hsync_len = 124, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 51: 720(1440)x480i @ 119.88/120Hz */
+       {.refresh = 119, .xres = 1440, .yres = 480, .pixclock = 18518,
+        .left_margin = 114, .right_margin = 38,
+        .upper_margin = 15, .lower_margin = 4,
+        .hsync_len = 124, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 52: 720x576p @ 200Hz */
+       {.refresh = 200, .xres = 720, .yres = 576, .pixclock = 9259,
+        .left_margin = 68, .right_margin = 12,
+        .upper_margin = 39, .lower_margin = 5,
+        .hsync_len = 64, .vsync_len = 5,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 53: 720x576p @ 200Hz */
+       {.refresh = 200, .xres = 720, .yres = 576, .pixclock = 9259,
+        .left_margin = 68, .right_margin = 12,
+        .upper_margin = 39, .lower_margin = 5,
+        .hsync_len = 64, .vsync_len = 5,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 54: 720(1440)x576i @ 200Hz */
+       {.refresh = 200, .xres = 1440, .yres = 576, .pixclock = 9259,
+        .left_margin = 138, .right_margin = 24,
+        .upper_margin = 19, .lower_margin = 2,
+        .hsync_len = 126, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 55: 720(1440)x576i @ 200Hz */
+       {.refresh = 200, .xres = 1440, .yres = 576, .pixclock = 9259,
+        .left_margin = 138, .right_margin = 24,
+        .upper_margin = 19, .lower_margin = 2,
+        .hsync_len = 126, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 56: 720x480p @ 239.76/240Hz */
+       {.refresh = 239, .xres = 720, .yres = 480, .pixclock = 9259,
+        .left_margin = 60, .right_margin = 16,
+        .upper_margin = 30, .lower_margin = 9,
+        .hsync_len = 62, .vsync_len = 6,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 57: 720x480p @ 239.76/240Hz */
+       {.refresh = 239, .xres = 720, .yres = 480, .pixclock = 9259,
+        .left_margin = 60, .right_margin = 16,
+        .upper_margin = 30, .lower_margin = 9,
+        .hsync_len = 62, .vsync_len = 6,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 58: 720(1440)x480i @ 239.76/240Hz */
+       {.refresh = 239, .xres = 1440, .yres = 480, .pixclock = 9259,
+        .left_margin = 114, .right_margin = 38,
+        .upper_margin = 15, .lower_margin = 4,
+        .hsync_len = 124, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_4_3 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 59: 720(1440)x480i @ 239.76/240Hz */
+       {.refresh = 239, .xres = 1440, .yres = 480, .pixclock = 9259,
+        .left_margin = 114, .right_margin = 38,
+        .upper_margin = 15, .lower_margin = 4,
+        .hsync_len = 124, .vsync_len = 3,
+        .sync = 0,
+        .flag = FB_FLAG_RATIO_16_9 | FB_FLAG_PIXEL_REPEAT,
+        .vmode = FB_VMODE_INTERLACED},
+       /* 60: 1280x720p @ 23.97Hz/24Hz */
+       {.refresh = 24, .xres = 1280, .yres = 720, .pixclock = 16835,
+        .left_margin = 220, .right_margin = 1760,
+        .upper_margin = 20, .lower_margin = 5,
+        .hsync_len = 40, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 61: 1280x720p @ 25Hz */
+       {.refresh = 25, .xres = 1280, .yres = 720, .pixclock = 13468,
+        .left_margin = 220, .right_margin = 2420,
+        .upper_margin = 20, .lower_margin = 5,
+        .hsync_len = 40, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 62: 1280x720p @ 29.97Hz/30Hz */
+       {.refresh = 30, .xres = 1280, .yres = 720, .pixclock = 13468,
+        .left_margin = 220, .right_margin = 1760,
+        .upper_margin = 20, .lower_margin = 5,
+        .hsync_len = 40, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 63: 1920x1080p @ 119.88/120Hz */
+       {.refresh = 120, .xres = 1920, .yres = 1080, .pixclock = 3367,
+        .left_margin = 148, .right_margin = 88,
+        .upper_margin = 36, .lower_margin = 4,
+        .hsync_len = 44, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+       /* 64: 1920x1080p @ 100Hz */
+       {.refresh = 100, .xres = 1920, .yres = 1080, .pixclock = 3367,
+        .left_margin = 148, .right_margin = 528,
+        .upper_margin = 36, .lower_margin = 4,
+        .hsync_len = 44, .vsync_len = 5,
+        .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
+        .flag = FB_FLAG_RATIO_16_9,
+        .vmode = FB_VMODE_NONINTERLACED},
+};
+EXPORT_SYMBOL(cea_modes);
+
+const struct fb_videomode vesa_modes[VESA_MODEDB_SIZE] = {
        /* 0 640x350-85 VESA */
        { NULL, 85, 640, 350, 31746,  96, 32, 60, 32, 64, 3,
          FB_SYNC_HOR_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA},
@@ -270,10 +820,10 @@ const struct fb_videomode vesa_modes[] = {
        { NULL, 85, 721, 400, 28169, 108, 36, 42, 01, 72, 3,
          FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
        /* 3 640x480-60 VESA */
-       { NULL, 60, 640, 480, 39682,  48, 16, 33, 10, 96, 2, 
+       { NULL, 60, 640, 480, 39682,  48, 16, 33, 10, 96, 2,
          0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
        /* 4 640x480-72 VESA */
-       { NULL, 72, 640, 480, 31746, 128, 24, 29, 9, 40, 2, 
+       { NULL, 72, 640, 480, 31746, 128, 24, 29, 9, 40, 2,
          0, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
        /* 5 640x480-75 VESA */
        { NULL, 75, 640, 480, 31746, 120, 16, 16, 01, 64, 3,
@@ -302,7 +852,7 @@ const struct fb_videomode vesa_modes[] = {
          FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
          FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
         /* 12 1024x768i-43 VESA */
-       { NULL, 53, 1024, 768, 22271, 56, 8, 41, 0, 176, 8,
+       { NULL, 43, 1024, 768, 22271, 56, 8, 41, 0, 176, 8,
          FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
          FB_VMODE_INTERLACED, FB_MODE_IS_VESA },
        /* 13 1024x768-60 VESA */
@@ -320,7 +870,7 @@ const struct fb_videomode vesa_modes[] = {
          FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
          FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
        /* 17 1152x864-75 VESA */
-       { NULL, 75, 1153, 864, 9259, 256, 64, 32, 1, 128, 3,
+       { NULL, 75, 1152, 864, 9259, 256, 64, 32, 1, 128, 3,
          FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
          FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
        /* 18 1280x960-60 VESA */
@@ -356,7 +906,7 @@ const struct fb_videomode vesa_modes[] = {
          FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
          FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
        /* 26 1600x1200-75 VESA */
-       { NULL, 75, 1600, 1200, 4938, 304, 64, 46, 1, 192, 3, 
+       { NULL, 75, 1600, 1200, 4938, 304, 64, 46, 1, 192, 3,
          FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
          FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
        /* 27 1600x1200-85 VESA */
@@ -379,27 +929,12 @@ const struct fb_videomode vesa_modes[] = {
        { NULL, 60, 1920, 1440, 4273, 344, 128, 56, 1, 200, 3,
          FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
        /* 33 1920x1440-75 VESA */
-       { NULL, 60, 1920, 1440, 3367, 352, 144, 56, 1, 224, 3,
+       { NULL, 75, 1920, 1440, 3367, 352, 144, 56, 1, 224, 3,
          FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED, FB_MODE_IS_VESA },
 };
 EXPORT_SYMBOL(vesa_modes);
 #endif /* CONFIG_FB_MODE_HELPERS */
 
-static int my_atoi(const char *name)
-{
-    int val = 0;
-
-    for (;; name++) {
-       switch (*name) {
-           case '0'...'9':
-               val = 10*val+(*name-'0');
-               break;
-           default:
-               return val;
-       }
-    }
-}
-
 /**
  *     fb_try_mode - test a video mode
  *     @var: frame buffer user defined part of display
@@ -496,21 +1031,25 @@ int fb_find_mode(struct fb_var_screeninfo *var,
     /* Set up defaults */
     if (!db) {
        db = modedb;
-       dbsize = sizeof(modedb)/sizeof(*modedb);
+       dbsize = ARRAY_SIZE(modedb);
     }
+
     if (!default_mode)
-       default_mode = &modedb[DEFAULT_MODEDB_INDEX];
+       default_mode = &db[0];
+
     if (!default_bpp)
        default_bpp = 8;
 
     /* Did the user specify a video mode? */
-    if (mode_option || (mode_option = global_mode_option)) {
+    if (!mode_option)
+       mode_option = fb_mode_option;
+    if (mode_option) {
        const char *name = mode_option;
        unsigned int namelen = strlen(name);
        int res_specified = 0, bpp_specified = 0, refresh_specified = 0;
        unsigned int xres = 0, yres = 0, bpp = default_bpp, refresh = 0;
        int yres_specified = 0, cvt = 0, rb = 0, interlace = 0, margins = 0;
-       u32 best, diff;
+       u32 best, diff, tdiff;
 
        for (i = namelen-1; i >= 0; i--) {
            switch (name[i]) {
@@ -518,7 +1057,7 @@ int fb_find_mode(struct fb_var_screeninfo *var,
                    namelen = i;
                    if (!refresh_specified && !bpp_specified &&
                        !yres_specified) {
-                       refresh = my_atoi(&name[i+1]);
+                       refresh = simple_strtol(&name[i+1], NULL, 10);
                        refresh_specified = 1;
                        if (cvt || rb)
                            cvt = 0;
@@ -528,7 +1067,7 @@ int fb_find_mode(struct fb_var_screeninfo *var,
                case '-':
                    namelen = i;
                    if (!bpp_specified && !yres_specified) {
-                       bpp = my_atoi(&name[i+1]);
+                       bpp = simple_strtol(&name[i+1], NULL, 10);
                        bpp_specified = 1;
                        if (cvt || rb)
                            cvt = 0;
@@ -537,12 +1076,12 @@ int fb_find_mode(struct fb_var_screeninfo *var,
                    break;
                case 'x':
                    if (!yres_specified) {
-                       yres = my_atoi(&name[i+1]);
+                       yres = simple_strtol(&name[i+1], NULL, 10);
                        yres_specified = 1;
                    } else
                        goto done;
                    break;
-               case '0'...'9':
+               case '0' ... '9':
                    break;
                case 'M':
                    if (!yres_specified)
@@ -565,7 +1104,7 @@ int fb_find_mode(struct fb_var_screeninfo *var,
            }
        }
        if (i < 0 && yres_specified) {
-           xres = my_atoi(name);
+           xres = simple_strtol(name, NULL, 10);
            res_specified = 1;
        }
 done:
@@ -578,6 +1117,7 @@ done:
                    "", (margins) ? " with margins" : "", (interlace) ?
                    " interlaced" : "");
 
+           memset(&cvt_mode, 0, sizeof(cvt_mode));
            cvt_mode.xres = xres;
            cvt_mode.yres = yres;
            cvt_mode.refresh = (refresh) ? refresh : 60;
@@ -600,43 +1140,66 @@ done:
        DPRINTK("Trying specified video mode%s %ix%i\n",
            refresh_specified ? "" : " (ignoring refresh rate)", xres, yres);
 
-       diff = refresh;
+       if (!refresh_specified) {
+               /*
+                * If the caller has provided a custom mode database and a
+                * valid monspecs structure, we look for the mode with the
+                * highest refresh rate.  Otherwise we play it safe it and
+                * try to find a mode with a refresh rate closest to the
+                * standard 60 Hz.
+                */
+               if (db != modedb &&
+                   info->monspecs.vfmin && info->monspecs.vfmax &&
+                   info->monspecs.hfmin && info->monspecs.hfmax &&
+                   info->monspecs.dclkmax) {
+                       refresh = 1000;
+               } else {
+                       refresh = 60;
+               }
+       }
+
+       diff = -1;
        best = -1;
        for (i = 0; i < dbsize; i++) {
-               if ((name_matches(db[i], name, namelen) &&
-                       !fb_try_mode(var, info, &db[i], bpp)))
-                       return 1;
-               if (res_specified && res_matches(db[i], xres, yres)) {
-                       if(!fb_try_mode(var, info, &db[i], bpp)) {
-                               if(!refresh_specified || db[i].refresh == refresh)
-                                       return 1;
-                               else {
-                                       if(diff > abs(db[i].refresh - refresh)) {
-                                               diff = abs(db[i].refresh - refresh);
-                                               best = i;
-                                       }
+               if ((name_matches(db[i], name, namelen) ||
+                   (res_specified && res_matches(db[i], xres, yres))) &&
+                   !fb_try_mode(var, info, &db[i], bpp)) {
+                       if (refresh_specified && db[i].refresh == refresh) {
+                               return 1;
+                       } else {
+                               if (abs(db[i].refresh - refresh) < diff) {
+                                       diff = abs(db[i].refresh - refresh);
+                                       best = i;
                                }
                        }
                }
        }
        if (best != -1) {
                fb_try_mode(var, info, &db[best], bpp);
-               return 2;
+               return (refresh_specified) ? 2 : 1;
        }
 
-       diff = xres + yres;
+       diff = 2 * (xres + yres);
        best = -1;
        DPRINTK("Trying best-fit modes\n");
        for (i = 0; i < dbsize; i++) {
-           if (xres <= db[i].xres && yres <= db[i].yres) {
                DPRINTK("Trying %ix%i\n", db[i].xres, db[i].yres);
                if (!fb_try_mode(var, info, &db[i], bpp)) {
-                   if (diff > (db[i].xres - xres) + (db[i].yres - yres)) {
-                       diff = (db[i].xres - xres) + (db[i].yres - yres);
-                       best = i;
-                   }
+                       tdiff = abs(db[i].xres - xres) +
+                               abs(db[i].yres - yres);
+
+                       /*
+                        * Penalize modes with resolutions smaller
+                        * than requested.
+                        */
+                       if (xres > db[i].xres || yres > db[i].yres)
+                               tdiff += xres + yres;
+
+                       if (diff > tdiff) {
+                               diff = tdiff;
+                               best = i;
+                       }
                }
-           }
        }
        if (best != -1) {
            fb_try_mode(var, info, &db[best], bpp);
@@ -663,7 +1226,7 @@ done:
  * @var: pointer to struct fb_var_screeninfo
  */
 void fb_var_to_videomode(struct fb_videomode *mode,
-                        struct fb_var_screeninfo *var)
+                        const struct fb_var_screeninfo *var)
 {
        u32 pixclock, hfreq, htotal, vtotal;
 
@@ -678,7 +1241,7 @@ void fb_var_to_videomode(struct fb_videomode *mode,
        mode->upper_margin = var->upper_margin;
        mode->lower_margin = var->lower_margin;
        mode->sync = var->sync;
-       mode->vmode = var->vmode & FB_VMODE_MASK;
+       mode->vmode = var->vmode & (FB_VMODE_MASK | FB_VMODE_STEREO_MASK);
        mode->flag = FB_MODE_IS_FROM_VAR;
        mode->refresh = 0;
 
@@ -707,19 +1270,23 @@ void fb_var_to_videomode(struct fb_videomode *mode,
  * @mode: pointer to struct fb_videomode
  */
 void fb_videomode_to_var(struct fb_var_screeninfo *var,
-                              struct fb_videomode *mode)
+                        const struct fb_videomode *mode)
 {
        var->xres = mode->xres;
        var->yres = mode->yres;
+       var->xres_virtual = mode->xres;
+       var->yres_virtual = mode->yres;
+       var->xoffset = 0;
+       var->yoffset = 0;
        var->pixclock = mode->pixclock;
        var->left_margin = mode->left_margin;
-       var->hsync_len = mode->hsync_len;
-       var->vsync_len = mode->vsync_len;
        var->right_margin = mode->right_margin;
        var->upper_margin = mode->upper_margin;
        var->lower_margin = mode->lower_margin;
+       var->hsync_len = mode->hsync_len;
+       var->vsync_len = mode->vsync_len;
        var->sync = mode->sync;
-       var->vmode = mode->vmode & FB_VMODE_MASK;
+       var->vmode = mode->vmode & (FB_VMODE_MASK | FB_VMODE_STEREO_MASK);
 }
 
 /**
@@ -730,8 +1297,8 @@ void fb_videomode_to_var(struct fb_var_screeninfo *var,
  * RETURNS:
  * 1 if equal, 0 if not
  */
-int fb_mode_is_equal(struct fb_videomode *mode1,
-                    struct fb_videomode *mode2)
+int fb_mode_is_equal(const struct fb_videomode *mode1,
+                    const struct fb_videomode *mode2)
 {
        return (mode1->xres         == mode2->xres &&
                mode1->yres         == mode2->yres &&
@@ -763,8 +1330,8 @@ int fb_mode_is_equal(struct fb_videomode *mode1,
  * var->xres and var->yres.  If more than 1 videomode is found, will return
  * the videomode with the highest refresh rate
  */
-struct fb_videomode *fb_find_best_mode(struct fb_var_screeninfo *var,
-                                      struct list_head *head)
+const struct fb_videomode *fb_find_best_mode(const struct fb_var_screeninfo *var,
+                                            struct list_head *head)
 {
        struct list_head *pos;
        struct fb_modelist *modelist;
@@ -783,8 +1350,9 @@ struct fb_videomode *fb_find_best_mode(struct fb_var_screeninfo *var,
                        if (diff > d) {
                                diff = d;
                                best = mode;
-                       } else if (diff == d && mode->refresh > best->refresh)
-                           best = mode;
+                       } else if (diff == d && best &&
+                                  mode->refresh > best->refresh)
+                               best = mode;
                }
        }
        return best;
@@ -800,8 +1368,8 @@ struct fb_videomode *fb_find_best_mode(struct fb_var_screeninfo *var,
  * If more than 1 videomode is found, will return the videomode with
  * the closest refresh rate.
  */
-struct fb_videomode *fb_find_nearest_mode(struct fb_videomode *mode,
-                                         struct list_head *head)
+const struct fb_videomode *fb_find_nearest_mode(const struct fb_videomode *mode,
+                                               struct list_head *head)
 {
        struct list_head *pos;
        struct fb_modelist *modelist;
@@ -818,6 +1386,7 @@ struct fb_videomode *fb_find_nearest_mode(struct fb_videomode *mode,
                        abs(cmode->yres - mode->yres);
                if (diff > d) {
                        diff = d;
+                       diff_refresh = abs(cmode->refresh - mode->refresh);
                        best = cmode;
                } else if (diff == d) {
                        d = abs(cmode->refresh - mode->refresh);
@@ -839,8 +1408,8 @@ struct fb_videomode *fb_find_nearest_mode(struct fb_videomode *mode,
  * RETURNS:
  * struct fb_videomode, NULL if none found
  */
-struct fb_videomode *fb_match_mode(struct fb_var_screeninfo *var,
-                                  struct list_head *head)
+const struct fb_videomode *fb_match_mode(const struct fb_var_screeninfo *var,
+                                        struct list_head *head)
 {
        struct list_head *pos;
        struct fb_modelist *modelist;
@@ -857,14 +1426,14 @@ struct fb_videomode *fb_match_mode(struct fb_var_screeninfo *var,
 }
 
 /**
- * fb_add_videomode: adds videomode entry to modelist
+ * fb_add_videomode - adds videomode entry to modelist
  * @mode: videomode to add
  * @head: struct list_head of modelist
  *
  * NOTES:
  * Will only add unmatched mode entries
  */
-int fb_add_videomode(struct fb_videomode *mode, struct list_head *head)
+int fb_add_videomode(const struct fb_videomode *mode, struct list_head *head)
 {
        struct list_head *pos;
        struct fb_modelist *modelist;
@@ -886,20 +1455,21 @@ int fb_add_videomode(struct fb_videomode *mode, struct list_head *head)
                if (!modelist)
                        return -ENOMEM;
                modelist->mode = *mode;
-               list_add(&modelist->list, head);
+               list_add_tail(&modelist->list, head);
        }
        return 0;
 }
 
 /**
- * fb_delete_videomode: removed videomode entry from modelist
+ * fb_delete_videomode - removed videomode entry from modelist
  * @mode: videomode to remove
  * @head: struct list_head of modelist
  *
  * NOTES:
  * Will remove all matching mode entries
  */
-void fb_delete_videomode(struct fb_videomode *mode, struct list_head *head)
+void fb_delete_videomode(const struct fb_videomode *mode,
+                        struct list_head *head)
 {
        struct list_head *pos, *n;
        struct fb_modelist *modelist;
@@ -916,7 +1486,7 @@ void fb_delete_videomode(struct fb_videomode *mode, struct list_head *head)
 }
 
 /**
- * fb_destroy_modelist: destroy modelist
+ * fb_destroy_modelist - destroy modelist
  * @head: struct list_head of modelist
  */
 void fb_destroy_modelist(struct list_head *head)
@@ -928,14 +1498,15 @@ void fb_destroy_modelist(struct list_head *head)
                kfree(pos);
        }
 }
+EXPORT_SYMBOL_GPL(fb_destroy_modelist);
 
 /**
- * fb_videomode_to_modelist: convert mode array to mode list
+ * fb_videomode_to_modelist - convert mode array to mode list
  * @modedb: array of struct fb_videomode
  * @num: number of entries in array
  * @head: struct list_head of modelist
  */
-void fb_videomode_to_modelist(struct fb_videomode *modedb, int num,
+void fb_videomode_to_modelist(const struct fb_videomode *modedb, int num,
                              struct list_head *head)
 {
        int i;
@@ -948,12 +1519,12 @@ void fb_videomode_to_modelist(struct fb_videomode *modedb, int num,
        }
 }
 
-struct fb_videomode *fb_find_best_display(struct fb_monspecs *specs,
-                                         struct list_head *head)
+const struct fb_videomode *fb_find_best_display(const struct fb_monspecs *specs,
+                                               struct list_head *head)
 {
        struct list_head *pos;
        struct fb_modelist *modelist;
-       struct fb_videomode *m, *m1 = NULL, *md = NULL, *best = NULL;
+       const struct fb_videomode *m, *m1 = NULL, *md = NULL, *best = NULL;
        int first = 0;
 
        if (!head->prev || !head->next || list_empty(head))
@@ -1012,10 +1583,9 @@ EXPORT_SYMBOL(fb_videomode_to_var);
 EXPORT_SYMBOL(fb_var_to_videomode);
 EXPORT_SYMBOL(fb_mode_is_equal);
 EXPORT_SYMBOL(fb_add_videomode);
-EXPORT_SYMBOL(fb_delete_videomode);
-EXPORT_SYMBOL(fb_destroy_modelist);
 EXPORT_SYMBOL(fb_match_mode);
 EXPORT_SYMBOL(fb_find_best_mode);
 EXPORT_SYMBOL(fb_find_nearest_mode);
 EXPORT_SYMBOL(fb_videomode_to_modelist);
 EXPORT_SYMBOL(fb_find_mode);
+EXPORT_SYMBOL(fb_find_mode_cvt);