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

DVD

开发平台:

C/C++

  1. /*
  2. ** FILE
  3. ** polling.c
  4. **
  5. ** DESCRIPTION
  6. ** polling hardware response.
  7. **
  8. **
  9. ** HISTORY     terry, maintain
  10. **             2003.03.07    reduce stack by inline function
  11. **
  12. **/
  13. #include "config.h"
  14. #include "global.h"
  15. #include "memmap.h"
  16. #include "memmap0.h"
  17. #include "avd.h"
  18. #include "util.h"
  19. #include "stc.h"
  20. #include "audio.h"
  21. #include "cd.h"
  22. #include "cddsp.h"
  23. #include "ringbuf.h"
  24. #include "sig.h"
  25. #include "user_init.h"
  26. #include "vfdfunc.h"
  27. #include "func.h"
  28. #include "cfont.h"
  29. #include "osd.h"
  30. #include "macro.h"
  31. #include "dsp3_if.h"
  32. #include "ircmd.h"
  33. #include "kernel.h"
  34. #include "fs96602.h"
  35. #include "fs.h"
  36. #include "nav.h"
  37. #include "polling.h"
  38. #include "fsnav.h"
  39. #include "kinf.h"
  40. #include "pinf.h"
  41. #include "gpio.h"
  42. #include "timer.h"
  43. #include "ircode.h"//terry 20030822
  44. #include "avi_if.h"
  45. #ifdef TTE_HOST_DVD
  46. #include "pca9564.c" //lijd for TTE PCA9564 2004-11-11 19:56
  47. #endif
  48. #ifdef UART_WITHOUT_DEBUG_MODE
  49. #include "io_uart0.h"
  50. #include "UartComm.h"
  51. #endif
  52. #ifdef UART_SWAP //axel swap uart0 and uar1 2004/10/29
  53. #include "io_uart1.h"
  54. #include "UartComm.h"
  55. #endif
  56. #ifdef QSI_PLATFORM //qsi: merge by johnson 20040712
  57. #include "drv.h"
  58. //sharon
  59. #endif
  60. #ifdef SUPPORT_MIDI
  61. #include "fsmidi.h"
  62.     #ifdef SUPPORT_MIDI_MENU_SEL  //by dtb in 20040225
  63. #include "fsMidiUI.h"
  64. #endif
  65. #endif
  66. #if defined(SUPPORT_TUNER_MV114) || defined(SUPPORT_TUNER_ALPS)
  67. #include "radio_mv114_kst.h"//xyy 2004-5-26
  68. #endif
  69. #ifdef SUPPORT_UART_UPGRADE
  70. #include "UartComm.h"
  71. #endif
  72. #ifdef SUPPORT_EXTERNAL_MIC
  73. #include "gpio.h"
  74. #endif
  75. #ifdef  SUPPORT_MP4_SUBTITLE
  76. #include "Subtitle.h"
  77. #endif
  78. #ifdef SUPPORT_REP_READ
  79. #include "read.h"
  80. #endif
  81. #ifdef PROVIEW_GPIO_KEY     //BRUCE ADD 2003/2/14 12:20PM
  82. #include ".\Customers\Conser\proviewkey.c"
  83. #endif
  84. #ifdef  SUPPORT_SPI
  85. #include "spi.h"
  86. #endif
  87. #ifdef SUPPORT_DISPLAY_MENU
  88. #include "setup_def.h"
  89. #endif
  90. #ifdef SUPPORT_CD_TEXT
  91. #include "CDTextUtil.h"
  92. #endif
  93. //for support SWD //jslin   //20041022
  94. #ifdef SUPPORT_PS2
  95. #include "polling_PS2.c"
  96. #endif
  97. #ifdef DVB1000_NON_OS //eric 2005-01-04 11:06
  98. #include "Sp_dtv.h"
  99. #endif
  100. #ifdef SUPPORT_PLAY_SWD
  101. extern void polling_SWD(void);
  102. #endif
  103. #ifdef HDMI
  104. //==========================kevin add for HDMI
  105. extern void HDCP_polling(void);
  106. //=============================================================
  107. #endif
  108. //=====================================================
  109. //* debug option
  110. //=====================================================
  111. #ifndef DVDRELEASE
  112. //#define POLLING_DBG     1
  113. #endif
  114. #ifdef  POLLING_DBG
  115. //#define MONE_TIMEOUT
  116. //#define MONE_TIMEOUT_SRC
  117. //#define MONE_DSP24
  118. #endif
  119. #ifndef POLLING_DBG
  120. #undef printf
  121. #undef print_block
  122. #define printf(f, a...) do {} while (0)
  123. #define print_block(x,y) do {} while (0)
  124. #endif
  125. #ifdef TTE_HOST_DVD  //lijd for TTE PCA9564 2004-11-11 19:56
  126. #define HDI_STATE_IDLE               0
  127. #define HDI_STATE_WAIT_CTL_RESERVED  1
  128. #define HDI_STATE_WAIT_CTL_CODE      2
  129. #define HDI_STATE_WAIT_SYS_RESERVED  3
  130. #define HDI_STATE_WAIT_SYS_CODE      4
  131. #define HDI_STATE_WAIT_INF_RESERVED  5
  132. #define HDI_STATE_WAIT_INF_CODE      6
  133. #define HDI_STATE_WAIT_SET_RESERVED  7
  134. #define HDI_STATE_WAIT_SET_CODE      8
  135. #endif
  136. //=====================================================
  137. //* extern function declare
  138. //=====================================================
  139. extern inline void  PollingI2CPageWrite();
  140. extern inline void Score_Polling(); // in score.c
  141. extern void ircmd_pre_paser(BYTE rx);
  142. extern inline void dvd_hl_force_action(void);
  143. extern void update_vfd_data(void);
  144. extern inline void polling_dvd_timer(void);
  145. extern inline void recover_hl_color(void);
  146. extern void DisplayEq(void);
  147. extern void DispPolling(BYTE bReset);
  148. extern void tv_format_machine(void);
  149. extern inline void dsp_watchdog(void);
  150. extern void reset_vfd_again(void);
  151. extern void polling_vfdsw(void);
  152. extern void polling_phone(void);            //////yangli 2004-10-12
  153. extern void AC3ShowReport();
  154. extern inline void polling_mp3(void);
  155. extern int ClockPolling(BYTE show);
  156. //extern void tuner_mute(int mute);
  157. extern void check_key_status(void);
  158. extern void check_key_status_ourmind();
  159. extern void check_ourmind_light_status();
  160. extern void check_keyboard_status();
  161. extern void check_keylight_status();
  162. #ifdef DVD_SERVO
  163. extern void ServoDecMainLoop(void);
  164. #endif
  165. extern void pollingUARTServo(void);
  166. extern void ircmd_play(void);
  167. extern inline void MPx_ChkSmpRate();
  168. extern UINT16 Is_JPEG_PLAY_STATE(void);
  169. extern void check_keyboard_status();
  170. #ifdef SUPPORT_CARD_STORAGE
  171. extern void polling_card_plug(void);
  172. #endif //SUPPORT_CARD_STORAGE
  173. #if defined(SUPPORT_USB)||defined(SPHE8202_CARD_STORAGE)
  174. extern void polling_storage();  //wthsin,2004/4/12 02:16pm
  175. #endif 
  176. #ifdef PMP_DVD 
  177.  extern void PMP_PC_Usb_PlugInOut();
  178. #endif //#ifdef PMP_DVD 
  179. #if defined(PCM1742)&&defined(CHECK_DAC_ZERO_FLAG_TO_GPIO_MUTE)     //gerry,3-10-20 11:35
  180. extern void check_pcm1742_zero_flag();
  181. #endif
  182. #ifdef  SETUP_DONT_PAUSE
  183. extern void polling_10ms_save(void);
  184. #endif
  185. #ifdef POLLING_10MS_SAVE_RESUME //Maoyong, 2004.03.01 10:02
  186. extern void polling_10ms_save_rsm(void);
  187. #endif  
  188. #ifdef SHOW_STANDBY_TIMER//suqiaoli 2003-8-7 
  189. extern void polling_setup_standby_timer(void);
  190. #endif  
  191. #if defined(SUPPORT_FS_LONGNAME)
  192. extern void FS_ScrollDispFileName(void);
  193. #endif
  194. #ifdef SUPPORT_DSPMUTE
  195. extern UINT32 coding_mode_now;      // benson add 2004-08-20 for receiver 
  196. #endif 
  197. #ifdef SUPPORT_UPGRADE_WHEN_RUNNING
  198. extern void polling_upgrade_info();
  199. #endif
  200. //=====================================================
  201. //* external var. decalare
  202. //=====================================================
  203. extern BYTE gAC3onoff;
  204. extern BYTE audioNotContinuous;
  205. extern BYTE tuner_mute_flag;
  206. extern BYTE polling_clock;
  207. extern BYTE bJpgVFDPause;
  208. extern UINT8  safe_on;
  209. #if defined(SUPPORT_BASS_TREBLE)
  210. extern BYTE flag_BassAdjust; //xulf
  211. extern BYTE flag_TrebleAdjust; //xulf
  212. #endif
  213. //============================kevin add for HDMI==============
  214. #ifdef HDMI
  215. extern void ResetAuthentStates();
  216. extern void AuthenticationHandler();  //authenticate the RX include all processes
  217. extern void DSIntegratyLinkCheck();
  218. #endif
  219. //===================================================
  220. //=====================================================
  221. //* define
  222. //=====================================================
  223. #define GET_RTC_15_0()  (regs0->rtc_15_0)
  224. //=====================================================
  225. //* local var.
  226. //=====================================================
  227. #ifdef CHECKPHONE
  228. int phone_flag=0;   /////////////////yangli add it for 5.1ch phone,2004-10-10
  229. int phone_flag_k=0;
  230. #endif
  231. #ifdef AUTO_CLOSE_LOADER
  232. UINT16 auto_close_timer=0;
  233. #endif
  234. #ifdef RECORD_PER_SECOND
  235. int resume_time_ourmind=0;
  236. #endif
  237. UINT8   polling_avoid_reentry=0;
  238. UINT8   dsp_delay=0;
  239. #ifdef AVOID_READDISC_WHEN_STARTUP  //xyy add for Oritron
  240. UINT16 uStartCounter=0;
  241. UINT16 uCounterFlag=0;
  242. #endif
  243. #ifdef SUPPORT_EXTERNAL_MIC
  244. UINT16 auto_mute_extern_mic_timer=0;
  245. #endif
  246. #ifdef CD_PLAYER        //liweihua 2003-9-3
  247. extern void DisplaycdEq(void);
  248. #endif
  249. #ifdef DVB1000_NON_OS //eric add 2005-01-04 13:53 
  250. int progCount=0;
  251. stProgramInfo_t *progInfo; 
  252. int nTimeCounter = 0;
  253. #endif
  254. //=====================================================
  255. //* static inline function
  256. //=====================================================
  257. //#include "line21.c"
  258. #include "polling_fun.h"
  259. //=====================================================
  260. //* Option function
  261. //=====================================================
  262. //terry,2004/2/11 04:44PM
  263. //move asv function to asv.c
  264. #ifdef AUTO_CLOSE_LOADER
  265. static inline void auto_close_fun(void)
  266. {
  267.     if(auto_close_timer&0x8000)
  268.     {
  269.         auto_close_timer++;
  270.         //printf("auto_close_timer=%xn",auto_close_timer);
  271.         if(auto_close_timer>0x8040)
  272.         {
  273.             if(system_state == SYSTEM_OPEN)
  274.             {
  275.                 auto_close_timer=0;
  276.                 ircmd_play();
  277.             }
  278.             else
  279.             {
  280.                 auto_close_timer=0;
  281.             }
  282.         }
  283.    }
  284. }
  285. #else
  286. #define auto_close_fun();
  287. #endif
  288. #ifdef RECORD_PER_SECOND
  289. static inline void auto_record_per_s(void)
  290. {
  291.     if(play_state==VCD_STATE_NORMAL)
  292.     {
  293.         if(Is_MP3_STATE()||((cd_type_loaded!=CDROM)&&(!is_menu())))
  294.         {   if(resume_time_ourmind<6)
  295.             {
  296.                 resume_time_ourmind++;
  297.                 //printf("resume_time_ourmind=%dn",resume_time_ourmind);
  298.             }
  299.             if(resume_time_ourmind>=6)
  300.             {
  301.                 RsmInfo2Flash(0);
  302.                 resume_time_ourmind=0;
  303.                 //printf("resume_time_ourmind=%dn",resume_time_ourmind);
  304.             }
  305.         }
  306.     }
  307. }
  308. #else
  309. #define auto_record_per_s();
  310. #endif
  311. #ifdef STB_2_0
  312. static inline void ethernet_access(void)
  313. {
  314.     //for Ethernet Access test
  315.     if (iIntCnt != pr0Cnt)
  316.     {
  317.       printf("cnt=%dn",iIntCnt);
  318.       pr0Cnt=iIntCnt;
  319.     }
  320.     *pEth=0x01;
  321.     p=*pEth;
  322.     if (p!=0x01) printf("Eth Error!!n");
  323. }
  324. #else
  325. #define ethernet_access()       ((void)(0))
  326. #endif //STB_2_0
  327. static inline void dsp_dbg_fun(void)
  328. {
  329. #ifndef MONE_DSP24
  330. regs0->dsp24_port[6] = 0;
  331. #else//#ifndef MONE_DSP24
  332.     int dbg_msg;
  333.     if (regs0->dsp24_port[6])
  334.     {
  335.     #ifndef  MONE_DSP24_LONG  //ycwen 2004/12/15  Printf short message to prevent from disturbing audio debugging
  336.     printf("DSP: %04xn", regs0->dsp24_port[7]);
  337.     //ycwen 2004/12/15 Print video and audio buffer status if necessary
  338.     //printf("DSP3: %04x %x %xn", regs0->dsp24_port[7], get_vbv_free_exact(vbv_y), dsp3_get_rest_buf_size());
  339.     #else//#ifndef  MONE_DSP24_LONG  //ycwen 2004/12/15  Printf short message to prevent from disturbing audio debugging
  340.     dbg_msg=regs0->dsp24_port[7];//show DSP message
  341.     printf("DSP3:");
  342.     switch(dbg_msg)
  343.     {
  344.     case 0xC011:
  345.     printf(" %04x download dsp3rom.d16.ac3.2ch successfullyn",dbg_msg);
  346.     break;
  347.     case 0xC012:
  348.     printf(" %04x download dsp3rom.d16.ac3.5.1ch.16M successfullyn",dbg_msg);
  349.     break;
  350.     case 0xC031:
  351.     printf(" %04x download dsp3rom.d16.mp3.2ch successfullyn",dbg_msg);
  352.     break;
  353.     case 0xC032:
  354.     printf(" %04x download dsp3rom.d16.mp3.2ch.EQ.16M successfullyn",dbg_msg);
  355.     break;
  356.     case 0xC041:
  357.     printf(" %04x download dsp3rom.d16.lpcm.2ch successfullyn",dbg_msg);
  358.     break;
  359.     case 0xC042:
  360.     printf(" %04x download dsp3rom.d16.lpcm.2ch.EQ.16M successfullyn",dbg_msg);
  361.     break;
  362.     case 0xC061:
  363.     printf(" %04x download dsp3rom.d16.cd.2ch successfullyn",dbg_msg);
  364.     break;
  365.     case 0xC071:
  366.     printf(" %04x download dsp3rom.d16.wma.2ch successfullyn",dbg_msg);
  367.     break;
  368.     case 0xC091:
  369.     printf(" %04x download dsp3rom.d16.spdif.2ch successfullyn",dbg_msg);
  370.     break;
  371.     case 0xC0B1:
  372.     printf(" %04x download dsp3rom.d16.nes.2ch successfullyn",dbg_msg);
  373.     break;
  374.     case 0xD011:
  375.     printf(" %04x download dsp3rom.d16.ac3 successfullyn",dbg_msg);
  376.     break;
  377.     case 0xD012:
  378.     printf(" %04x download dsp3rom.d16.ac3.spi successfullyn",dbg_msg);
  379.     break;  
  380.     case 0xD013:
  381.     printf(" %04x download dsp3rom.d16.945.ac3 successfullyn",dbg_msg);
  382.     break;  
  383.     case 0xD021:
  384.     printf(" %04x download dsp3rom.d16.dts successfullyn",dbg_msg);
  385.     break;  
  386.     case 0xD022:
  387.     printf(" %04x download dsp3rom.d16.dts.spi successfullyn",dbg_msg);
  388.     break;  
  389.     case 0xD023:
  390.     printf(" %04x download dsp3rom.d16.dtscd successfullyn",dbg_msg);
  391.     break;  
  392.     case 0xD024:
  393.     printf(" %04x download dsp3rom.d16.945.dts successfullyn",dbg_msg);
  394.     break;  
  395.     case 0xD025:
  396.     printf(" %04x download dsp3rom.d16.108.dtscd successfullyn",dbg_msg);
  397.     break;
  398.     case 0xD026:
  399.     printf(" %04x download dsp3rom.d16.raw.dtscd successfullyn",dbg_msg);
  400.     break;
  401.     case 0xD031:
  402.     printf(" %04x download dsp3rom.d16.mp3 successfullyn",dbg_msg);
  403.     break;
  404.     case 0xD041:
  405.     printf(" %04x download dsp3rom.d16.lpcm successfullyn",dbg_msg);
  406.     break;
  407.     case 0xD042:
  408.     printf(" %04x download dsp3rom.d16.lpcm.fudo successfullyn",dbg_msg);
  409.     break;  
  410.     case 0xD051:
  411.     printf(" %04x download dsp3rom.d16.ppcm successfullyn",dbg_msg);
  412.     break;
  413.     case 0xD061:
  414.     printf(" %04x download dsp3rom.d16.cd successfullyn",dbg_msg);
  415.     break;
  416.     case 0xD062:
  417.     printf(" %04x download dsp3rom.d16.cd.spi successfullyn",dbg_msg);
  418.     break;
  419.     case 0xD071:
  420.     printf(" %04x download dsp3rom.d16.wma successfullyn",dbg_msg);
  421.     break;
  422.     case 0xD081:
  423.     printf(" %04x download dsp3rom.d16.midi successfullyn",dbg_msg);
  424.     break;
  425.     case 0xD091:
  426.     printf(" %04x download dsp3rom.d16.spdif successfullyn",dbg_msg);
  427.     break;
  428.     case 0xD0A1:
  429.     printf(" %04x download dsp3rom.d16.noise successfullyn",dbg_msg);
  430.     break;
  431.     case 0xD0B1:
  432.     printf(" %04x download dsp3rom.d16.nes successfullyn",dbg_msg);
  433.     break;
  434.     case 0xD0C1:
  435.     printf(" %04x download dsp3rom.d16.tuner successfullyn",dbg_msg);
  436.     break;
  437.     case 0xCDEF:
  438.     printf(" %04x DSP PCM output underflown",dbg_msg);
  439.     break;
  440.     case 0xDEAD:
  441.     printf(" %04x bitstream  errorn",dbg_msg);
  442.     break;
  443.     default:
  444.     printf(" %04xn",dbg_msg);
  445.     }//switch(dbg_msg)
  446. #endif //#ifndef  MONE_DSP24_LONG  //ycwen 2004/12/15  Printf short message to prevent from disturbing audio debugging
  447.         regs0->dsp24_port[6]=0;
  448.     }// if (regs0->dsp24_port[6])
  449. #endif // #ifndef MONE_DSP24
  450. }
  451. #ifdef TURN_OFF_POWER_RESUME
  452. //wangap add 2004/4/21
  453. void polling_resume(void)
  454. {
  455. RsmInfo2Flash(0);
  456. }    
  457. #endif
  458. //=====================================================
  459. //* function
  460. //=====================================================
  461. //
  462. // FUNCTION
  463. // polling_timeout()
  464. //
  465. // DESCRIPTION
  466. // check if timeout
  467. //
  468. void polling_timeout(void)
  469. {
  470.     if( ( timeout_playback )        // 2004/12/29 yltseng
  471. #ifndef SETUP_DONT_PAUSE
  472.         && ( full_scrn != SETUP )
  473. #endif
  474. #ifndef PROG_DONT_PAUSE
  475.         && ( full_scrn != PROGRAM )
  476. #endif
  477.     )
  478.     {
  479.         if (get_rtc() > timeout_playback)
  480.         {
  481.           //if (GetIntrMask()&INTR_TIMEOUT)
  482.           //    SetIntrFlag(GetIntrFlag()|INTR_TIMEOUT);
  483. #ifdef MONE_TIMEOUR_SRC
  484.           printf(__FUNCTION__" timeoutn");
  485. #endif
  486.           if(auto_pause)
  487.           {
  488.             timeout_playback=0;
  489.             ircmd_play();
  490.           }
  491.           else
  492.             AVD_SetMediaTimeout();
  493.         }
  494.     }
  495. }
  496. #ifdef SUPPORT_HEADPHONE  //xyy 2004-10-9
  497. #define TEST_HEADPHONE_SENSE      (regs0->gpio_in[HEADPHONE_SENSE/16]&(1<<(HEADPHONE_SENSE%16)))    //pin71
  498. extern void ddx_masterMute(BYTE mute);
  499. extern void ddx_enableEPAD(void);
  500. extern void ddx_disableEPAD(void);
  501. extern void write_reg_bit(int addr,BYTE bit,BYTE val);
  502. BYTE bHpPlug;  // 1: headphone plug in   0:headphone not plug in
  503. BYTE bCounter[2];
  504. void polling_headphone(void)
  505. {
  506. static BYTE bOldStas,bNewStas;
  507. if(TEST_HEADPHONE_SENSE)
  508. {
  509. bCounter[0]++;
  510. if(bCounter[0]<5 && !TEST_HEADPHONE_SENSE)
  511. bCounter[0] = 0;
  512. if(bCounter[0] == 5)
  513. {
  514. bHpPlug = 1;
  515. bCounter[0] = 0;
  516. }
  517. }
  518. else
  519. {
  520. bCounter[1]++;
  521. if(bCounter[1]<5 && TEST_HEADPHONE_SENSE)
  522. bCounter[1] = 0;
  523. if(bCounter[1] == 5)
  524. {
  525. bHpPlug = 0;
  526. bCounter[1] = 0;
  527. }
  528. }
  529. bNewStas = bHpPlug;
  530. if(bHpPlug && (bNewStas!=bOldStas))
  531. {
  532.     ddx_masterMute(1);
  533. ddx_disableEPAD();
  534. write_reg_bit(0x04,6,1);//set channel 7/8 to binary mode
  535. write_reg_bit(0x04,7,1);
  536. ddx_masterMute(0);
  537. }
  538. else if((!bHpPlug) && (bNewStas!=bOldStas))
  539. {
  540.     ddx_masterMute(1);
  541. write_reg_bit(0x04,6,0);//set channel 7/8 to ddx mode
  542. write_reg_bit(0x04,7,0);
  543. ddx_enableEPAD();
  544. ddx_masterMute(0);
  545. }
  546. bOldStas = bNewStas;
  547. }
  548. #endif
  549. void disp_fan_in(void)
  550. {
  551.     extern BYTE    osd0_state;           //OSD0 state
  552.     if (osd0_state>1)
  553.     {
  554.         #ifdef SUPPORT_FUNCTION_MENU
  555.         if ((full_scrn!=SETUP) && (full_scrn!=SETUP_PLUS))
  556.         #else
  557.         if (full_scrn!=SETUP)
  558.         #endif //end #ifdef SUPPORT_FUNCTION_MENU
  559.             DispPolling(2);
  560.     }
  561. }
  562. #ifdef QSI_PLATFORM//liulifeng add 2004-10-13////jhuang 2004/11/23
  563. enum  {
  564.     ERROR_CODE_N = 0x0,
  565.     ERROR_CODE_1,
  566.     ERROR_CODE_2,
  567.     ERROR_CODE_3,
  568.     ERROR_CODE_4
  569. };
  570. BYTE QSI_PIPO_error_code_station = ERROR_CODE_3;
  571. BYTE QSI_PIPO_error_code_time_flag=0;
  572. static inline void QSI_PIPO_error_code ( void )
  573. {
  574.     if ( QSI_PIPO_error_code_station != 0 )//error occur
  575.     {
  576.         if ( QSI_PIPO_error_code_time_flag < 21)
  577.         {
  578.             if ( ( (QSI_PIPO_error_code_time_flag / 3) %2 )
  579.                ||(  QSI_PIPO_error_code_time_flag  > ((QSI_PIPO_error_code_station - 1 )*6 + 3))
  580.                )
  581.                 GPIO_O_SET(GPIO_IS_FOR_SYSTEM_LED,0); // led Off
  582.             else
  583.                 GPIO_O_SET(GPIO_IS_FOR_SYSTEM_LED,1); // led On
  584.         }
  585.         else if ( QSI_PIPO_error_code_time_flag < 25 )
  586.         {
  587.             GPIO_O_SET(GPIO_IS_FOR_SYSTEM_LED,0); // led Off
  588.         }
  589.         else if ( QSI_PIPO_error_code_time_flag < 28 )
  590.         {
  591.             GPIO_O_SET(GPIO_IS_FOR_SYSTEM_LED,1); // led On
  592.         }
  593.         else if ( QSI_PIPO_error_code_time_flag < 50 )
  594.         {
  595.             GPIO_O_SET(GPIO_IS_FOR_SYSTEM_LED,0); // led Off
  596.         }
  597.         else
  598.             QSI_PIPO_error_code_time_flag = 0xff;
  599.         QSI_PIPO_error_code_time_flag++;
  600.     }
  601. }
  602. #endif//#ifdef QSI_PLATFORM
  603. //#define SUPPORT_DEBUG_FOR_TRAY_IN_AND_HOME_SWITCH   // 2004/12/17 yltseng
  604. static inline void DebugFuncForTrayInAndHomeSwitch()
  605. {
  606. #ifdef SUPPORT_DEBUG_FOR_TRAY_IN_AND_HOME_SWITCH
  607.     // First parameter is TryIn, Second is HomeSwitch
  608.     // TrayIn     : Defined in sys_servo.c TRAY_IS_IN_GPIO
  609.     // HomeSwitch : Fixed at GPIO 6
  610.     psprintf( RegionValStr[REGION1], "%d %d", GPIO_I_GET(5), GPIO_I_GET(6) );
  611.     PrintOsdMsg(STR_OS_SPACE, REGION1, 1, 1);
  612. #endif
  613. }
  614. //
  615. // FUNCTION
  616. // polling_100ms
  617. //
  618. static inline void polling_100ms(void)
  619. {
  620.     DebugFuncForTrayInAndHomeSwitch();
  621.     
  622. #ifdef QSI_PLATFORM//liulifeng add 2004-10-13//jhuang 2004/11/23
  623.     QSI_PIPO_error_code ();
  624. #endif
  625. #ifdef PMP_MCU810
  626.   if((GetCurrentFileType() != CDROM_JPEG )&&(GetCurrentFileType() != CDROM_DAT )
  627.       &&(GetCurrentFileType() != CDROM_MPG) &&(GetCurrentFileType() != CDROM_MP4) 
  628.    ||(pFsJpeg->gifsState == FS_STATE_LIST||pFsJpeg->gifsState == FS_STATE_MP3))
  629.      Show_PMP_Bat();
  630. #endif
  631. #ifdef  SUPPORT_SPI
  632.     polling_spi();
  633.     spi_service();
  634. #endif
  635. #ifdef  SUPPORT_MP4_SUBTITLE
  636.     if (GetCurrentFileType() == CDROM_MP4) ///David add 2004-5-9,  no need to polling subtitle except MP4 disc. 
  637.     {
  638.         if( (full_scrn & SOUND) || (play_state == VCD_STATE_PAUSE) )  //David 2004-5-12
  639.             return;
  640.     if (IS_EXT_SUP_ACTIVATED())
  641.     {
  642.         extern ifunc polling_subtitle;
  643.         if( polling_subtitle )
  644.         {
  645.         #ifdef SPHE8202_FAT_Write_Function
  646.         if(!(full_scrn & PERIPHERAL))              //sunzhh add 2004-11-25
  647.         #endif
  648.         polling_subtitle();
  649.     }
  650.     }
  651.     }
  652. #endif
  653. #ifdef PDVD_USE_IO_SCAN_KEY //Jack modified 04/06/03
  654. //#ifdef GBM_PORTABLE_DVD
  655.   check_portable_key(); //rbhung for GBM Portable DVD
  656. #endif
  657. //freyman 2002-7-4 11:30
  658. #ifdef VFD_VOLUME_DISPLAY
  659. {
  660.     int diff;
  661.     //diff=timenow-rtc_100ms;
  662.     
  663.     polling_vfdtime(diff);
  664. }
  665. #endif
  666. #ifdef USE_GAMEPORT_TO_BUTTON//nono 20020824
  667.     check_key_status();
  668. #elif defined(OURMIND_VFDPORT_TO_BUTTON)//nono 20020824
  669.     check_key_status_ourmind();
  670.     check_ourmind_light_status();
  671. #elif defined(USE_VFDPORT_TO_BUTTON)
  672.     check_keyboard_status();
  673. #elif defined(USE_VFDPORT_TO_KEYLIGHT)
  674.     check_keylight_status();
  675. #endif
  676. #if defined(FAT_Write_UI)||defined(CF_CARD_WRITE)//||defined(WRITE_USB)//liweihua 2003-10-29
  677. extern void polling_input_name(void);
  678. extern BYTE input_flag;
  679. if((full_scrn & PERIPHERAL) && (input_flag == 1))
  680.     polling_input_name();
  681. #endif
  682. #ifdef AC3TEST
  683.   if (gAC3onoff==1) {
  684.     AC3ShowReport();
  685.   }
  686.   AC3CheckSampling();
  687. #endif
  688.     if ( (audioNotContinuous>0) && (play_state==VCD_STATE_NORMAL) ) { //count it when STATE_NORMAL, Jeff 20021202
  689.         audioNotContinuous--;
  690.         if (audioNotContinuous==0) {
  691.       if (!user_mute) {
  692.                 AUDIF_Demute();//2004AUDDRV AudioDemute();
  693. #ifdef CHANGE_DSP_SPDIF_OFF
  694.                 AUDIF_Set_SPDIF(setupGetSetting(14));//2004AUDDRV AudioSetSPDIF(setupGetSetting(14));
  695. #endif//#ifdef CHANGE_DSP_SPDIF_OFF
  696.       }
  697.     }
  698.   }
  699. #ifdef NF_100
  700.   if( (play_state!=VCD_STATE_PAUSE)&&(full_scrn!=SETUP) )
  701.   {
  702.     if( dvd_timer>0 )
  703.     {
  704.       //printf("polling_100ms  play_state = %dn",play_state);
  705.       polling_dvd_timer();
  706.     }
  707.   }
  708. #else
  709.     if( ( P_frame == 0 )            // 2004/12/29 yltseng
  710. #ifndef SETUP_DONT_PAUSE
  711.         && ( full_scrn != SETUP )
  712. #endif
  713. #ifndef PROG_DONT_PAUSE
  714.         && ( full_scrn != PROGRAM )
  715. #endif
  716.     )
  717.     {
  718.         if(!IsAVDPaused() && (dvd_timer>0) )
  719.           polling_dvd_timer();
  720.     }
  721. #endif
  722.   if (hl_timer>0)
  723.     recover_hl_color();
  724.   if (auto_pause)
  725.     polling_timeout();
  726.     
  727.     #ifdef SUPPORT_FUNCTION_MENU
  728.     if(setup_menu_plus_timer)
  729.       polling_setup_menu_plus();
  730.     #endif //end #ifdef SUPPORT_FUNCTION_MENU
  731.     
  732. #ifdef SUPPORT_REP_READ
  733.     if(IsReadMode())
  734.         PollingRecBufStatus();
  735. #endif
  736.     
  737. #ifdef FS_BMP_GUI//zhaoyanhua add 2004-6-29 15:58    
  738.     if(cd_type_loaded == CDROM) // Robert 021004
  739.     {
  740.         if ((GetCurrentFileType() == CDROM) || (GetCurrentFileType() == CD_DA) || (GetCurrentFileType() == CDROM_WMA) || (GetCurrentFileType() == CDROM_AAC))
  741.             polling_mp3();
  742.     }
  743. #endif//#ifdef FS_BMP_GUI   
  744.  
  745. #ifdef BRIGHTNESS_COLOR_KEY
  746.     polling_BCtimer();
  747. #endif
  748.    
  749. #ifdef SUPPORT_HEADPHONE  //xyy 2004-10-9 
  750. polling_headphone();
  751. #endif
  752. #ifdef ALONE_GPIO_KEY//Jack 20041008
  753.     polling_portable_akey();
  754. #endif
  755. #ifdef CONTINUOUS_NUM_KEY_SELECT
  756.   if(ir_num_timer)
  757.     polling_ir_num();  
  758. #endif 
  759. #ifdef DVB1000_NON_OS
  760. if(system_state == SYSTEM_TS)
  761. {
  762. CheckProgInterval();
  763. CheckDvbTunerStatus();
  764. }
  765. #endif
  766. }
  767. //
  768. //
  769. extern int gbm_gpio_led_flag;
  770. extern  BYTE   cd_type_loaded;
  771. #ifdef SunplusMoudleTest //axel 2004/4/2 11:55am while detected DVD, wait for 15 sec, tray out...
  772. UINT16 ModuleTicks=0;
  773. static inline void auto_modual_test(void)
  774. {
  775.     if(cd_type_loaded==CDDVD)
  776.     {
  777.         if(ModuleTicks>=45)
  778.          {
  779.             ModuleTicks=0;
  780.             ircmd_stop();
  781.             delay_srv_10ms(100);
  782.             //ircmd_power();
  783. /*          delay_srv_10ms(500);
  784.             ircmd_trayin();*/
  785.          }  
  786.         else
  787.          ModuleTicks++; 
  788.         
  789.     }   
  790. }
  791. #else
  792. #define auto_modual_test();
  793. #endif
  794. /*
  795. * polling_one_minute()  wangap add 2004/4/26 
  796. */
  797. static inline void polling_one_minute(void)
  798. {
  799.   #ifdef TURN_OFF_POWER_RESUME //wangap 2004/4/21  
  800.   if(play_state!=VCD_STATE_STOP)
  801.   polling_resume();
  802.   #endif  
  803. }
  804.                     
  805. #ifdef  AUTO_ADJUST_TV_TYPE
  806. BYTE  Adjust_TV_type =0;
  807. #endif                    
  808. #ifdef UART_WITHOUT_DEBUG_MODE //axelchen 2004/10/20 
  809.               
  810. void ReturnFromUart(void)
  811. {
  812.   int d;
  813.     if (!IsEPPRxEmpty())
  814.     {
  815.         d = EPP_GETC();
  816.         UART0_putc(d);
  817.     }   
  818. }
  819. #endif
  820. #ifdef SLEEP_CONTROL_COUNTER   //liumzh 2004-12-10 23:53
  821. UINT32 counter_sleep_control = 0;
  822. UINT32 sleep_time = 15;//seconds
  823. #endif
  824. #ifdef  STOP_15M_AUTO_POWEROFF
  825. extern UINT8 STOP_15M_STATE;
  826. unsigned short int second_counter=0;
  827. unsigned short int sleep_counter=0;
  828. unsigned char one_second_flag=1;
  829. int  timer_counter=0;
  830. unsigned char sleep_show_flags;
  831. #endif
  832. /*
  833. *   polling_500ms()
  834. */
  835. static inline void polling_500ms(void)
  836. {
  837. /*#ifdef DVB1000_NON_OS
  838. int iHasTDT=0;
  839. iHasTDT=PollingTDT(5);//eric add 2004-12-16 15:12 use Demux channel 5
  840. if((full_scrn == PROGRAMINFO)&&iHasTDT)
  841. {
  842. printf("full_scrn == PROGRAMINFO)&&PollingTDT(5)n");
  843.  DisplayProgramInfo(1);
  844. }
  845. #endif*/ //eric change  polling TDT to 1SEC 
  846. #ifdef PMP_KEYBOARD  //xyy 2005-1-10
  847.     extern polling_pmpkey(void);
  848.     polling_pmpkey();
  849. #endif
  850. #ifdef EASTECH_SETUPMENU
  851. extern BYTE check_show_pscan_wait_time_mode;
  852. extern void pscan_change_time_out(void);
  853. extern void refresh_pscan_wait_time(BYTE wait_time);
  854. static BYTE wait_time=CHANGE_TO_PSCAN_WAIT_TIME_TOTAL;
  855. if(check_show_pscan_wait_time_mode==1){
  856. wait_time--;
  857. if(wait_time==0){
  858. pscan_change_time_out();
  859. wait_time=0;
  860. check_show_pscan_wait_time_mode=0;
  861. }
  862. else{
  863. refresh_pscan_wait_time(wait_time);
  864. }
  865. }
  866. else wait_time=CHANGE_TO_PSCAN_WAIT_TIME_TOTAL;
  867. #endif
  868. #ifdef UART_WITHOUT_DEBUG_MODE //axelchen 2004/10/20 
  869. ReturnFromUart();
  870. #endif
  871. #ifdef SLEEP_CONTROL_COUNTER   //liumzh 2004-12-10 23:53
  872. if(counter_sleep_control >= sleep_time *100*60)
  873. {
  874. counter_sleep_control = 0;
  875. sleep_time = 0;
  876. ircmd_power();
  877. }
  878. #endif
  879. #ifdef  STOP_15M_AUTO_POWEROFF
  880. if(STOP_15M_STATE==1)
  881. {
  882. if((sleep_counter)/*&&(system_state== SYSTEM_STOP)*/)
  883. {
  884. sleep_show_flags--;
  885. if(!sleep_show_flags)
  886. ;//osd_sleep_disp(sleep_counter);
  887.          second_counter++;
  888.          if(second_counter>=60*2)
  889.          {  second_counter=0;          
  890.             
  891.                  sleep_counter--;
  892.                 if(sleep_counter==0)
  893.                  {
  894. if((system_state== SYSTEM_STOP)||(play_state==VCD_STATE_STOP))
  895. ircmd_power();  
  896.                  }
  897.          }
  898.  }
  899. }
  900. #endif
  901.     #ifdef SUPPORT_CD_TEXT             //lizhx  add 04/10/17
  902.     if (cd_type_loaded == CDDA)
  903.     {
  904.         if(!((full_scrn & PROGRAM)||(full_scrn & SETUP)||(full_scrn & SOUND)))
  905.             show_CDText_Title_Content(v11_trk_now);
  906.     }
  907.     #endif
  908. #ifdef  MIDI_SCORE_TEST //modify by xlluo for test
  909.     extern BYTE gb_showScore;
  910.     #endif
  911.     auto_modual_test();//terry,2004/4/2 04:49PM
  912.      #ifdef  AUTO_ADJUST_TV_TYPE
  913.     if((play_state==VCD_STATE_NORMAL) && (Adjust_TV_type==1))
  914.     {        
  915.         auto_adjust_tv_type();       
  916.     }
  917.     #endif
  918.     // mute mute
  919.     if (is_dts_force_spdif_bitstream()) {
  920.         regs0->aud_pcm_ramp_delta   = 0xff;
  921.         regs0->aud_pcm_ramp_cfg     = 1;
  922.     }
  923.     
  924.     #ifdef TEST_SERVO
  925.     srv_mode_test_polling();//terry,2003/9/10 12:57AM
  926.     #endif
  927. #ifdef  RECORD_KEY//zhaoyanhua add 03-11-5 13:02
  928.     if(same_disc_flag)
  929.         same_disc_flag++;
  930.     #endif
  931.     auto_close_fun();
  932.     auto_record_per_s();
  933. #ifdef SCRN_SAVER_WHEN_PAUSE
  934.     if (full_scrn & SETUP)//4-3-5 23:24
  935.         safe_srn_off();
  936.     else if(play_state == VCD_STATE_PAUSE)
  937.         #ifdef SUPPORT_MIDI    //ouyang add for don't show saver in midi2005-1-12 19:22
  938.         if(!gIsMidiSelMenu)  
  939.         #endif 
  940.         safe_srn_on();
  941. #endif
  942. #ifdef USE_PIN31_CONTROL_POWER_LED      //gerry,2004-3-9 19:42
  943.     if(gbm_gpio_led_flag<=4)
  944.     gbm_gpio_led_flag++;
  945.     else
  946.     {
  947.         GPIO_O_SET(4,1);
  948.     }
  949. #endif//USE_PIN31_CONTROL_POWER_LED
  950.     if (regs0->dsp24_port[4]==1)
  951.     { //to check whether MIC is on or off, Jeff 20020904
  952.         mic_on = 1;
  953.     } else {
  954.         mic_on = 0;
  955.     }
  956.   if ((full_scrn & SCORE)
  957. #ifdef  MIDI_SCORE_TEST //modify by xlluo 
  958.     ||(gb_showScore)
  959. #endif    
  960. #ifdef SUPPORT_SANJING_SCORE            //xlluo for sjspical score ui 04 -10 -15
  961.     ||(bIsSJScoreInvaild)
  962. #endif
  963.     )
  964.   { //Jeff 20020404
  965.     Score_Polling();
  966.   }
  967.   // check mp2/mp3 sample-rate (reported from audio decoder)
  968.   if(mpeg_audio) MPx_ChkSmpRate();
  969.   if(auto_download_audio_chn)
  970.   {
  971.        if(AUDIF_AutoDownload_Codec(auto_download_audio_chn-1))//2004AUDDRV audif_auto_download_codec(auto_download_audio_chn-1)
  972.        {//sucess
  973.            auto_download_audio_chn=0;
  974.        }
  975.   }
  976. #ifndef FS_BMP_GUI//zhaoyanhua 2004-6-29 15:58 
  977.   if(cd_type_loaded == CDROM) // Robert 021004
  978.   {
  979.       if ((GetCurrentFileType() == CDROM) || (GetCurrentFileType() == CD_DA) || (GetCurrentFileType() == CDROM_WMA) || (GetCurrentFileType() == CDROM_AAC))
  980.           polling_mp3();
  981.   }
  982. #endif//#ifndef FS_BMP_GUI
  983.   #ifdef REMAIN_TIME//nono 2-7-13 11:27
  984. //  printf("polling:polling_clock=%dn",polling_clock);
  985.   if(polling_clock<7)
  986.   {
  987.     if( (polling_clock==6)&&(t_disp) )
  988.       t_disp+=10;
  989.     polling_clock++;
  990.    }
  991.   #endif
  992. #if defined(SUPPORT_TUNER_MV114) || defined(SUPPORT_TUNER_ALPS)  //xyy 2003-9-20 14:45
  993.     if( system_state==SYSTEM_DOING_TUNER ) //huziqin 2004-2-26
  994.      {
  995.         if(tuner_mute_flag)
  996.            tuner_mute_flag++;
  997.         if(tuner_mute_flag>2)  // mute 500mS
  998.           {
  999.             tuner_mute_flag=0;
  1000.             if(!user_mute)
  1001.              tuner_mute(0);
  1002.            }
  1003.      }
  1004.  #endif
  1005. /*Here deleted by xyy 2004-8-5 */
  1006. #ifdef SUPPORT_FS_LONGNAME  //Maoyong 2004.06.24
  1007.     if( (play_state != VCD_STATE_PAUSE) && (play_state != VCD_STATE_STOP) 
  1008.         &&(pFsJpeg->gifsState == FS_STATE_LIST||pFsJpeg->gifsState == FS_STATE_MP3))                    
  1009.         FS_ScrollDispFileName();
  1010. #endif
  1011. //nono add "&&defined(USE_GPIO_MUTE)  "20040821
  1012. #if defined(SUPPORT_DSPMUTE)&&defined(USE_GPIO_MUTE)      //BENSON 2004/7/12 11:25