亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? xlcanfunctions.cpp

?? 實現了汽車開發領域的can總線pc端的監控程序
?? CPP
字號:
/*----------------------------------------------------------------------------
| File        : xlCANFunctions.cpp
| Project     : Vector CAN Example 
|
| Description : Shows the basic CAN functionality for the XL Driver Library
|-----------------------------------------------------------------------------
| $Author: J鰎g $    $Locker: $   $Revision: 11 $
| $Header: /VCANDRV/XLAPI/samples/xlCANcontrol/xlCANFunctions.cpp 11    14.11.05 10:59 J鰎g $
|-----------------------------------------------------------------------------
| Copyright (c) 2004 by Vector Informatik GmbH.  All rights reserved.
|---------------------------------------------------------------------------*/

#include "stdafx.h"
#include "xlCANcontrol.h"
#include "xlCANFunctions.h"
#include "debug.h"

#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif

//////////////////////////////////////////////////////////////////////
// globals
//////////////////////////////////////////////////////////////////////

TStruct g_th;
BOOL    g_bThreadRun;

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CCANFunctions::CCANFunctions()
{
  m_xlChannelMask[CHAN01] = 0;
  m_xlChannelMask[CHAN02] = 0;
}

CCANFunctions::~CCANFunctions()
{
  CloseHandle(m_hThread);
  CloseHandle(m_hMsgEvent);
}

////////////////////////////////////////////////////////////////////////////

//! CANInit

//! Open the driver, get the channelmasks and create the RX thread.
//! 
//!
//////////////////////////////////////////////////////////////////////////// 

XLstatus CCANFunctions::CANInit()
{
  XLstatus        xlStatus = XL_ERROR;
  char            tmp[100];

  xlStatus = xlOpenDriver();
  sprintf(tmp, "xlOpenDriver, stat: %d", xlStatus);
  DEBUG(DEBUG_ADV, tmp);
  if (xlStatus != XL_SUCCESS) return xlStatus;

  // ---------------------------------------
  // Get/Set the application within VHWConf
  // ---------------------------------------
  xlStatus = canGetChannelMask();
  if ( (xlStatus) || (m_xlChannelMask[CHAN01] == 0) || (m_xlChannelMask[CHAN02] == 0) ) return XL_ERROR;

  // ---------------------------------------
  // Open ONE port for both channels
  // ---------------------------------------
  xlStatus = canInit();
  if (xlStatus) return xlStatus;

  // ---------------------------------------
  // Create ONE thread for both channels
  // ---------------------------------------
  xlStatus = canCreateRxThread();
  if (xlStatus) return xlStatus;

  return xlStatus;
}

////////////////////////////////////////////////////////////////////////////

//! canGetChannelMask

//! parse the registry to get the channelmask
//!
//////////////////////////////////////////////////////////////////////////// 

