2 * Copyright 1998-2008 VIA Technologies, Inc. All Rights Reserved.
3 * Copyright 2001-2008 S3 Graphics, Inc. All Rights Reserved.
5 * This program is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU General Public
7 * License as published by the Free Software Foundation;
8 * either version 2, or (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTIES OR REPRESENTATIONS; without even
12 * the implied warranty of MERCHANTABILITY or FITNESS FOR
13 * A PARTICULAR PURPOSE.See the GNU General Public License
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
19 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
25 /* Define Return Value */
33 /* Define Bit Field */
43 /* Video Memory Size */
44 #define VIDEO_MEMORY_SIZE_16M 0x1000000
46 /* standard VGA IO port
48 #define VIARMisc 0x3CC
49 #define VIAWMisc 0x3C2
50 #define VIAStatus 0x3DA
68 /* Define Color Depth */
77 /* Sequencer Registers */
122 /* CRT Controller Registers */
149 /* Extend CRT Controller Registers */
271 #define LUT_DATA 0x3C9 /* DACDATA */
272 #define LUT_INDEX_READ 0x3C7 /* DACRX */
273 #define LUT_INDEX_WRITE 0x3C8 /* DACWX */
274 #define DACMASK 0x3C6
276 /* Definition Device */
277 #define DEVICE_CRT 0x01
278 #define DEVICE_DVI 0x03
279 #define DEVICE_LCD 0x04
281 /* Device output interface */
282 #define INTERFACE_NONE 0x00
283 #define INTERFACE_ANALOG_RGB 0x01
284 #define INTERFACE_DVP0 0x02
285 #define INTERFACE_DVP1 0x03
286 #define INTERFACE_DFP_HIGH 0x04
287 #define INTERFACE_DFP_LOW 0x05
288 #define INTERFACE_DFP 0x06
289 #define INTERFACE_LVDS0 0x07
290 #define INTERFACE_LVDS1 0x08
291 #define INTERFACE_LVDS0LVDS1 0x09
292 #define INTERFACE_TMDS 0x0A
294 #define HW_LAYOUT_LCD_ONLY 0x01
295 #define HW_LAYOUT_DVI_ONLY 0x02
296 #define HW_LAYOUT_LCD_DVI 0x03
297 #define HW_LAYOUT_LCD1_LCD2 0x04
298 #define HW_LAYOUT_LCD_EXTERNAL_LCD2 0x10
300 /* Definition Refresh Rate */
301 #define REFRESH_50 50
302 #define REFRESH_60 60
303 #define REFRESH_75 75
304 #define REFRESH_85 85
305 #define REFRESH_100 100
306 #define REFRESH_120 120
308 /* Definition Sync Polarity*/
312 /*480x640@60 Sync Polarity (GTF)
314 #define M480X640_R60_HSP NEGATIVE
315 #define M480X640_R60_VSP POSITIVE
317 /*640x480@60 Sync Polarity (VESA Mode)
319 #define M640X480_R60_HSP NEGATIVE
320 #define M640X480_R60_VSP NEGATIVE
322 /*640x480@75 Sync Polarity (VESA Mode)
324 #define M640X480_R75_HSP NEGATIVE
325 #define M640X480_R75_VSP NEGATIVE
327 /*640x480@85 Sync Polarity (VESA Mode)
329 #define M640X480_R85_HSP NEGATIVE
330 #define M640X480_R85_VSP NEGATIVE
332 /*640x480@100 Sync Polarity (GTF Mode)
334 #define M640X480_R100_HSP NEGATIVE
335 #define M640X480_R100_VSP POSITIVE
337 /*640x480@120 Sync Polarity (GTF Mode)
339 #define M640X480_R120_HSP NEGATIVE
340 #define M640X480_R120_VSP POSITIVE
342 /*720x480@60 Sync Polarity (GTF Mode)
344 #define M720X480_R60_HSP NEGATIVE
345 #define M720X480_R60_VSP POSITIVE
347 /*720x576@60 Sync Polarity (GTF Mode)
349 #define M720X576_R60_HSP NEGATIVE
350 #define M720X576_R60_VSP POSITIVE
352 /*800x600@60 Sync Polarity (VESA Mode)
354 #define M800X600_R60_HSP POSITIVE
355 #define M800X600_R60_VSP POSITIVE
357 /*800x600@75 Sync Polarity (VESA Mode)
359 #define M800X600_R75_HSP POSITIVE
360 #define M800X600_R75_VSP POSITIVE
362 /*800x600@85 Sync Polarity (VESA Mode)
364 #define M800X600_R85_HSP POSITIVE
365 #define M800X600_R85_VSP POSITIVE
367 /*800x600@100 Sync Polarity (GTF Mode)
369 #define M800X600_R100_HSP NEGATIVE
370 #define M800X600_R100_VSP POSITIVE
372 /*800x600@120 Sync Polarity (GTF Mode)
374 #define M800X600_R120_HSP NEGATIVE
375 #define M800X600_R120_VSP POSITIVE
377 /*800x480@60 Sync Polarity (CVT Mode)
379 #define M800X480_R60_HSP NEGATIVE
380 #define M800X480_R60_VSP POSITIVE
382 /*848x480@60 Sync Polarity (CVT Mode)
384 #define M848X480_R60_HSP NEGATIVE
385 #define M848X480_R60_VSP POSITIVE
387 /*852x480@60 Sync Polarity (GTF Mode)
389 #define M852X480_R60_HSP NEGATIVE
390 #define M852X480_R60_VSP POSITIVE
392 /*1024x512@60 Sync Polarity (GTF Mode)
394 #define M1024X512_R60_HSP NEGATIVE
395 #define M1024X512_R60_VSP POSITIVE
397 /*1024x600@60 Sync Polarity (GTF Mode)
399 #define M1024X600_R60_HSP NEGATIVE
400 #define M1024X600_R60_VSP POSITIVE
402 /*1024x768@60 Sync Polarity (VESA Mode)
404 #define M1024X768_R60_HSP NEGATIVE
405 #define M1024X768_R60_VSP NEGATIVE
407 /*1024x768@75 Sync Polarity (VESA Mode)
409 #define M1024X768_R75_HSP POSITIVE
410 #define M1024X768_R75_VSP POSITIVE
412 /*1024x768@85 Sync Polarity (VESA Mode)
414 #define M1024X768_R85_HSP POSITIVE
415 #define M1024X768_R85_VSP POSITIVE
417 /*1024x768@100 Sync Polarity (GTF Mode)
419 #define M1024X768_R100_HSP NEGATIVE
420 #define M1024X768_R100_VSP POSITIVE
422 /*1152x864@75 Sync Polarity (VESA Mode)
424 #define M1152X864_R75_HSP POSITIVE
425 #define M1152X864_R75_VSP POSITIVE
427 /*1280x720@60 Sync Polarity (GTF Mode)
429 #define M1280X720_R60_HSP NEGATIVE
430 #define M1280X720_R60_VSP POSITIVE
432 /* 1280x768@50 Sync Polarity (GTF Mode) */
433 #define M1280X768_R50_HSP NEGATIVE
434 #define M1280X768_R50_VSP POSITIVE
436 /*1280x768@60 Sync Polarity (GTF Mode)
438 #define M1280X768_R60_HSP NEGATIVE
439 #define M1280X768_R60_VSP POSITIVE
441 /*1280x800@60 Sync Polarity (CVT Mode)
443 #define M1280X800_R60_HSP NEGATIVE
444 #define M1280X800_R60_VSP POSITIVE
446 /*1280x960@60 Sync Polarity (VESA Mode)
448 #define M1280X960_R60_HSP POSITIVE
449 #define M1280X960_R60_VSP POSITIVE
451 /*1280x1024@60 Sync Polarity (VESA Mode)
453 #define M1280X1024_R60_HSP POSITIVE
454 #define M1280X1024_R60_VSP POSITIVE
456 /* 1360x768@60 Sync Polarity (CVT Mode) */
457 #define M1360X768_R60_HSP POSITIVE
458 #define M1360X768_R60_VSP POSITIVE
460 /* 1360x768@60 Sync Polarity (CVT Reduce Blanking Mode) */
461 #define M1360X768_RB_R60_HSP POSITIVE
462 #define M1360X768_RB_R60_VSP NEGATIVE
464 /* 1368x768@50 Sync Polarity (GTF Mode) */
465 #define M1368X768_R50_HSP NEGATIVE
466 #define M1368X768_R50_VSP POSITIVE
468 /* 1368x768@60 Sync Polarity (VESA Mode) */
469 #define M1368X768_R60_HSP NEGATIVE
470 #define M1368X768_R60_VSP POSITIVE
472 /*1280x1024@75 Sync Polarity (VESA Mode)
474 #define M1280X1024_R75_HSP POSITIVE
475 #define M1280X1024_R75_VSP POSITIVE
477 /*1280x1024@85 Sync Polarity (VESA Mode)
479 #define M1280X1024_R85_HSP POSITIVE
480 #define M1280X1024_R85_VSP POSITIVE
482 /*1440x1050@60 Sync Polarity (GTF Mode)
484 #define M1440X1050_R60_HSP NEGATIVE
485 #define M1440X1050_R60_VSP POSITIVE
487 /*1600x1200@60 Sync Polarity (VESA Mode)
489 #define M1600X1200_R60_HSP POSITIVE
490 #define M1600X1200_R60_VSP POSITIVE
492 /*1600x1200@75 Sync Polarity (VESA Mode)
494 #define M1600X1200_R75_HSP POSITIVE
495 #define M1600X1200_R75_VSP POSITIVE
497 /* 1680x1050@60 Sync Polarity (CVT Mode) */
498 #define M1680x1050_R60_HSP NEGATIVE
499 #define M1680x1050_R60_VSP NEGATIVE
501 /* 1680x1050@60 Sync Polarity (CVT Reduce Blanking Mode) */
502 #define M1680x1050_RB_R60_HSP POSITIVE
503 #define M1680x1050_RB_R60_VSP NEGATIVE
505 /* 1680x1050@75 Sync Polarity (CVT Mode) */
506 #define M1680x1050_R75_HSP NEGATIVE
507 #define M1680x1050_R75_VSP POSITIVE
509 /*1920x1080@60 Sync Polarity (CVT Mode)
511 #define M1920X1080_R60_HSP NEGATIVE
512 #define M1920X1080_R60_VSP POSITIVE
514 /* 1920x1080@60 Sync Polarity (CVT Reduce Blanking Mode) */
515 #define M1920X1080_RB_R60_HSP POSITIVE
516 #define M1920X1080_RB_R60_VSP NEGATIVE
518 /*1920x1440@60 Sync Polarity (VESA Mode)
520 #define M1920X1440_R60_HSP NEGATIVE
521 #define M1920X1440_R60_VSP POSITIVE
523 /*1920x1440@75 Sync Polarity (VESA Mode)
525 #define M1920X1440_R75_HSP NEGATIVE
526 #define M1920X1440_R75_VSP POSITIVE
529 /* 1400x1050@60 Sync Polarity (VESA Mode) */
530 #define M1400X1050_R60_HSP NEGATIVE
531 #define M1400X1050_R60_VSP NEGATIVE
534 /* 1400x1050@60 Sync Polarity (CVT Mode) */
535 #define M1400X1050_R60_HSP NEGATIVE
536 #define M1400X1050_R60_VSP POSITIVE
538 /* 1400x1050@60 Sync Polarity (CVT Reduce Blanking Mode) */
539 #define M1400X1050_RB_R60_HSP POSITIVE
540 #define M1400X1050_RB_R60_VSP NEGATIVE
542 /* 1400x1050@75 Sync Polarity (CVT Mode) */
543 #define M1400X1050_R75_HSP NEGATIVE
544 #define M1400X1050_R75_VSP POSITIVE
546 /* 960x600@60 Sync Polarity (CVT Mode) */
547 #define M960X600_R60_HSP NEGATIVE
548 #define M960X600_R60_VSP POSITIVE
550 /* 1000x600@60 Sync Polarity (GTF Mode) */
551 #define M1000X600_R60_HSP NEGATIVE
552 #define M1000X600_R60_VSP POSITIVE
554 /* 1024x576@60 Sync Polarity (GTF Mode) */
555 #define M1024X576_R60_HSP NEGATIVE
556 #define M1024X576_R60_VSP POSITIVE
558 /*1024x600@60 Sync Polarity (GTF Mode)*/
559 #define M1024X600_R60_HSP NEGATIVE
560 #define M1024X600_R60_VSP POSITIVE
562 /* 1088x612@60 Sync Polarity (CVT Mode) */
563 #define M1088X612_R60_HSP NEGATIVE
564 #define M1088X612_R60_VSP POSITIVE
566 /* 1152x720@60 Sync Polarity (CVT Mode) */
567 #define M1152X720_R60_HSP NEGATIVE
568 #define M1152X720_R60_VSP POSITIVE
570 /* 1200x720@60 Sync Polarity (GTF Mode) */
571 #define M1200X720_R60_HSP NEGATIVE
572 #define M1200X720_R60_VSP POSITIVE
574 /* 1280x600@60 Sync Polarity (GTF Mode) */
575 #define M1280x600_R60_HSP NEGATIVE
576 #define M1280x600_R60_VSP POSITIVE
578 /* 1280x720@50 Sync Polarity (GTF Mode) */
579 #define M1280X720_R50_HSP NEGATIVE
580 #define M1280X720_R50_VSP POSITIVE
582 /* 1280x720@60 Sync Polarity (CEA Mode) */
583 #define M1280X720_CEA_R60_HSP POSITIVE
584 #define M1280X720_CEA_R60_VSP POSITIVE
586 /* 1440x900@60 Sync Polarity (CVT Mode) */
587 #define M1440X900_R60_HSP NEGATIVE
588 #define M1440X900_R60_VSP POSITIVE
590 /* 1440x900@75 Sync Polarity (CVT Mode) */
591 #define M1440X900_R75_HSP NEGATIVE
592 #define M1440X900_R75_VSP POSITIVE
594 /* 1440x900@60 Sync Polarity (CVT Reduce Blanking Mode) */
595 #define M1440X900_RB_R60_HSP POSITIVE
596 #define M1440X900_RB_R60_VSP NEGATIVE
598 /* 1600x900@60 Sync Polarity (CVT Mode) */
599 #define M1600X900_R60_HSP NEGATIVE
600 #define M1600X900_R60_VSP POSITIVE
602 /* 1600x900@60 Sync Polarity (CVT Reduce Blanking Mode) */
603 #define M1600X900_RB_R60_HSP POSITIVE
604 #define M1600X900_RB_R60_VSP NEGATIVE
606 /* 1600x1024@60 Sync Polarity (GTF Mode) */
607 #define M1600X1024_R60_HSP NEGATIVE
608 #define M1600X1024_R60_VSP POSITIVE
610 /* 1792x1344@60 Sync Polarity (DMT Mode) */
611 #define M1792x1344_R60_HSP NEGATIVE
612 #define M1792x1344_R60_VSP POSITIVE
614 /* 1856x1392@60 Sync Polarity (DMT Mode) */
615 #define M1856x1392_R60_HSP NEGATIVE
616 #define M1856x1392_R60_VSP POSITIVE
618 /* 1920x1200@60 Sync Polarity (CVT Mode) */
619 #define M1920X1200_R60_HSP NEGATIVE
620 #define M1920X1200_R60_VSP POSITIVE
622 /* 1920x1200@60 Sync Polarity (CVT Reduce Blanking Mode) */
623 #define M1920X1200_RB_R60_HSP POSITIVE
624 #define M1920X1200_RB_R60_VSP NEGATIVE
626 /* 1920x1080@60 Sync Polarity (CEA Mode) */
627 #define M1920X1080_CEA_R60_HSP POSITIVE
628 #define M1920X1080_CEA_R60_VSP POSITIVE
630 /* 2048x1536@60 Sync Polarity (CVT Mode) */
631 #define M2048x1536_R60_HSP NEGATIVE
632 #define M2048x1536_R60_VSP POSITIVE
634 /* define PLL index: */
635 #define CLK_25_175M 25175000
636 #define CLK_26_880M 26880000
637 #define CLK_29_581M 29581000
638 #define CLK_31_490M 31490000
639 #define CLK_31_500M 31500000
640 #define CLK_31_728M 31728000
641 #define CLK_32_668M 32688000
642 #define CLK_36_000M 36000000
643 #define CLK_40_000M 40000000
644 #define CLK_41_291M 41291000
645 #define CLK_43_163M 43163000
646 #define CLK_45_250M 45250000 /* 45.46MHz */
647 #define CLK_46_000M 46000000
648 #define CLK_46_996M 46996000
649 #define CLK_48_000M 48000000
650 #define CLK_48_875M 48875000
651 #define CLK_49_500M 49500000
652 #define CLK_52_406M 52406000
653 #define CLK_52_977M 52977000
654 #define CLK_56_250M 56250000
655 #define CLK_60_466M 60466000
656 #define CLK_61_500M 61500000
657 #define CLK_65_000M 65000000
658 #define CLK_65_178M 65178000
659 #define CLK_66_750M 66750000 /* 67.116MHz */
660 #define CLK_68_179M 68179000
661 #define CLK_69_924M 69924000
662 #define CLK_70_159M 70159000
663 #define CLK_72_000M 72000000
664 #define CLK_74_270M 74270000
665 #define CLK_78_750M 78750000
666 #define CLK_80_136M 80136000
667 #define CLK_83_375M 83375000
668 #define CLK_83_950M 83950000
669 #define CLK_84_750M 84750000 /* 84.537Mhz */
670 #define CLK_85_860M 85860000
671 #define CLK_88_750M 88750000
672 #define CLK_94_500M 94500000
673 #define CLK_97_750M 97750000
674 #define CLK_101_000M 101000000
675 #define CLK_106_500M 106500000
676 #define CLK_108_000M 108000000
677 #define CLK_113_309M 113309000
678 #define CLK_118_840M 118840000
679 #define CLK_119_000M 119000000
680 #define CLK_121_750M 121750000 /* 121.704MHz */
681 #define CLK_125_104M 125104000
682 #define CLK_133_308M 133308000
683 #define CLK_135_000M 135000000
684 #define CLK_136_700M 136700000
685 #define CLK_138_400M 138400000
686 #define CLK_146_760M 146760000
687 #define CLK_148_500M 148500000
689 #define CLK_153_920M 153920000
690 #define CLK_156_000M 156000000
691 #define CLK_157_500M 157500000
692 #define CLK_162_000M 162000000
693 #define CLK_187_000M 187000000
694 #define CLK_193_295M 193295000
695 #define CLK_202_500M 202500000
696 #define CLK_204_000M 204000000
697 #define CLK_218_500M 218500000
698 #define CLK_234_000M 234000000
699 #define CLK_267_250M 267250000
700 #define CLK_297_500M 297500000
701 #define CLK_74_481M 74481000
702 #define CLK_172_798M 172798000
703 #define CLK_122_614M 122614000
707 #define CLE266_PLL_25_175M 0x0000C763
708 #define CLE266_PLL_26_880M 0x0000440F
709 #define CLE266_PLL_29_581M 0x00008421
710 #define CLE266_PLL_31_490M 0x00004721
711 #define CLE266_PLL_31_500M 0x0000C3B5
712 #define CLE266_PLL_31_728M 0x0000471F
713 #define CLE266_PLL_32_668M 0x0000C449
714 #define CLE266_PLL_36_000M 0x0000C5E5
715 #define CLE266_PLL_40_000M 0x0000C459
716 #define CLE266_PLL_41_291M 0x00004417
717 #define CLE266_PLL_43_163M 0x0000C579
718 #define CLE266_PLL_45_250M 0x0000C57F /* 45.46MHz */
719 #define CLE266_PLL_46_000M 0x0000875A
720 #define CLE266_PLL_46_996M 0x0000C4E9
721 #define CLE266_PLL_48_000M 0x00001443
722 #define CLE266_PLL_48_875M 0x00001D63
723 #define CLE266_PLL_49_500M 0x00008653
724 #define CLE266_PLL_52_406M 0x0000C475
725 #define CLE266_PLL_52_977M 0x00004525
726 #define CLE266_PLL_56_250M 0x000047B7
727 #define CLE266_PLL_60_466M 0x0000494C
728 #define CLE266_PLL_61_500M 0x00001456
729 #define CLE266_PLL_65_000M 0x000086ED
730 #define CLE266_PLL_65_178M 0x0000855B
731 #define CLE266_PLL_66_750M 0x0000844B /* 67.116MHz */
732 #define CLE266_PLL_68_179M 0x00000413
733 #define CLE266_PLL_69_924M 0x00001153
734 #define CLE266_PLL_70_159M 0x00001462
735 #define CLE266_PLL_72_000M 0x00001879
736 #define CLE266_PLL_74_270M 0x00004853
737 #define CLE266_PLL_78_750M 0x00004321
738 #define CLE266_PLL_80_136M 0x0000051C
739 #define CLE266_PLL_83_375M 0x0000C25D
740 #define CLE266_PLL_83_950M 0x00000729
741 #define CLE266_PLL_84_750M 0x00008576 /* 84.537MHz */
742 #define CLE266_PLL_85_860M 0x00004754
743 #define CLE266_PLL_88_750M 0x0000051F
744 #define CLE266_PLL_94_500M 0x00000521
745 #define CLE266_PLL_97_750M 0x00004652
746 #define CLE266_PLL_101_000M 0x0000497F
747 #define CLE266_PLL_106_500M 0x00008477 /* 106.491463 MHz */
748 #define CLE266_PLL_108_000M 0x00008479
749 #define CLE266_PLL_113_309M 0x00000C5F
750 #define CLE266_PLL_118_840M 0x00004553
751 #define CLE266_PLL_119_000M 0x00000D6C
752 #define CLE266_PLL_121_750M 0x00004555 /* 121.704MHz */
753 #define CLE266_PLL_125_104M 0x000006B5
754 #define CLE266_PLL_133_308M 0x0000465F
755 #define CLE266_PLL_135_000M 0x0000455E
756 #define CLE266_PLL_136_700M 0x00000C73
757 #define CLE266_PLL_138_400M 0x00000957
758 #define CLE266_PLL_146_760M 0x00004567
759 #define CLE266_PLL_148_500M 0x00000853
760 #define CLE266_PLL_153_920M 0x00000856
761 #define CLE266_PLL_156_000M 0x0000456D
762 #define CLE266_PLL_157_500M 0x000005B7
763 #define CLE266_PLL_162_000M 0x00004571
764 #define CLE266_PLL_187_000M 0x00000976
765 #define CLE266_PLL_193_295M 0x0000086C
766 #define CLE266_PLL_202_500M 0x00000763
767 #define CLE266_PLL_204_000M 0x00000764
768 #define CLE266_PLL_218_500M 0x0000065C
769 #define CLE266_PLL_234_000M 0x00000662
770 #define CLE266_PLL_267_250M 0x00000670
771 #define CLE266_PLL_297_500M 0x000005E6
772 #define CLE266_PLL_74_481M 0x0000051A
773 #define CLE266_PLL_172_798M 0x00004579
774 #define CLE266_PLL_122_614M 0x0000073C
778 #define K800_PLL_25_175M 0x00539001
779 #define K800_PLL_26_880M 0x001C8C80
780 #define K800_PLL_29_581M 0x00409080
781 #define K800_PLL_31_490M 0x006F9001
782 #define K800_PLL_31_500M 0x008B9002
783 #define K800_PLL_31_728M 0x00AF9003
784 #define K800_PLL_32_668M 0x00909002
785 #define K800_PLL_36_000M 0x009F9002
786 #define K800_PLL_40_000M 0x00578C02
787 #define K800_PLL_41_291M 0x00438C01
788 #define K800_PLL_43_163M 0x00778C03
789 #define K800_PLL_45_250M 0x007D8C83 /* 45.46MHz */
790 #define K800_PLL_46_000M 0x00658C02
791 #define K800_PLL_46_996M 0x00818C83
792 #define K800_PLL_48_000M 0x00848C83
793 #define K800_PLL_48_875M 0x00508C81
794 #define K800_PLL_49_500M 0x00518C01
795 #define K800_PLL_52_406M 0x00738C02
796 #define K800_PLL_52_977M 0x00928C83
797 #define K800_PLL_56_250M 0x007C8C02
798 #define K800_PLL_60_466M 0x00A78C83
799 #define K800_PLL_61_500M 0x00AA8C83
800 #define K800_PLL_65_000M 0x006B8C01
801 #define K800_PLL_65_178M 0x00B48C83
802 #define K800_PLL_66_750M 0x00948C82 /* 67.116MHz */
803 #define K800_PLL_68_179M 0x00708C01
804 #define K800_PLL_69_924M 0x00C18C83
805 #define K800_PLL_70_159M 0x00C28C83
806 #define K800_PLL_72_000M 0x009F8C82
807 #define K800_PLL_74_270M 0x00ce0c03
808 #define K800_PLL_78_750M 0x00408801
809 #define K800_PLL_80_136M 0x00428801
810 #define K800_PLL_83_375M 0x005B0882
811 #define K800_PLL_83_950M 0x00738803
812 #define K800_PLL_84_750M 0x00748883 /* 84.477MHz */
813 #define K800_PLL_85_860M 0x00768883
814 #define K800_PLL_88_750M 0x007A8883
815 #define K800_PLL_94_500M 0x00828803
816 #define K800_PLL_97_750M 0x00878883
817 #define K800_PLL_101_000M 0x008B8883
818 #define K800_PLL_106_500M 0x00758882 /* 106.491463 MHz */
819 #define K800_PLL_108_000M 0x00778882
820 #define K800_PLL_113_309M 0x005D8881
821 #define K800_PLL_118_840M 0x00A48883
822 #define K800_PLL_119_000M 0x00838882
823 #define K800_PLL_121_750M 0x00A88883 /* 121.704MHz */
824 #define K800_PLL_125_104M 0x00688801
825 #define K800_PLL_133_308M 0x005D8801
826 #define K800_PLL_135_000M 0x001A4081
827 #define K800_PLL_136_700M 0x00BD8883
828 #define K800_PLL_138_400M 0x00728881
829 #define K800_PLL_146_760M 0x00CC8883
830 #define K800_PLL_148_500M 0x00ce0803
831 #define K800_PLL_153_920M 0x00548482
832 #define K800_PLL_156_000M 0x006B8483
833 #define K800_PLL_157_500M 0x00142080
834 #define K800_PLL_162_000M 0x006F8483
835 #define K800_PLL_187_000M 0x00818483
836 #define K800_PLL_193_295M 0x004F8481
837 #define K800_PLL_202_500M 0x00538481
838 #define K800_PLL_204_000M 0x008D8483
839 #define K800_PLL_218_500M 0x00978483
840 #define K800_PLL_234_000M 0x00608401
841 #define K800_PLL_267_250M 0x006E8481
842 #define K800_PLL_297_500M 0x00A48402
843 #define K800_PLL_74_481M 0x007B8C81
844 #define K800_PLL_172_798M 0x00778483
845 #define K800_PLL_122_614M 0x00878882
848 #define CX700_25_175M 0x008B1003
849 #define CX700_26_719M 0x00931003
850 #define CX700_26_880M 0x00941003
851 #define CX700_29_581M 0x00A49003
852 #define CX700_31_490M 0x00AE1003
853 #define CX700_31_500M 0x00AE1003
854 #define CX700_31_728M 0x00AF1003
855 #define CX700_32_668M 0x00B51003
856 #define CX700_36_000M 0x00C81003
857 #define CX700_40_000M 0x006E0C03
858 #define CX700_41_291M 0x00710C03
859 #define CX700_43_163M 0x00770C03
860 #define CX700_45_250M 0x007D0C03 /* 45.46MHz */
861 #define CX700_46_000M 0x007F0C03
862 #define CX700_46_996M 0x00818C83
863 #define CX700_48_000M 0x00840C03
864 #define CX700_48_875M 0x00508C81
865 #define CX700_49_500M 0x00880C03
866 #define CX700_52_406M 0x00730C02
867 #define CX700_52_977M 0x00920C03
868 #define CX700_56_250M 0x009B0C03
869 #define CX700_60_466M 0x00460C00
870 #define CX700_61_500M 0x00AA0C03
871 #define CX700_65_000M 0x006B0C01
872 #define CX700_65_178M 0x006B0C01
873 #define CX700_66_750M 0x00940C02 /*67.116MHz */
874 #define CX700_68_179M 0x00BC0C03
875 #define CX700_69_924M 0x00C10C03
876 #define CX700_70_159M 0x00C20C03
877 #define CX700_72_000M 0x009F0C02
878 #define CX700_74_270M 0x00CE0C03
879 #define CX700_74_481M 0x00CE0C03
880 #define CX700_78_750M 0x006C0803
881 #define CX700_80_136M 0x006E0803
882 #define CX700_83_375M 0x005B0882
883 #define CX700_83_950M 0x00730803
884 #define CX700_84_750M 0x00740803 /* 84.537Mhz */
885 #define CX700_85_860M 0x00760803
886 #define CX700_88_750M 0x00AC8885
887 #define CX700_94_500M 0x00820803
888 #define CX700_97_750M 0x00870803
889 #define CX700_101_000M 0x008B0803
890 #define CX700_106_500M 0x00750802
891 #define CX700_108_000M 0x00950803
892 #define CX700_113_309M 0x005D0801
893 #define CX700_118_840M 0x00A40803
894 #define CX700_119_000M 0x00830802
895 #define CX700_121_750M 0x00420800 /* 121.704MHz */
896 #define CX700_125_104M 0x00AD0803
897 #define CX700_133_308M 0x00930802
898 #define CX700_135_000M 0x00950802
899 #define CX700_136_700M 0x00BD0803
900 #define CX700_138_400M 0x00720801
901 #define CX700_146_760M 0x00CC0803
902 #define CX700_148_500M 0x00a40802
903 #define CX700_153_920M 0x00540402
904 #define CX700_156_000M 0x006B0403
905 #define CX700_157_500M 0x006C0403
906 #define CX700_162_000M 0x006F0403
907 #define CX700_172_798M 0x00770403
908 #define CX700_187_000M 0x00810403
909 #define CX700_193_295M 0x00850403
910 #define CX700_202_500M 0x008C0403
911 #define CX700_204_000M 0x008D0403
912 #define CX700_218_500M 0x00970403
913 #define CX700_234_000M 0x00600401
914 #define CX700_267_250M 0x00B90403
915 #define CX700_297_500M 0x00CE0403
916 #define CX700_122_614M 0x00870802
919 #define VX855_22_000M 0x007B1005
920 #define VX855_25_175M 0x008D1005
921 #define VX855_26_719M 0x00961005
922 #define VX855_26_880M 0x00961005
923 #define VX855_27_000M 0x00971005
924 #define VX855_29_581M 0x00A51005
925 #define VX855_29_829M 0x00641003
926 #define VX855_31_490M 0x00B01005
927 #define VX855_31_500M 0x00B01005
928 #define VX855_31_728M 0x008E1004
929 #define VX855_32_668M 0x00921004
930 #define VX855_36_000M 0x00A11004
931 #define VX855_40_000M 0x00700C05
932 #define VX855_41_291M 0x00730C05
933 #define VX855_43_163M 0x00790C05
934 #define VX855_45_250M 0x007F0C05 /* 45.46MHz */
935 #define VX855_46_000M 0x00670C04
936 #define VX855_46_996M 0x00690C04
937 #define VX855_48_000M 0x00860C05
938 #define VX855_48_875M 0x00890C05
939 #define VX855_49_500M 0x00530C03
940 #define VX855_52_406M 0x00580C03
941 #define VX855_52_977M 0x00940C05
942 #define VX855_56_250M 0x009D0C05
943 #define VX855_60_466M 0x00A90C05
944 #define VX855_61_500M 0x00AC0C05
945 #define VX855_65_000M 0x006D0C03
946 #define VX855_65_178M 0x00B60C05
947 #define VX855_66_750M 0x00700C03 /*67.116MHz */
948 #define VX855_67_295M 0x00BC0C05
949 #define VX855_68_179M 0x00BF0C05
950 #define VX855_68_369M 0x00BF0C05
951 #define VX855_69_924M 0x00C30C05
952 #define VX855_70_159M 0x00C30C05
953 #define VX855_72_000M 0x00A10C04
954 #define VX855_73_023M 0x00CC0C05
955 #define VX855_74_481M 0x00D10C05
956 #define VX855_78_750M 0x006E0805
957 #define VX855_79_466M 0x006F0805
958 #define VX855_80_136M 0x00700805
959 #define VX855_81_627M 0x00720805
960 #define VX855_83_375M 0x00750805
961 #define VX855_83_527M 0x00750805
962 #define VX855_83_950M 0x00750805
963 #define VX855_84_537M 0x00760805
964 #define VX855_84_750M 0x00760805 /* 84.537Mhz */
965 #define VX855_85_500M 0x00760805 /* 85.909080 MHz*/
966 #define VX855_85_860M 0x00760805
967 #define VX855_85_909M 0x00760805
968 #define VX855_88_750M 0x007C0805
969 #define VX855_89_489M 0x007D0805
970 #define VX855_94_500M 0x00840805
971 #define VX855_96_648M 0x00870805
972 #define VX855_97_750M 0x00890805
973 #define VX855_101_000M 0x008D0805
974 #define VX855_106_500M 0x00950805
975 #define VX855_108_000M 0x00970805
976 #define VX855_110_125M 0x00990805
977 #define VX855_112_000M 0x009D0805
978 #define VX855_113_309M 0x009F0805
979 #define VX855_115_000M 0x00A10805
980 #define VX855_118_840M 0x00A60805
981 #define VX855_119_000M 0x00A70805
982 #define VX855_121_750M 0x00AA0805 /* 121.704MHz */
983 #define VX855_122_614M 0x00AC0805
984 #define VX855_126_266M 0x00B10805
985 #define VX855_130_250M 0x00B60805 /* 130.250 */
986 #define VX855_135_000M 0x00BD0805
987 #define VX855_136_700M 0x00BF0805
988 #define VX855_137_750M 0x00C10805
989 #define VX855_138_400M 0x00C20805
990 #define VX855_144_300M 0x00CA0805
991 #define VX855_146_760M 0x00CE0805
992 #define VX855_148_500M 0x00D00805
993 #define VX855_153_920M 0x00540402
994 #define VX855_156_000M 0x006C0405
995 #define VX855_156_867M 0x006E0405
996 #define VX855_157_500M 0x006E0405
997 #define VX855_162_000M 0x00710405
998 #define VX855_172_798M 0x00790405
999 #define VX855_187_000M 0x00830405
1000 #define VX855_193_295M 0x00870405
1001 #define VX855_202_500M 0x008E0405
1002 #define VX855_204_000M 0x008F0405
1003 #define VX855_218_500M 0x00990405
1004 #define VX855_229_500M 0x00A10405
1005 #define VX855_234_000M 0x00A40405
1006 #define VX855_267_250M 0x00BB0405
1007 #define VX855_297_500M 0x00D00405
1008 #define VX855_339_500M 0x00770005
1009 #define VX855_340_772M 0x00770005
1012 /* Definition CRTC Timing Index */
1013 #define H_TOTAL_INDEX 0
1014 #define H_ADDR_INDEX 1
1015 #define H_BLANK_START_INDEX 2
1016 #define H_BLANK_END_INDEX 3
1017 #define H_SYNC_START_INDEX 4
1018 #define H_SYNC_END_INDEX 5
1019 #define V_TOTAL_INDEX 6
1020 #define V_ADDR_INDEX 7
1021 #define V_BLANK_START_INDEX 8
1022 #define V_BLANK_END_INDEX 9
1023 #define V_SYNC_START_INDEX 10
1024 #define V_SYNC_END_INDEX 11
1025 #define H_TOTAL_SHADOW_INDEX 12
1026 #define H_BLANK_END_SHADOW_INDEX 13
1027 #define V_TOTAL_SHADOW_INDEX 14
1028 #define V_ADDR_SHADOW_INDEX 15
1029 #define V_BLANK_SATRT_SHADOW_INDEX 16
1030 #define V_BLANK_END_SHADOW_INDEX 17
1031 #define V_SYNC_SATRT_SHADOW_INDEX 18
1032 #define V_SYNC_END_SHADOW_INDEX 19
1034 /* Definition Video Mode Pixel Clock (picoseconds)
1036 #define RES_480X640_60HZ_PIXCLOCK 39722
1037 #define RES_640X480_60HZ_PIXCLOCK 39722
1038 #define RES_640X480_75HZ_PIXCLOCK 31747
1039 #define RES_640X480_85HZ_PIXCLOCK 27777
1040 #define RES_640X480_100HZ_PIXCLOCK 23168
1041 #define RES_640X480_120HZ_PIXCLOCK 19081
1042 #define RES_720X480_60HZ_PIXCLOCK 37020
1043 #define RES_720X576_60HZ_PIXCLOCK 30611
1044 #define RES_800X600_60HZ_PIXCLOCK 25000
1045 #define RES_800X600_75HZ_PIXCLOCK 20203
1046 #define RES_800X600_85HZ_PIXCLOCK 17777
1047 #define RES_800X600_100HZ_PIXCLOCK 14667
1048 #define RES_800X600_120HZ_PIXCLOCK 11912
1049 #define RES_800X480_60HZ_PIXCLOCK 33805
1050 #define RES_848X480_60HZ_PIXCLOCK 31756
1051 #define RES_856X480_60HZ_PIXCLOCK 31518
1052 #define RES_1024X512_60HZ_PIXCLOCK 24218
1053 #define RES_1024X600_60HZ_PIXCLOCK 20460
1054 #define RES_1024X768_60HZ_PIXCLOCK 15385
1055 #define RES_1024X768_75HZ_PIXCLOCK 12699
1056 #define RES_1024X768_85HZ_PIXCLOCK 10582
1057 #define RES_1024X768_100HZ_PIXCLOCK 8825
1058 #define RES_1152X864_75HZ_PIXCLOCK 9259
1059 #define RES_1280X768_60HZ_PIXCLOCK 12480
1060 #define RES_1280X800_60HZ_PIXCLOCK 11994
1061 #define RES_1280X960_60HZ_PIXCLOCK 9259
1062 #define RES_1280X1024_60HZ_PIXCLOCK 9260
1063 #define RES_1280X1024_75HZ_PIXCLOCK 7408
1064 #define RES_1280X768_85HZ_PIXCLOCK 6349
1065 #define RES_1440X1050_60HZ_PIXCLOCK 7993
1066 #define RES_1600X1200_60HZ_PIXCLOCK 6172
1067 #define RES_1600X1200_75HZ_PIXCLOCK 4938
1068 #define RES_1280X720_60HZ_PIXCLOCK 13426
1069 #define RES_1920X1080_60HZ_PIXCLOCK 5787
1070 #define RES_1400X1050_60HZ_PIXCLOCK 8214
1071 #define RES_1400X1050_75HZ_PIXCLOCK 6410
1072 #define RES_1368X768_60HZ_PIXCLOCK 11647
1073 #define RES_960X600_60HZ_PIXCLOCK 22099
1074 #define RES_1000X600_60HZ_PIXCLOCK 20834
1075 #define RES_1024X576_60HZ_PIXCLOCK 21278
1076 #define RES_1088X612_60HZ_PIXCLOCK 18877
1077 #define RES_1152X720_60HZ_PIXCLOCK 14981
1078 #define RES_1200X720_60HZ_PIXCLOCK 14253
1079 #define RES_1280X600_60HZ_PIXCLOCK 16260
1080 #define RES_1280X720_50HZ_PIXCLOCK 16538
1081 #define RES_1280X768_50HZ_PIXCLOCK 15342
1082 #define RES_1366X768_50HZ_PIXCLOCK 14301
1083 #define RES_1366X768_60HZ_PIXCLOCK 11646
1084 #define RES_1360X768_60HZ_PIXCLOCK 11799
1085 #define RES_1440X900_60HZ_PIXCLOCK 9390
1086 #define RES_1440X900_75HZ_PIXCLOCK 7315
1087 #define RES_1600X900_60HZ_PIXCLOCK 8415
1088 #define RES_1600X1024_60HZ_PIXCLOCK 7315
1089 #define RES_1680X1050_60HZ_PIXCLOCK 6814
1090 #define RES_1680X1050_75HZ_PIXCLOCK 5348
1091 #define RES_1792X1344_60HZ_PIXCLOCK 4902
1092 #define RES_1856X1392_60HZ_PIXCLOCK 4577
1093 #define RES_1920X1200_60HZ_PIXCLOCK 5173
1094 #define RES_1920X1440_60HZ_PIXCLOCK 4274
1095 #define RES_1920X1440_75HZ_PIXCLOCK 3367
1096 #define RES_2048X1536_60HZ_PIXCLOCK 3742
1098 #define RES_1360X768_RB_60HZ_PIXCLOCK 13889
1099 #define RES_1400X1050_RB_60HZ_PIXCLOCK 9901
1100 #define RES_1440X900_RB_60HZ_PIXCLOCK 11268
1101 #define RES_1600X900_RB_60HZ_PIXCLOCK 10230
1102 #define RES_1680X1050_RB_60HZ_PIXCLOCK 8403
1103 #define RES_1920X1080_RB_60HZ_PIXCLOCK 7225
1104 #define RES_1920X1200_RB_60HZ_PIXCLOCK 6497
1106 /* LCD display method
1108 #define LCD_EXPANDSION 0x00
1109 #define LCD_CENTERING 0x01
1113 #define LCD_OPENLDI 0x00
1114 #define LCD_SPWG 0x01
1116 /* Define display timing
1118 struct display_timing {
1121 u16 hor_blank_start;
1127 u16 ver_blank_start;
1133 struct crt_mode_table {
1136 int h_sync_polarity;
1137 int v_sync_polarity;
1138 struct display_timing crtc;
1148 #endif /* __SHARE_H__ */