亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? vfd.c

?? 代碼有點(diǎn)長,需細(xì)心閱讀,僅供影音視聽類產(chǎn)品的開發(fā)人員參考
?? C
字號(hào):
/*
** FILE 
** vfd.c
**
** DESCRIPTION
** handle VFD functions.
*/
#include "user_init.h"
#include "config.h"
#include "global.h"
#include "sio.h"
//#include "ircode.h"   //JJDing 2002/08/30,code reduced 
#include "irconfig.h"                       //JJDing 2002/08/30.code reduced
#include "ircmd.h"
#include "func.h"
#include "osd.h"
#include "regmap.h"
#include "avd.h"
#include "reverse.h"
#include "iop.h"
#include "memmap.h"
#include "auctrl.h"
#include "vfd.h"
#include "vfdmap.h"
#include "vfdkey.h"
#include "fs9660.h"                         //wyf .


#if defined(DEBUG_VFDSEG)||defined(VFD_KEY_TEST)
int  vfd_digital = 0;
#endif

#if VFD_DRIVER==SPL10                       //zhg 2002/10/16
extern BYTE Select_Dir_flag;        //zhg 2002/09/26 13:50
#endif

#ifdef VFD_KEY_TEST
void print_debug_msg(BYTE data)
{
#ifdef DEBUG_VFDSEG 
        vfd_digital++;
        if(vfd_digital > 96) 
            vfd_digital = 1; 
            polling_vfd();
        psprintf(RegionValStr[REGION2], "VFDSEG: %02d", vfd_digital-1);  
        PrintOsdMsg(STR_OS_NULL, REGION2, 0, 1, CH_N);  
#endif
        //psprintf(linebuf, "KEY=%02d,FUN=%02d,MEM=%02d,BIT=%02d,KEY=%03d\n",
        //             data, vfd_keycode[data - 1], vfd_digital / 8,
        //             vfd_digital % 8, vfd_digital);
        //epp_write_slow(linebuf);
        //osd_print(linebuf);
        psprintf(RegionValStr[REGION0], "VFDKEY: %02d\n", data);
        PrintOsdMsg(STR_OS_NULL, REGION0, 0, 1, CH_N);
        //ZHX 062303
}
#endif

#ifdef SUPPORT_VFD_SW
/*==========================================================
void polling_vfd_sw()
Use 16312's data setting command to read its switch port.
and control volume via the port status.
 
SUNPLUS huziqin 2003-6-4 12:31
==========================================================*/
#define ROTATE_L  0x02//0x0d
#define ROTATE_R  0x01//0x0e
void polling_vfd_sw()
{
    BYTE data;
    static BYTE old_data;
    data = regs0->iop_data[1];
    if(old_data != data)
    {
        old_data = data;
        //psprintf(RegionValStr[REGION2], "VFDSWKEY: %02x\n", data);
        //PrintOsdMsg(STR_OS_NULL, REGION2, 5, 1, CH_N);
        if(data == ROTATE_L)
            ircmd_volume_down();
        else if(data == ROTATE_R)
            ircmd_volume_up();
    }
}
#endif

#if (VFD_DRIVER==NEC16312)&&defined(IR_NEC)
/*============================================================
set_vfd_light_level(BYTE level)
Use 16312's display control command to set lighting level 

in: level---only the lower 3bits is valid,that mean we have 8
    grade of lighting control.
    
out: this parameter will sent to 16312 throught vfd port.    

SUNPLUS huziqin 2003-6-4 12:16
============================================================*/
void vfd_set_light_level(void)
{
    static BYTE vfd_level = 4;
    static BYTE level_flag = 1;
    BYTE   *p = (BYTE *) (SDRAM_BASE_CACHED + regs0->iopya * 1024 + 0x400);
    if (level_flag)  vfd_level --;
    else   vfd_level ++;
    psprintf(RegionValStr[REGION1], "VFD LEVEL: %d\n", vfd_level);
    PrintOsdMsg(STR_OS_NULL, REGION1, 1, 1, CH_N);
    if(vfd_level ==4) {
    	 level_flag = 1;
    	 *(p+1) = 0x8f;
    } else {
         if (!vfd_level) level_flag = 0;
         *(p+1) = 0x88 |vfd_level;
      }
}