XLstatus CCANFunctions::canGetChannelMask()
{
  XLstatus        xlStatus = XL_ERROR;
  char            tmp[100];

  // default values
  unsigned int  hwType     = 0;
  unsigned int  hwIndex    = 0;
  unsigned int  hwChannel  = 0;
  unsigned int  appChannel = 0;
  unsigned int  busType    = XL_BUS_TYPE_CAN;   
  unsigned int  i; 
 
  XLdriverConfig  xlDrvConfig;

   //check for hardware:
  xlStatus = xlGetDriverConfig(&xlDrvConfig);
  if (xlStatus) return xlStatus;
  
  // we check only if there is an application registered or not.
  xlStatus = xlGetApplConfig("xlCANcontrol", CHAN01, &hwType, &hwIndex, &hwChannel, busType); 
 
  // Set the params into registry (default values...!)
  if (xlStatus) {
    DEBUG(DEBUG_ADV,"set in VHWConf");

    for (i=0; i < xlDrvConfig.channelCount; i++) {

      sprintf (tmp, "hwType: %d, bustype: %d, hwChannel: %d, cap: 0x%x", 
        xlDrvConfig.channel[i].hwType, 
        xlDrvConfig.channel[i].connectedBusType,
        xlDrvConfig.channel[i].hwChannel,
        xlDrvConfig.channel[i].channelBusCapabilities);
      DEBUG(DEBUG_ADV,tmp);

      // we search not the first CAN cabs
      if ( (xlDrvConfig.channel[i].channelBusCapabilities & XL_BUS_ACTIVE_CAP_CAN) && (appChannel < 2) ) {

        hwType    = xlDrvConfig.channel[i].hwType;
        hwIndex   = xlDrvConfig.channel[i].hwIndex;
        hwChannel = xlDrvConfig.channel[i].hwChannel;

        xlStatus = xlSetApplConfig( // Registration of Application with default settings
        "xlCANcontrol",             // Application Name
        appChannel,                 // Application channel 0 or 1
        hwType,                     // hwType  (CANcardXL...)    
        hwIndex,                    // Index of hardware (slot) (0,1,...)
        hwChannel,                  // Index of channel (connector) (0,1,...)
        busType);                   // the application is for CAN.

        m_xlChannelMask[appChannel] = xlGetChannelMask(hwType, hwIndex, hwChannel);
        sprintf (tmp, "Register CAN hWType: %d, CM: 0x%I64x", hwType, m_xlChannelMask[appChannel]);
        DEBUG(DEBUG_ADV,tmp);

        m_pHardware->InsertString(-1, xlDrvConfig.channel[i].name);

        appChannel++;
      }
     
    }
  }
  else {
    
    m_xlChannelMask[CHAN01] = xlGetChannelMask(hwType, hwIndex, hwChannel);
    sprintf (tmp, "Found CAN in VHWConf, hWType: %d, CM: 0x%I64x", hwType, m_xlChannelMask[CHAN01]);
    DEBUG(DEBUG_ADV,tmp);
 
    for (i=0; i < xlDrvConfig.channelCount; i++) {

      if ( xlDrvConfig.channel[i].channelMask == m_xlChannelMask[CHAN01])
        m_pHardware->AddString(xlDrvConfig.channel[i].name);
    }

    // get the second channel
    xlStatus = xlGetApplConfig("xlCANcontrol", CHAN02, &hwType, &hwIndex, &hwChannel, busType); 
    if (xlStatus) return xlStatus;

    m_xlChannelMask[CHAN02] = xlGetChannelMask(hwType, hwIndex, hwChannel);
    sprintf (tmp, "Found CAN in VHWConf, hWType: %d, CM: 0x%I64x", hwType, m_xlChannelMask[CHAN02]);
    DEBUG(DEBUG_ADV,tmp);

    for (i=0; i < xlDrvConfig.channelCount; i++) {

      if ( xlDrvConfig.channel[i].channelMask == m_xlChannelMask[CHAN02])
        m_pHardware->AddString(xlDrvConfig.channel[i].name);
    }
 
  }

  return xlStatus;
}

////////////////////////////////////////////////////////////////////////////

//! canInit

//! xlCANcontrol use ONE port for both channels.
//!
//////////////////////////////////////////////////////////////////////////// 

XLstatus CCANFunctions::canInit()
{
  XLstatus         xlStatus = XL_ERROR;
  XLaccess         xlPermissionMask;
  char             tmp[100];

  // ---------------------------------------
  // Open ONE port for both channels 
  // ---------------------------------------

  // calculate the channelMask for both channel 
  m_xlChannelMask_both = m_xlChannelMask[CHAN01] + m_xlChannelMask[CHAN02];
  xlPermissionMask = m_xlChannelMask_both;

  xlStatus = xlOpenPort(&m_xlPortHandle, "xlCANcontrol", m_xlChannelMask_both, &xlPermissionMask, 256, XL_INTERFACE_VERSION, XL_BUS_TYPE_CAN); 
  sprintf(tmp, "xlOpenPort: PortHandle: %d; Permissionmask: 0x%I64x; Status: %d", m_xlPortHandle, xlPermissionMask, xlStatus);
  DEBUG(DEBUG_ADV, tmp);

  if (m_xlPortHandle == XL_INVALID_PORTHANDLE) return XL_ERROR;
  if (xlStatus == XL_ERR_INVALID_ACCESS) return xlStatus;

  return xlStatus;
}

////////////////////////////////////////////////////////////////////////////

//! canCreateRxThread

//! set the notification and creates the thread.
//!
////////////////////////////////////////////////////////////////////////////

