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

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

?? boardchangecli.c

?? dsp DM642 pci 詳細的開發例程
?? C
字號:
// BoardChangeCLI.c
//////////////////////////////////////////////////////////////////////////////
////
////  Copyright (c) 2003, Valley Technologies, Inc.
////  All rights reserved.
////
//////////////////////////////////////////////////////////////////////////////
////
////  $Header $
////
////  $ReleaseClass: src $
////
////  Original Author                 : ebersole
////  Most Recent Contributing $Author: ebersole $
////
//////////////////////////////////////////////////////////////////////////////
////
////  This file contains the CLI routines necessary to open, close, change,
////    and find DM642 cards.  The routines in this file interact with the
////    user to obtain certain information.  The routines pass this info
////    on into the DM642 Library, which does the lower-level dirty work.
////
//////////////////////////////////////////////////////////////////////////////


//############################################################################


// Includes
#include <stdio.h>
#include <dm642_lib.h>
#include "Dm642Cli.h"


//############################################################################
//                        Static (PRIVATE) Functions
//############################################################################


//////////////////////////////////////////////////////////////////////////////
////
////  Name: getVendorAndDeviceIDsFromUser
////
////  Purpose: This routine gets the Vendor ID and Device ID (of a PCI
////           device) from the user.
////
////  Input Parameters: none
////
////  Output Parameters:
////      pdwVendorID -- The PCI Vendor ID that the user entered
////      pdwDeviceID -- The PCI Device ID that the user entered
////
////  Return Value(s):
////      -1 => ERROR => invalid Vendor ID from user
////                     If this value is returned, none of the output
////                     parameters will be set/changed.
////       0 => SUCCESS
////
//////////////////////////////////////////////////////////////////////////////

static int getVendorAndDeviceIDsFromUser( DWORD *pdwVendorID,
                                          DWORD *pdwDeviceID )
{
    char  line[80];
    DWORD dwVendorID, dwDeviceID;


    printf ("Enter VendorID: ");

    fgets (line, sizeof(line), stdin);
    sscanf(line, "%x",         &dwVendorID);

    if (dwVendorID == 0)
    {
        return (-1);
    }

    printf ("Enter DeviceID: ");

    fgets (line, sizeof(line), stdin);
    sscanf(line, "%x",         &dwDeviceID);

    *pdwVendorID = dwVendorID;
    *pdwDeviceID = dwDeviceID;

    return (0);

}       // END getVendorAndDeviceIDsFromUser()

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


//////////////////////////////////////////////////////////////////////////////
////
////  Name: getCardNumberFromUser
////
////  Purpose: This routine gets, from user, the number of the DM642 card
////           to use/activate.  An invalid choice by the user causes the
////           routine to return a default selection of '0'.
////
////  Input Parameters:
////      nNumCards -- Total number of DM642 cards found by the most recent
////                   scan of the PCI bus.
////
////  Output Parameters: none
////
////  Return Value(s):
////       0                 Either card #0 was selected, or a bad selection
////                         resulted in an auto-select of card #0
////       1..(nNumCards-1)  The number of the card selectd by the user.
////
//////////////////////////////////////////////////////////////////////////////

static DWORD getCardNumberFromUser(DWORD nNumCards)
{
    char  line[80];
    DWORD nMyCard;


    //--------------------------------------
    // Prompt the user to select a card #
    //--------------------------------------
    printf ("Found %u matching PCI cards\n", (UINT)nNumCards);
    printf ("Select card (0-%u): ",          (UINT)nNumCards - 1);

    //----------------------------------
    // Flush/Clean the input 'buffers'
    //----------------------------------
    nMyCard = 0;
    fflush(stdin);

    //-------------------------
    // Get the card # ...
    //-------------------------
    fgets (line, sizeof(line), stdin);
    sscanf(line, "%d",         &nMyCard);

    //---------------------------------------------
    // Verify that the user's choice is valid
    //   If so, return that choice to the caller
    //---------------------------------------------
    if ((nMyCard >= 0) && (nMyCard < nNumCards))
    {
        return(nMyCard);
    }

    printf ("Choice is out of range\n");

    //------------------------------------------------
    // If the user selects an invalid card, use
    //   card #0 as his/her selection.
    //------------------------------------------------
    return (0);

}       // End getCardNumberFromUser()

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


