1 
   2 
   3 
   4 
   5 
   6 
   7 
   8 #ifndef __HW_H__
   9 #define __HW_H__
  10 
  11 #include <linux/seq_file.h>
  12 
  13 #include "viamode.h"
  14 #include "global.h"
  15 #include "via_modesetting.h"
  16 
  17 #define viafb_read_reg(p, i)                    via_read_reg(p, i)
  18 #define viafb_write_reg(i, p, d)                via_write_reg(p, i, d)
  19 #define viafb_write_reg_mask(i, p, d, m)        via_write_reg_mask(p, i, d, m)
  20 
  21 
  22 #define VIA_LDVP0       0x00000001
  23 #define VIA_LDVP1       0x00000002
  24 #define VIA_DVP0        0x00000004
  25 #define VIA_CRT         0x00000010
  26 #define VIA_DVP1        0x00000020
  27 #define VIA_LVDS1       0x00000040
  28 #define VIA_LVDS2       0x00000080
  29 
  30 
  31 #define VIA_STATE_ON            0
  32 #define VIA_STATE_STANDBY       1
  33 #define VIA_STATE_SUSPEND       2
  34 #define VIA_STATE_OFF           3
  35 
  36 
  37 #define VIA_HSYNC_NEGATIVE      0x01
  38 #define VIA_VSYNC_NEGATIVE      0x02
  39 
  40 
  41 
  42 
  43 #define IGA2_HOR_TOTAL_SHADOW_FORMULA(x)           ((x/8)-5)
  44 #define IGA2_HOR_BLANK_END_SHADOW_FORMULA(x, y)     (((x+y)/8)-1)
  45 #define IGA2_VER_TOTAL_SHADOW_FORMULA(x)           ((x)-2)
  46 #define IGA2_VER_ADDR_SHADOW_FORMULA(x)            ((x)-1)
  47 #define IGA2_VER_BLANK_START_SHADOW_FORMULA(x)     ((x)-1)
  48 #define IGA2_VER_BLANK_END_SHADOW_FORMULA(x, y)     ((x+y)-1)
  49 #define IGA2_VER_SYNC_START_SHADOW_FORMULA(x)      (x)
  50 #define IGA2_VER_SYNC_END_SHADOW_FORMULA(x, y)      (x+y)
  51 
  52 
  53 
  54 
  55 #define IGA2_SHADOW_HOR_TOTAL_REG_NUM       2
  56 
  57 #define IGA2_SHADOW_HOR_BLANK_END_REG_NUM   1
  58 
  59 #define IGA2_SHADOW_VER_TOTAL_REG_NUM       2
  60 
  61 #define IGA2_SHADOW_VER_ADDR_REG_NUM        2
  62 
  63 #define IGA2_SHADOW_VER_BLANK_START_REG_NUM 2
  64 
  65 #define IGA2_SHADOW_VER_BLANK_END_REG_NUM   2
  66 
  67 #define IGA2_SHADOW_VER_SYNC_START_REG_NUM  2
  68 
  69 #define IGA2_SHADOW_VER_SYNC_END_REG_NUM    1
  70 
  71 
  72 
  73 
  74 #define IGA1_FETCH_COUNT_REG_NUM        2
  75 
  76 #define IGA1_FETCH_COUNT_ALIGN_BYTE     16
  77 
  78 #define IGA1_FETCH_COUNT_PATCH_VALUE    4
  79 #define IGA1_FETCH_COUNT_FORMULA(x, y)   \
  80         (((x*y)/IGA1_FETCH_COUNT_ALIGN_BYTE) + IGA1_FETCH_COUNT_PATCH_VALUE)
  81 
  82 
  83 #define IGA2_FETCH_COUNT_REG_NUM        2
  84 #define IGA2_FETCH_COUNT_ALIGN_BYTE     16
  85 #define IGA2_FETCH_COUNT_PATCH_VALUE    0
  86 #define IGA2_FETCH_COUNT_FORMULA(x, y)   \
  87         (((x*y)/IGA2_FETCH_COUNT_ALIGN_BYTE) + IGA2_FETCH_COUNT_PATCH_VALUE)
  88 
  89 
  90 
  91 
  92 #define IGA1_STARTING_ADDR_REG_NUM      4
  93 
  94 #define IGA2_STARTING_ADDR_REG_NUM      3
  95 
  96 
  97 
  98 
  99 #define K800_IGA1_FIFO_MAX_DEPTH                384
 100 
 101 #define K800_IGA1_FIFO_THRESHOLD                328
 102 
 103 #define K800_IGA1_FIFO_HIGH_THRESHOLD           296
 104 
 105                                 
 106 #define K800_IGA1_DISPLAY_QUEUE_EXPIRE_NUM      0
 107 
 108 
 109 #define K800_IGA2_FIFO_MAX_DEPTH                384
 110 
 111 #define K800_IGA2_FIFO_THRESHOLD                328
 112 
 113 #define K800_IGA2_FIFO_HIGH_THRESHOLD           296
 114 
 115 #define K800_IGA2_DISPLAY_QUEUE_EXPIRE_NUM      128
 116 
 117 
 118 #define P880_IGA1_FIFO_MAX_DEPTH                192
 119 
 120 #define P880_IGA1_FIFO_THRESHOLD                128
 121 
 122 #define P880_IGA1_FIFO_HIGH_THRESHOLD           64
 123 
 124                                 
 125 #define P880_IGA1_DISPLAY_QUEUE_EXPIRE_NUM      0
 126 
 127 
 128 #define P880_IGA2_FIFO_MAX_DEPTH                96
 129 
 130 #define P880_IGA2_FIFO_THRESHOLD                64
 131 
 132 #define P880_IGA2_FIFO_HIGH_THRESHOLD           32
 133 
 134 #define P880_IGA2_DISPLAY_QUEUE_EXPIRE_NUM      128
 135 
 136 
 137 
 138 
 139 #define CN700_IGA1_FIFO_MAX_DEPTH               96
 140 
 141 #define CN700_IGA1_FIFO_THRESHOLD               80
 142 
 143 #define CN700_IGA1_FIFO_HIGH_THRESHOLD          64
 144 
 145 
 146 #define CN700_IGA1_DISPLAY_QUEUE_EXPIRE_NUM     0
 147 
 148 #define CN700_IGA2_FIFO_MAX_DEPTH               96
 149 
 150 #define CN700_IGA2_FIFO_THRESHOLD               80
 151 
 152 #define CN700_IGA2_FIFO_HIGH_THRESHOLD          32
 153 
 154 #define CN700_IGA2_DISPLAY_QUEUE_EXPIRE_NUM     128
 155 
 156 
 157 
 158 #define CX700_IGA1_FIFO_MAX_DEPTH               192
 159 
 160 #define CX700_IGA1_FIFO_THRESHOLD               128
 161 
 162 #define CX700_IGA1_FIFO_HIGH_THRESHOLD          128
 163 
 164 #define CX700_IGA1_DISPLAY_QUEUE_EXPIRE_NUM     124
 165 
 166 
 167 #define CX700_IGA2_FIFO_MAX_DEPTH               96
 168 
 169 #define CX700_IGA2_FIFO_THRESHOLD               64
 170 
 171 #define CX700_IGA2_FIFO_HIGH_THRESHOLD          32
 172 
 173 #define CX700_IGA2_DISPLAY_QUEUE_EXPIRE_NUM     128
 174 
 175 
 176 
 177 #define K8M890_IGA1_FIFO_MAX_DEPTH               360
 178 
 179 #define K8M890_IGA1_FIFO_THRESHOLD               328
 180 
 181 #define K8M890_IGA1_FIFO_HIGH_THRESHOLD          296
 182 
 183 #define K8M890_IGA1_DISPLAY_QUEUE_EXPIRE_NUM     124
 184 
 185 
 186 #define K8M890_IGA2_FIFO_MAX_DEPTH               360
 187 
 188 #define K8M890_IGA2_FIFO_THRESHOLD               328
 189 
 190 #define K8M890_IGA2_FIFO_HIGH_THRESHOLD          296
 191 
 192 #define K8M890_IGA2_DISPLAY_QUEUE_EXPIRE_NUM     124
 193 
 194 
 195 
 196 #define P4M890_IGA1_FIFO_MAX_DEPTH               96
 197 
 198 #define P4M890_IGA1_FIFO_THRESHOLD               76
 199 
 200 #define P4M890_IGA1_FIFO_HIGH_THRESHOLD          64
 201 
 202 #define P4M890_IGA1_DISPLAY_QUEUE_EXPIRE_NUM     32
 203 
 204 #define P4M890_IGA2_FIFO_MAX_DEPTH               96
 205 
 206 #define P4M890_IGA2_FIFO_THRESHOLD               76
 207 
 208 #define P4M890_IGA2_FIFO_HIGH_THRESHOLD          64
 209 
 210 #define P4M890_IGA2_DISPLAY_QUEUE_EXPIRE_NUM     32
 211 
 212 
 213 
 214 #define P4M900_IGA1_FIFO_MAX_DEPTH               96
 215 
 216 #define P4M900_IGA1_FIFO_THRESHOLD               76
 217 
 218 #define P4M900_IGA1_FIFO_HIGH_THRESHOLD          76
 219 
 220 #define P4M900_IGA1_DISPLAY_QUEUE_EXPIRE_NUM     32
 221 
 222 #define P4M900_IGA2_FIFO_MAX_DEPTH               96
 223 
 224 #define P4M900_IGA2_FIFO_THRESHOLD               76
 225 
 226 #define P4M900_IGA2_FIFO_HIGH_THRESHOLD          76
 227 
 228 #define P4M900_IGA2_DISPLAY_QUEUE_EXPIRE_NUM     32
 229 
 230 
 231 
 232 #define VX800_IGA1_FIFO_MAX_DEPTH               192
 233 
 234 #define VX800_IGA1_FIFO_THRESHOLD               152
 235 
 236 #define VX800_IGA1_FIFO_HIGH_THRESHOLD          152
 237 
 238 #define VX800_IGA1_DISPLAY_QUEUE_EXPIRE_NUM      64
 239 
 240 #define VX800_IGA2_FIFO_MAX_DEPTH               96
 241 
 242 #define VX800_IGA2_FIFO_THRESHOLD               64
 243 
 244 #define VX800_IGA2_FIFO_HIGH_THRESHOLD          32
 245 
 246 #define VX800_IGA2_DISPLAY_QUEUE_EXPIRE_NUM     128
 247 
 248 
 249 #define VX855_IGA1_FIFO_MAX_DEPTH               400
 250 #define VX855_IGA1_FIFO_THRESHOLD               320
 251 #define VX855_IGA1_FIFO_HIGH_THRESHOLD          320
 252 #define VX855_IGA1_DISPLAY_QUEUE_EXPIRE_NUM     160
 253 
 254 #define VX855_IGA2_FIFO_MAX_DEPTH               200
 255 #define VX855_IGA2_FIFO_THRESHOLD               160
 256 #define VX855_IGA2_FIFO_HIGH_THRESHOLD          160
 257 #define VX855_IGA2_DISPLAY_QUEUE_EXPIRE_NUM     320
 258 
 259 
 260 #define VX900_IGA1_FIFO_MAX_DEPTH               400
 261 #define VX900_IGA1_FIFO_THRESHOLD               320
 262 #define VX900_IGA1_FIFO_HIGH_THRESHOLD          320
 263 #define VX900_IGA1_DISPLAY_QUEUE_EXPIRE_NUM     160
 264 
 265 #define VX900_IGA2_FIFO_MAX_DEPTH               192
 266 #define VX900_IGA2_FIFO_THRESHOLD               160
 267 #define VX900_IGA2_FIFO_HIGH_THRESHOLD          160
 268 #define VX900_IGA2_DISPLAY_QUEUE_EXPIRE_NUM     320
 269 
 270 #define IGA1_FIFO_DEPTH_SELECT_REG_NUM          1
 271 #define IGA1_FIFO_THRESHOLD_REG_NUM             2
 272 #define IGA1_FIFO_HIGH_THRESHOLD_REG_NUM        2
 273 #define IGA1_DISPLAY_QUEUE_EXPIRE_NUM_REG_NUM   1
 274 
 275 #define IGA2_FIFO_DEPTH_SELECT_REG_NUM          3
 276 #define IGA2_FIFO_THRESHOLD_REG_NUM             2
 277 #define IGA2_FIFO_HIGH_THRESHOLD_REG_NUM        2
 278 #define IGA2_DISPLAY_QUEUE_EXPIRE_NUM_REG_NUM   1
 279 
 280 #define IGA1_FIFO_DEPTH_SELECT_FORMULA(x)                   ((x/2)-1)
 281 #define IGA1_FIFO_THRESHOLD_FORMULA(x)                      (x/4)
 282 #define IGA1_DISPLAY_QUEUE_EXPIRE_NUM_FORMULA(x)            (x/4)
 283 #define IGA1_FIFO_HIGH_THRESHOLD_FORMULA(x)                 (x/4)
 284 #define IGA2_FIFO_DEPTH_SELECT_FORMULA(x)                   (((x/2)/4)-1)
 285 #define IGA2_FIFO_THRESHOLD_FORMULA(x)                      (x/4)
 286 #define IGA2_DISPLAY_QUEUE_EXPIRE_NUM_FORMULA(x)            (x/4)
 287 #define IGA2_FIFO_HIGH_THRESHOLD_FORMULA(x)                 (x/4)
 288 
 289 
 290 
 291 
 292 
 293 
 294 #define LCD_POWER_SEQ_TD0               500000
 295 
 296 #define LCD_POWER_SEQ_TD1               50000
 297 
 298 #define LCD_POWER_SEQ_TD2               0
 299 
 300 #define LCD_POWER_SEQ_TD3               210000
 301 
 302 #define CLE266_POWER_SEQ_UNIT           71
 303 
 304 #define K800_POWER_SEQ_UNIT             142
 305 
 306 #define P880_POWER_SEQ_UNIT             572
 307 
 308 #define CLE266_POWER_SEQ_FORMULA(x)     ((x)/CLE266_POWER_SEQ_UNIT)
 309 #define K800_POWER_SEQ_FORMULA(x)       ((x)/K800_POWER_SEQ_UNIT)
 310 #define P880_POWER_SEQ_FORMULA(x)       ((x)/P880_POWER_SEQ_UNIT)
 311 
 312 
 313 #define LCD_POWER_SEQ_TD0_REG_NUM       2
 314 
 315 #define LCD_POWER_SEQ_TD1_REG_NUM       2
 316 
 317 #define LCD_POWER_SEQ_TD2_REG_NUM       2
 318 
 319 #define LCD_POWER_SEQ_TD3_REG_NUM       2
 320 
 321 
 322 
 323 
 324 
 325 
 326 #define CLE266_LCD_HOR_SCF_FORMULA(x, y)   (((x-1)*1024)/(y-1))
 327 
 328 #define CLE266_LCD_VER_SCF_FORMULA(x, y)   (((x-1)*1024)/(y-1))
 329 
 330 #define K800_LCD_HOR_SCF_FORMULA(x, y)     (((x-1)*4096)/(y-1))
 331 
 332 #define K800_LCD_VER_SCF_FORMULA(x, y)     (((x-1)*2048)/(y-1))
 333 
 334 
 335 #define LCD_HOR_SCALING_FACTOR_REG_NUM  3
 336 
 337 #define LCD_VER_SCALING_FACTOR_REG_NUM  3
 338 
 339 #define LCD_HOR_SCALING_FACTOR_REG_NUM_CLE  2
 340 
 341 #define LCD_VER_SCALING_FACTOR_REG_NUM_CLE  2
 342 
 343 struct io_register {
 344         u8 io_addr;
 345         u8 start_bit;
 346         u8 end_bit;
 347 };
 348 
 349 
 350 
 351 
 352 
 353 
 354 struct iga2_shadow_hor_total {
 355         int reg_num;
 356         struct io_register reg[IGA2_SHADOW_HOR_TOTAL_REG_NUM];
 357 };
 358 
 359 
 360 struct iga2_shadow_hor_blank_end {
 361         int reg_num;
 362         struct io_register reg[IGA2_SHADOW_HOR_BLANK_END_REG_NUM];
 363 };
 364 
 365 
 366 struct iga2_shadow_ver_total {
 367         int reg_num;
 368         struct io_register reg[IGA2_SHADOW_VER_TOTAL_REG_NUM];
 369 };
 370 
 371 
 372 struct iga2_shadow_ver_addr {
 373         int reg_num;
 374         struct io_register reg[IGA2_SHADOW_VER_ADDR_REG_NUM];
 375 };
 376 
 377 
 378 struct iga2_shadow_ver_blank_start {
 379         int reg_num;
 380         struct io_register reg[IGA2_SHADOW_VER_BLANK_START_REG_NUM];
 381 };
 382 
 383 
 384 struct iga2_shadow_ver_blank_end {
 385         int reg_num;
 386         struct io_register reg[IGA2_SHADOW_VER_BLANK_END_REG_NUM];
 387 };
 388 
 389 
 390 struct iga2_shadow_ver_sync_start {
 391         int reg_num;
 392         struct io_register reg[IGA2_SHADOW_VER_SYNC_START_REG_NUM];
 393 };
 394 
 395 
 396 struct iga2_shadow_ver_sync_end {
 397         int reg_num;
 398         struct io_register reg[IGA2_SHADOW_VER_SYNC_END_REG_NUM];
 399 };
 400 
 401 
 402 struct iga1_fetch_count {
 403         int reg_num;
 404         struct io_register reg[IGA1_FETCH_COUNT_REG_NUM];
 405 };
 406 
 407 
 408 struct iga2_fetch_count {
 409         int reg_num;
 410         struct io_register reg[IGA2_FETCH_COUNT_REG_NUM];
 411 };
 412 
 413 struct fetch_count {
 414         struct iga1_fetch_count iga1_fetch_count_reg;
 415         struct iga2_fetch_count iga2_fetch_count_reg;
 416 };
 417 
 418 
 419 struct iga1_starting_addr {
 420         int reg_num;
 421         struct io_register reg[IGA1_STARTING_ADDR_REG_NUM];
 422 };
 423 
 424 struct iga2_starting_addr {
 425         int reg_num;
 426         struct io_register reg[IGA2_STARTING_ADDR_REG_NUM];
 427 };
 428 
 429 struct starting_addr {
 430         struct iga1_starting_addr iga1_starting_addr_reg;
 431         struct iga2_starting_addr iga2_starting_addr_reg;
 432 };
 433 
 434 
 435 struct lcd_pwd_seq_td0 {
 436         int reg_num;
 437         struct io_register reg[LCD_POWER_SEQ_TD0_REG_NUM];
 438 };
 439 
 440 struct lcd_pwd_seq_td1 {
 441         int reg_num;
 442         struct io_register reg[LCD_POWER_SEQ_TD1_REG_NUM];
 443 };
 444 
 445 struct lcd_pwd_seq_td2 {
 446         int reg_num;
 447         struct io_register reg[LCD_POWER_SEQ_TD2_REG_NUM];
 448 };
 449 
 450 struct lcd_pwd_seq_td3 {
 451         int reg_num;
 452         struct io_register reg[LCD_POWER_SEQ_TD3_REG_NUM];
 453 };
 454 
 455 struct _lcd_pwd_seq_timer {
 456         struct lcd_pwd_seq_td0 td0;
 457         struct lcd_pwd_seq_td1 td1;
 458         struct lcd_pwd_seq_td2 td2;
 459         struct lcd_pwd_seq_td3 td3;
 460 };
 461 
 462 
 463 struct _lcd_hor_scaling_factor {
 464         int reg_num;
 465         struct io_register reg[LCD_HOR_SCALING_FACTOR_REG_NUM];
 466 };
 467 
 468 struct _lcd_ver_scaling_factor {
 469         int reg_num;
 470         struct io_register reg[LCD_VER_SCALING_FACTOR_REG_NUM];
 471 };
 472 
 473 struct _lcd_scaling_factor {
 474         struct _lcd_hor_scaling_factor lcd_hor_scaling_factor;
 475         struct _lcd_ver_scaling_factor lcd_ver_scaling_factor;
 476 };
 477 
 478 struct pll_limit {
 479         u16 multiplier_min;
 480         u16 multiplier_max;
 481         u8 divisor;
 482         u8 rshift;
 483 };
 484 
 485 struct rgbLUT {
 486         u8 red;
 487         u8 green;
 488         u8 blue;
 489 };
 490 
 491 struct lcd_pwd_seq_timer {
 492         u16 td0;
 493         u16 td1;
 494         u16 td2;
 495         u16 td3;
 496 };
 497 
 498 
 499 struct iga1_fifo_depth_select {
 500         int reg_num;
 501         struct io_register reg[IGA1_FIFO_DEPTH_SELECT_REG_NUM];
 502 };
 503 
 504 struct iga1_fifo_threshold_select {
 505         int reg_num;
 506         struct io_register reg[IGA1_FIFO_THRESHOLD_REG_NUM];
 507 };
 508 
 509 struct iga1_fifo_high_threshold_select {
 510         int reg_num;
 511         struct io_register reg[IGA1_FIFO_HIGH_THRESHOLD_REG_NUM];
 512 };
 513 
 514 struct iga1_display_queue_expire_num {
 515         int reg_num;
 516         struct io_register reg[IGA1_DISPLAY_QUEUE_EXPIRE_NUM_REG_NUM];
 517 };
 518 
 519 struct iga2_fifo_depth_select {
 520         int reg_num;
 521         struct io_register reg[IGA2_FIFO_DEPTH_SELECT_REG_NUM];
 522 };
 523 
 524 struct iga2_fifo_threshold_select {
 525         int reg_num;
 526         struct io_register reg[IGA2_FIFO_THRESHOLD_REG_NUM];
 527 };
 528 
 529 struct iga2_fifo_high_threshold_select {
 530         int reg_num;
 531         struct io_register reg[IGA2_FIFO_HIGH_THRESHOLD_REG_NUM];
 532 };
 533 
 534 struct iga2_display_queue_expire_num {
 535         int reg_num;
 536         struct io_register reg[IGA2_DISPLAY_QUEUE_EXPIRE_NUM_REG_NUM];
 537 };
 538 
 539 struct fifo_depth_select {
 540         struct iga1_fifo_depth_select iga1_fifo_depth_select_reg;
 541         struct iga2_fifo_depth_select iga2_fifo_depth_select_reg;
 542 };
 543 
 544 struct fifo_threshold_select {
 545         struct iga1_fifo_threshold_select iga1_fifo_threshold_select_reg;
 546         struct iga2_fifo_threshold_select iga2_fifo_threshold_select_reg;
 547 };
 548 
 549 struct fifo_high_threshold_select {
 550         struct iga1_fifo_high_threshold_select
 551          iga1_fifo_high_threshold_select_reg;
 552         struct iga2_fifo_high_threshold_select
 553          iga2_fifo_high_threshold_select_reg;
 554 };
 555 
 556 struct display_queue_expire_num {
 557         struct iga1_display_queue_expire_num
 558          iga1_display_queue_expire_num_reg;
 559         struct iga2_display_queue_expire_num
 560          iga2_display_queue_expire_num_reg;
 561 };
 562 
 563 struct iga2_shadow_crtc_timing {
 564         struct iga2_shadow_hor_total hor_total_shadow;
 565         struct iga2_shadow_hor_blank_end hor_blank_end_shadow;
 566         struct iga2_shadow_ver_total ver_total_shadow;
 567         struct iga2_shadow_ver_addr ver_addr_shadow;
 568         struct iga2_shadow_ver_blank_start ver_blank_start_shadow;
 569         struct iga2_shadow_ver_blank_end ver_blank_end_shadow;
 570         struct iga2_shadow_ver_sync_start ver_sync_start_shadow;
 571         struct iga2_shadow_ver_sync_end ver_sync_end_shadow;
 572 };
 573 
 574 
 575 #define CLE266_FUNCTION3    0x3123
 576 #define KM400_FUNCTION3     0x3205
 577 #define CN400_FUNCTION2     0x2259
 578 #define CN400_FUNCTION3     0x3259
 579 
 580 #define CN700_FUNCTION2     0x2314
 581 #define CN700_FUNCTION3     0x3208
 582 
 583 #define CX700_FUNCTION2     0x2324
 584 #define CX700_FUNCTION3     0x3324
 585 
 586 #define KM800_FUNCTION3      0x3204
 587 
 588 #define KM890_FUNCTION3      0x3336
 589 
 590 #define P4M890_FUNCTION3     0x3327
 591 
 592 #define CN750_FUNCTION3     0x3208
 593 
 594 #define P4M900_FUNCTION3    0x3364
 595 
 596 #define VX800_FUNCTION3     0x3353
 597 
 598 #define VX855_FUNCTION3     0x3409
 599 
 600 #define VX900_FUNCTION3     0x3410
 601 
 602 struct IODATA {
 603         u8 Index;
 604         u8 Mask;
 605         u8 Data;
 606 };
 607 
 608 struct pci_device_id_info {
 609         u32 vendor;
 610         u32 device;
 611         u32 chip_index;
 612 };
 613 
 614 struct via_device_mapping {
 615         u32 device;
 616         const char *name;
 617 };
 618 
 619 extern int viafb_SAMM_ON;
 620 extern int viafb_dual_fb;
 621 extern int viafb_LCD2_ON;
 622 extern int viafb_LCD_ON;
 623 extern int viafb_DVI_ON;
 624 extern int viafb_hotplug;
 625 
 626 struct via_display_timing var_to_timing(const struct fb_var_screeninfo *var,
 627         u16 cxres, u16 cyres);
 628 void viafb_fill_crtc_timing(const struct fb_var_screeninfo *var,
 629         u16 cxres, u16 cyres, int iga);
 630 void viafb_set_vclock(u32 CLK, int set_iga);
 631 void viafb_load_reg(int timing_value, int viafb_load_reg_num,
 632         struct io_register *reg,
 633               int io_type);
 634 void via_set_source(u32 devices, u8 iga);
 635 void via_set_state(u32 devices, u8 state);
 636 void via_set_sync_polarity(u32 devices, u8 polarity);
 637 u32 via_parse_odev(char *input, char **end);
 638 void via_odev_to_seq(struct seq_file *m, u32 odev);
 639 void init_ad9389(void);
 640 
 641 void viafb_lock_crt(void);
 642 void viafb_unlock_crt(void);
 643 void viafb_load_fetch_count_reg(int h_addr, int bpp_byte, int set_iga);
 644 void viafb_write_regx(struct io_reg RegTable[], int ItemNum);
 645 void viafb_load_FIFO_reg(int set_iga, int hor_active, int ver_active);
 646 void viafb_set_dpa_gfx(int output_interface, struct GFX_DPA_SETTING\
 647                                         *p_gfx_dpa_setting);
 648 
 649 int viafb_setmode(void);
 650 void viafb_fill_var_timing_info(struct fb_var_screeninfo *var,
 651         const struct fb_videomode *mode);
 652 void viafb_init_chip_info(int chip_type);
 653 void viafb_init_dac(int set_iga);
 654 int viafb_get_refresh(int hres, int vres, u32 float_refresh);
 655 void viafb_update_device_setting(int hres, int vres, int bpp, int flag);
 656 
 657 void viafb_set_iga_path(void);
 658 void viafb_set_primary_color_register(u8 index, u8 red, u8 green, u8 blue);
 659 void viafb_set_secondary_color_register(u8 index, u8 red, u8 green, u8 blue);
 660 void viafb_get_fb_info(unsigned int *fb_base, unsigned int *fb_len);
 661 
 662 #endif