XLstatus CCANFunctions::canCreateRxThread()
{
  
  XLstatus      xlStatus = XL_ERROR;
  DWORD         ThreadId=0;
  char          tmp[100];
  
  if (m_xlPortHandle!= XL_INVALID_PORTHANDLE) {

    // Send a event for each Msg!!!
    xlStatus = xlSetNotification (m_xlPortHandle, &m_hMsgEvent, 1);
    sprintf(tmp, "SetNotification '%d', xlStatus: %d", m_hMsgEvent, xlStatus);
    DEBUG(DEBUG_ADV, tmp);

    // for the RxThread
    g_th.xlPortHandle = m_xlPortHandle;
    g_th.hMsgEvent    = m_hMsgEvent; 
    g_th.pOutput      = m_pOutput;
   
    m_hThread = CreateThread(0, 0x1000, RxThread, (LPVOID) &g_th, 0, &ThreadId);
    sprintf(tmp, "CreateThread %d", m_hThread);
    DEBUG(DEBUG_ADV, tmp);
    
  }
  return xlStatus;
}


////////////////////////////////////////////////////////////////////////////

//! CANGoOnBus

//! set the selected baudrate and go on bus.
//!
////////////////////////////////////////////////////////////////////////////

XLstatus CCANFunctions::CANGoOnBus(unsigned long baudrate)
{
  XLstatus      xlStatus = XL_ERROR;
  char          tmp[100];

  xlStatus = xlCanSetChannelBitrate(m_xlPortHandle, m_xlChannelMask_both, baudrate);
  sprintf(tmp, "SetBaudrate: %d, stat: %d", baudrate, xlStatus);
  DEBUG(DEBUG_ADV, tmp);

  xlStatus = xlActivateChannel(m_xlPortHandle, m_xlChannelMask_both, XL_BUS_TYPE_CAN, XL_ACTIVATE_RESET_CLOCK);
  sprintf(tmp, "ActivateChannel, stat: %d",  xlStatus);
  DEBUG(DEBUG_ADV, tmp);

  return xlStatus;
}

////////////////////////////////////////////////////////////////////////////

//! CANGoOffBus

//! Deactivate the channel
//!
////////////////////////////////////////////////////////////////////////////

XLstatus CCANFunctions::CANGoOffBus()
{
  XLstatus      xlStatus = XL_ERROR;
  char          tmp[100];

  xlStatus = xlDeactivateChannel(m_xlPortHandle, m_xlChannelMask_both);
  sprintf(tmp, "DeactivateChannel, stat: %d",  xlStatus);
  DEBUG(DEBUG_ADV, tmp);

  return xlStatus;
}

////////////////////////////////////////////////////////////////////////////

//! CANSend

//! transmit a CAN message to the selected channel with the give values.
//!
////////////////////////////////////////////////////////////////////////////

XLstatus CCANFunctions::CANSend(XLevent xlEvent, int channel)
{
  
  XLstatus      xlStatus;
  char          tmp[100];
  unsigned int  messageCount = 1;

  xlStatus = xlCanTransmit(m_xlPortHandle, m_xlChannelMask[channel], &messageCount, &xlEvent);
  sprintf(tmp, "Transmit, mc: %d, channel: %d, stat: %d",  messageCount, channel, xlStatus);
  DEBUG(DEBUG_ADV, tmp);

  return xlStatus;
}

////////////////////////////////////////////////////////////////////////////

//! CANResetFilter

//! Reset the acceptancefilter
//!
////////////////////////////////////////////////////////////////////////////

XLstatus CCANFunctions::CANResetFilter()
{
  XLstatus      xlStatus;
  char          tmp[100];

  xlStatus = xlCanResetAcceptance(m_xlPortHandle, m_xlChannelMask_both, XL_CAN_STD);
  sprintf(tmp, "CanResetAcceptance, stat: %d",  xlStatus);
  DEBUG(DEBUG_ADV, tmp);

  return xlStatus;
}

////////////////////////////////////////////////////////////////////////////

//! CANSetFilter

//! Reset the acceptancefilter
//!
////////////////////////////////////////////////////////////////////////////

XLstatus CCANFunctions::CANSetFilter(unsigned long first_id, unsigned long last_id)
{
  XLstatus      xlStatus;
  char          tmp[100];
  
  // because there all filters open, we close all.
  xlStatus = xlCanSetChannelAcceptance(m_xlPortHandle, m_xlChannelMask_both, 0xFFF, 0xFFF, XL_CAN_STD);
  sprintf(tmp, "CanSetChannelAcceptance, stat: %d",  xlStatus);
  DEBUG(DEBUG_ADV, tmp);
  
  // and now we can set the acceptance filter range.
  xlStatus = xlCanAddAcceptanceRange(m_xlPortHandle, m_xlChannelMask_both, first_id, last_id);
  sprintf(tmp, "CanAddAcceptanceRange, firstID: %d, lastID: %d, stat: %d",  first_id, last_id, xlStatus);
  DEBUG(DEBUG_ADV, tmp);
  
  
  return xlStatus;
}