//////////////////////////////////////////////////////////////////////////////
////
////  Name: DM642LocateBoard
////
////  Purpose: This routine determines which DM642 card to use/activate.
////           It will get input from the user, as necesary.
////
////  Input Parameters:
////      pdwVendorID -- The PCI Vendor ID to locate
////                     [if 0, user is prompted for a VID+DID]
////      pdwDeviceID -- The PCI Device ID to locate
////                     [undefined if pdwVendorID == NULL/0]
////
////  Output Parameters:
////      pdwVendorID -- PCI Vendor ID, as entered by the user
////      pdwDeviceID -- PCI Device ID, as entered by the user
////
////  Return Value(s):
////       < 0: ERROR
////      >= 0: The number of the card to use/activate
////
//////////////////////////////////////////////////////////////////////////////

static DWORD DM642LocateBoard(DWORD *pdwVendorID, DWORD *pdwDeviceID)
{
    DWORD  nNumCards,
           nCardSelected;


    //------------------------------------------------------------------------
    // If an invalid Vendor ID was entered, then get BOTH the Vendor ID and
    //   the Device ID from the user.
    //------------------------------------------------------------------------
    if (pdwVendorID == NULL || *pdwVendorID == 0)
    {
        if (getVendorAndDeviceIDsFromUser(pdwVendorID, pdwDeviceID) < 0)
        {
            // ERROR -- invalid VID or DID ...
            return (-1);
        }
    }

    //---------------------------------------------------------------
    // Count the number of cards in the chassis that have the given 
    //   VID & DID combo ...
    //---------------------------------------------------------------
    nNumCards = DM642CountCards (*pdwVendorID, *pdwDeviceID);

    //-----------------------------------------
    // Not finding any cards is an error ...
    //-----------------------------------------
    if (nNumCards == 0)
    {
        printf ("%s", DM642_ErrorString);
        return (-1);
    }

    //---------------------------------------------------
    // Finding one card makes choosing superfluous ...
    //---------------------------------------------------
    if (nNumCards == 1)
    {
        return (0);
    }

    //---------------------------------------------------
    // Finding more than one card requires the user to
    //   choose which one to use/activate
    //---------------------------------------------------
    nCardSelected = getCardNumberFromUser(nNumCards);

    return (nCardSelected);

}       // END DM642LocateBoard()


//############################################################################
//                        Non-Static (PUBLIC) Functions
//############################################################################


//////////////////////////////////////////////////////////////////////////////
////
////  Name: DM642OpenBoard
////
////  Purpose: Opens/Activates the given DM642 board.  If this fails,
////           the routine prints an error message.
////
////  Input Parameters:
////      pdwVendorID -- The PCI Vendor ID of the DM642 board to open/enable
////      pdwDeviceID -- The PCI Device ID of the DM642 board to open/enable
////      dwBoardNum  -- The number of the DM642 board to open/enable
////
////  Output Parameters: none
////
////  Return Value(s):
////      NULL    : ERROR opening the card
////      non-NULL: Handle to the DM642 board just opened
////
//////////////////////////////////////////////////////////////////////////////

DM642_HANDLE DM642OpenBoard(DWORD dwVendorID, DWORD dwDeviceID, DWORD dwBoardNum)
{
    DM642_HANDLE hDM642 = NULL;


    //----------------------------------------------------------------------
    // Attempt to open the indicated DM642.
    // If this fails, print an error message (constructed inside the DM642
    //   library) and bail.
    //----------------------------------------------------------------------
    if (!DM642Open (&hDM642, dwVendorID, dwDeviceID, dwBoardNum))
    {
        printf ("%s", DM642_ErrorString);
        return (NULL);
    }

    printf ("DM642 PCI card opened!\n");

    //--------------------------------------------------------
    // If we do open the DM642 successfully, set our global
    //   board-number constant to the open card's number
    //--------------------------------------------------------
    g_dwBoardNum = dwBoardNum;

    return (hDM642);

}       // END DM642OpenBoard()

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


//////////////////////////////////////////////////////////////////////////////
////
////  Name: DM642CloseBoard
////
////  Purpose: This routine closes/deactivates an open DM642 card.
////           The occurs iff the given card is already open.
////
////  Input Parameters:
////      phDM642 - POINTER to handle of currently-open DM642 board
////
////  Output Parameters:
////      phDM642 - POINTER to handle of a DM642 board
////                Will be set to NULL.
////
////  Return Value(s)  : none
////
//////////////////////////////////////////////////////////////////////////////

void DM642CloseBoard(DM642_HANDLE *phDM642)
{
    if (*phDM642 != NULL)
    {
        DM642Close(*phDM642);
    }

    *phDM642     = NULL;
    g_dwBoardNum = -1;

}       // End DM642CloseBoard()

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