/*============================================================
void set_vfd_led(BYTE led_port)
Use 16312's data setting command to control its led port.
in: led---the lower 4 bits stand for the 4 led.

SUNPLUS huziqin 2003-6-4 12:27
============================================================*/
void vfd_set_led(void)
{
    static BYTE led;
    led ++;
    if (led > 3)  led = 0;    	
    *led_port = (~(1<<led))&0x0f;   
}

#endif

/*===============================================================
polling_vfdr()
Description:
    polling the key data register,if there is key down,a flag
    bit of the key data register will be set,then we get the key 
    data by reading lower 6 bits of this regs.Once the key data is get,
    we should clear the flag bit.
    To identify long press key and short press key,vfdr_long_count
    is defined,if (vfdr_long_count > 20),we consider it long,else
    short.

in:
    none
out:
    none
global r:
    VFD_NORM_RECV()
    game_ret_flag
global w:
    CLR_VFD_NORM_RECV()
    game_ret_flag
behavious:
    call_ir_func()
    
SUNPLUS huziqin 2003-8-4
===============================================================*/
BYTE game_ret_flag;
#if(VFD_DRIVER==NEC16312||VFD_DRIVER==UPD16311)
//#define DEBUG_VFDR
int polling_vfdr()
{
#ifdef SUPPORT_VFD_SW
    BYTE vfd_key_data = 0;
    static int vfdr_count = 0;
    static int vfdr_long_count = 0;
    static BYTE vfdr_state = 0;
    static BYTE old_key_data = 0;

    switch(vfdr_state)
    {
        case 0:  //check key down
            if(VFD_NORM_RECV())
            {
#ifdef DEBUG_VFDR           
                //epp_write("key down\n");
#endif
        vfd_key_data = GET_VFD_KEY();
        CLR_VFD_NORM_RECV();
                old_key_data = vfd_key_data; 
                vfdr_state = 1;
            }
            break;
        case 1:  //check release
            if(VFD_NORM_RECV())
            {
#ifdef DEBUG_VFDR           
                //epp_write("down2\n");
#endif
                CLR_VFD_NORM_RECV();
                vfdr_count = 0;
                vfdr_long_count ++;
            }
            else
            {
#ifdef DEBUG_VFDR           
                //epp_write("no key\n");
#endif
                if(vfdr_count ++ > 100)
                {
                    vfdr_state = 2;
                }
            }
            break;
        case 2:  //check long or short and execute  
            if(vfdr_long_count > 40)
            {
#ifdef DEBUG_VFDR           
                epp_write("long\n");
#endif
            }
            else
            {
#ifdef DEBUG_VFDR           
                epp_write("short\n");
#endif
            }
#ifdef VFD_KEY_TEST
            print_debug_msg(vfd_key_data);
#else
            if(game_ret_flag)
                game_ret_flag=0;
            else            
                call_ir_func(vfd_keycode[old_key_data-1]);
#endif
            
            //clear var
            vfdr_long_count = 0;
            vfdr_state = 0;
            vfdr_count = 0;
            old_key_data = 0;
            break;
        default:
            break;
    }//end of switch
#else //-----------------upper is SUPPORT_VFD_SW------------------------
    UINT32  key_data;
    key_data = GET_VFD_KEY(); 

#ifdef VFD_KEY_TEST
    print_debug_msg(key_data);
#else   
    call_ir_func(vfd_keycode[key_data - 1]);
#endif 
#endif  //upper is not SUPPORT_VFD_SW  
    return key_data;
}
#endif  //(VFD_DRIVER==NEC16312)



