uart.cpp
上传用户:gelin96
上传日期:2017-01-08
资源大小:20993k
文件大小:10k
源码类别:

MTK

开发平台:

C++ Builder

  1. /*****************************************************************************
  2. *  Copyright Statement:
  3. *  --------------------
  4. *  This software is protected by Copyright and the information contained
  5. *  herein is confidential. The software may not be copied and the information
  6. *  contained herein may not be used or disclosed except with the written
  7. *  permission of MediaTek Inc. (C) 2005
  8. *
  9. *  BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
  10. *  THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
  11. *  RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
  12. *  AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
  13. *  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
  14. *  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
  15. *  NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
  16. *  SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
  17. *  SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
  18. *  THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
  19. *  NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
  20. *  SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
  21. *
  22. *  BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
  23. *  LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
  24. *  AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
  25. *  OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
  26. *  MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
  27. *
  28. *  THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
  29. *  WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
  30. *  LAWS PRINCIPLES.  ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
  31. *  RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
  32. *  THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
  33. *
  34. *****************************************************************************/
  35. /*****************************************************************************
  36.  *
  37.  * Filename:
  38.  * ---------
  39.  *   uart.cpp
  40.  *
  41.  * Project:
  42.  * --------
  43.  *   Maui META APP
  44.  *
  45.  * Description:
  46.  * ------------
  47.  *   UART handling source
  48.  *
  49.  * Author:
  50.  * -------
  51.  *  Andy Ueng (mtk00490)
  52.  *
  53.  *============================================================================
  54.  *             HISTORY
  55.  * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
  56.  *------------------------------------------------------------------------------
  57.  * $Revision$
  58.  * $Modtime$
  59.  * $Log$
  60.  *
  61.  *------------------------------------------------------------------------------
  62.  * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
  63.  *============================================================================
  64.  ****************************************************************************/
  65. #include <stdio.h>
  66. #include <IniFiles.hpp>
  67. #pragma hdrstop
  68. #ifndef  _MAN_ACTIVE_H_
  69. #include "man_active.h"
  70. #endif
  71. #ifndef  _MAN_ERROR_H_
  72. #include "man_error.h"
  73. #endif
  74. #include "uart.h"
  75. //===========================================================================
  76. static CUART*  uart_ptr;
  77. //===========================================================================
  78. //---------------------------------------------------------------------------
  79. static void  REQ_TimeOut( void )
  80. {   uart_ptr->REQ_TimeOut();
  81. }
  82. //---------------------------------------------------------------------------
  83. static void  REQ_Finish( void )
  84. {   uart_ptr->REQ_Finish();
  85. }
  86. //===========================================================================
  87. CUART::CUART( void )
  88. {
  89.     IsRunning = false;
  90.     ConfirmCallback = 0;
  91.    // RFReq_ID = NULL;
  92. }
  93. //---------------------------------------------------------------------------
  94. CUART::~CUART()
  95. {
  96.     IsRunning = false;
  97.     ConfirmCallback = 0;
  98. }
  99. //---------------------------------------------------------------------------
  100. void  CUART::REQ_Finish( void )
  101. {
  102.     if(!IsRunning)  return;
  103.     Confirm( STATE_UART_OK );
  104.     IsRunning = false;
  105. }
  106. //---------------------------------------------------------------------------
  107. void  CUART::REQ_Stop( void )
  108. {
  109.     if(!IsRunning)  return;
  110.     Confirm( STATE_UART_STOP );
  111.     IsRunning = false;
  112. }
  113. //---------------------------------------------------------------------------
  114. void  CUART::REQ_TimeOut( void )
  115. {
  116.     if(!IsRunning)  return;
  117.     Confirm( STATE_UART_TIMEOUT );
  118.     IsRunning = false;
  119. }
  120. //---------------------------------------------------------------------------
  121. void  CUART::Confirm( int confirm_state )
  122. {
  123.     if(!IsRunning)  return;
  124.     if(ConfirmCallback==0)  return;
  125.     ConfirmState = confirm_state;
  126.     ActiveMan->SetActiveFunction( ConfirmCallback );
  127. }
  128. //===========================================================================
  129. bool  CUART::UART_Open( HANDLE  &hCOM, sUART uart )
  130. {
  131.     char  str[20];
  132.     sprintf( str, "\\.\COM%d", uart.com_port );
  133.     hCOM = ::CreateFile( str,
  134.                                GENERIC_READ|GENERIC_WRITE,
  135.                                0,
  136.                                NULL,
  137.                                OPEN_EXISTING,
  138.                                0,
  139.                                NULL
  140.                              );
  141.     if( hCOM==INVALID_HANDLE_VALUE || hCOM == 0)
  142.     {
  143.         //MSG_CHECK_ERROR( MSG_ERR_OPEN_COM_FAIL );
  144.         hCOM = NULL;
  145.         return false;
  146.     }
  147.     DCB dcb;
  148.     if(! ::GetCommState( hCOM, &dcb ) )
  149.     {
  150.         hCOM = NULL;
  151.         return false;
  152.     }
  153.     original_dcb = dcb;
  154.     dcb.fBinary           = true;
  155.     dcb.fParity           = true;
  156.     dcb.fOutxCtsFlow      = false;
  157.     dcb.fOutxDsrFlow      = false;
  158.     dcb.fDtrControl       = DTR_CONTROL_DISABLE;
  159.     dcb.fDsrSensitivity   = false;
  160.     dcb.fTXContinueOnXoff = false;
  161.     dcb.fOutX             = false;
  162.     dcb.fInX              = false;
  163.     dcb.fErrorChar        = false;
  164.     dcb.fNull             = false;
  165.     dcb.fRtsControl       = RTS_CONTROL_DISABLE;
  166.     dcb.wReserved         = 0;
  167.     dcb.fAbortOnError     = false;
  168.     dcb.BaudRate        = uart.baud_rate;
  169.     dcb.ByteSize        = uart.byte_size;
  170.     dcb.Parity          = uart.parity;
  171.     dcb.StopBits        = uart.stop_bits;
  172.     if(! ::SetCommState( hCOM, &dcb ) )
  173.     {
  174.         hCOM = NULL;
  175.         return false;
  176.     }
  177.     return  true;
  178. }
  179. //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  180. bool  CUART::UART_GetCommTimeouts( HANDLE hCOM, COMMTIMEOUTS &timeout)
  181. {
  182.      if( ! ::GetCommTimeouts( hCOM, &timeout ) )   return false;
  183.      return true;
  184. }
  185. //------------------------------------------------------------------------
  186. bool  CUART::UART_SetCommTimeouts( HANDLE hCOM, COMMTIMEOUTS timeout)
  187. {
  188.      if( ! ::SetCommTimeouts( hCOM, &timeout ) )   return false;
  189.      return true;
  190. }
  191. //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  192. bool  CUART::UART_GetCommMask( HANDLE hCOM, DWORD &dwEvtMask )
  193. {
  194.     if( ! ::GetCommMask( hCOM, &dwEvtMask) )   return false;
  195.     return true;
  196. }
  197. //--------------------------------------------------------------------------
  198. bool  CUART::UART_SetCommMask( HANDLE hCOM, DWORD dwEvtMask )
  199. {
  200.     if( ! ::SetCommMask(hCOM, dwEvtMask) )   return false;
  201.     return true;
  202. }
  203. //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  204. bool  CUART::UART_EscapeCommFunction( HANDLE hCOM, DWORD dwFunc )
  205. {
  206.     if( ! ::EscapeCommFunction(hCOM, dwFunc) )   return false;
  207.     return true;
  208. }
  209. //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  210. bool  CUART::UART_SendData( HANDLE hCOM, char* p_data )
  211. {
  212.     if( hCOM == INVALID_HANDLE_VALUE || hCOM == NULL)   return false;
  213.     int len = 0;
  214.     unsigned long rlen;
  215.     for(int i=0; i<MAX_COM_BUF_LEN; i++)
  216.     {
  217.         if( *(p_data+i) == '' )
  218.         {
  219.             len = i;
  220.             break;
  221.         }
  222.     }
  223.     if( ! ::WriteFile( hCOM, p_data, len, &rlen, NULL ) ) return false;
  224.     return true;
  225. }
  226. //------------------------------------------------------------------------
  227. bool  CUART::UART_ReceiveData( HANDLE hCOM, char* p_data, DWORD  &dw_byte_read )
  228. {
  229.     char buf[MAX_COM_BUF_LEN];
  230.     DWORD  dw_err;
  231.     COMSTAT com_stat;
  232.     if( hCOM == INVALID_HANDLE_VALUE || hCOM == NULL)     return false;
  233.     if( ! ::ClearCommError( hCOM, &dw_err, &com_stat ) )  return false;
  234.     if( com_stat.cbInQue > sizeof(buf) )
  235.     {
  236.         PurgeComm( hCOM, PURGE_RXCLEAR );
  237.         return false;
  238.     }
  239.     if( ! ::ReadFile( hCOM, p_data, com_stat.cbInQue, &dw_byte_read, NULL ) )  return false;
  240.     return true;
  241. }
  242. //------------------------------------------------------------------------
  243. bool  CUART::UART_Close( HANDLE hCOM )
  244. {
  245.     if( hCOM == INVALID_HANDLE_VALUE || hCOM == 0)   return false;
  246.     if(! ::SetCommState(hCOM, &original_dcb) )       return false;
  247.     if(! ::CloseHandle( hCOM ) )                     return false;
  248.     return true;
  249. }
  250. //===========================================================================
  251. ////////////////////////////    Global information   ////////////////////////
  252. //===========================================================================
  253. int  CUART::Get_ConfirmState( void )
  254. {
  255.     return ConfirmState;
  256. }
  257. //---------------------------------------------------------------------------
  258. DCB CUART::Get_OriginalDCB( void )
  259. {
  260.      return  original_dcb;
  261. }
  262. //---------------------------------------------------------------------------
  263. bool CUART::Set_OriginalDCB( DCB &dcb )
  264. {
  265.     original_dcb = dcb;
  266.     return true;
  267. }