//////////////////////////////////////////////////////////////////////////////
////
////  Name: ChangeBoard
////
////  Purpose: This routine changes the currently active/open DM642 to a
////           different one.  Any necessary info is obtained from the user.
////           If no boards are open, this routine will just open the newly
////           selected DM642 (ie, it can be used at boot/init)
////
////  Input Parameters:
////      phDM642     - POINTER to handle of currently-open DM642 board
////      pdwVendorID - The PCI Vendor ID of the board to change to
////      pdwDeviceID - The PCI Device ID of the board to change to
////
////  Output Parameters:
////      phDM642 - POINTER to handle of a DM642 board
////                NULL     if opening a new board fails
////                non-NULL (valid board handle) otherwise
////
////  Return Value(s):
////      -1 : ERROR     (either invalid input OR board-open failed)
////       0 : SUCCESS
////
//////////////////////////////////////////////////////////////////////////////

int ChangeBoard(DM642_HANDLE *phDM642, DWORD dwVendorID, DWORD dwDeviceID)
{
    DWORD dwBoardNum;


    ///--------------------------------------
    // Determine which DM642 to switch to.
    ///--------------------------------------
    dwBoardNum = DM642LocateBoard(&dwVendorID, &dwDeviceID);

    //------------------------------------------------------------------------
    // If an error (including invalid user input) occurred while determining
    //  the new board number to use, bail w/o changing a thing.
    //------------------------------------------------------------------------
    if (dwBoardNum < 0)
    {
        return (-1);
    }

    //----------------------------------------------------------
    // ASSERT: dwBoardNum (newly selected board number) >= 0
    //         IE, the new board number is valid.
    //----------------------------------------------------------

    //------------------------------------------------------------
    // Skip the Close()-then-Open() sequence if we actually are
    //   not changing boards.  We already have the desired board
    //   opened, in that case.
    //------------------------------------------------------------
    if (g_dwBoardNum == dwBoardNum)
    {
        return (0);
    }

    //--------------------------------------------
    // Close the old board and Open the new one
    //--------------------------------------------
    DM642CloseBoard(phDM642);
    *phDM642 = DM642OpenBoard(dwVendorID, dwDeviceID, dwBoardNum);
    if (NULL == *phDM642)
    {
        return (-1);
    }

    return (0);

}       // END ChangeBoard()


