国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

電子工程網(wǎng)

標(biāo)題: OK210開發(fā)板使用感想續(xù)之自己設(shè)計(jì)的紅外驅(qū)動(dòng) [打印本頁(yè)]

作者: flyday    時(shí)間: 2013-9-17 15:15
標(biāo)題: OK210開發(fā)板使用感想續(xù)之自己設(shè)計(jì)的紅外驅(qū)動(dòng)
經(jīng)過幾天的研究,終于把OK210開發(fā)板wince紅外驅(qū)動(dòng)的部分給完成了。
開發(fā)工具:vs2005,飛凌官方OK210開發(fā)板,杜邦線3根,烙鐵一把,焊錫,4.7k電阻一個(gè)。
開發(fā)軟件:Win CE 6.0
下圖是所需的開發(fā)工具
從網(wǎng)上找了好久,不是不能用,就是騙子代碼,根本不能用,最可氣的就是掛羊頭賣狗肉,標(biāo)著紅外驅(qū)動(dòng),用自己寶貴的積分,下載下來(lái)一看根本就不是,浪費(fèi)了我很多時(shí)間,最后沒辦法只能自己動(dòng)手了,這里充分體現(xiàn)了毛主席“自己動(dòng)手,豐衣足食”這句話的重要性。好了廢話不多說(shuō)吧我自己的這幾天的思路告訴大家讓大家以后少走彎路,在這里我也希望廣大網(wǎng)友能夠不吝惜自己的勞動(dòng)成果,把自己的奮斗果實(shí)奉獻(xiàn)下,這樣能讓很多網(wǎng)友少走彎路,大家慶幸之余也會(huì)非常感激”挖井人“的。首先,我是按照單片機(jī)解碼的思路,開始制作的Win CE操作系統(tǒng)的紅外驅(qū)動(dòng),可把我害苦了。我用的是中斷+定時(shí)器。思路呢和網(wǎng)上所有的都一樣,但是總是卡死在定時(shí)器上,定時(shí)器我用的是微秒級(jí)別的延時(shí),這樣已進(jìn)入系統(tǒng),總是不停地去響應(yīng)定時(shí)器的中斷,這樣就卡死在線程了。系統(tǒng)連起都起不來(lái)了,害的我倒騰了好幾天,最后沒辦法只能放棄了,改用延時(shí),網(wǎng)上有現(xiàn)成的函數(shù)。解碼的遙控器類型有很多,這里我只做了最通用的NEC遙控器,其他的只需要改一下高低電平時(shí)間就行了。NEC紅外協(xié)議,作為接收端來(lái)講,首先是引導(dǎo)碼,有9ms的低電平,然后是4.5ms的高電平,然后是32位的操作碼,對(duì)于按鍵來(lái)說(shuō)我們只需要解第三組就可以了,其他的NEC協(xié)議的知識(shí)可以從網(wǎng)上搜索下有很多的。現(xiàn)在只做紅外接收模塊,將準(zhǔn)備好的杜邦線插在紅外的三個(gè)引腳上,引腳順序,大家從網(wǎng)上搜索下,然后就是找一個(gè)直插的4.7k上拉電阻,接到hs0038的接受引腳和5v引腳中間。由于我的紅外解碼思路是中斷所以只能找中斷引腳了,但是通篇的找飛凌OK210開發(fā)板上中斷引腳真的是太難找了,(o)最后沒辦法只能找已經(jīng)引出的引腳了,最后發(fā)現(xiàn)按鍵上每個(gè)引腳都能用,都是中斷引腳,最后我選擇了外部中斷6,開發(fā)板的k4按鍵,將按鍵的上拉電阻去掉,然后焊接出一條引線,接到紅外接收器的接收引腳。下面是自己焊的紅外接收模塊。 好了硬件準(zhǔn)備完畢,現(xiàn)在開始寫驅(qū)動(dòng)。1.包含的頭文件:
  1. //made in 2013-6-7 by mr wang
  2. #include "stdafx.h"
  3. #include
  4. #include
  5. #include
  6. #include
  7. #include
  8. #include
  9. #include "pmplatform.h"
  10. #include "Pkfuncs.h"
  11. #include
  12. #include
  13. #include "gpioentry_reg.h"
  14. #include
  15. typedef enum
  16. {
  17.     EINT_SIGNAL_LOW_LEVEL = 0,
  18.     EINT_SIGNAL_HIGH_LEVEL,
  19.     EINT_SIGNAL_FALL_EDGE,
  20.     EINT_SIGNAL_RISE_EDGE,
  21.     EINT_SIGNAL_BOTH_EDGE
  22. } EINT_SIGNAL_METHOD;

  23. typedef enum
  24. {
  25.     EINT_FILTER_DISABLE = 0,
  26.     EINT_FILTER_DELAY,
  27.     EINT_FILTER_DIGITAL
  28. } EINT_FILTER_METHOD;


  29. static volatile GPIO_REG *  g_pGPIOReg = NULL;
  30. static DWORD                                 g_dwSysIntrHS38 = SYSINTR_UNDEFINED;
  31. static HANDLE                                 g_hEventHS38 = NULL;
  32. static HANDLE                                 g_hEventResetBtn = NULL;
  33. static HANDLE                                 g_hThreadHS38 = NULL;
  34. static BOOL                                 g_bExitThread = FALSE;
  35. static BOOL                                 pwstatus=TRUE;

  36. void Delay_us(int n);//延時(shí)us
  37. BOOL IRS_date(void);//判斷遙控低電平
  38. static void InitInterrupt(void);//中斷初始化
  39. void IRS_port_init(void); //引腳初始化
  40. void IRS_enable_interrupt(void);//使能中斷
  41. void IRS_disable_interrupt(void);//不使能中斷
  42. void IRS_clear_interrupt_pending(void);//清楚中斷屏蔽位
  43. BOOL IRS_set_filter_method(EINT_FILTER_METHOD eMethod, unsigned int uiFilterWidth);//選擇中斷的filter方式
  44. BOOL IRS_set_interrupt_method(EINT_SIGNAL_METHOD eMethod);//設(shè)置中斷方式
  45. 2.解碼線程:
  46. INT WINAPI HS38Thread(void)
  47. {
  48.         int i,j;
  49.         byte ircode[4];//四位編碼

  50.         while(!g_bExitThread)
  51.         {
  52.                 WaitForSingleObject(g_hEventHS38, INFINITE);

  53.                 if(g_bExitThread)
  54.                 {
  55.                         break;
  56.                 }
  57.                 IRS_disable_interrupt();                          // 禁止中斷

  58.                 IRS_clear_interrupt_pending();                // 清除中斷標(biāo)志位

  59.                 InterruptDone(g_dwSysIntrHS38);    //中斷完成,開始解碼

  60.                 Delay_us(8000);//延時(shí)掉ms的低電平,

  61.                 while(IRS_date());

  62.                 Delay_us(4000);//4.5ms高電平

  63.                 while(!IRS_date());

  64.                 for(j=0;j<4;j++)
  65.                 {
  66.                         for(i=0;i<8;i++)
  67.                         {
  68.                                 while(IRS_date());
  69.                                 Delay_us(700);
  70.                                 if(IRS_date())// send 0
  71.                                 {
  72.                                         ircode[j]=ircode[j]>>1;
  73.                                 }
  74.                                 else
  75.                                 {
  76.                                         ircode[j]=ircode[j]|0x80;
  77.                                         ircode[j]=ircode[j]>>1;
  78.                                         Delay_us(1200);
  79.                                 }
  80.                         }
  81.                 }
  82.                 Sleep(100);
  83.                 RETAILMSG(1,(TEXT("******* ircode[3] = %x\r\n"),ircode[3]));//打印第三組操作碼,便是按鍵的鍵碼
  84.                 IRS_enable_interrupt();
  85.         }
  86.         return 0;
  87. }
  88. 3.微妙延時(shí)函數(shù)
  89. void Delay_us(int n)
  90. {
  91.         LARGE_INTEGER litmp;
  92.         LONGLONG QPart1,QPart2;
  93.         double dfMinus, dfFreq, dfTim;
  94.         if(QueryPerformanceFrequency(&litmp)==FALSE)
  95.         {
  96.                 return;
  97.         }
  98.         dfFreq = (double)litmp.QuadPart;
  99.         QueryPerformanceCounter(&litmp);
  100.         QPart1 = litmp.QuadPart;
  101.         do
  102.         {
  103.                 QueryPerformanceCounter(&litmp);
  104.                 QPart2=litmp.QuadPart;
  105.                 dfMinus=(double)(QPart2-QPart1);
  106.                 dfTim=dfMinus/dfFreq;
  107.         }while(dfTim <0.000001*n);

  108. }
  109. 4.其他流驅(qū)動(dòng)接口函數(shù)
  110. //設(shè)置寄存器地址
  111. BOOL HS38_initialize_register_address(void *pGPIOReg)//,void *pHSReg)
  112. {
  113.         if (pGPIOReg == NULL)
  114.         {
  115.                 return FALSE;
  116.         }
  117.         else
  118.         {
  119.                 g_pGPIOReg = (GPIO_REG *)pGPIOReg;
  120.                
  121.         }

  122.         return TRUE;
  123. }
  124. //初始化
  125. void IRS_port_init(void)
  126. {
  127.         Set_PinFunction(g_pGPIOReg, GPH06_EXT_INT_6);   
  128.         Set_PinPullUD(g_pGPIOReg, GPH06_EXT_INT_6,  sgip_PULL_UP);   

  129. }

  130. //使能引腳中斷
  131. void IRS_enable_interrupt(void)
  132. {

  133.         Unmask_EXTINT(g_pGPIOReg, EXT_INT_6);
  134. }

  135. //禁止引腳中斷
  136. void IRS_disable_interrupt(void)
  137. {

  138.         Mask_EXTINT(g_pGPIOReg, EXT_INT_6);

  139. }

  140. //清除引腳中斷
  141. void IRS_clear_interrupt_pending(void)
  142. {

  143.         Clear_EXTINT(g_pGPIOReg, EXT_INT_6);

  144. }

  145. //設(shè)置中斷方式
  146. BOOL IRS_set_interrupt_method(EINT_SIGNAL_METHOD eMethod)
  147. {
  148.         BOOL Ret = TRUE;

  149.         switch(eMethod)
  150.         {
  151.                 case EINT_SIGNAL_LOW_LEVEL:
  152.                         Set_EXTINT_TRLVL(g_pGPIOReg, EXT_INT_6, sgip_LOW_LEVEL);
  153.                         break;
  154.                 case EINT_SIGNAL_HIGH_LEVEL:
  155.                         Set_EXTINT_TRLVL(g_pGPIOReg, EXT_INT_6, sgip_HIGH_LEVEL);
  156.                         break;
  157.                 case EINT_SIGNAL_FALL_EDGE:
  158.                         Set_EXTINT_TRLVL(g_pGPIOReg, EXT_INT_6, sgip_FALLING_EDGE);
  159.                         break;
  160.                 case EINT_SIGNAL_RISE_EDGE:
  161.                         Set_EXTINT_TRLVL(g_pGPIOReg, EXT_INT_6, sgip_RISING_EDGE);
  162.                         break;
  163.                 case EINT_SIGNAL_BOTH_EDGE:
  164.                         Set_EXTINT_TRLVL(g_pGPIOReg, EXT_INT_6, sgip_BOTH_EDGE);
  165.                         break;
  166.                 default:
  167.                 Ret = FALSE;
  168.                 break;
  169.         }


  170.         return Ret;
  171. }

  172. //設(shè)置中斷filter方式
  173. BOOL IRS_set_filter_method(EINT_FILTER_METHOD eMethod, unsigned int uiFilterWidth)
  174. {
  175.         BOOL Ret =TRUE;

  176.         switch(eMethod)
  177.         {
  178.                 case EINT_FILTER_DISABLE:
  179.                         Clr_EXTINT_FILTER(g_pGPIOReg, EXT_INT_6);
  180.                         break;
  181.                 case EINT_FILTER_DELAY:
  182.                         Set_EXTINT_FILTER(g_pGPIOReg, EXT_INT_6, sgip_DELAY_FLT, 0);
  183.                         break;
  184.                 case EINT_FILTER_DIGITAL:
  185.                         Set_EXTINT_FILTER(g_pGPIOReg, EXT_INT_6, sgip_DIGITAL_FLT, uiFilterWidth);
  186.                         break;
  187.         default:
  188.                 Ret = FALSE;
  189.         break;
  190.         }
  191.         return Ret;
  192. }

  193. //判斷遙控接收引腳低電平,返回true
  194. BOOL IRS_date(void)
  195. {

  196.         if(Get_PinData(g_pGPIOReg,GPH06_EXT_INT_6))
  197.         {
  198.                 return FALSE;        // Low Active Switch (Pull-up switch)
  199.         }
  200.         else
  201.         {
  202.                 return TRUE;
  203.         }
  204. }

  205. static BOOL AllocResources(void)
  206. {
  207.         DWORD dwIRQ;
  208.         PHYSICAL_ADDRESS        ioPhysicalBase = {0,0};

  209.         //------------------
  210.         // GPIO Controller SFR
  211.         //------------------
  212.         ioPhysicalBase.LowPart = BASE_REG_PA_GPIO;
  213.         g_pGPIOReg = (GPIO_REG *)MmMapIoSpace(ioPhysicalBase, sizeof(GPIO_REG), FALSE);
  214.         if (g_pGPIOReg == NULL)
  215.         {
  216.                 return FALSE;
  217.         }

  218.         dwIRQ = IRQ_EINT6;

  219.         g_dwSysIntrHS38 = SYSINTR_UNDEFINED;
  220.         g_hEventHS38 = NULL;

  221.         if (!KernelIoControl(IOCTL_HAL_REQUEST_SYSINTR, &dwIRQ, sizeof(DWORD), &g_dwSysIntrHS38, sizeof(DWORD), NULL))
  222.         {
  223.                 g_dwSysIntrHS38 = SYSINTR_UNDEFINED;
  224.                 return FALSE;
  225.         }

  226.         g_hEventHS38 = CreateEvent(NULL, FALSE, FALSE, NULL);
  227.         if(NULL == g_hEventHS38)
  228.         {
  229.                 return FALSE;
  230.         }

  231.         if (!(InterruptInitialize(g_dwSysIntrHS38, g_hEventHS38, 0, 0)))
  232.         {
  233.                 return FALSE;
  234.         }


  235.         return TRUE;
  236. }
  237. static void ReleaseResources(void)
  238. {

  239.         if (g_pGPIOReg != NULL)
  240.         {
  241.                 MmUnmapIoSpace((PVOID)g_pGPIOReg, sizeof(GPIO_REG));
  242.                 g_pGPIOReg = NULL;
  243.         }

  244.         if (g_dwSysIntrHS38 != SYSINTR_UNDEFINED)
  245.         {
  246.                 InterruptDisable(g_dwSysIntrHS38);
  247.         }

  248.         if (g_hEventHS38 != NULL)
  249.         {
  250.                 CloseHandle(g_hEventHS38);
  251.         }

  252.         if (g_dwSysIntrHS38 != SYSINTR_UNDEFINED)
  253.         {
  254.                 KernelIoControl(IOCTL_HAL_RELEASE_SYSINTR, &g_dwSysIntrHS38, sizeof(DWORD), NULL, 0, NULL);
  255.         }


  256.         g_pGPIOReg = NULL;

  257.         g_dwSysIntrHS38 = SYSINTR_UNDEFINED;

  258.         g_hEventHS38 = NULL;

  259. }

  260. static void InitInterrupt(void)
  261. {
  262.         // 禁止中斷
  263.         IRS_disable_interrupt();

  264.         // I初始化端口
  265.         IRS_port_init();

  266.         // 設(shè)置中斷模式
  267.         IRS_set_interrupt_method(EINT_SIGNAL_BOTH_EDGE);
  268.         IRS_set_filter_method(EINT_FILTER_DELAY, 0);

  269.         // 清除中斷標(biāo)志位
  270.         IRS_clear_interrupt_pending();

  271.         // 使能中斷
  272.         IRS_enable_interrupt();
  273. }

  274. BOOL WINAPI  
  275. DllEntry(HANDLE        hinstDLL,
  276.                         DWORD dwReason,
  277.                         LPVOID /* lpvReserved */)
  278. {
  279.         switch(dwReason)
  280.         {
  281.         case DLL_PROCESS_ATTACH:
  282.                 DEBUGREGISTER((HINSTANCE)hinstDLL);
  283.                 return TRUE;
  284.         case DLL_THREAD_ATTACH:
  285.                 break;
  286.         case DLL_THREAD_DETACH:
  287.                 break;
  288.         case DLL_PROCESS_DETACH:
  289.                 break;
  290. #ifdef UNDER_CE
  291.         case DLL_PROCESS_EXITING:
  292.                 break;
  293.         case DLL_SYSTEM_STARTED:
  294.                 break;
  295. #endif
  296.         }

  297.         return TRUE;
  298. }


  299. BOOL IRS_Deinit(DWORD hDeviceContext)
  300. {
  301.         g_bExitThread = TRUE;

  302.         if (g_hThreadHS38)                // Make Sure if thread is exist
  303.         {
  304.                 IRS_disable_interrupt();
  305.                 IRS_clear_interrupt_pending();

  306.                 // Signal Thread to Finish
  307.                 SetEvent(g_hEventHS38);
  308.                 // Wait for Thread to Finish
  309.                 WaitForSingleObject(g_hThreadHS38, INFINITE);
  310.                 CloseHandle(g_hThreadHS38);
  311.                 g_hThreadHS38 = NULL;
  312.         }


  313.         ReleaseResources();
  314.        
  315.         //RETAILMSG(1,(TEXT("USERLED: IRS_Deinit\r\n")));

  316.         return TRUE;
  317. }


  318. DWORD IRS_Init(DWORD dwContext)
  319. {
  320.         RETAILMSG(1,(TEXT("Key_Gpio_Setting----\r\n")));
  321.         if (AllocResources() == FALSE)
  322.         {
  323.                 goto CleanUp;
  324.         }

  325.         HS38_initialize_register_address((void *)g_pGPIOReg);

  326.         InitInterrupt();
  327.        
  328.         g_hThreadHS38 = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE) HS38Thread, NULL, 0, NULL);
  329.         if (g_hThreadHS38 == NULL )
  330.         {
  331.                 goto CleanUp;
  332.         }


  333.         return TRUE;

  334. CleanUp:

  335.         IRS_Deinit(0);

  336.         return FALSE;
  337. }

  338. //-----------------------------------------------------------------------------
  339. //-----------------------------------------------------------------------------
  340. BOOL IRS_IOControl(DWORD hOpenContext,
  341.                                    DWORD dwCode,
  342.                                    PBYTE pBufIn,
  343.                                    DWORD dwLenIn,
  344.                                    PBYTE pBufOut,
  345.                                    DWORD dwLenOut,
  346.                                    PDWORD pdwActualOut)
  347. {
  348.         return TRUE;
  349. }

  350. //-----------------------------------------------------------------------------
  351. //-----------------------------------------------------------------------------
  352. DWORD IRS_Open(DWORD hDeviceContext, DWORD AccessCode, DWORD ShareMode)
  353. {
  354.         RETAILMSG(0,(TEXT("USERLED: IRS_Open\r\n")));
  355.         return TRUE;
  356. }

  357. //-----------------------------------------------------------------------------
  358. //-----------------------------------------------------------------------------
  359. BOOL IRS_Close(DWORD hOpenContext)
  360. {
  361.         RETAILMSG(0,(TEXT("USERLED: IRS_Close\r\n")));
  362.         return TRUE;
  363. }

  364. //-----------------------------------------------------------------------------
  365. //-----------------------------------------------------------------------------
  366. void IRS_PowerDown(DWORD hDeviceContext)
  367. {
  368.         RETAILMSG(0,(TEXT("USERLED: IRS_PowerDown\r\n")));
  369. }

  370. //-----------------------------------------------------------------------------
  371. //-----------------------------------------------------------------------------
  372. void IRS_PowerUp(DWORD hDeviceContext)
  373. {
  374.         RETAILMSG(0,(TEXT("USERLED: IRS_PowerUp\r\n")));

  375. }

  376. //-----------------------------------------------------------------------------
  377. //-----------------------------------------------------------------------------
  378. DWORD IRS_Read(DWORD hOpenContext, LPVOID pBuffer, DWORD Count)
  379. {
  380.         RETAILMSG(0,(TEXT("USERLED: IRS_Read\r\n")));
  381.         return TRUE;
  382. }

  383. //-----------------------------------------------------------------------------
  384. //-----------------------------------------------------------------------------
  385. DWORD IRS_Seek(DWORD hOpenContext, long Amount, DWORD Type)
  386. {
  387.         RETAILMSG(0,(TEXT("USERLED: IRS_Seek\r\n")));
  388.         return 0;
  389. }

  390. //-----------------------------------------------------------------------------
  391. //-----------------------------------------------------------------------------
  392. DWORD IRS_Write(DWORD hOpenContext, LPCVOID pSourceBytes, DWORD NumberOfBytes)
  393. {
  394.         RETAILMSG(0,(TEXT("USERLED: IRS_Write\r\n")));
  395.         return 0;
  396. }
