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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? pci.cpp

?? djgpp bt878 capture for DOS
?? CPP
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
#include "pci.h"


/////////////////////////////////////////////////////
PCI::PCI(void)
{
    status = 0;
    CheckBIOS();
}

/////////////////////////////////////////////////////
int PCI::CheckBIOS(void)
{
    int ret_value;
    regs.x.ax = PCI_INSTALLCHECK;

    ret_value = __dpmi_int(PCI_INT_NUM, &regs);
    if(ret_value == -1) {
        status = 1;
        return PCI_FAIL;
    }

    if(regs.d.edx != 0x20494350 || regs.h.ah != 0) {
        status = 2;
        return PCI_FAIL;
    }

    function_number = 0;

    if(status == 0)
    {
        hardware_characteristics = regs.h.al;
        pmode_entry_point = regs.d.edi;
        major_rev_number = regs.h.bh;
        minor_rev_number = regs.h.bl;
        bus_number = regs.h.cl;
    }
    else
    {
        hardware_characteristics = regs.h.al;
        pmode_entry_point = 0;
        major_rev_number = 0;
        minor_rev_number = 0;
        bus_number = 0;
    }
    
    if(status == 0)
        return PCI_PASS;
    else
        return PCI_FAIL;
}

/////////////////////////////////////////////////////
int PCI::FindDevice(int devID, int vendID, int devIndex)
{
    int ret_value;
    if(status != 0)
        return PCI_FAIL;

    regs.x.ax = PCI_FINDDEVICE;
    regs.x.cx = devID;
    regs.x.dx = vendID;
    regs.x.si = devIndex;

    ret_value = __dpmi_int(PCI_INT_NUM, &regs);
    if(ret_value == -1) {
        status = 1;
        return PCI_FAIL;
    }

    bus_number = regs.h.bh;
    function_number = regs.h.bl;

    if(regs.h.ah == SUCCESSFUL)
        return PCI_PASS;
    else
        return PCI_FAIL;
}

/////////////////////////////////////////////////////
int PCI::FindClassCode(int baseclass, int subclass, int interface, int devIndex)
{
    int ret_value;
    int class_code;

    if(status != 0)
        return PCI_FAIL;

    class_code = ((baseclass&0xff)<<16) | ((subclass&0xff<<8) | (interface&0xff));
    regs.x.ax = PCI_FINDCLASSCODE;
    regs.d.ecx = class_code;
    regs.x.si = devIndex;

    ret_value = __dpmi_int(PCI_INT_NUM, &regs);
    if(ret_value == -1) {
        status = 1;
        return PCI_FAIL;
    }

    bus_number = regs.h.bh;
    function_number = regs.h.bl;

    if(regs.h.ah == SUCCESSFUL)
        return PCI_PASS;
    else
        return PCI_FAIL;
}

/////////////////////////////////////////////////////
void PCI::SetFunctionNumber(int funct_num)
{
    function_number = funct_num;
}

/////////////////////////////////////////////////////
int PCI::GetFunctionNumbet(void)
{
    return function_number;
}

/////////////////////////////////////////////////////
void PCI::SetBusNumber(int bus_num)
{
    bus_number = bus_num;
}

/////////////////////////////////////////////////////
int PCI::GetBusNumber(void)
{
    return bus_number;
}

/////////////////////////////////////////////////////
int PCI::ReadConfigBYTE(int reg, BYTE *retBYTE, int funct_num, int bus_num)
{
    int ret_value;
    if(status != 0)
        return PCI_FAIL;

    regs.x.ax = PCI_READCONFIGBYTE;
    if(bus_num == -1)
        regs.h.bh = bus_number;
    else
        regs.h.bh = bus_num;

    if(funct_num == -1)
        regs.h.bl = function_number;
    else
        regs.h.bl = funct_num;

    regs.x.di = reg;

    ret_value = __dpmi_int(PCI_INT_NUM, &regs);
    if(ret_value == -1) {
        status = 1;
        return PCI_FAIL;
    }

    if(regs.h.ah != SUCCESSFUL)
        status = 3;

    *retBYTE = regs.h.cl;

    if(status == 0)
        return PCI_PASS;
    else
        return PCI_FAIL;
}

