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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(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一区二区三区免费野_久草精品视频
91精品一区二区三区久久久久久| 日韩亚洲欧美高清| 三级影片在线观看欧美日韩一区二区| 91精品国产欧美日韩| 国产91精品一区二区麻豆网站| 午夜欧美在线一二页| 国产精品美日韩| 精品三级av在线| 欧美色欧美亚洲另类二区| 国产盗摄视频一区二区三区| 亚洲成av人影院| 国产精品久久久一本精品| 日韩三级精品电影久久久| 在线视频你懂得一区| 国产成人超碰人人澡人人澡| 热久久免费视频| 亚洲大片在线观看| 亚洲欧美综合另类在线卡通| 国产午夜精品理论片a级大结局| 欧美一区二区三区的| 欧美日韩在线三区| 色狠狠桃花综合| av中文一区二区三区| 国产精品亚洲午夜一区二区三区 | 一区二区免费在线播放| 国产亚洲一二三区| 亚洲精品一线二线三线| 91精品国产高清一区二区三区| 欧美在线不卡视频| 91蜜桃网址入口| 9人人澡人人爽人人精品| 国产精品1区二区.| 国产乱码精品一品二品| 紧缚捆绑精品一区二区| 蜜桃av噜噜一区| 久久国产精品第一页| 久久国产日韩欧美精品| 麻豆免费精品视频| 狠狠色丁香久久婷婷综合丁香| 在线免费一区三区| 91小视频在线| 91老师片黄在线观看| 色婷婷亚洲综合| 91免费看片在线观看| 99精品1区2区| 91精品福利视频| 欧美日韩一级二级| 欧美另类videos死尸| 欧美日韩小视频| 制服丝袜亚洲播放| 欧美va天堂va视频va在线| 精品国产凹凸成av人网站| 久久色在线观看| 亚洲国产精品传媒在线观看| 国产精品成人在线观看| 亚洲综合色区另类av| 亚洲777理论| 久久精品国产亚洲高清剧情介绍| 韩国成人福利片在线播放| 国产黄人亚洲片| 91在线看国产| 欧美日韩一区二区三区不卡| 91精品国产高清一区二区三区| 精品国产免费一区二区三区四区 | 亚洲精品第一国产综合野| 亚洲一级在线观看| 免费高清在线视频一区·| 国产一区二区91| av一区二区三区| 欧美日韩国产一二三| 欧美精品一区二区高清在线观看| 极品少妇xxxx偷拍精品少妇| 国产精品亚洲午夜一区二区三区| av爱爱亚洲一区| 制服视频三区第一页精品| 久久久久久久久久久久久女国产乱| 中文字幕高清不卡| 亚洲成人黄色影院| 国产成人在线电影| 欧美少妇xxx| 久久精品一级爱片| 亚洲主播在线播放| 国产美女在线观看一区| 色综合久久综合中文综合网| 欧美一区二区在线免费播放| 国产精品毛片大码女人| 日韩电影在线观看一区| 不卡一区二区在线| 日韩午夜激情免费电影| 国产美女一区二区| 欧美伊人久久久久久久久影院| 精品美女被调教视频大全网站| 成人免费视频在线观看| 日本欧美加勒比视频| aaa国产一区| 精品电影一区二区三区| 亚洲午夜三级在线| 成人看片黄a免费看在线| 91精品国产综合久久久久久久 | 欧美四级电影网| 国产日韩av一区| 视频精品一区二区| 一本到高清视频免费精品| 精品奇米国产一区二区三区| 夜夜揉揉日日人人青青一国产精品| 国产在线精品一区二区| 欧美伊人精品成人久久综合97| 国产三级一区二区| 久久精品国产一区二区三区免费看| 色综合久久中文字幕| 欧美国产日产图区| 狂野欧美性猛交blacked| 欧美三级蜜桃2在线观看| 国产精品三级久久久久三级| 久久91精品国产91久久小草| 欧美日韩国产一级片| 亚洲天堂福利av| 成人精品国产一区二区4080| 精品不卡在线视频| 美腿丝袜亚洲三区| 欧美久久久久久久久久| 亚洲高清一区二区三区| 91成人免费电影| 一区二区三区在线看| 99久久精品一区二区| 中文字幕va一区二区三区| 国产精品一卡二卡| 久久亚洲精精品中文字幕早川悠里| 久久国产日韩欧美精品| 欧美一区二区三区视频免费| 肉肉av福利一精品导航| 欧美日本一区二区| 性做久久久久久| 5566中文字幕一区二区电影| 亚洲成a人片在线观看中文| 欧美性一区二区| 亚洲一区二区在线播放相泽| 在线亚洲欧美专区二区| 亚洲精品国产一区二区精华液 | 精品免费视频.| 免费亚洲电影在线| 日韩欧美高清在线| 韩国av一区二区| 国产日韩欧美高清| 粉嫩aⅴ一区二区三区四区 | 99免费精品在线| 日韩伦理av电影| 欧洲精品在线观看| 亚洲第一成人在线| 91精品国产福利| 精品一区二区三区久久| 久久亚洲精精品中文字幕早川悠里| 国产一区二区毛片| 国产精品网友自拍| 91国产丝袜在线播放| 天天综合日日夜夜精品| 欧美大片在线观看一区二区| 国产伦理精品不卡| 亚洲日本成人在线观看| 欧美日韩五月天| 久久不见久久见免费视频7| 久久精品亚洲精品国产欧美 | 一级精品视频在线观看宜春院| 欧美日精品一区视频| 美女久久久精品| 亚洲国产精华液网站w| 色菇凉天天综合网| 日韩成人一级片| 欧美极品aⅴ影院| 欧美在线观看一二区| 日韩成人一级片| 中文字幕高清一区| 亚洲精品综合在线| 欧美猛男男办公室激情| 国产尤物一区二区| 亚洲欧美另类图片小说| 欧美一级生活片| 成人精品鲁一区一区二区| 午夜精品久久久久久久| 欧美成人video| 91免费观看在线| 蜜臀av一区二区| 亚洲欧洲av一区二区三区久久| 欧美疯狂性受xxxxx喷水图片| 国产精品资源站在线| 亚洲综合视频网| 久久久精品中文字幕麻豆发布| 日本韩国欧美在线| 国产一区二区在线免费观看| 一区二区三区毛片| 久久久精品天堂| 欧美精品18+| 99国产精品一区| 国产一区在线观看麻豆| 亚洲线精品一区二区三区八戒| 国产亚洲午夜高清国产拍精品| 在线观看网站黄不卡| 丁香网亚洲国际| 另类欧美日韩国产在线| 亚洲国产裸拍裸体视频在线观看乱了|