regmap_8202.h
上传用户:poi891205
上传日期:2013-07-15
资源大小:9745k
文件大小:48k
源码类别:

DVD

开发平台:

C/C++

  1. #ifndef __REGMAP_8202_H
  2. #define __REGMAP_8202_H
  3. /*
  4. ** FILE
  5. ** regmap.h
  6. **
  7. ** DESCRIPTION
  8. ** define register-file structure.
  9. **
  10. ** NOTE:
  11. ** specific for sphe8202
  12. */
  13. #include "types.h"
  14. #include "dmabuf.h"
  15. /*
  16. ** TYPE
  17. ** RegisterFile
  18. */
  19. typedef struct
  20. {
  21.   // GROUP 0: Chip Information
  22.   UINT32 stamp;                                 // 00    0      (0000) $bffe8000
  23.   UINT32 emulation;                             // 01    1      (0004)
  24.   UINT32 reset;                                 // 02    2      (0008)
  25.   UINT32 reset2;                                // 03    3      (000c)
  26.   UINT32 pad_ctrl;                              // 04    4      (0010)
  27.   UINT32 sdram_clko_cfg;                        // 05    5      (0014)
  28.   UINT32 sdram_clki_cfg;                        // 06    6      (0018)
  29.   UINT32 sdram_clki_dly_cfg;                    // 07    7      (001c)
  30.   UINT32 clk_mon_sel;                           // 08    8      (0020)
  31.   UINT32 clk_mon_result;                        // 09    9      (0024)
  32.   UINT32 clken0;                                // 0a   10      (0028)
  33.   UINT32 clken1;                                // 0b   11      (002c)
  34.   UINT32 gclken0;                               // 0c   12      (0030)
  35.   UINT32 gclken1;                               // 0d   13      (0034)
  36.   UINT32 sysclk_div_sel;                        // 0e   14      (0038)
  37.   UINT32 sysclk_sel;                            // 0f   15      (003c)
  38.   UINT32 pllv_cfg;                              // 10   16      (0040)
  39.   UINT32 sft_cfg0;                              // 11   17      (0044)
  40.   UINT32 sft_cfg1;                              // 12   18      (0048)
  41.   UINT32 sft_cfg2;                              // 13   19      (004c)
  42.   UINT32 sft_cfg3;                              // 14   20      (0050)
  43.   UINT32 sft_cfg4;                              // 15   21      (0054)
  44.   UINT32 sft_cfg5;                              // 16   22      (0058)
  45.   UINT32 sft_cfg6;                              // 17   23      (005c)
  46.   UINT32 sft_cfg7;                              // 18   24      (0060)
  47.   UINT32 sft_cfg8;                              // 19   25      (0064)
  48.   UINT32 hw_bo;                                 // 1a   26      (0068)
  49.   UINT32 hw_cfg;                                // 1b   27      (006c)
  50.   UINT32 hw_cfg_chg;                            // 1c   28      (0070)
  51.   UINT32 sft_cfg9;                              // 1d   29      (0074)
  52.   UINT32 sft_cfga;                              // 1e   30      (0078)
  53.   UINT32 g0_reserved_1[1];                      // 1f   31~  31 (007c)
  54.   // GROUP 1: Timers
  55.   UINT32 stc_15_0;                              // 00   32      (0080) $bffe8080
  56.   UINT32 stc_31_16;                             // 01   33      (0084)
  57.   UINT32 stc_32;                                // 02   34      (0088)
  58.   UINT32 stc_divisor;                           // 03   35      (008c)
  59.   UINT32 rtc_15_0;                              // 04   36      (0090)
  60.   UINT32 rtc_31_16;                             // 05   37      (0094)
  61.   UINT32 rtc_divisor;                           // 06   38      (0098)
  62.   UINT32 stc_config;                            // 07   39      (009c)
  63.   UINT32 timer0_ctrl;                           // 08   40      (00a0)
  64.   UINT32 timer0_cnt;                            // 09   41      (00a4)
  65.   UINT32 timer1_ctrl;                           // 0a   42      (00a8)
  66.   UINT32 timer1_cnt;                            // 0b   43      (00ac)
  67.   UINT32 timerw_ctrl;                           // 0c   44      (00b0)
  68.   UINT32 timerw_cnt;                            // 0d   45      (00b4)
  69.   UINT32 g1_unused_1[2];                        // 0e   46~  47 (00b8)
  70.   UINT32 timer2_ctrl;                           // 10   48      (00c0)
  71.   UINT32 timer2_divisor;                        // 11   49      (00c4)
  72.   UINT32 timer2_reload;                         // 12   50      (00c8)
  73.   UINT32 timer2_cnt;                            // 13   51      (00cc)
  74.   UINT32 timer3_ctrl;                           // 14   52      (00d0)
  75.   UINT32 timer3_divisor;                        // 15   53      (00d4)
  76.   UINT32 timer3_reload;                         // 16   54      (00d8)
  77.   UINT32 timer3_cnt;                            // 17   55      (00dc)
  78.   UINT32 stcl_0;                                // 18   56      (00e0)
  79.   UINT32 stcl_1;                                // 19   57      (00e4)
  80.   UINT32 stcl_2;                                // 1a   58      (00e8)
  81.   UINT32 atc_0;                                 // 1b   59      (00ec)
  82.   UINT32 atc_1;                                 // 1c   60      (00f0)
  83.   UINT32 atc_2;                                 // 1d   61      (00f4)
  84.   UINT32 g1_reserved[2];                        // 1e   62~  63 (00f8)
  85.   // GROUP 2: RISC interface
  86.   UINT32 intr_mask;                             // 00   64      (0100) $bffe8100
  87.   UINT32 intr_flag;                             // 01   65      (0104)
  88.   UINT32 intr_masked_flag;                      // 02   66      (0108)
  89.   UINT32 intr_clear;                            // 03   67      (010c)
  90.   UINT32 intr_polarity;                         // 04   68      (0110)
  91.   UINT32 intr_edge;                             // 05   69      (0114)
  92.   UINT32 intr1_mask;                            // 06   70      (0118)
  93.   UINT32 intr1_flag;                            // 07   71      (011c)
  94.   UINT32 intr1_masked_flag;                     // 08   72      (0120)
  95.   UINT32 intr1_clear;                           // 09   73      (0124)
  96.   UINT32 intr1_polarity;                        // 0a   74      (0128)
  97.   UINT32 intr1_edge;                            // 0b   75      (012c)
  98.   UINT32 lbc_control;                           // 0c   76      (0130)
  99.   UINT32 lbc_watchdog;                          // 0d   77      (0134)
  100.   UINT32 rec_start;                             // 0e   78      (0138)
  101.   UINT32 rec_end;                               // 0f   79      (013c)
  102.   UINT32 rec_l_m;                               // 10   80      (0140)
  103.   UINT32 g2_reserved[13];                       // 11   81~  93 (0144)
  104.   UINT32 ri_misc_b0;                            // 1e   94      (0178)
  105.   UINT32 ri_misc_b1;                            // 1f   95      (017c)
  106.   // GROUP 3: Video bitstream parameters
  107.   UINT32 seq_ext;                               // 00   96      (0180) $bffe8180
  108.   UINT32 h_size;                                // 01   97      (0184)
  109.   UINT32 v_size;                                // 02   98      (0188)
  110.   UINT32 g3_unused;                             // 03   99      (018c)
  111.   UINT32 pic_coding_type;                       // 04  100      (0190)
  112.   UINT32 pic_f_code;                            // 05  101      (0194)
  113.   UINT32 pic_coding_ext0;                       // 06  102      (0198)
  114.   UINT32 pic_coding_ext1;                       // 07  103      (019c)
  115.   UINT32 pic_start;                             // 08  104      (01a0)
  116.   UINT32 dis_pic_id;                            // 09  105      (01a4)
  117.   UINT32 dis_seq_tag;                           // 0a  106      (01a8)
  118.   UINT32 g3_reserved[21];                       // 0b  107~ 127 (01ac)
  119.   // GROUP 4: VLD parameters
  120.   UINT32 vld_ctrl;                              // 00  128      (0200) $bffe8200
  121.   UINT32 vld_status;                            // 01  129      (0204)
  122.   UINT32 vld_decode_time;                       // 02  130      (0208)
  123.   UINT32 vld_int_trb_trd;                             // 03  131      (020c)
  124.   UINT32 vld_mon0;                              // 04  132      (0210)
  125.   UINT32 vld_mon1;                              // 05  133      (0214)
  126.   UINT32 vld_mon2;                              // 06  134      (0218)
  127.   UINT32 vld_mon3;                              // 07  135      (021c)
  128.   UINT32 jpeg_control;                          // 08  136      (0220)
  129.   UINT32 jpeg_write_addr;                       // 09  137      (0224)
  130.   UINT32 jpeg_write_data;                       // 0a  138      (0228)
  131.   UINT32 jpeg_read_addr;                        // 0b  139      (022c)
  132.   UINT32 jpeg_read_data;                        // 0c  140      (0230)
  133.   UINT32 error_mb_threshold;                    // 0d  141      (0234)
  134.   UINT32 vld_config;                            // 0e  142      (0238)
  135.   UINT32 vld_trb_trd;                           // 0f  143      (023c)
  136.   UINT32 vld_trb_trd_ext;                       // 10  144      (0240)
  137.   UINT32 vld_2trbp_2dp;                         // 11  145      (0244)
  138.   UINT32 vld_2trbm_2dm;                         // 12  146      (0248)
  139.   UINT32 vld_packet_header;                     // 13  147      (024c)
  140.   UINT32 vld_vol_header;                        // 14  148      (0250)
  141.   UINT32 vld_vop_header;                        // 15  149      (0254)
  142.   UINT32 vld_mp4_misc;                         // 16  150      (0258)
  143.   UINT32 g4_reserved[8];                        // 17  151~ 158 (025c)
  144.   UINT32 vld_gob_num;                           // 1f  159      (027c)
  145.   // GROUP 5: MC configuration zero registers
  146.   UINT32 mc_config;                             // 00  160      (0280) $bffe8280
  147.   UINT32 ref0_luma;                             // 01  161      (0284)
  148.   UINT32 ref0_chroma;                           // 02  162      (0288)
  149.   UINT32 ref1_luma;                             // 03  163      (028c)
  150.   UINT32 ref1_chroma;                           // 04  164      (0290)
  151.   UINT32 bidir_luma;                            // 05  165      (0294)
  152.   UINT32 bidir_chroma;                          // 06  166      (0298)
  153.   UINT32 g5_reserved_0[5];                      // 07  167~ 171 (029c)
  154.   UINT32 divx_mw_pad;                           // 0c  172      (02b0)
  155.   UINT32 vop_round_type;                        // 0d  173      (02b4)
  156.   UINT32 mc_time_ctrl;                     // 0e  174 (02b8)
  157.   UINT32 qpel_gmc_ctrl;                     // 0f  175 (02bc)
  158.   UINT32 g5_reserved_1[8];                      // 10  176~ 183 (02c0)
  159.   UINT32 mc_spare_0;                            // 18  184      (02e0)
  160.   UINT32 mc_compress;                           // 19  185      (02e4)
  161.   UINT32 mc_pardec_start;                       // 1a  186      (02e8)
  162.   UINT32 mc_pardec_end;                         // 1b  187      (02ec)
  163.   UINT32 mc_mbwidth;                            // 1c  188      (02f0)
  164.   UINT32 mc_pardec_en;                          // 1d  189      (02f4)
  165.   UINT32 mc_spare_6;                            // 1e  190      (02f8)
  166.   UINT32 mc_spare_7;                            // 1f  191      (02fc)
  167.   // GROUP 6: SDRAM control
  168.   UINT32 sdctrl_cfg0;                           // 00  192      (0300) $bffe8300
  169.   UINT32 sdctrl_cfg1;                           // 01  193      (0304)
  170.   UINT32 sdctrl_cfg2;                           // 02  194      (0308)
  171.   UINT32 sdctrl_mrs;                            // 03  195      (030c)
  172.   UINT32 sdctrl_sref_cfg;                       // 04  196      (0310)
  173.   UINT32 sdctrl_cfg3;                           // 05  197      (0314)
  174.   UINT32 sdctrl_data_mon_st;                    // 06  198      (0318)
  175.   UINT32 sdctrl_data_cyc_l;                     // 07  199      (031c)
  176.   UINT32 sdctrl_data_cyc_h;                     // 08  200      (0320)
  177.   UINT32 sdctrl_data_cnt_l;                     // 09  201      (0324)
  178.   UINT32 sdctrl_data_cnt_h;                     // 0a  202      (0328)
  179.   UINT32 sdctrl_gclk_dis;                       // 0b  203      (032c)
  180.   UINT32 sdctrl_aref1_cfg;                      // 0c  204      (0330)
  181.   UINT32 sdctrl_int;                            // 0d  205      (0334)
  182.   UINT32 sdctrl_int_mask;                       // 0e  206      (0338)
  183.   UINT32 sdctrl_int_status;                     // 0f  207      (033c)
  184.   UINT32 sdctrl_lmem_base;                      // 10  208      (0340)
  185.   UINT32 sdctrl_lmem_row_st;                    // 11  209      (0344)
  186.   UINT32 g6_unused_0;                           // 12  210      (0348)
  187.   UINT32 sdctrl_cfg4;                           // 13  211      (034c)
  188.   UINT32 sdctrl_mon[10];                        // 14  212~ 221 (0350)
  189.   UINT32 sdctrl_misc_b0;                        // 1e  222      (0378)
  190.   UINT32 sdctrl_misc_b1;                        // 1f  223      (037c)
  191.   // GROUP 7: VPP Control
  192.   UINT32 dis_x_start;                           // 00  224      (0380) $bffe8380
  193.   UINT32 dis_y_start;                           // 01  225      (0384)
  194.   UINT32 dis_x_size;                            // 02  226      (0388)
  195.   UINT32 dis_y_size;                            // 03  227      (038c)
  196.   UINT32 v_offset;                              // 04  228      (0390)
  197.   UINT32 h_offset;                              // 05  229      (0394)
  198.   UINT32 vpp_bg_y;                              // 06  230      (0398)
  199.   UINT32 vpp_bg_cb_cr;                          // 07  231      (039c)
  200.   UINT32 v_filter0_setup;                       // 08  232      (03a0)
  201.   UINT32 v_filter1_setup;                       // 09  233      (03a4)
  202.   UINT32 h_filter_setup;                        // 0a  234      (03a8)
  203.   UINT32 vpp_config;                            // 0b  235      (03ac)
  204.   UINT32 vpp_config1;                           // 0c  236      (03b0)
  205.   UINT32 ds_field_config;                       // 0d  237      (03b4)
  206.   UINT32 dip_config;                            // 0e  238      (03b8)
  207.   UINT32 dip_param;                             // 0f  239      (03bc)
  208.   UINT32 dip_mv_ptr;                            // 10  240      (03c0)
  209.   UINT32 vppref0_luma;                          // 11  241      (03c4)
  210.   UINT32 vppref0_chroma;                        // 12  242      (03c8)
  211.   UINT32 vppref1_luma;                          // 13  243      (03cc)
  212.   UINT32 vppref1_chroma;                        // 14  244      (03d0)
  213.   UINT32 vppbidir_luma;                         // 15  245      (03d4)
  214.   UINT32 vppbidir_chroma;                       // 16  246      (03d8)
  215.   UINT32 dip_ref_base;                          // 17  247      (03dc)
  216.   UINT32 dip_param_threshold;                   // 18  248      (03e0)
  217.   UINT32 dip_param_fading;                      // 19  249      (03e4)
  218.   UINT32 vpp_act_region_top;                    // 1a  250      (03e8)
  219.   UINT32 vpp_act_region_bottom;                 // 1b  251      (03ec)
  220.   UINT32 vpp_spare_0;                           // 1c  252      (03f0)
  221.   UINT32 vpp_clut_ay;                           // 1d  253      (03f4)
  222.   UINT32 vpp_clut_uv;                           // 1e  254      (03f8)
  223.   UINT32 vpp_spare_1;                           // 1f  255      (03fc)
  224.   /*
  225.   UINT32 vpp_config2;                           // 1c  252      (03f0)
  226.   UINT32 vpp_clut_ay;                           // 1d  253      (03f4)
  227.   UINT32 vpp_clut_uv;                           // 1e  254      (03f8)
  228.   UINT32 vpp_video_in;                          // 1f  255      (03fc)
  229.   */
  230.   // GROUP 8: TV0
  231.   UINT32 tv_mode[6];                            // 00  256~ 261 (0400) $bffe8400
  232.   UINT32 tv_subc_f[2];                          // 06  262~ 263 (0418)
  233.   UINT32 tv_subc_p;                             // 08  264      (0420)
  234.   UINT32 tv_line_t[2];                          // 09  265~ 266 (0424)
  235.   UINT32 tv_line_b[2];                          // 0b  267~ 268 (042c)
  236.   UINT32 tv_cc_t;                               // 0d  269      (0434)
  237.   UINT32 tv_cc_b;                               // 0e  270      (0438)
  238.   UINT32 tv_cgms[2];                            // 0f  271~ 272 (043c)
  239.   UINT32 tv_id_status;                          // 11  273      (0444)
  240.   UINT32 tv_dac[2];                             // 12  274~ 275 (0448)
  241.   UINT32 tv_misc[12];                           // 14  276~ 287 (0450)
  242.   // GROUP 9: DSP24
  243.   UINT32 dsp24_control;                         // 00  288      (0480) $bffe8480
  244.   UINT32 dsp3dbg_mode;                          // 01  289      (0484)
  245.   UINT32 dsp3dbg_break;                         // 02  290      (0488)
  246.   UINT32 dsp3dbg_addr;                          // 03  291      (048c)
  247.   UINT32 dsp3dbg_step;                          // 04  292      (0490)
  248.   UINT32 dsp3dbg_rd_l;                          // 05  293      (0494)
  249.   UINT32 dsp3dbg_rd_h;                          // 06  294      (0498)
  250.   UINT32 dsp3dbg_wr_l;                          // 07  295      (049c)
  251.   UINT32 dsp3dbg_wr_h;                          // 08  296      (04a0)
  252.   UINT32 dsp3dbg_pc;                            // 09  297      (04a4)
  253.   UINT32 rom_l;                                 // 0a  298      (04a8)
  254.   UINT32 rom_h;                                 // 0b  299      (04ac)
  255.   UINT32 dsp24ya;                               // 0c  300      (04b0)
  256.   UINT32 pcmya;                                 // 0d  301      (04b4)
  257.   UINT32 audya;                                 // 0e  302      (04b8)
  258.   UINT32 g9_reserved;                           // 0f  303      (04bc)
  259.   UINT32 dsp24_port[16];                        // 10  304~ 319 (04c0)
  260.   // GROUP 10: OSD control
  261.   UINT32 osd_tv_std;                            // 00  320      (0500) $bffe8500
  262.   UINT32 osd_tv_out;                            // 01  321      (0504)
  263.   UINT32 osd_mixer;                             // 02  322      (0508)
  264.   UINT32 osd_display_status;                    // 03  323      (050c)
  265.   UINT32 osd_en;                                // 04  324      (0510)
  266.   UINT32 osd_tlink_addr;                        // 05  325      (0514)
  267.   UINT32 osd_blink_addr;                        // 06  326      (0518)
  268.   UINT32 y_clip;                                // 07  327      (051c)
  269.   UINT32 cb_clip;                               // 08  328      (0520)
  270.   UINT32 osd_base_addr;                         // 09  329      (0524)
  271.   UINT32 osd_mode[12];                          // 0a  330~ 341 (0528)
  272.   UINT32 g10_reserved[10];                      // 16  342~ 351 (0558)
  273.   // GROUP 11: Graphic control
  274.   UINT32 graph_mode;                            // 00  352      (0580) $bffe8580
  275.   UINT32 graph_status;                          // 01  353      (0584)
  276.   UINT32 dma_mode;                              // 02  354      (0588)
  277.   UINT32 dma_xaddr;                             // 03  355      (058c)
  278.   UINT32 dma_yaddr;                             // 04  356      (0590)
  279.   UINT32 dma_done;                              // 05  357      (0594)
  280.   UINT32 g11_reserved[26];                      // 06  358~ 383 (0598)
  281.   // GROUP 12: HOST
  282.   UINT32 g12_dvddsp_vy;                         // 00  384      (0600) $bffe8600
  283.   UINT32 g12_dvddsp_vx;                         // 01  385      (0604)
  284.   UINT32 dvddsp_function;                       // 02  386      (0608)
  285.   UINT32 dvddsp_ata_config;                     // 03  387      (060c)
  286.   UINT32 dvddsp_blocksize;                      // 04  388      (0610)
  287.   UINT32 dvddsp_blocklength;                    // 05  389      (0614)
  288.   UINT32 g12_dvddsp_ry;                         // 06  390      (0618)
  289.   UINT32 dvddsp_rx;                             // 07  391      (061c)
  290.   UINT32 dvddsp_public;                         // 08  392      (0620)
  291.   UINT32 dvddsp_ude_config;                     // 09  393      (0624)
  292.   UINT32 dvddsp_ata_pio_cycle;                  // 0a  394      (0628)
  293.   UINT32 dvddsp_ata_udma_cycle;                 // 0b  395      (062c)
  294.   UINT32 g12_reserved[4];                       // 0c  396~ 399 (0630)
  295.   UINT32 dvddsp_mon[4];                         // 10  400~ 403 (0640)
  296.   UINT32 g12_reserved1[12];                     // 14  404~ 415 (0650)
  297.   // GROUP 13: CSS
  298.   UINT32 css_tk0;                               // 00  416      (0680) $bffe8680
  299.   UINT32 css_tk1;                               // 01  417      (0684)
  300.   UINT32 css_tk2;                               // 02  418      (0688)
  301.   UINT32 css_tk3;                               // 03  419      (068c)
  302.   UINT32 css_tbyte;                             // 04  420      (0690)
  303.   UINT32 css_public;                            // 05  421      (0694)
  304.   UINT32 css_config;                            // 06  422      (0698)
  305.   UINT32 css_l0;                                // 07  423      (069c)
  306.   UINT32 css_l1;                                // 08  424      (06a0)
  307.   UINT32 css_r0;                                // 09  425      (06a4)
  308.   UINT32 css_r1;                                // 0a  426      (06a8)
  309.   UINT32 cppm_aukey3;                           // 0b  427      (06ac)
  310.   UINT32 cppm_aukey2;                           // 0c  428      (06b0)
  311.   UINT32 cppm_aukey1;                           // 0d  429      (06b4)
  312.   UINT32 cppm_aukey0;                           // 0e  430      (06b8)
  313.   UINT32 g13_reserved[17];                      // 0f  431~ 447 (06bc)
  314.   // GROUP 14:  IOP
  315.   UINT32 iop_control;                           // 00  448      (0700) $bffe8700
  316.   UINT32 iop_status;                            // 01  449      (0704)
  317.   UINT32 iop_bp;                                // 02  450      (0708)
  318.   UINT32 iop_regsel;                            // 03  451      (070c)
  319.   UINT32 iop_regout;                            // 04  452      (0710)
  320.   UINT32 iop_memlimit;                          // 05  453      (0714)
  321.   UINT32 g14_reserved[2];                       // 06  454~ 455 (0718)
  322.   UINT32 iop_data[8];                           // 08  456~ 463 (0720)
  323.   UINT32 g14_reserved1[16];                     // 10  464~ 479 (0740)
  324.   // GROUP 15:  SUP
  325.   UINT32 sup_fst_cmd_addr;                      // 00  480      (0780) $bffe8780
  326.   UINT32 sup_snd_cmd_addr;                      // 01  481      (0784)
  327.   UINT32 sup_h_size;                            // 02  482      (0788)
  328.   UINT32 sup_mode;                              // 03  483      (078c)
  329.   UINT32 sup_tv_mode;                           // 04  484      (0790)
  330.   UINT32 sup_panning;                           // 05  485      (0794)
  331.   UINT32 sup_aspect_ratio;                      // 06  486      (0798)
  332.   UINT32 sup_mon[5];                            // 07  487~ 491 (079c)
  333.   UINT32 sup_config;                            // 0c  492      (07b0)
  334.   UINT32 sup_buffer_limit;                      // 0d  493      (07b4)
  335.   UINT32 g15_reserved[18];                      // 0e  494~ 511 (07b8)
  336.   // GROUP 16
  337.   UINT32 g16_reserved[32];                      // 00  512~ 543 (0800) $bffe8800
  338.   // GROUP 17
  339.   UINT32 g17_reserved[32];                      // 00  544~ 575 (0880) $bffe8880
  340.   // GROUP 18:  UARTs
  341.   // UART0
  342.   UINT32 uart0_data;                            // 00  576      (0900) $bffe8900
  343.   UINT32 uart0_lsr;                             // 01  577      (0904)
  344.   UINT32 uart0_msr;                             // 02  578      (0908)
  345.   UINT32 uart0_lcr;                             // 03  579      (090c)
  346.   UINT32 uart0_mcr;                             // 04  580      (0910)
  347.   UINT32 uart0_div_l;                           // 05  581      (0914)
  348.   UINT32 uart0_div_h;                           // 06  582      (0918)
  349.   UINT32 uart0_isc;                             // 07  583      (091c)
  350.   // UART1
  351.   UINT32 uart1_data;                            // 08  584      (0920)
  352.   UINT32 uart1_lsr;                             // 09  585      (0924)
  353.   UINT32 uart1_msr;                             // 0a  586      (0928)
  354.   UINT32 uart1_lcr;                             // 0b  587      (092c)
  355.   UINT32 uart1_mcr;                             // 0c  588      (0930)
  356.   UINT32 uart1_div_l;                           // 0d  589      (0934)
  357.   UINT32 uart1_div_h;                           // 0e  590      (0938)
  358.   UINT32 uart1_isc;                             // 0f  591      (093c)
  359.   UINT32 g18_reserved[16];                      // 10  592~ 607 (0940)
  360.   // GROUP 19:  GPIO control
  361.   UINT32 gpio_master[8];                        // 00  608~ 615 (0980) $bffe8980
  362.   UINT32 gpio_oe[8];                            // 08  616~ 623 (09a0)
  363.   UINT32 gpio_out[8];                           // 10  624~ 631 (09c0)
  364.   UINT32 gpio_in[8];                            // 18  632~ 639 (09e0)
  365.   // GROUP 20:  CDDSP
  366.   UINT32 cddsp_config;                          // 00  640      (0a00) $bffe8a00
  367.   UINT32 cddsp_control;                         // 01  641      (0a04)
  368.   UINT32 cddsp_mm_bcd;                          // 02  642      (0a08)
  369.   UINT32 cddsp_ss_bcd;                          // 03  643      (0a0c)
  370.   UINT32 cddsp_ff_bcd;                          // 04  644      (0a10)
  371.   UINT32 cddsp_status;                          // 05  645      (0a14)
  372.   UINT32 cddsp_mmss;                            // 06  646      (0a18)
  373.   UINT32 cddsp_ffmm;                            // 07  647      (0a1c)
  374.   UINT32 g20_reserved[24];                      // 08  648~ 671 (0a20)
  375.   // GROUP 21:  TV1
  376.   UINT32 tv_gamma[5];                           // 00  672~ 676 (0a80) $bffe8a80
  377.   UINT32 tv_pccon[18];                          // 05  677~ 694 (0a94)
  378.   UINT32 g21_reserved[9];                       // 17  695~ 703 (0adc)
  379.   // GROUP 22:  MBUS
  380.   UINT32 mbus_bridge_config;                    // 00  704      (0b00) $bffe8b00
  381.   UINT32 evbya;                                 // 01  705      (0b04)
  382.   UINT32 osdya;                                 // 02  706      (0b08)
  383.   UINT32 cdwya;                                 // 03  707      (0b0c)
  384.   UINT32 cdrya;                                 // 04  708      (0b10)
  385.   UINT32 supya;                                 // 05  709      (0b14)
  386.   UINT32 evbya_limit;                           // 06  710      (0b18)
  387.   UINT32 osdya_limit;                           // 07  711      (0b1c)
  388.   UINT32 cdwya_limit;                           // 08  712      (0b20)
  389.   UINT32 cdrya_limit;                           // 09  713      (0b24)
  390.   UINT32 supya_limit;                           // 0a  714      (0b28)
  391.   UINT32 bs_ystop;                              // 0b  715      (0b2c)
  392.   UINT32 bs_ry;                                 // 0c  716      (0b30)
  393.   UINT32 bs_yinit;                              // 0d  717      (0b34)
  394.   UINT32 bs_xinit;                              // 0e  718      (0b38)
  395.   UINT32 dvddsp_vy;                             // 0f  719      (0b3c)
  396.   UINT32 dvddsp_vx;                             // 10  720      (0b40)
  397.   UINT32 dvddsp_ry;                             // 11  721      (0b44)
  398.   UINT32 cdr_vy;                                // 12  722      (0b48)
  399.   UINT32 cdr_vx;                                // 13  723      (0b4c)
  400.   UINT32 supya2;                                // 14  724      (0b50)
  401.   UINT32 supya2_limit;                          // 15  725      (0b54)
  402.   UINT32 iopya;                                 // 16  726      (0b58)
  403.   UINT32 cdrya_xlimit;                          // 17  727      (0b5c)
  404.   UINT32 mvcya;                                 // 18  728      (0b60)
  405.   UINT32 g22_reserved[7];                       // 19  729~ 735 (0b64)
  406.   // GROUP 23: VPP2
  407.   UINT32 g23_vpp_contrast_adj[2];               // 00  736~ 737 (0b80) $bffe8b80
  408.   UINT32 g23_vpp_contrast_slope[3];             // 02  738~ 740 (0b88)
  409.   UINT32 g23_vpp_histogram[8];                  // 05  741~ 748 (0b94)
  410.   UINT32 g23_vpp_chksum;                        // 0d  749      (0bb4)
  411.   UINT32 g23_vpp_mv_ptr;                        // 0e  750      (0bb8)
  412.   UINT32 g23_vpp_hue_adj[2];                    // 0f  751~ 752 (0bbc)
  413.   UINT32 g23_reserved[15];                      // 11  753~ 767 (0bc4)
  414.   /*
  415.   UINT32 g23_vpp_contrast_adj[2];               // 00  736~ 737 (0b80) $bffe8b80
  416.   UINT32 g23_vpp_contrast_slope[3];             // 02  738~ 740 (0b88)
  417.   UINT32 g23_vpp_histogram[8];                  // 05  741~ 748 (0b94)
  418.   UINT32 g23_vpp_chksum;                        // 0d  749      (0bb4)
  419.   UINT32 g23_vpp_mv_ptr;                        // 0e  750      (0bb8)
  420.   UINT32 g23_vpp_sb_checksum;                   // 0f  751 (0bbc)
  421.   UINT32 g23_vpp_sb_eflg;                     // 10  752  (0bc0)
  422.   UINT32 g23_vpp_linear_size;                   // 11  753  (0bc4)
  423.   UINT32 g23_vpp_c_up_sample;                   // 12  754  (0bc8)
  424.   UINT32 g23_vpp_mask_frame;                    // 13  755  (0bcc)
  425.   UINT32 g23_dip_threshold2;                    // 14  756  (0bd0)
  426.   UINT32 g23_dip_mv_ptr;                     // 15  757  (0bd4)
  427.   UINT32 g23_ds_pic_id2;                     // 16  758  (0bd8)
  428.   UINT32 g23_bdir2_luma_base;               // 17  759  (0bdc)
  429.   UINT32 g23_bdir2_chroma_base;             // 18  760  (0be0)
  430.   UINT32 g23_color_space;                     // 19  761  (0be4)
  431.   UINT32 g23_mask_win_start;                  // 1a  762  (0be8)
  432.   UINT32 g23_mask_win_end;                  // 1b  763  (0bec)
  433.   UINT32 g23_video_h_size;                  // 1c  764  (0bf0)
  434.   UINT32 g23_spare1;                  // 1d  765  (0bf4)
  435.   UINT32 g23_spare2;                  // 1e  766  (0bf8)
  436.   UINT32 g23_stamp;                  // 1f  767  (0bfc)
  437. */
  438.   // GROUP 24: Buffer Control
  439.   UINT32 bufctl[8];                             // 00  768~ 775 (0c00) $bffe8c00
  440.   UINT32 g24_reserved[24];                      // 08  776~ 799 (0c20)
  441.   // GROUP 25: INVQ
  442.   UINT32 invq_qmx_par;                          // 00  800      (0c80) $bffe8c80
  443.   UINT32 invq_mode;                             // 01  801      (0c84)
  444.   UINT32 invq_chksum;                           // 02  802      (0c88)
  445.   UINT32 g25_reserved_0[2];                     // 03  803~ 804 (0c8c)
  446.   UINT32 invq_vol_header;                       // 05  805      (0c94)
  447.   UINT32 g25_reserved_1[26];                    // 06  806~ 831 (0c98)
  448.   // GROUP 26: RI/ROM
  449.   UINT32 rom_config;                            // 00  832      (0d00) $bffe8d00
  450.   UINT32 wait_cyc1_0;                           // 01  833      (0d04)
  451.   UINT32 wait_cyc3_2;                           // 02  834      (0d08)
  452.   UINT32 oe_wait_cyc1_0;                        // 03  835      (0d0c)
  453.   UINT32 oe_wait_cyc3_2;                        // 04  836      (0d10)
  454.   UINT32 we_wait_cyc1_0;                        // 05  837      (0d14)
  455.   UINT32 we_wait_cyc3_2;                        // 06  838      (0d18)
  456.   UINT32 iochrdy_wait_cyc;                      // 07  839      (0d1c)
  457.   UINT32 rom1_base;                             // 08  840      (0d20)
  458.   UINT32 rom2_base;                             // 09  841      (0d24)
  459.   UINT32 rom3_base;                             // 0a  842      (0d28)
  460.   UINT32 pcmcia_iorw_wait;                      // 0b  843      (0d2c)
  461.   UINT32 pcmcia_ctrl;                           // 0c  844      (0d30)
  462.   UINT32 g26_reserved1[8];                      // 0d  845~ 852 (0d34)
  463.   UINT32 adt[4];                                // 15  853~ 856 (0d54)
  464.   UINT32 dat[4];                                // 19  857~ 860 (0d64)
  465.   UINT32 adm[2];                                // 1d  861~ 862 (0d74)
  466.   UINT32 dar;                                   // 1f  863      (0d7c)
  467.   // GROUP 27: System Bus Arbitrator
  468.   UINT32 sbar_config;                           // 00  864      (0d80) $bffe8d80
  469.   UINT32 sbar_prr[16];                          // 01  865~ 880 (0d84)
  470.   UINT32 g27_reserved[2];                       // 11  881~ 882 (0dc4)
  471.   UINT32 sbar_sdram_rom;                        // 13  883      (0dcc)
  472.   UINT32 g27_reserved1[12];                     // 14  884~ 895 (0dd0)
  473.   // GROUP 28: Bridge
  474.   UINT32 rf_sdramif_tbya;                       // 00  896      (0e00) $bffe8e00
  475.   UINT32 rf_servo_band_en;                      // 01  897      (0e04)
  476.   UINT32 rf_servo_band_val;                     // 02  898      (0e08)
  477.   UINT32 g28_reserved[29];                      // 03  899~ 927 (0e0c)
  478.   // GROUP 29: Servo
  479.   UINT32 rf_regif_addr;                         // 00  928      (0e80) $bffe8e80
  480.   UINT32 rf_regif_wdata;                        // 01  929      (0e84)
  481.   UINT32 rf_regif_rdata;                        // 02  930      (0e88)
  482.   UINT32 rf_regif_sample_ctrl;                  // 03  931      (0e8c)
  483.   UINT32 rf_regif_intr_addr;                    // 04  932      (0e90)
  484.   UINT32 rf_regif_intr_wdata;                   // 05  933      (0e94)
  485.   UINT32 rf_regif_intr_rdata;                   // 06  934      (0e98)
  486.   UINT32 g29_reserved[25];                      // 07  935~ 959 (0e9c)
  487.   // GROUP 30: Emulation control
  488.   UINT32 emu_cfg[32];                           // 00  960~ 991 (0f00) $bffe8f00
  489.   // GROUP 31: Audio hardware control
  490.   UINT32 aud_reset;                             // 00  992      (0f80) $bffe8f80
  491.   UINT32 aud_pcm_cfg;                           // 01  993      (0f84)
  492.   UINT32 aud_spdif_cfg;                         // 02  994      (0f88)
  493.   UINT32 aud_enable;                            // 03  995      (0f8c)
  494.   UINT32 aud_adc_stereo_cfg;                    // 04  996      (0f90)
  495.   UINT32 aud_adc_mono_cfg;                      // 05  997      (0f94)
  496.   UINT32 aud_pcm_ramp_delta;                    // 06  998      (0f98)
  497.   UINT32 aud_pcm_ramp_cfg;                      // 07  999      (0f9c)
  498.   UINT32 aud_pcm_ramp_value;                    // 08 1000      (0fa0)
  499.   UINT32 aud_spdif_period;                      // 09 1001      (0fa4)
  500.   UINT32 aud_fifo_flag;                         // 0a 1002      (0fa8)
  501.   UINT32 aud_chn_pcm_cnt[10];                   // 0b 1003~1012 (0fac)
  502.   UINT32 aud_xck_cfg;                           // 15 1013      (0fd4)
  503.   UINT32 aud_pcm_bck_cfg;                       // 16 1014      (0fd8)
  504.   UINT32 aud_iec_bclk_cfg;                      // 17 1015      (0fdc)
  505.   UINT32 aud_adc_mclk_cfg;                      // 18 1016      (0fe0)
  506.   UINT32 aud_dsp_run_cnt;                       // 19 1017      (0fe4)
  507.   UINT32 aud_dsp_stall_cnt;                     // 1a 1018      (0fe8)
  508.   UINT32 aud_dsp_reset_flag;                    // 1b 1019      (0fec)
  509.   UINT32 aud_dsp_dec_cnt_toggle;                // 1c 1020      (0ff0)
  510.   UINT32 aud_dsp_dec_cnt;                       // 1d 1021      (0ff4)
  511.   UINT32 aud_fpga_v2[2];                        // 1e 1022~1023 (0ff8)
  512.   // GROUP 32
  513.   //UINT32 g32_reserved[32];                    // 00 1024~1055 (1000) $bffe9000
  514.   UINT32 card_mediaType;
  515.   UINT32 g32_reserved1[10];
  516.   UINT32 fm_gpio_mode; // 11
  517.   UINT32 fm_gpio_len; //12
  518.   UINT32 g32_reserved2[19];
  519.   // GROUP 33
  520.   //UINT32 g33_reserved[32];                      // 00 1056~1087 (1080) $bffe9080
  521.   UINT32 ndData;             // 0x20
  522.   UINT32 ndTimeProf;         // 0x21
  523.   UINT32 g33_reserved1;      // 0x22
  524.   UINT32 ndCtrl[2];          // 0x23 ~ 0x24
  525.   UINT32 g33_reserved2[11];  // 0x25 ~ 0x2f
  526.   UINT32 ataData;            // 0x30
  527.   UINT32 cfCtrl;             // 0x31
  528.   UINT32 cfAddrLsb;          // 0x32
  529.   UINT32 cfAddrMsb;          // 0x33
  530.   UINT32 ataMode;            // 0x34
  531.   UINT32 ataPulsWidth;       // 0x35
  532.   UINT32 ataCsnn;            // 0x36
  533.   UINT32 g33_reserved3[2];   // 0x37 ~ 0x38
  534.   UINT32 ataRegnn;           // 0x39
  535.   UINT32 ataRstnn;           // 0x3A
  536.   UINT32 fmGpioA;            // 0x3B
  537.   UINT32 g33_reserved4;      // 0x3C
  538.   UINT32 cfActTime;          // 0x3D
  539.   UINT32 g33_reserved5[2];   // 0x3e ~ 0x3f
  540.   // GROUP 34
  541.   //UINT32 g34_reserved[32];                      // 00 1088~1119 (1100) $bffe9100
  542.     UINT32  g34_reserved1[6];     // (1100) $bffe9100
  543. UINT32  spiFreq;            /* 0x46          */// (1106) $bffe9118
  544. UINT32  spiConfig;          /* 0x47          */// (1107) $bffe911C
  545. UINT32  spiMode;            /* 0x48          */
  546. UINT32  g34_reserved2[2];
  547. UINT32  spiStatus;          /* 0x4B          */
  548. UINT32  g34_reserved3[4];   /* 0x4C ~ 0x4F   */
  549. UINT32  sdRst;              /* 0x50          */
  550. UINT32  sdConfig;           /* 0x51          */
  551. UINT32  sdCtrl;             /* 0x52          */
  552. UINT32  sdStatus0;          /* 0x53          */
  553. UINT32  sdStatus1;          /* 0x54          */
  554. UINT32  sdBlockSize;        /* 0x55          */
  555. UINT32  g34_reserved4;      /* 0x56          */
  556. UINT32  sdRspTmr;           /* 0x57          */
  557. UINT32  sdCrcTmr;           /* 0x58          */
  558. UINT32  sdPioDataTx;        /* 0x59          */
  559. UINT32  sdPioDataRx;        /* 0x5a          */
  560. UINT32  sdCmdBuf[5];        /* 0x5b ~ 0x5f   */
  561.   // GROUP 35
  562.   //UINT32 g35_reserved[32];                      // 00 1120~1151 (1180) $bffe9180
  563.     UINT32  sdRspBuf[6];        /* 0x60 ~ 0x65   */
  564. UINT32  sdCrc7Buf;          /* 0x66          */
  565. UINT32  sdCrc16Buf0Lsb;     /* 0x67          */
  566. UINT32  sdCrc16Buf0Msb;     /* 0x68          */
  567. UINT32  sdCrc16Buf1Lsb;     /* 0x69          */
  568. UINT32  sdCrc16Buf1Msb;     /* 0x6a          */
  569. UINT32  sdCrc16Buf2Lsb;     /* 0x6b          */
  570. UINT32  sdCrc16Buf2Msb;     /* 0x6c          */
  571. UINT32  sdCrc16Buf3Lsb;     /* 0x6d          */
  572. UINT32  sdCrc16Buf3Msb;     /* 0x6e          */
  573. UINT32  sdCrc16Flag;        /* 0x6f          */
  574.     UINT32  msPioDmaRst;        /* 0x70          */
  575.     UINT32  msCmd;              /* 0x71          */
  576.     UINT32  g35_reserved1[2];   /* 0x72,0x73     */
  577.     UINT32  msModeSpeed;        /* 0x74          */
  578.     UINT32  msTimout;           /* 0x75          */
  579.     UINT32  msState1;           /* 0x76          */
  580.     UINT32  msState2;           /* 0x77          */
  581.     UINT32  msRddata[4];        /* 0x78~0x7B     */
  582.     UINT32  msCrcBufLsb;        /* 0x7C          */
  583.     UINT32  msCrcBufMsb;        /* 0x7D          */
  584.     UINT32  msCrcError;         /* 0x7E          */
  585.     UINT32  msPioRdy;           /* 0x7F          */
  586.     // GROUP 36
  587.     UINT32  msWdData[16];       /* 0x80~0x8f     */
  588.     UINT32  g36_reserved1[16];
  589.     // GROUP 37
  590.     //UINT32 g37_reserved[32];                      // 00 1184~1215 (1280) $bffe9280
  591.     UINT32  eccReset;           /* 0xa0        */
  592.     UINT32  psFmData;           /* 0xa1        */
  593.     UINT32  eccMask;            /* 0xa2        */
  594.     UINT32  eccMode;            /* 0xa3        */
  595.     UINT32  ecc1;               /* 0xa4        */
  596.     UINT32  ecc0;               /* 0xa5        */
  597.     UINT32  ecc2;               /* 0xa6        */
  598.     UINT32  ecc4;               /* 0xa7        */
  599.     UINT32  ecc3;               /* 0xa8        */
  600.     UINT32  ecc5;               /* 0xa9        */
  601.     UINT32  ecc7;               /* 0xaa        */
  602.     UINT32  ecc6;               /* 0xab        */
  603.     UINT32  ecc8;               /* 0xac        */
  604.     UINT32  ecca;               /* 0xad        */
  605.     UINT32  ecc9;               /* 0xae        */
  606.     UINT32  eccb;               /* 0xaf        */
  607.     UINT32  g37_reserved1[16];  /* 0xb0~ 0xbf  */
  608.   // GROUP 38
  609.   UINT32 g38_reserved[32];                      // 00 1216~1247 (1300) $bffe9300
  610.   // GROUP 39
  611.   UINT32 gpio_mode_B;
  612.   UINT32 g39_reserved[31];                      // 00 1248~1279 (1380) $bffe9380
  613.   // GROUP 40: DMA Controller Register
  614.   UINT32 dma_data;                              // 0x00 1280      (1400) $bffe9400
  615.   UINT32 dma_srcDst;                            // 0x01 1281~1308
  616.   UINT32 dma_size;                              // 0x02
  617.   UINT32 g40_reserved1;     // 0x03
  618.   UINT32 dma_ctrl; // 0x04
  619.   UINT32 dma_base_addrL;    // 0x05
  620.   UINT32 dma_base_addrH; // 0x06
  621.   UINT32 g40_reserved2[14]; // 0x07 ~  0x14
  622.   UINT32 dma_start;  // 0x15
  623.   UINT32 g40_reserved3;  // 0x16
  624.   UINT32 dma_cmp; // 0x17
  625.   UINT32 dma_cmpEn; // 0x18
  626.   UINT32 g40_reserved4[7];    // 0x19 ~  0x1f
  627.   // GROUP 41: (EMU) SDRAM 6A
  628.   UINT32 sdc_data_cnt[14][2];                   // 00 1312~1339 (0520) $bffe9480
  629.   UINT32 sdc_n_req_cnt[2];                      // 1c 1340~1341 (14f0)
  630.   UINT32 sdc_cke_cnt[2];                        // 1e 1342~1343 (14f8)
  631.   // GROUP 42~44
  632.   UINT32 g42_reserved[32];                      // 00 1344~1375 (1500) $bffe9500
  633.   UINT32 g43_reserved[32];                      // 00 1376~1407 (1580) $bffe9580
  634.   UINT32 g44_reserved[32];                      // 00 1408~1439 (1600) $bffe9600
  635.   // GROUP 45:  GAME16  
  636.   UINT32 game16_control; // 00  512~ 543 (0800) $bffe9680
  637.   UINT32 game16_status; // 0xbffe8804
  638.   UINT32 game16_code_base; // 0xbffe8808
  639.   UINT32 game16_vram_base; // 0xbffe880c
  640.   UINT32 game16_work_base;  // 0xbffe8810
  641.   UINT32 game16_game_dsp_dec_base; // 0xbffe8814
  642.   UINT32 game16_frame_base0; // 0xbffe8818
  643.   UINT32 game16_frame_base1; // 0xbffe881c
  644.   UINT32 game16_version; // 0xbffe8820
  645.   UINT32 game16_int_mode; // 0xbffe8824
  646.   UINT32 game16_io_data1; // 0xbffe8828
  647.   UINT32 game16_io_data2; // 0xbffe882c
  648.   UINT32 game16_io_data3; // 0xbffe8830
  649.   UINT32 game16_dma_control; // 0xbffe8834
  650.   UINT32 game16_game_dsp_dec_control; // 0xbffe8838
  651.   UINT32 game16_game_dsp_dec_wait; // 0xbffe883c
  652.   UINT32 game16_game_dsp_dec_buf_base; // 0xbffe8840
  653.   UINT32 game16_game_dsp_dec_buf_size; // 0xbffe8844
  654.   UINT32 game16_game_dsp_dec_buf_in; // 0xbffe8848 
  655.   UINT32 game16_game_dsp_dec_buf_out; // 0xbffe884c
  656.   UINT32 game16_game_dsp_dec_ice_base; // 0xbffe8850
  657.   UINT32 game16_game_dsp_dec_int_addr; // 0xbffe8854  
  658.   UINT32 game16_disp_control; // 0xbffe8858  
  659.   UINT32 game16_risc_control; // 0xbffe885c 
  660.   UINT32 game16_risc_data; // 0xbffe8860   
  661.   UINT32 g45_reserved[7]; // 
  662.   // GROUP 46~49
  663.   UINT32 g46_reserved[32];                      // 00 1472~1503 (1700) $bffe9700
  664.   UINT32 g47_reserved[32];                      // 00 1504~1535 (1780) $bffe9780
  665.   UINT32 g48_reserved[32];                      // 00 1536~1567 (1800) $bffe9800
  666.   UINT32 g49_reserved[32];                      // 00 1568~1599 (1880) $bffe9880
  667.   // GROUP 50
  668.   UINT32 g50_reserved[29];                      // 00 1600~1628 (1900) $bffe9900
  669.   UINT32 risc_fpga_version[3];                  // 1d 1629~1631 (1974)
  670.   // GROUP 51
  671.   UINT32 g51_reserved[29];                      // 00 1632~1660 (1980) $bffe9980
  672.   UINT32 block_fpga_version[3];                 // 1d 1661~1663 (19f4)
  673.   // GROUP 52
  674.   UINT32 g52_reserved[29];                      // 00 1664~1692 (1a00) $bffe9a00
  675.   UINT32 aud_fpga_version[3];                   // 1d 1693~1695 (1a74)
  676.   // GROUP 53~63
  677.   UINT32 g53_reserved[32];                      // 00 1696~1727 (1a80) $bffe9a80
  678.   UINT32 g54_reserved[32];                      // 00 1728~1759 (1b00) $bffe9b00
  679.   UINT32 g55_reserved[32];                      // 00 1760~1791 (1b80) $bffe9b80
  680.   UINT32 g56_reserved[32];                      // 00 1792~1823 (1c00) $bffe9c00
  681.   UINT32 g57_reserved[32];                      // 00 1824~1855 (1c80) $bffe9c80
  682.   UINT32 g58_reserved[32];                      // 00 1856~1887 (1d00) $bffe9d00
  683.   UINT32 g59_reserved[32];                      // 00 1888~1919 (1d80) $bffe9d80
  684.   UINT32 g60_reserved[32];                      // 00 1920~1951 (1e00) $bffe9e00
  685.   UINT32 g61_reserved[32];                      // 00 1952~1983 (1e80) $bffe9e80
  686.   UINT32 g62_reserved[32];                      // 00 1984~2015 (1f00) $bffe9f00
  687.   UINT32 g63_reserved[32];                      // 00 2016~2047 (1f80) $bffe9f80
  688.   // GROUP 64~255
  689.   UINT32 gxx_reserved[192][32];                 // 00 2048~8191 (0800) $bffea000
  690.   // GROUP
  691.   WorkBuf reg_dma_buf;
  692.   WorkBuf reg_dma_buf256;
  693.   WorkBuf reg_dma_buf512;
  694.   WorkBuf reg_dma_buf768;
  695.   //
  696.   // (OLD hardware, just for compatible issue)
  697.   //
  698. //  UINT32 evbya2;                                // 00 8192      (8000) $bfff0000
  699. //  UINT32 eabya;                                 // 01 8193      (8004)
  700. //  UINT32 dsp16ya;                               // 02 8194      (8008)
  701. //  UINT32 dma_addrmode;                          // 03 8195      (800c)
  702. //  UINT32 dma_addrlen;                           // 04 8196      (8010)
  703. //  UINT32 epp_status;                            // 05 8197      (8014)
  704. //  UINT32 epp_data;                              // 06 8198      (8018)
  705. //  UINT32 agdc_config;                           // 07 8199      (801c)
  706. //  UINT32 video_compress;                        // 08 8200      (8020)
  707. //  UINT32 dis_tv_out;                            // 09 8201      (8024)
  708. //  UINT32 audio_clkgen;                          // 05    5      (0014)
  709. } RegisterFile;
  710. /*
  711. **  Video
  712. */
  713. #define RF_CODING_EXT0_PROGRESSIVE_FRAME (1<<0)
  714. #define RF_CODING_EXT0_CHROMA_420_TYPE (1<<1)
  715. #define RF_CODING_EXT0_REPEAT_FIRST_FIELD (1<<2)
  716. #define RF_CODING_EXT0_ALTERNATE_SCAN (1<<3)
  717. #define RF_CODING_EXT0_INTRA_VLC_FORMAT (1<<4)
  718. #define RF_CODING_EXT0_Q_SCALE_TYPE (1<<5)
  719. #define RF_CODING_EXT0_CONCEAL_MOTION_VECTORS (1<<6)
  720. #define RF_CODING_EXT0_FRAME_PRED_FRAME_DCT (1<<7)
  721. #define RF_CODING_EXT0_TOP_FIELD_FIRST (1<<8)
  722. #define RF_CODING_EXT0_PICTURE_STRUCTURE (0x03<<9)
  723. #define RF_CODING_EXT0_INTRA_DC_PRECISION (0x03<<11)
  724. //#define RF_CODING_EXT0_LAST_PICTURE (1<<14)
  725. #define RF_CODING_EXT0_BACK_LAST (1<<14)
  726. #define RF_CODING_EXT0_SECOND_FIELD (1<<15)
  727. #define ext0_pic_struct(x) (((x)>>9)&0x03)
  728. /*
  729. ** Display Output Tweaking
  730. */
  731. #define RF_VOUT_SWAP_CBCR (1<<1)
  732. #define RF_VOUT_SWAP_LC (1<<2)
  733. /*
  734. **  Display Status
  735. */
  736. #define RF_Display_OSDRegion 0x00ff
  737. #define RF_Display_FieldNo 0x8000
  738. #define RF_Display_VSyncB 0x4000
  739. #define RF_Display_HSyncB 0x2000
  740. #define RF_Display_FieldEnd 0x1000
  741. #define DISPLAY_STATUS                  regs0->osd_display_status
  742. #define IsVSync()                       ((DISPLAY_STATUS & RF_Display_VSyncB)==0)
  743. #define IsHSync()                       ((DISPLAY_STATUS & RF_Display_HSyncB)==0)
  744. #define IsTopField()                    ((DISPLAY_STATUS & RF_Display_FieldNo)==0)
  745. #define IsBottomField()                 ((DISPLAY_STATUS & RF_Display_FieldNo))
  746. #define IsFieldEnd()                    ((DISPLAY_STATUS & RF_Display_FieldEnd))
  747. #define RF_Video_VPicEnd 0x0001
  748. #define RF_Video_VTblErr 0x0002
  749. #define RF_Video_VRunErr 0x0004
  750. #define RF_Video_VSliceErr 0x0008
  751. #define RF_Video_VErr 0x8000
  752. /*
  753. ** RISC Picture Start
  754. */
  755. #define IsRPicStart (regs0->pic_start)
  756. /*
  757. ** VLD Decoding Status
  758. */
  759. #define VLD_STATUS                      (regs0->vld_status)
  760. #define IsVPicEnd                       (VLD_STATUS & RF_Video_VPicEnd)
  761. #define IsVRunErr                       (VLD_STATUS & RF_Video_VRunErr)
  762. #define IsVTblErr                       (VLD_STATUS & RF_Video_VTblErr)
  763. #define IsVErr                          (VLD_STATUS & RF_Video_VErr)
  764. #define RF_CODING_EXT1_FORWARD_REF0 (0<<1)
  765. #define RF_CODING_EXT1_FORWARD_REF1 (1<<1)
  766. #define RF_CODING_EXT1_RECONST_REF0 (0<<2)
  767. #define RF_CODING_EXT1_RECONST_REF1 (1<<2)
  768. #define RF_CODING_EXT1_RECONST_B (2<<2)
  769. #define RF_CODING_EXT1_FIELDID (1<<4)
  770. //
  771. // TIMER TIMER TIMER TIMER TIMER TIMER TIMER
  772. //
  773. #define RF_TIMER_SRC_SYSCLK (0<<14)
  774. #define RF_TIMER_SRC_STC (1<<14)
  775. #define RF_TIMER_SRC_RTC (2<<14)
  776. #define RF_TIMER_SRC_TIMER (3<<14)
  777. #define RF_TIMER_RUN_ON (1<<13)
  778. #define RF_TIMER_RUN_OFF (0<<13)
  779. #define RF_TIMER_GO_ON (1<<11)
  780. #define RF_TIMER_GO_OFF (0<<11)
  781. #define RF_TIMER_MASK (0x3ff)
  782. #define TIMER_CONFIG_STOP ( RF_TIMER_GO_OFF )
  783. #define TIMER_CONFIG_STC ( RF_TIMER_SRC_STC
  784. | RF_TIMER_RUN_ON
  785. | RF_TIMER_GO_ON)
  786. #define TIMER_CONFIG_10ms ( TIMER_CONFIG_STC | (900-1))
  787. #define TIMER_CONFIG_4ms ( TIMER_CONFIG_STC | (360-1))
  788. #define TIMER_CONFIG_1ms ( TIMER_CONFIG_STC | (90-1))
  789. #define TIMER_CONFIG_dly ( RF_TIMER_SRC_STC
  790.      | RF_TIMER_RUN_OFF
  791. | RF_TIMER_GO_ON)
  792. #define TIMER_CONFIG_dlys(n) ( TIMER_CONFIG_dly | (n-1))
  793. #define TIMER_CONFIG_90k(n) ( TIMER_CONFIG_STC | (n-1))
  794. /*
  795. ** VPP VPP VPP VPP VPP VPP VPP
  796. */
  797. #define RF_HFACTOR_HEXP_ENABLE (1<<8)
  798. #define RF_HFACTOR_CIF_ENABLE (1<<9)
  799. /*
  800. **  CDDSP Control/Status
  801. */
  802. #define RF_CDDSP_RESET 0x0001
  803. #define RF_CDDSP_STOP 0x0002
  804. #define RF_CDDSP_PAUSE 0x0004
  805. #define RF_CDDSP_SEEK 0x0008
  806. #define RF_CDDSP_CRC_ERROR 0x0001
  807. #define RF_CDDSP_CRC_ERROR_LAST 0x0002
  808. #define RF_CDDSP_CRC_ERROR_MASK 0x0003
  809. /*
  810. **
  811. */
  812. #define RF_DSP24_RESET (1<<0)
  813. #define RF_DSP24_STALL (1<<1)
  814. /*
  815. ** EPP status
  816. */
  817. #define RF_EPP_IN_FULL (1<<3)
  818. #define RF_EPP_IN_EMPTY (1<<2)
  819. #define RF_EPP_OUT_FULL (1<<1)
  820. #define RF_EPP_OUT_EMPTY (1<<0)
  821. #define RF_Video_MPEG2_flag 0x08
  822. /*
  823. ** AGDC config
  824. */
  825. #define RF_AGDC_BPIC_LOC_RIGHT (0 << 0)
  826. #define RF_AGDC_BPIC_LOC_BOTTOM (1 << 0)
  827. #define RF_AGDC_BPIC_SIZE_LINE (0 << 2)
  828. #define RF_AGDC_BPIC_SIZE_FIELD (1 << 2)
  829. #define RF_AGDC_BPIC_SIZE_FULL (2 << 2)
  830. #define RF_AGDC_SDRAM_64MB (0 << 6)
  831. #define RF_AGDC_SDRAM_16MB (1 << 6)
  832. #define set_dis_tv_std(n) (regs0->osd_tv_std=(n))
  833. /*
  834. ** VIDEO VIDEO VIDEO VIDEO VIDEO VIDEO VIDEO VIDEO
  835. */
  836. #define RF_COMPRESS_888 (0 << 0)
  837. #define RF_COMPRESS_866 (1 << 0)
  838. #define RF_COMPRESS_666 (2 << 0)
  839. #define RF_COMPRESS_8655 (3 << 0)
  840. #define RF_COMPRESS_DITHER_ON (1 << 7)
  841. #define RF_COMPRESS_DITHER_OFF (0 << 7)
  842. #define RF_COMPRESS_CHROMA_FULL (0 << 8)
  843. #define RF_COMPRESS_CHROMA_HALF (1 << 8)
  844. /*
  845. ** regs0: register file pointer
  846. */
  847. #ifdef  GLOBAL_REGISTER
  848. register volatile       RegisterFile    *regs0  asm ("22");
  849. #define InitRegFile()   (regs0 = (volatile RegisterFile *)RGST_OFFSET)
  850. #else
  851. #define regs0           ((volatile RegisterFile *)RGST_OFFSET)
  852. #define InitRegFile()   {}
  853. #endif
  854. #endif/*__REGMAP_DVD_H*/