/////////////////////////////////////////////////////
int PCI::ReadConfigWORD(int reg, WORD *retWORD, int funct_num, int bus_num)
{
    int ret_value;
    if(status != 0)
        return PCI_FAIL;

    regs.x.ax = PCI_READCONFIGWORD;
    if(bus_num == -1)
        regs.h.bh = bus_number;
    else
        regs.h.bh = bus_num;

    if(funct_num == -1)
        regs.h.bl = function_number;
    else
        regs.h.bl = funct_num;

    regs.x.di = reg;

    ret_value = __dpmi_int(PCI_INT_NUM, &regs);
    if(ret_value == -1) {
        status = 1;
        return PCI_FAIL;
    }

    if(regs.h.ah != SUCCESSFUL)
        status = 3;

    *retWORD = regs.x.cx;

    if(status == 0)
        return PCI_PASS;
    else
        return PCI_FAIL;
}

/////////////////////////////////////////////////////
int PCI::ReadConfigDWORD(int reg, DWORD *retDWORD, int funct_num, int bus_num)
{
    int ret_value;
    if(status != 0)
        return PCI_FAIL;

    regs.x.ax = PCI_READCONFIGDWORD;
    if(bus_num == -1)
        regs.h.bh = bus_number;
    else
        regs.h.bh = bus_num;

    if(funct_num == -1)
        regs.h.bl = function_number;
    else
        regs.h.bl = funct_num;

    regs.x.di = reg;

    ret_value = __dpmi_int(PCI_INT_NUM, &regs);
    if(ret_value == -1) {
        status = 1;
        return PCI_FAIL;
    }

    if(regs.h.ah != SUCCESSFUL)
        status = 3;

    *retDWORD = regs.d.ecx;

    if(status == 0)
        return PCI_PASS;
    else
        return PCI_FAIL;
}

/////////////////////////////////////////////////////
int PCI::WriteConfigBYTE(int reg, BYTE writeBYTE, int funct_num, int bus_num)
{
    int ret_value;
    if(status != 0)
        return PCI_FAIL;

    regs.x.ax = PCI_WRITECONFIGBYTE;
    if(bus_num == -1)
        regs.h.bh = bus_number;
    else
    regs.h.bl = bus_num;
     
    if(funct_num == -1)
        regs.h.bh = function_number;
    else
        regs.h.bh = funct_num;
    regs.x.di = reg;
    regs.h.cl = writeBYTE;

    ret_value = __dpmi_int(PCI_INT_NUM, &regs);
    if(ret_value == -1) {
        status = 1;
        return PCI_FAIL;
    }
    
    if(regs.h.ah != SUCCESSFUL)
        status = 4;

    if(status == 0)
        return PCI_PASS;
    else
        return PCI_FAIL;
}

/////////////////////////////////////////////////////
int PCI::WriteConfigWORD(int reg, WORD writeWORD, int funct_num, int bus_num)
{
    int ret_value;
    if(status !=0)
        return PCI_FAIL;

    regs.x.ax = PCI_WRITECONFIGWORD;
    if(bus_num == -1)
        regs.h.bh = bus_number;
    else
        regs.h.bl = bus_num;
     
    if(funct_num == -1)
        regs.h.bh = function_number;
    else
        regs.h.bh = funct_num;
    regs.x.di = reg;
    regs.x.cx = writeWORD;

    ret_value = __dpmi_int(PCI_INT_NUM, &regs);
    if(ret_value == -1) {
        status = 1;
        return PCI_FAIL;
    }
    
    if(regs.h.ah != SUCCESSFUL)
        status = 4;

    if(status == 0)
        return PCI_PASS;
    else
        return PCI_FAIL;
}

/////////////////////////////////////////////////////
int PCI::WriteConfigDWORD(int reg, DWORD writeDWORD, int funct_num, int bus_num)
{
    int ret_value;
    if(status !=0)
        return PCI_FAIL;

    regs.x.ax = PCI_WRITECONFIGDWORD;
    if(bus_num == -1)
        regs.h.bh = bus_number;
    else
        regs.h.bl = bus_num;
     
    if(funct_num == -1)
        regs.h.bh = function_number;
    else
        regs.h.bh = funct_num;
    regs.x.di = reg;
    regs.d.ecx = writeDWORD;

    ret_value = __dpmi_int(PCI_INT_NUM, &regs);
    if(ret_value == -1) {
        status = 1;
        return PCI_FAIL;
    }
    
    if(regs.h.ah != SUCCESSFUL)
        status = 4;

    if(status == 0)
        return PCI_PASS;
    else
        return PCI_FAIL;
}