#if ((VFD_DRIVER==SPL10)||(VFD_DRIVER==SPL10_FOR_718))
BYTE    vfdr_1s_timer = 0;
BYTE    key_long_press = 0;
int polling_vfdr(void)
{
    static int vfdr_count = 0;
    static BYTE vfdr_state = 0;
    static BYTE old_key_data = 0;
    UINT32  key_data;
    key_data = GET_VFD_KEY(); 
#ifdef VFD_KEY_TEST
    print_debug_msg(key_data);
    return;
#endif
    switch (vfdr_state)
    {
        case 0x00:
            if(key_data != 0)
            {
                vfdr_count++;
                vfdr_state++;
                vfdr_1s_timer = 200;
                //vfdr_1s_timer=50;
                old_key_data = key_data;
                //  epp_write_wait("vfdr state 1\n");
                //psprintf(linebuf,"%d",key_data);
                //epp_write_wait(linebuf);
            }
            break;
        case 0x01:
            if(key_data != 0)
            {
                vfdr_count++;
                //psprintf(linebuf,"%d\n",vfdr_count);
                //epp_write_wait(linebuf);
            }
            if(vfdr_1s_timer == 0 || key_data == 0)
            {
                if(vfdr_count > 10)
                {
                    key_long_press = 1;
                    vfdr_state++;
                    vfdr_1s_timer = 30;
                    //epp_write_wait("long press\n");

                }
                else
                {
                    key_long_press = 0;
                    vfdr_state = 0;
                    //epp_write_wait("short press\n");                  
                }
                call_ir_func(vfd_keycode[old_key_data - 1]);
                vfdr_count = 0;
            }
            break;
        case 0x02:
            if(key_data != 0)
                vfdr_count++;
            if(vfdr_1s_timer == 0)
            {
                if(vfdr_count < 5)
                {
                    key_long_press = 2;
                    vfdr_state = 0;
                    //epp_write_wait("long press release\n");
                    call_ir_func(vfd_keycode[old_key_data - 1]);
                }
                else
                    vfdr_1s_timer = 30;
                vfdr_count = 0;
            }

            break;
        default:
            break;
    }
}
#endif  //(VFD_DRIVER==SPL10)


/*
** FUNCTION
** polling_vfd
** 
** DESCRIPTION
** checking if we could issue VFD task
*/

int polling_vfd(void)
{
#ifdef DEBUG_VFDSEG
    static int j = 0;
    init_vfd_clear(0xff);
#ifdef DEBUG_IR_CODE
    j++;
    if (j > 8)  j = 1;
    if (j%2)             //ZHX 033103
#else
    if(j ^= 0x01)
#endif
        vfd_dot(0, vfd_digital-1);
#else
    switch (play_state)
    {
        case VCD_STATE_NORMAL:
        case VCD_STATE_FREEZE:
        case VCD_STATE_SLOW:                //wyf.2-6-28 14:29
        case VCD_STATE_STEP:
        case VCD_STATE_PAUSE:
        case VCD_STATE_FORWARD:
        case VCD_STATE_BACKWARD:
            if(play_state == VCD_STATE_PAUSE) 
#if VFD_DRIVER==SPL10                       //zhg 2002/10/16
            vfd_show_time();
#else
            vfd_pause();
#endif
            else {
               cd_pause_ss = 0;   //ZHX 092703
               vfd_normal_state();
             }
            break;
        case VCD_STATE_STOP:                //zhyf for intro end show total time 2-10-25 9:03
#ifdef VFDVOL_DISPLAY
            volFlag = 0;
#endif            	
           vfd_stop();
            break;
        case VCD_STATE_OPEN:
            osd_time_flag = 0;                  //ZHX 062403
#ifdef VFDVOL_DISPLAY
            volFlag = 0;
#endif            	
            init_vfd_clear(0);
            vfd_open();
#if VFD_DRIVER==HT1621      //ZHX 040203 LCD ERR AT OPEN
            PrintOsdMsg(STR_OS_NULL, REGION2, 0, 0, CH_N); 
#endif
            break;
        case VCD_STATE_CLOSE:
        case VCD_STATE_READTOC:
            init_vfd_clear(0);
            vfd_close();
            break;
            #ifdef POWER_KEY         //zhyf test 2-9-12 10:30 
                   case VCD_STATE_POWER:
            osd_time_flag = 0;                  //ZHX 062403
#ifdef VFDVOL_DISPLAY
            volFlag = 0;
#endif            	
                            init_vfd_clear(0);      
            break;
            #endif
        default:
            break;
    }

#endif
    return 0;
}