//############################################################################
//                             End of Functions
//############################################################################

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品奇米国产一区二区三区| 亚洲综合网站在线观看| 久久久影视传媒| 欧美日韩国产一二三| 日韩一区二区三区av| 国产精品天天摸av网| 一区二区国产视频| 国产一区二三区| 在线视频一区二区三区| 日韩精品一区二区三区四区| 欧美一区二区三区四区视频| 国产三级一区二区三区| 天天做天天摸天天爽国产一区| 国产精品一级片在线观看| 欧美中文字幕一二三区视频| 久久精品人人爽人人爽| 丝袜诱惑制服诱惑色一区在线观看 | 国产欧美综合在线| 一区二区欧美国产| 国产a久久麻豆| 日韩一级完整毛片| 亚洲精品视频在线| 国产激情精品久久久第一区二区 | 欧美一区二区二区| 亚洲精品综合在线| 国产成人自拍高清视频在线免费播放| 欧美日韩国产首页在线观看| 国产精品久久久久久久久果冻传媒 | 国产精品久久免费看| 狠狠色综合日日| 成人h版在线观看| 久久影音资源网| 日本女人一区二区三区| 色av一区二区| 中文字幕一区在线观看视频| 国产乱理伦片在线观看夜一区| 91精品国产综合久久婷婷香蕉| 亚洲精品乱码久久久久久黑人| av午夜一区麻豆| 中文字幕高清不卡| 国产成人福利片| 久久久夜色精品亚洲| 日本在线观看不卡视频| 欧美日韩国产精品成人| 亚洲一区精品在线| 欧美性猛交xxxxxx富婆| 中文子幕无线码一区tr| 风间由美一区二区三区在线观看| 国产人妖乱国产精品人妖| 国产精品一二三区在线| 久久久高清一区二区三区| 国产91精品露脸国语对白| 久久综合色播五月| 国产精品一二一区| 中文一区在线播放| 99久久精品情趣| 亚洲另类一区二区| 欧美色视频在线观看| 日韩vs国产vs欧美| 欧美一区二区三区在线电影| 免费久久99精品国产| 精品99999| 懂色中文一区二区在线播放| 亚洲国产高清不卡| 91成人看片片| 亚洲乱码中文字幕| 在线一区二区视频| 奇米影视一区二区三区小说| 精品久久久三级丝袜| 国产一区二区美女诱惑| 综合中文字幕亚洲| 欧美日韩你懂得| 日韩电影免费在线观看网站| 日韩一区二区免费在线观看| 国产毛片精品国产一区二区三区| 国产肉丝袜一区二区| 久久综合网色—综合色88| 国产一区二区三区电影在线观看| 欧美高清在线一区二区| 在线免费精品视频| 蜜臀精品一区二区三区在线观看| 久久久亚洲午夜电影| 欧美亚洲一区二区三区四区| 日本va欧美va瓶| 日韩理论在线观看| 2023国产精华国产精品| 91成人国产精品| 国产一级精品在线| 亚洲电影欧美电影有声小说| 26uuu色噜噜精品一区二区| 国产成人午夜片在线观看高清观看| 亚洲天堂福利av| 欧美三级电影网| 国产精品原创巨作av| 午夜伦欧美伦电影理论片| 国产女主播在线一区二区| 欧美另类久久久品| 美女尤物国产一区| 亚洲免费伊人电影| 久久久不卡网国产精品二区| 欧美色综合网站| 国产99精品在线观看| 日韩va欧美va亚洲va久久| 中文字幕欧美一区| 精品久久久久av影院| 色欲综合视频天天天| 国产一区二区三区美女| 日韩专区一卡二卡| 国产综合久久久久久鬼色| 亚洲成人免费在线观看| 欧美激情综合五月色丁香| 色婷婷久久一区二区三区麻豆| 亚洲自拍偷拍综合| 国产精品久久精品日日| 久久九九久精品国产免费直播| 欧美高清hd18日本| 欧美亚洲综合久久| 91社区在线播放| 激情五月婷婷综合| 久久精品久久精品| 理论片日本一区| 日韩国产欧美在线观看| 亚洲图片欧美一区| 亚洲日本韩国一区| 亚洲手机成人高清视频| 欧美一级在线观看| 欧美一区二区三区四区久久| 在线观看国产一区二区| 在线观看三级视频欧美| 欧美一区二区三区系列电影| 精品国内二区三区| 欧美激情一区二区三区不卡| 亚洲精品综合在线| 性久久久久久久久| 韩国成人福利片在线播放| 韩国v欧美v亚洲v日本v| 91小视频在线免费看| 欧美日韩久久久一区| 日韩欧美一区二区视频| 欧美激情一区二区| 亚洲综合色婷婷| 国精产品一区一区三区mba桃花| 成人av午夜影院| 欧美日本一区二区三区四区| 久久综合九色综合97婷婷女人 | 中日韩免费视频中文字幕| 亚洲免费观看高清完整版在线| 亚洲综合激情另类小说区| 狠狠色丁香久久婷婷综合丁香| 暴力调教一区二区三区| 欧美精品aⅴ在线视频| 欧美韩国日本不卡| 奇米影视在线99精品| 99久久er热在这里只有精品15| 欧美日韩一二三区| 久久久精品日韩欧美| 亚洲午夜一区二区三区| 国产999精品久久久久久绿帽| 欧美中文字幕亚洲一区二区va在线 | 韩日精品视频一区| 91美女精品福利| www国产成人免费观看视频 深夜成人网| 亚洲三级小视频| 久久国产成人午夜av影院| 欧美羞羞免费网站| 国产精品美女久久久久aⅴ国产馆| 香蕉av福利精品导航| 成人少妇影院yyyy| 欧美sm美女调教| 亚洲国产欧美日韩另类综合| www.视频一区| 欧美极品aⅴ影院| 韩国成人在线视频| 日韩欧美亚洲另类制服综合在线| 亚洲视频在线一区二区| 成人久久视频在线观看| 精品国产免费久久| 日韩精品1区2区3区| 欧美私模裸体表演在线观看| 日韩毛片在线免费观看| 成人免费视频一区二区| 久久夜色精品一区| 久久爱另类一区二区小说| 欧美精品一卡二卡| 亚洲午夜精品17c| 在线观看日韩电影| 亚洲欧洲制服丝袜| 一本色道久久综合狠狠躁的推荐| 中文字幕精品三区| 国产精品77777| 国产欧美日韩视频在线观看| 国精产品一区一区三区mba桃花 | 日韩理论电影院| 91亚洲精品久久久蜜桃| 中文字幕一区二区视频| av电影在线观看不卡| 国产精品女主播在线观看| 成人97人人超碰人人99| 国产精品传媒视频| 91免费版在线看|