/////////////////////////////////////////////////////
WORD PCI::GetVendorID(int funct_num, int bus_num)
{
    DWORD value;
        
    if(ReadConfigDWORD(0, &value, funct_num, bus_num) == PCI_FAIL)
        return 0xFFFF;
    
    return(value & 0xFFFF);
}

/////////////////////////////////////////////////////
WORD PCI::GetDeviceID(int funct_num, int bus_num)
{
    DWORD value;
        
    if(ReadConfigDWORD(0, &value, funct_num, bus_num) == PCI_FAIL)
        return 0xFFFF;
    
    return((value>>16) & 0xFFFF);
}

/////////////////////////////////////////////////////
WORD PCI::GetStatusReg(int funct_num, int bus_num)
{
    DWORD value;
        
    if(ReadConfigDWORD(4, &value, funct_num, bus_num) == PCI_FAIL)
        return 0x0000;
    
    return((value>>16) & 0xFFFF);
}

/////////////////////////////////////////////////////
WORD PCI::GetCommandReg(int funct_num, int bus_num)
{
    DWORD value;
        
    if(ReadConfigDWORD(4, &value, funct_num, bus_num) == PCI_FAIL)
        return 0xFFFF;
    
    return(value & 0xFFFF);
}

/////////////////////////////////////////////////////
DWORD PCI::GetClassCodeReg(int funct_num, int bus_num)
{
    DWORD value;
        
    if(ReadConfigDWORD(8, &value, funct_num, bus_num) == PCI_FAIL)
        return 0x000000;
    
    return((value>>8) & 0xFFFFFF);
}