void init_vfd_clear(BYTE c)
{
#ifdef SUPPORT_VFD
#if (VFD_DRIVER==NEC16312||VFD_DRIVER==SPL10||\
     VFD_DRIVER==SPL10_FOR_718||VFD_DRIVER==UPD16311)
    BYTE    i;
    BYTE   *p = (BYTE *) (SDRAM_BASE_CACHED + regs0->iopya * 1024 + 0x404);

    for(i = 0; i < INIT_IOP_VFD_SENT_CNT; i++)
    {
        *(p + i) = c;
    }
#endif

#if VFD_DRIVER==HT1621
    BYTE    i;
    BYTE   *p =
        (BYTE *) (SDRAM_BASE_CACHED + regs0->iopya * 1024 + LCD_CMD_OFFSET);
    for(i = 0; i < INIT_IOP_VFD_PARA_0; i++)
    {
        *(p + i) = c;
    }
#endif
#endif
}


 /*
  ** FUNCTION
  ** reset_vfd
  **
  ** DESCRIPTION
  ** setup VFD.  Should only called at power-up or emergency.
  */
#ifdef IR_NEC
void reset_vfd(void)
{
#ifdef SUPPORT_VFD
#if  (VFD_DRIVER==NEC16312||VFD_DRIVER==SPL10||\
      VFD_DRIVER==SPL10_FOR_718||VFD_DRIVER==UPD16311)
    BYTE   *p = (BYTE *) (SDRAM_BASE_CACHED + regs0->iopya * 1024 + 0x400);

    vfd_mem = (BYTE *) (SDRAM_BASE_CACHED + regs0->iopya * 1024 + 0x404);
    led_port = (p + 0);
   *led_port = 0x0f;    //LED data(the lower 4 bits)
    *(p + 1) = 0x8f;   //lighting level(the lower 4 bits)
    
    init_vfd_clear(0);
#endif

#if VFD_DRIVER==HT1621
    int     i;
    BYTE   *p = (BYTE *) (SDRAM_BASE_CACHED + regs0->iopya * 1024 + 0x400);

    vfd_mem =
        (BYTE *) (SDRAM_BASE_CACHED + regs0->iopya * 1024 + LCD_CMD_OFFSET);
    *(p + 0) = (INIT_IOP_VFD_PARA_0);
    for(i = 1; i <= LCD_CMD_TABLE_LEN; i++)
        *(p + i) = bLcdCmdTable[i - 1];
    init_vfd_clear(0);
#endif
#endif
}
#else
void reset_vfd(void)
{
#ifdef SUPPORT_VFD
#if  VFD_DRIVER==NEC16312||VFD_DRIVER==SPL10
    BYTE   *p = (BYTE *) (SDRAM_BASE_CACHED + regs0->iopya * 1024 + 0x400);

    vfd_mem = (BYTE *) (SDRAM_BASE_CACHED + regs0->iopya * 1024 + 0x404);
    *(p + 0) = 0x0f;
    *(p + 1) = 0x02;
    *(p + 2) = 0x8c;
    *(p + 3) = 0xc0;
    init_vfd_clear(0);//don't earse or else when turn on VFD flash a moment.wangbin 2003-05
#endif

#if VFD_DRIVER==HT1621
    int     i;
    BYTE   *p = (BYTE *) (SDRAM_BASE_CACHED + regs0->iopya * 1024 + 0x400);

    vfd_mem =
        (BYTE *) (SDRAM_BASE_CACHED + regs0->iopya * 1024 + LCD_CMD_OFFSET);
    *(p + 0) = (INIT_IOP_VFD_PARA_0);
    for(i = 1; i <= LCD_CMD_TABLE_LEN; i++)
        *(p + i) = bLcdCmdTable[i - 1];
    init_vfd_clear(0);
#endif
#endif
}
#endif

void vfd_dot(BYTE method, BYTE vfd_dot)
{
#ifdef SUPPORT_VFD
    if(method)
        vfd_mem[vfd_dot / 8] |= (1 << (vfd_dot % 8));
    else
        vfd_mem[vfd_dot / 8] &= (~(1 << (vfd_dot % 8)));
#endif
}

