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

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.  *  Keithley_2306.cpp
  40.  *
  41.  * Project:
  42.  * --------
  43.  *   Maui META APP
  44.  *
  45.  * Description:
  46.  * ------------
  47.  *  Keithley power supply control function 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 <vcl.h>
  66. #include <math.h>
  67. #ifndef __VISA_HEADER__
  68. #include "visa.h"
  69. #endif
  70. #pragma hdrstop
  71. #ifndef  _VISA_COMMON_H_
  72. #include "visa_common.h"
  73. #endif
  74. // misc
  75. #ifndef  _FT_UTILS_H_
  76. #include "ft_utils.h"
  77. #endif
  78. #ifndef  _META_UTILS_H_
  79. #include "meta_utils.h"
  80. #endif
  81. //=============================================================================
  82. ViStatus kei2306_init(ViRsrc resourceName, ViPSession p_RM, ViBoolean idQuery, ViBoolean resetDevice, ViPSession p_vi)
  83. {
  84.    // ViSession RM, base;
  85.     ViStatus vistat;
  86.     vistat = viOpenDefaultRM( p_RM );
  87.         if( vistat<VI_SUCCESS ) return vistat;
  88.     vistat=viOpen( *p_RM, resourceName, VI_NULL, 5000, p_vi);
  89.     if( vistat<VI_SUCCESS ) return vistat;
  90.     return VI_SUCCESS;
  91. }
  92. //--------------------------------------------------------------------------
  93. ViStatus kei2306_outputVoltCurr( ViSession vi, ViReal64 voltLev, ViReal64 currLev )
  94. {
  95.     ViStatus vistat;
  96.     unsigned long num;
  97.     char buf[BUFSIZE];
  98.     AnsiString as_cmd = "SOURCE:VOLT " + Double_To_AnsiString( voltLev );
  99.     vistat=viWrite(vi, as_cmd.c_str(), strlen(as_cmd.c_str()), &num);
  100.     if( vistat!=VI_SUCCESS ) return vistat;
  101.     as_cmd = "SOURCE:CURR " + Double_To_AnsiString( currLev );
  102.     vistat=viWrite(vi, as_cmd.c_str(), strlen(as_cmd.c_str()), &num);
  103.     if( vistat!=VI_SUCCESS ) return vistat;
  104.     
  105.     return VI_SUCCESS;
  106. }
  107. //--------------------------------------------------------------------------
  108. ViStatus kei2306_measureVolt(ViSession vi, ViReal64 *p_voltLev )
  109. {
  110.     ViStatus vistat;
  111.     unsigned long num;
  112.     char buf[BUFSIZE];
  113.     AnsiString asBase;
  114.     AnsiString asExponent;
  115.     AnsiString as_cmd = "READ?";
  116.     vistat=viWrite(vi, as_cmd.c_str(), strlen(as_cmd.c_str()), &num);
  117.     if( vistat!=VI_SUCCESS ) return vistat;
  118.     vistat=viRead(vi, buf, BUFSIZE, &num);
  119.     if( vistat!=VI_SUCCESS ) return vistat;
  120.     buf[num-1]=NULL;
  121.     AnsiString asStr(buf);
  122.     
  123.     if( getBaseFromStr( asStr, asBase ) == false )  return VI_ERROR_ABORT;
  124.     if( getExponentFromStr( asStr, asExponent )== false )  return VI_ERROR_ABORT;
  125.     *p_voltLev = (ViReal64) atof(asBase.c_str()) *  pow10( asExponent.ToInt() );
  126.     return VI_SUCCESS;
  127. }
  128. //--------------------------------------------------------------------------
  129. ViStatus kei2306_close( ViSession &RM, ViSession &vi )
  130. {
  131.     if( vi == NULL )  return VI_SUCCESS;
  132.     ViStatus vistat;
  133.     vistat = viClose( vi );
  134.     if( vistat<VI_SUCCESS ) return vistat;
  135.     vi = NULL;
  136.     vistat = viClose( RM );
  137.     if( vistat<VI_SUCCESS ) return vistat;
  138.     RM = NULL;
  139.     
  140.     return VI_SUCCESS;
  141. }