復(fù)制代碼
6.實(shí)驗(yàn)結(jié)果,當(dāng)你按下遙控器上的按鍵時(shí),dnw或超級(jí)終端上會(huì)顯示相應(yīng)的按鍵碼如下: 長(zhǎng)時(shí)間按某一個(gè)按鍵,會(huì)顯示同一個(gè)鍵值如下:


作者: moonly    時(shí)間: 2013-9-24 11:04
樓主精神可嘉  佩服   學(xué)習(xí)了
作者: liqiaw    時(shí)間: 2013-9-27 23:52
感謝分享,當(dāng)初用1602顯示遙控器的紅外碼,那時(shí)候用51的中斷解碼的,現(xiàn)在跑cortex—A9+Android,還可以可以裝ubuntu,可以加入學(xué)習(xí)交流群187587764,畢竟現(xiàn)在android相對(duì)于linux還是火很多的。。。




歡迎光臨 電子工程網(wǎng) (http://m.qingdxww.cn/) Powered by Discuz! X3.4
主站蜘蛛池模板: 日本成人免费观看| 亚洲视频在线观看免费视频| 深夜你懂的在线网址入口| 亚洲天堂男人| 国产亚洲精品在线视频| 偷拍久久国产视频免费| 自拍黄色片| 日韩一级欧美一级在线观看| 亚洲国产精品久久精品成人| 污丝瓜视频| 草莓视频免费在线观看| 日韩人妻少妇一区二区三区| 特级免费毛片| 日韩一区二区三区免费视频| 网站在线观看高清免费| www.绿巨人| 桃花在线观看播放| 四虎激情影院| 天天躁夜夜躁狠狠躁躁| 亚洲另类在线观看| 草莓视频在线看免费高清观看 | 手伸进内衣揉捏办公室羞羞漫画| 佐佐木明希 中文 在线| 日韩精品卡1卡2三卡四卡乱码| 校园春色欧美日韩| 日韩欧美在线免费观看| 午夜视频在线观看一区二区| 国产91青青成人a在线| 色色男_免费| 四虎影库网址| 天天视频色| 色站综合| yellow日本高清在线| 亚洲av欧美在我| 日韩欧美一区二区久久 | 四虎私人影院| 色免费网站| 亚洲视频免费在线看| 久久高清内射无套| 午夜激情网站| 天堂资源站|