hc4094.c
上传用户:caisangzi8
上传日期:2013-10-25
资源大小:15756k
文件大小:2k
源码类别:

DVD

开发平台:

C/C++

  1. #ifdef HC4094
  2. #define HC4094_STR   98   // pin231
  3. #define HC4094_DAT   99   // pin232
  4. #define HC4094_CLK   100  //pin233
  5. #define HC4094_STR_INIT {GPIO_M_SET(HC4094_STR,1);GPIO_E_SET(HC4094_STR, 1);}
  6. #define HC4094_DAT_INIT {GPIO_M_SET(HC4094_DAT,1);GPIO_E_SET(HC4094_DAT, 1);}
  7. #define HC4094_CLK_INIT {GPIO_M_SET(HC4094_CLK,1);GPIO_E_SET(HC4094_CLK, 1);}
  8. #define HC4094_STR_SET(d) GPIO_O_SET(HC4094_STR, d)
  9. #define HC4094_DAT_SET(d) GPIO_O_SET(HC4094_DAT, d)
  10. #define HC4094_CLK_SET(d) GPIO_O_SET(HC4094_CLK, d)
  11. #define AMP_STANDBY  (1<<0)
  12. #define TUNER_ON     (1<<1)
  13. #define SCA_DISP     (1<<2)
  14. #define SCA_SIG      (1<<3)
  15. #define REL_SCA      (1<<4)
  16. #define SEL_B        (1<<5)
  17. #define SEL_A        (1<<6)
  18. #define AMP_MUTE     (1<<7)
  19. #define HC4094_TUNER_MODE   (TUNER_ON|SEL_B)
  20. #define HC4094_DVD_MODE     (SEL_B|SEL_A)
  21. #define HC4094_AV1_MODE     (SEL_A)
  22. void set_cfg(void)
  23. {
  24. regs0->sft_cfg7 &= ~(0x17<<1);
  25. regs0->sft_cfg0 &= (~(0x01<<14))|(0x01<<11);
  26. regs0->fm_gpio_len &= ~(0x0f);
  27. }
  28. /*
  29. 74HC4094 -- 8 stage shit and store bus register ,three state
  30. Q0--Q7
  31. io bit 0--bit 7
  32. */
  33. void hc4094_set_io(BYTE io)
  34. {
  35. BYTE i;
  36. //regs0->sft_cfg6 &= ~(0x1 << 5); // SA12 as GPIO 18, pin 151
  37. //regs0->sft_cfg3 &= ~(0x1 << 5); // AU4 as GPIO 57, pin163
  38. set_cfg();
  39. HC4094_STR_INIT;
  40. HC4094_DAT_INIT;
  41. HC4094_CLK_INIT;
  42. HC4094_STR_SET(0);
  43. HC4094_CLK_SET(0);
  44. for(i=0;i<8;i++)
  45. {
  46. if(io&0x80)
  47. HC4094_DAT_SET(1);
  48. else
  49. HC4094_DAT_SET(0);
  50. io<<=1;
  51. HC4094_CLK_SET(1);
  52. HC4094_CLK_SET(0);
  53. }
  54. HC4094_STR_SET(1);
  55. HC4094_STR_SET(0);
  56. }
  57. #endif  //HC4094