#if 0 //(VFD_MODULE==VFD_EQ)
void show_VFD_EQ_init(void)
{
    int i;
    
    for(i=0;i<VFD_EQ_MAX;i++)
      vfd_mem[vfd_eq[i]]=0;
        
    vfd_eq_display = 1;
    eq_UI_init();
    AVAPI_control(C_WRITE, AVAPI_SPECTRUM, C_ON);
        
}

void show_VFD_EQ(BYTE *EQ_value)
{
   int i,j;
   
   for(i=0;i<VFD_EQ_MAX;i++)
     vfd_mem[vfd_eq[i]]=0;
          
   if(vfd_eq_display && (!(MENU_SLIST() && MENU_PSEG())))
   {
      for(j=1;j<=VFD_EQ_MAX;j++) 
      {
        for(i=0;i<(EQ_value[j]/3);i++)
     vfd_dot(1,vfd_eq[VFD_EQ_MAX-j]*8+i);
      } 
      
      #if 0
      for(i=0;i<(bEqValue[1]/3);i++)
        vfd_dot(1,vfd_eq[3]*8+i);
  
      for(i=0;i<(bEqValue[2]/3);i++)
        vfd_dot(1,vfd_eq[2]*8+i);
  
      for(i=0;i<(bEqValue[3]/3);i++)
        vfd_dot(1,vfd_eq[1]*8+i);
  
      for(i=0;i<(bEqValue[4]/3);i++)
        vfd_dot(1,vfd_eq[0]*8+i);
      #endif
   }
}
#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久综合色8888| 6080国产精品一区二区| 亚洲第一二三四区| 亚洲精品在线免费观看视频| 99这里只有精品| 日本在线播放一区二区三区| 国产精品国产自产拍在线| 日韩限制级电影在线观看| 91啪亚洲精品| 国产成人8x视频一区二区 | 亚洲婷婷综合色高清在线| 欧美大片顶级少妇| 欧美日韩在线一区二区| 成人精品鲁一区一区二区| 青青国产91久久久久久| 亚洲精品一二三| 国产精品毛片a∨一区二区三区| 欧美丰满少妇xxxxx高潮对白 | 91色综合久久久久婷婷| 国产一区欧美二区| 蜜桃一区二区三区在线| 日韩综合小视频| 亚洲高清视频的网址| 中文字幕亚洲一区二区av在线 | 日韩欧美中文一区| 欧美日韩一区中文字幕| 色婷婷久久99综合精品jk白丝| 国产经典欧美精品| 国内精品嫩模私拍在线| 石原莉奈在线亚洲二区| 视频在线观看一区二区三区| 国产精品婷婷午夜在线观看| 久久免费午夜影院| 久久综合五月天婷婷伊人| 欧美一二三区在线| 51精品久久久久久久蜜臀| 欧美色精品在线视频| 欧美怡红院视频| 欧美日韩国产精选| 欧美精品18+| 这里只有精品免费| 日韩一区二区免费高清| 欧美精品乱人伦久久久久久| 欧美日韩精品欧美日韩精品| 欧美日韩亚洲综合在线| 欧美美女bb生活片| 91精品福利在线一区二区三区| 欧美日韩视频在线观看一区二区三区 | 欧美一级电影网站| 欧美一级片免费看| 精品免费99久久| 久久欧美一区二区| 日韩av一级片| 日韩电影在线观看电影| 日韩高清欧美激情| 精品综合免费视频观看| 欧美一区二区三区小说| 成人av在线网| 一本色道亚洲精品aⅴ| 91麻豆国产福利在线观看| 91在线视频观看| 91蝌蚪porny九色| 欧美日韩另类一区| 精品伦理精品一区| 国产精品三级av| 一区二区三区成人在线视频| 久久久午夜电影| 久久久久国产一区二区三区四区| 国产日韩亚洲欧美综合| 91精品欧美一区二区三区综合在| 97久久精品人人做人人爽| 国产精品白丝av| 国产91在线|亚洲| 不卡影院免费观看| 成人av在线一区二区| 成人小视频免费在线观看| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 亚洲欧美日韩久久精品| 一区二区三区在线免费视频| 日韩高清不卡一区二区三区| 美女尤物国产一区| 91香蕉视频mp4| 欧美一级精品在线| 亚洲精品美腿丝袜| 日本在线观看不卡视频| 99天天综合性| 69堂成人精品免费视频| 国产精品丝袜黑色高跟| 亚洲 欧美综合在线网络| 国产精品羞羞答答xxdd| 欧美中文字幕一区| 国产亚洲一区二区三区四区| 亚洲一区二区成人在线观看| 国产精品一区不卡| 欧美日韩激情在线| 国产精品毛片a∨一区二区三区| 午夜精品久久久久影视| 成人av在线网站| 精品亚洲成a人| 欧美午夜电影网| 1000部国产精品成人观看| 亚洲宅男天堂在线观看无病毒| 91一区二区三区在线播放| 精品国产乱码久久久久久图片| 久久久不卡网国产精品二区| 精品一区二区在线视频| 激情丁香综合五月| 欧美在线免费观看视频| 欧美国产1区2区| 国产激情一区二区三区桃花岛亚洲| 日韩欧美在线综合网| 国内精品免费**视频| 国产精品国产馆在线真实露脸| 9l国产精品久久久久麻豆| 一区二区三区在线视频观看| 91精品久久久久久蜜臀| 国产在线精品一区二区三区不卡| 日本一区二区在线不卡| 欧美在线色视频| 久久国产人妖系列| 国产精品成人免费| 欧美日韩精品免费| 国产成人免费av在线| 一区二区三区欧美| 欧美一区二区播放| 色狠狠一区二区三区香蕉| 精品一区在线看| 亚洲高清不卡在线| 综合中文字幕亚洲| 久久久精品影视| 在线播放视频一区| 不卡在线观看av| 国产伦精品一区二区三区视频青涩| 亚洲精品国产无天堂网2021| 9191成人精品久久| 九一久久久久久| 日韩精品一级二级 | 91女人视频在线观看| 午夜精品福利一区二区三区av| 中日韩免费视频中文字幕| 欧美一区二区黄| 91精品国产91久久综合桃花| 久久国产精品72免费观看| 亚洲精品日韩综合观看成人91| 久久精品亚洲麻豆av一区二区| 91国产免费观看| 91国偷自产一区二区开放时间 | 亚洲欧美日韩国产成人精品影院| 精品区一区二区| 黄色日韩网站视频| 欧洲av一区二区嗯嗯嗯啊| 精品制服美女久久| 国产毛片精品视频| 国产成人免费视频精品含羞草妖精| 国产.欧美.日韩| 国产成人啪午夜精品网站男同| 美日韩一区二区| 99在线视频精品| 欧美大片一区二区| 亚洲第一主播视频| 福利一区在线观看| 日韩一区二区在线看| 日韩欧美国产wwwww| 亚洲精品国久久99热| 国产乱人伦偷精品视频免下载| 欧美日韩一区三区| 亚洲欧美偷拍卡通变态| 国产精品一区二区x88av| 欧美色网一区二区| 国产精品欧美一区二区三区| 日韩精品91亚洲二区在线观看| 国产999精品久久久久久| 色成人在线视频| 欧美一区午夜视频在线观看| 中文在线资源观看网站视频免费不卡 | 日本不卡一区二区三区| 成人性生交大片免费看在线播放| 精品久久久久久久久久久久包黑料 | 日日嗨av一区二区三区四区| 国产精品综合二区| 欧美剧情片在线观看| 国产精品二区一区二区aⅴ污介绍| 亚洲bt欧美bt精品| 欧美在线视频你懂得| 国产精品久久久久久福利一牛影视| 免费在线成人网| 91精品国产91久久综合桃花| 亚洲午夜电影在线观看| 色国产综合视频| 一区二区三区免费观看| 99re热这里只有精品免费视频| 国产女主播视频一区二区| 国产精品99久久久久久久vr| 久久久久久久久久久电影| 成人性生交大片免费看中文网站| 国产精品毛片大码女人| 97se亚洲国产综合自在线不卡| 精品久久久久一区| 一区二区免费视频| 日韩精品一区二区三区老鸭窝|