/////////////////////////////////////////////////////
BYTE PCI::GetRevisionID(int funct_num, int bus_num)
{
    DWORD value;
        
    if(ReadConfigDWORD(8, &value, funct_num, bus_num) == PCI_FAIL)
        return 0x00;
    
    return(value & 0xFF);
}

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

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日产国产精品| 亚洲综合在线电影| 精品电影一区二区三区| 欧美日本精品一区二区三区| 欧美日韩亚洲综合在线 欧美亚洲特黄一级 | 欧美成人精品3d动漫h| 欧美日韩国产高清一区二区| 欧美日韩国产不卡| 欧美一区二区三区影视| 欧美本精品男人aⅴ天堂| 精品国产网站在线观看| 国产亚洲一区二区三区| 中文字幕第一页久久| 亚洲三级理论片| 亚洲国产精品一区二区尤物区| 亚洲成av人片一区二区梦乃 | 91美女福利视频| 91久久久免费一区二区| 欧美日韩精品一区二区三区| 宅男噜噜噜66一区二区66| 日韩久久久精品| 久久精品欧美一区二区三区不卡 | 久久天天做天天爱综合色| 久久精品欧美一区二区三区不卡| 国产日韩综合av| 日韩一区有码在线| 午夜精品久久久久久久久久久 | 成人av手机在线观看| 一本色道久久综合亚洲aⅴ蜜桃| 91丝袜呻吟高潮美腿白嫩在线观看| 91福利资源站| 日韩欧美电影一区| 国产欧美日韩三区| 亚洲精品网站在线观看| 日韩电影一二三区| 成人免费毛片高清视频| 在线视频国内一区二区| 精品嫩草影院久久| 亚洲天堂成人在线观看| 亚洲国产精品一区二区www| 老司机免费视频一区二区| 成人免费视频caoporn| 欧美日本在线看| 国产精品丝袜在线| 亚洲伊人伊色伊影伊综合网| 久久不见久久见中文字幕免费| 成人黄色网址在线观看| 7777精品伊人久久久大香线蕉最新版| 精品999在线播放| 亚洲美女视频在线| 精品亚洲国产成人av制服丝袜| 色婷婷亚洲综合| 精品国产亚洲一区二区三区在线观看 | 中文字幕+乱码+中文字幕一区| 一区二区三区av电影| 麻豆极品一区二区三区| 日韩欧美亚洲国产精品字幕久久久| 国产精品久久久久影视| 青青草视频一区| 色狠狠色噜噜噜综合网| 久久久久久免费网| 肉肉av福利一精品导航| 91啪亚洲精品| 国产女同性恋一区二区| 日本三级韩国三级欧美三级| 97精品视频在线观看自产线路二| 日韩欧美国产一区二区在线播放 | 免费在线观看一区二区三区| 色婷婷av一区| 中文字幕第一区第二区| 精品一区二区精品| 欧美人妖巨大在线| 亚洲青青青在线视频| 国产精品一区二区视频| 制服丝袜中文字幕一区| 亚洲一卡二卡三卡四卡五卡| www.日本不卡| 国产日产欧美精品一区二区三区| 免费观看久久久4p| 欧美精品国产精品| 一区二区三区精密机械公司| 成人理论电影网| 国产欧美一区二区精品性| 久久精品国产精品青草| 欧美一区国产二区| 五月天丁香久久| 欧美视频一区二区三区| 亚洲在线一区二区三区| 91啪九色porn原创视频在线观看| 日本一区二区不卡视频| 国产精品香蕉一区二区三区| 精品999在线播放| 国产一区高清在线| 天天免费综合色| 欧美人狂配大交3d怪物一区| 亚洲理论在线观看| 91国产免费观看| 亚洲精品免费电影| 99久久99精品久久久久久| 中文字幕制服丝袜成人av | 国产亚洲成aⅴ人片在线观看| 麻豆视频观看网址久久| 日韩精品在线一区二区| 六月丁香婷婷久久| 精品剧情在线观看| 国内精品久久久久影院色| 久久久噜噜噜久噜久久综合| 黄色日韩网站视频| 2023国产精品自拍| 风间由美一区二区三区在线观看| 久久久国产精品麻豆| 国产成人亚洲综合色影视| 日本一区二区三级电影在线观看| 国产精品一品二品| 中文一区在线播放| 97aⅴ精品视频一二三区| 亚洲免费在线视频一区 二区| 色欧美88888久久久久久影院| 亚洲综合av网| 91精品在线一区二区| 麻豆成人久久精品二区三区小说| 日韩欧美www| 国产精品1区2区3区| 中文字幕中文字幕一区| 欧美视频在线一区二区三区| 免费人成网站在线观看欧美高清| 日韩视频免费直播| 国产91精品一区二区麻豆亚洲| 中文字幕亚洲电影| 欧美日韩国产不卡| 国产麻豆精品theporn| 亚洲天堂精品视频| 制服.丝袜.亚洲.中文.综合| 国产传媒一区在线| 一区二区在线观看av| 欧美一区二区三区在线看| 国产一区二区三区国产| 亚洲精品国产视频| 欧美成人精品1314www| 成人午夜激情在线| 亚洲国产精品一区二区久久| 亚洲精品一区二区三区香蕉| 99久久久精品免费观看国产蜜| 日韩精品一二三四| 欧美mv日韩mv国产网站app| 国产视频911| 波多野结衣中文字幕一区| 亚洲成人精品影院| 久久男人中文字幕资源站| 色哟哟欧美精品| 经典三级视频一区| 一区二区三区不卡视频在线观看| 欧美成人精品1314www| 国产肉丝袜一区二区| 欧美日韩成人一区二区| 国产精品自拍在线| 亚洲成av人片在线观看无码| 国产欧美在线观看一区| 欧美一卡二卡三卡| 91免费视频大全| 国产一区二区在线看| 亚洲一二三四区不卡| 国产三级一区二区三区| 欧美日韩成人综合天天影院| 成人美女视频在线观看18| 久久国产精品一区二区| 一区二区三区在线免费观看 | 夜夜嗨av一区二区三区四季av| 337p粉嫩大胆噜噜噜噜噜91av| 色久综合一二码| 国产伦精品一区二区三区视频青涩| 亚洲一区二区三区精品在线| 国产日韩精品一区| 91精品国产一区二区三区蜜臀 | av网站免费线看精品| 蜜桃传媒麻豆第一区在线观看| 亚洲人成7777| 国产清纯美女被跳蛋高潮一区二区久久w | 精品一区免费av| 日韩在线观看一区二区| 亚洲美女电影在线| 国产精品久线在线观看| 国产日本欧洲亚洲| 欧美一区二区三区小说| 欧美日韩在线三区| 在线视频国内自拍亚洲视频| 97国产一区二区| av资源站一区| 成人永久aaa| 高清成人免费视频| 国产精品一线二线三线精华| 国产自产高清不卡| 久久精品国产99| 免费观看成人av| 青青草成人在线观看| 午夜久久电影网| 亚洲欧洲综合另类| 亚洲视频每日更新| 国产精品夫妻自拍| 成人免费在线观看入口|