///////////////////////////////////////////////////////////////////////////

//! RxThread

//! thread to readout the message queue and parse the incoming messages
//!
////////////////////////////////////////////////////////////////////////////

DWORD WINAPI RxThread(LPVOID par) 
{

  XLstatus        xlStatus;

  unsigned int    msgsrx = 1;
  XLevent         xlEvent; 
  char            tmp[110];
  CString         str;
  char				data=77;
  char				data_array[10]={0,0,0,0,0,0,0,0,0,0};
  
  g_bThreadRun = TRUE;

  TStruct *g_th;

  g_th = (TStruct*) par;  

  sprintf(tmp, "thread: SetNotification '%d'", g_th->hMsgEvent);
  DEBUG(DEBUG_ADV, tmp);

  while (g_bThreadRun) { 
   
    WaitForSingleObject(g_th->hMsgEvent,10);
    
    xlStatus = XL_SUCCESS;
   
    while (!xlStatus) {
        
	  msgsrx = 1;
      xlStatus = xlReceive(g_th->xlPortHandle, &msgsrx, &xlEvent);	
		
	  if ( xlStatus!=XL_ERR_QUEUE_IS_EMPTY ) {
          
        sprintf(tmp, "%s", xlGetEventString(&xlEvent));
        DEBUG(DEBUG_ADV, tmp);
        g_th->pOutput->InsertString(-1, tmp);

        g_th->pOutput->SetCurSel(g_th->pOutput->GetCount()-1);

		// added by Cellming.Chen
		//g_th->pOutput->InsertString(-1, "Cellming's Test");
		data = xlEvent.tagData.msg.data[0];
		itoa(data,data_array,16);
		g_th->pOutput->InsertString(-1, data_array);		
      }
    
    }
          
  }
  return NO_ERROR; 
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区在线视频| 中文乱码免费一区二区| 久久亚洲综合av| 亚洲欧洲精品一区二区三区 | 在线免费不卡电影| 欧美一区二区三区色| 国产精品午夜在线观看| 亚洲v中文字幕| 国产精品资源在线看| 色综合久久久久久久久| 欧美电影免费观看完整版| 国产精品久久久久aaaa| 日本中文字幕不卡| 99视频在线精品| 日韩视频一区二区在线观看| 亚洲人成小说网站色在线| 卡一卡二国产精品| 99久久精品免费看国产| 日韩免费在线观看| 亚洲精品视频一区| 国产九色精品成人porny | 国产亚洲精品久| 亚洲一区二三区| 国产91富婆露脸刺激对白| 欧美性生交片4| 国产情人综合久久777777| 全国精品久久少妇| 色噜噜狠狠成人网p站| 国产午夜亚洲精品理论片色戒| 亚洲不卡av一区二区三区| 91色porny蝌蚪| 国产欧美日本一区视频| 激情欧美日韩一区二区| 在线电影院国产精品| 亚洲欧美成人一区二区三区| 国产毛片精品国产一区二区三区| 欧美美女激情18p| 亚洲人妖av一区二区| 国产a级毛片一区| 久久综合丝袜日本网| 男人的天堂亚洲一区| 欧美日韩电影在线| 一区二区三区成人| 成人美女视频在线看| 国产亚洲精品7777| 国产一区二区三区不卡在线观看| 日韩欧美一区二区不卡| 日韩不卡一二三区| 91精品欧美一区二区三区综合在| 亚洲国产精品一区二区尤物区| 97精品久久久午夜一区二区三区| 亚洲国产精品成人综合| 国产69精品久久久久777| 久久久久九九视频| 国产一区二区三区精品视频| 国产午夜精品久久久久久免费视| 国产露脸91国语对白| 国产亚洲婷婷免费| 成人小视频免费观看| 中文字幕一区二区三区色视频 | www.成人网.com| 亚洲视频免费观看| 成人污视频在线观看| 亚洲欧洲无码一区二区三区| 91丝袜国产在线播放| 亚洲精品视频免费观看| 欧美三区在线观看| 亚洲最新视频在线观看| 欧美二区在线观看| 国产美女精品在线| 国产精品福利av| 欧洲亚洲精品在线| 午夜亚洲国产au精品一区二区| 欧美嫩在线观看| 国产在线精品一区二区夜色| 精品国产一区二区精华 | 日韩欧美一区二区在线视频| 麻豆久久一区二区| 国产欧美一区二区三区沐欲| 色欧美片视频在线观看在线视频| 午夜日韩在线电影| 亚洲国产高清aⅴ视频| 成人午夜短视频| 亚洲永久免费av| 精品国产污污免费网站入口| 成人黄色av网站在线| 另类小说综合欧美亚洲| 亚洲午夜精品在线| 国产精品视频yy9299一区| 日韩精品中文字幕在线不卡尤物| 色老汉av一区二区三区| 国产91富婆露脸刺激对白| 美女视频黄频大全不卡视频在线播放| 亚洲欧美日韩中文播放| 亚洲国产精品99久久久久久久久 | 亚洲成国产人片在线观看| 亚洲国产高清不卡| 久久久久一区二区三区四区| 欧美美女直播网站| 欧美少妇性性性| 在线观看日韩一区| 色av成人天堂桃色av| 99精品视频在线观看| 成人福利视频在线看| 国产成人在线电影| 国产福利精品导航| 国产精品一区二区久激情瑜伽| 美日韩一区二区| 日本系列欧美系列| 蜜桃视频免费观看一区| 日本在线不卡视频| 蜜臀a∨国产成人精品| 日韩精品乱码av一区二区| 午夜精品视频在线观看| 亚洲高清三级视频| 日韩va亚洲va欧美va久久| 免费看日韩精品| 免费欧美在线视频| 国产在线视频一区二区| 国产精品一区二区久久不卡| 国产东北露脸精品视频| 风间由美性色一区二区三区| 成人妖精视频yjsp地址| 99视频精品在线| 欧洲精品一区二区| 9191国产精品| 精品久久人人做人人爰| 国产欧美日韩视频在线观看| 国产亚洲欧洲997久久综合 | 久久久亚洲午夜电影| 久久精品人人做人人爽人人| 欧美国产成人精品| 亚洲四区在线观看| 亚洲成在人线在线播放| 理论电影国产精品| 粉嫩久久99精品久久久久久夜| 99久久精品国产观看| 欧美日韩二区三区| 久久综合中文字幕| 成人做爰69片免费看网站| 国产免费成人在线视频| 国产精品欧美久久久久一区二区 | 欧美美女黄视频| 久久久久综合网| 亚洲精品免费看| 奇米影视7777精品一区二区| 国产成人鲁色资源国产91色综| 91色婷婷久久久久合中文| 91麻豆精品国产91久久久 | 91网站最新地址| 欧美日韩在线观看一区二区| 精品欧美一区二区在线观看 | 91亚洲精华国产精华精华液| 欧美日韩在线播| 久久精品人人做人人爽人人| 亚洲乱码中文字幕综合| 久久精品噜噜噜成人88aⅴ | 国产精品亚洲综合一区在线观看| 色悠悠亚洲一区二区| 日韩欧美一二三四区| 亚洲免费观看视频| 国产成人免费在线| 欧美一区二区日韩| 亚洲精品你懂的| 国产精华液一区二区三区| 欧美日韩国产区一| 国产精品久久久99| 精品无人区卡一卡二卡三乱码免费卡 | 国产成人午夜精品影院观看视频| 欧美最新大片在线看 | 综合分类小说区另类春色亚洲小说欧美| 亚洲成人午夜影院| av激情综合网| 久久久午夜精品理论片中文字幕| 亚洲国产乱码最新视频| 99视频精品全部免费在线| 亚洲精品一区二区三区四区高清| 一区二区三区四区蜜桃| 成人开心网精品视频| 国产亚洲精品7777| 久久99国内精品| 日韩欧美一级二级三级久久久| 亚洲午夜久久久久久久久电影院| 99精品视频在线观看| 国产精品视频麻豆| 国产成都精品91一区二区三| xfplay精品久久| 全部av―极品视觉盛宴亚洲| 欧美日韩国产在线观看| 亚洲国产日韩a在线播放性色| 色综合久久中文综合久久牛| 国产精品人成在线观看免费| 国产一区在线不卡| 精品国产制服丝袜高跟| 精品无人区卡一卡二卡三乱码免费卡| 欧美一区二区三区视频在线| 免费精品99久久国产综合精品| 欧美日本乱大交xxxxx| 丝袜美腿亚洲综合| 欧美一区二区三区四区在线观看 |