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

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

?? ppw9xring0.c

?? simple MIPS EJTAG u-boot loader
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*****************************************************************************//* *      ppw9xring0.c  --  Parport direct access under Win9x using Ring0 hack. * *      Copyright (C) 1998-2000  Thomas Sailer (sailer@ife.ee.ethz.ch) * *      This program is free software; you can redistribute it and/or modify *      it under the terms of the GNU General Public License as published by *      the Free Software Foundation; either version 2 of the License, or *      (at your option) any later version. * *      This program is distributed in the hope that it will be useful, *      but WITHOUT ANY WARRANTY; without even the implied warranty of *      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *      GNU General Public License for more details. * *      You should have received a copy of the GNU General Public License *      along with this program; if not, write to the Free Software *      Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * *  Please note that the GPL allows you to use the driver, NOT the radio. *  In order to use the radio, you need a license from the communications *  authority of your country. * *//*****************************************************************************/#include <windows.h>#include "parport.h"/* ---------------------------------------------------------------------- *//* LPT registers *//* ECP specific registers */#define LPTREG_ECONTROL       0x402#define LPTREG_CONFIGB        0x401#define LPTREG_CONFIGA        0x400#define LPTREG_TFIFO          0x400#define LPTREG_DFIFO          0x400#define LPTREG_AFIFO          0x000#define LPTREG_DSR            0x001#define LPTREG_DCR            0x002/* EPP specific registers */#define LPTREG_EPPDATA        0x004#define LPTREG_EPPADDR        0x003/* standard registers */#define LPTREG_CONTROL        0x002#define LPTREG_STATUS         0x001#define LPTREG_DATA           0x000/* ECP config A */#define LPTCFGA_INTRISALEVEL  0x80#define LPTCFGA_IMPIDMASK     0x70#define LPTCFGA_IMPID16BIT    0x00#define LPTCFGA_IMPID8BIT     0x10#define LPTCFGA_IMPID32BIT    0x20#define LPTCFGA_NOPIPELINE    0x04#define LPTCFGA_PWORDCOUNT    0x03/* ECP config B */#define LPTCFGB_COMPRESS      0x80#define LPTCFGB_INTRVALUE     0x40#define LPTCFGB_IRQMASK       0x38#define LPTCFGB_IRQ5          0x38#define LPTCFGB_IRQ15         0x30#define LPTCFGB_IRQ14         0x28#define LPTCFGB_IRQ11         0x20#define LPTCFGB_IRQ10         0x18#define LPTCFGB_IRQ9          0x10#define LPTCFGB_IRQ7          0x08#define LPTCFGB_IRQJUMPER     0x00#define LPTCFGB_DMAMASK       0x07#define LPTCFGB_DMA7          0x07#define LPTCFGB_DMA6          0x06#define LPTCFGB_DMA5          0x05#define LPTCFGB_DMAJUMPER16   0x04#define LPTCFGB_DMA3          0x03#define LPTCFGB_DMA2          0x02#define LPTCFGB_DMA1          0x01#define LPTCFGB_DMAJUMPER8    0x00/* ECP ECR */#define LPTECR_MODEMASK       0xe0#define LPTECR_MODESPP        0x00#define LPTECR_MODEPS2        0x20#define LPTECR_MODESPPFIFO    0x40#define LPTECR_MODEECP        0x60#define LPTECR_MODEECPEPP     0x80#define LPTECR_MODETEST       0xc0#define LPTECR_MODECFG        0xe0#define LPTECR_NERRINTRDIS    0x10#define LPTECR_DMAEN          0x08#define LPTECR_SERVICEINTR    0x04#define LPTECR_FIFOFULL       0x02#define LPTECR_FIFOEMPTY      0x01/* ---------------------------------------------------------------------- */unsigned int pp_w9xring0_iobase = 0x378;unsigned int pp_w9xring0_flags = 0;#define FLAGS_PCSPP              (1<<0)#define FLAGS_PCPS2              (1<<1)#define FLAGS_PCEPP              (1<<2)#define FLAGS_PCECR              (1<<3)  /* ECR Register Exists */#define FLAGS_PCECP              (1<<4)#define FLAGS_PCECPEPP           (1<<5)#define FLAGS_PCECPPS2           (1<<6)/* ---------------------------------------------------------------------- */asm(".text\n\t"    ".align\t4\n"    "_do_ring0_inb:\n\t"    "inb %dx,%al\n\t"    "lret\n\n\t"    ".align\t4\n"    "_do_ring0_outb:\n\t"    "outb %al,%dx\n\t"    "lret\n\n\t"    ".align\t4\n\t"    ".data\n\t");extern int do_ring0_inb(int,int);extern int do_ring0_outb(int,int);static int call_ring0(int (*routine)(int,int), int param1, int param2){        unsigned short gdtbase[3];        unsigned short callgateaddr[3];        struct gdt {                unsigned short offslo;                unsigned short selector;                unsigned short flags;                unsigned short offshi;        } *gdt, *mygdt;        unsigned int i, maxgdt;        int ret;                asm("sgdt\t%0" : "=m" (gdtbase));        gdt = (struct gdt *)((gdtbase[2] << 16) | gdtbase[1]);        maxgdt = gdtbase[0]/8; /* gdt limit */        for (i = 1; i < maxgdt; i++) {                if (!gdt[i].flags && !gdt[i].selector && !gdt[i].offslo && !gdt[i].offshi)                        break;        }        if (i >= maxgdt) {                lprintf(3, "Cannot find free GDT entry\n");                return -1;        }        mygdt = &gdt[i];        mygdt->flags = (1 << 15) | /* present */                (0x0c00) |         /* type: call gate */                (3 << 13) |        /* DPL */                0;                 /* dword count */        mygdt->selector = 0x28;        mygdt->offslo = ((unsigned long)routine);        mygdt->offshi = ((unsigned long)routine) >> 16;        callgateaddr[0] = callgateaddr[1] = 0;        callgateaddr[2] = (i << 3) | 3;        asm("lcall\t%1" : "=a" (ret) : "m" (callgateaddr[0]), "d" (param1), "0" (param2) : "memory");        memset(mygdt, 0, sizeof(struct gdt));        return ret;}unsigned char ring0_inb(unsigned int port){        return call_ring0(do_ring0_inb, port, 0);}void ring0_outb(unsigned char val, unsigned int port){        call_ring0(do_ring0_outb, port, val);}void ring0_outsb(unsigned int port, const unsigned char *bp, unsigned int count){        while (count > 0) {                ring0_outb(*bp++, port);                count--;        }}void ring0_insb(unsigned int port, unsigned char *bp, unsigned int count){        while (count > 0) {                *bp++ = ring0_inb(port);                count--;        }}/* ---------------------------------------------------------------------- */extern inline void setecr(unsigned char ecr){	if (pp_w9xring0_flags & FLAGS_PCECR)		ring0_outb(ecr, pp_w9xring0_iobase + LPTREG_ECONTROL);}int pp_w9xring0_epp_clear_timeout(void){        unsigned char r;        if (!(ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS) & LPTSTAT_EPPTIMEOUT))                return 1;        /* To clear timeout some chips require double read */	ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS);	r = ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS);	ring0_outb(r | 0x01, pp_w9xring0_iobase + LPTREG_STATUS); /* Some reset by writing 1 */	ring0_outb(r & 0xfe, pp_w9xring0_iobase + LPTREG_STATUS); /* Others by writing 0 */        r = ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS);        return !(r & 0x01);}/* ---------------------------------------------------------------------- */unsigned char parport_w9xring0_read_data(void){	return ring0_inb(pp_w9xring0_iobase + LPTREG_DATA);}void parport_w9xring0_write_data(unsigned char d){	ring0_outb(d, pp_w9xring0_iobase + LPTREG_DATA);}unsigned char parport_w9xring0_read_status(void){	return ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS);}unsigned char parport_w9xring0_read_control(void){	return ring0_inb(pp_w9xring0_iobase + LPTREG_CONTROL);}void parport_w9xring0_write_control(unsigned char d){	ring0_outb(d, pp_w9xring0_iobase + LPTREG_CONTROL);}void parport_w9xring0_frob_control(unsigned char mask, unsigned char val){	unsigned char d = ring0_inb(pp_w9xring0_iobase + LPTREG_CONTROL);	d = (d & (~mask)) ^ val;	ring0_outb(d, pp_w9xring0_iobase + LPTREG_CONTROL);}/* ---------------------------------------------------------------------- */unsigned parport_w9xring0_epp_write_data(const void *buf, unsigned sz){	unsigned char *bp = (unsigned char *)buf;	unsigned ret = 0;	setecr(0x90); /* EPP mode */	for (; sz > 0; sz--, bp++) {		ring0_outb(*bp, pp_w9xring0_iobase + LPTREG_EPPDATA);		if (ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS) & LPTSTAT_EPPTIMEOUT) {			pp_w9xring0_epp_clear_timeout();			goto rt;		}		ret++;	} rt:	setecr(0x30); /* PS/2 mode */	return ret;}unsigned parport_w9xring0_epp_read_data(void *buf, unsigned sz){	unsigned char *bp = (unsigned char *)buf;	unsigned ret = 0;	setecr(0x90); /* EPP mode */	for (; sz > 0; sz--, bp++) {		*bp = ring0_inb(pp_w9xring0_iobase + LPTREG_EPPDATA);		if (ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS) & LPTSTAT_EPPTIMEOUT) {			pp_w9xring0_epp_clear_timeout();			goto rt;		}		ret++;	} rt:	setecr(0x30); /* PS/2 mode */	return ret;}unsigned parport_w9xring0_epp_write_addr(const void *buf, unsigned sz){	unsigned char *bp = (unsigned char *)buf;	unsigned ret = 0;	setecr(0x90); /* EPP mode */	for (; sz > 0; sz--, bp++) {		ring0_outb(*bp, pp_w9xring0_iobase + LPTREG_EPPADDR);		if (ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS) & LPTSTAT_EPPTIMEOUT) {			pp_w9xring0_epp_clear_timeout();			goto rt;		}		ret++;	} rt:	setecr(0x30); /* PS/2 mode */	return ret;}unsigned parport_w9xring0_epp_read_addr(void *buf, unsigned sz){	unsigned char *bp = (unsigned char *)buf;	unsigned ret = 0;	setecr(0x90); /* EPP mode */	for (; sz > 0; sz--, bp++) {		*bp = ring0_inb(pp_w9xring0_iobase + LPTREG_EPPADDR);		if (ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS) & LPTSTAT_EPPTIMEOUT) {			pp_w9xring0_epp_clear_timeout();			goto rt;		}		ret++;	} rt:	setecr(0x30); /* PS/2 mode */	return ret;}/* ---------------------------------------------------------------------- */unsigned parport_w9xring0_emul_epp_write_data(const void *buf, unsigned sz){	unsigned char *bp = (unsigned char *)buf;	unsigned ret = 0;	unsigned tmo;	ring0_outb(LPTCTRL_PROGRAM | LPTCTRL_WRITE, pp_w9xring0_iobase + LPTREG_CONTROL);	for (; sz > 0; sz--, bp++) {		ring0_outb(*bp, pp_w9xring0_iobase + LPTREG_DATA);		for (tmo = 0; ; tmo++) {			if (ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS) & LPTSTAT_WAIT)				break;			if (tmo > 1000)				return ret;		}		ring0_outb(LPTCTRL_PROGRAM | LPTCTRL_WRITE | LPTCTRL_DATASTB, pp_w9xring0_iobase + LPTREG_CONTROL);		for (tmo = 0; ; tmo++) {			if (!(ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS) & LPTSTAT_WAIT))				break;			if (tmo > 1000)				return ret;		}		ring0_outb(LPTCTRL_PROGRAM | LPTCTRL_WRITE, pp_w9xring0_iobase + LPTREG_CONTROL);		ret++;	}	return ret;}unsigned parport_w9xring0_emul_epp_read_data(void *buf, unsigned sz){	unsigned char *bp = (unsigned char *)buf;	unsigned ret = 0;	unsigned tmo;	ring0_outb(LPTCTRL_PROGRAM | LPTCTRL_DIRECTION, pp_w9xring0_iobase + LPTREG_CONTROL);	for (; sz > 0; sz--, bp++) {		for (tmo = 0; ; tmo++) {			if (ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS) & LPTSTAT_WAIT)				break;			if (tmo > 1000)				return ret;		}		ring0_outb(LPTCTRL_PROGRAM | LPTCTRL_DIRECTION | LPTCTRL_DATASTB, pp_w9xring0_iobase + LPTREG_CONTROL);		for (tmo = 0; ; tmo++) {			if (!(ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS) & LPTSTAT_WAIT))				break;			if (tmo > 1000)				return ret;		}		*bp = ring0_inb(pp_w9xring0_iobase + LPTREG_DATA);		ring0_outb(LPTCTRL_PROGRAM | LPTCTRL_DIRECTION, pp_w9xring0_iobase + LPTREG_CONTROL);		ret++;	}	return ret;}unsigned parport_w9xring0_emul_epp_write_addr(const void *buf, unsigned sz){	unsigned char *bp = (unsigned char *)buf;	unsigned ret = 0;	unsigned tmo;	ring0_outb(LPTCTRL_PROGRAM | LPTCTRL_WRITE, pp_w9xring0_iobase + LPTREG_CONTROL);	for (; sz > 0; sz--, bp++) {		ring0_outb(*bp, pp_w9xring0_iobase + LPTREG_DATA);		for (tmo = 0; ; tmo++) {			if (ring0_inb(pp_w9xring0_iobase + LPTREG_STATUS) & LPTSTAT_WAIT)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91视频.com| 国产成人精品三级| 中文字幕一区二区三区乱码在线| 精品国产99国产精品| 精品国产伦一区二区三区免费| 日韩午夜在线观看| 日韩一区二区在线观看视频| 日韩欧美一区二区在线视频| 日韩精品一区国产麻豆| 亚洲精品在线网站| 国产欧美视频在线观看| 国产精品麻豆网站| 亚洲一区二区三区自拍| 亚洲午夜电影在线| 亚洲成人一区在线| 狠狠网亚洲精品| 成人91在线观看| 欧美手机在线视频| 精品三级在线观看| 国产精品网站在线观看| 亚洲人吸女人奶水| 日韩极品在线观看| 国产伦精一区二区三区| 色综合色狠狠天天综合色| 欧美午夜一区二区| 久久亚洲私人国产精品va媚药| 中文在线资源观看网站视频免费不卡| 亚洲人午夜精品天堂一二香蕉| 亚洲123区在线观看| 国产精品18久久久| 欧美性高清videossexo| 久久久久高清精品| 亚洲综合精品自拍| 国产呦萝稀缺另类资源| 在线亚洲精品福利网址导航| 日韩精品一区在线观看| 国产精品私房写真福利视频| 亚洲国产中文字幕| 成人午夜免费av| 日韩精品一区二区三区在线播放| 国产精品久久二区二区| 久久国产精品区| 色欧美日韩亚洲| 欧美激情一区二区三区全黄| 偷拍与自拍一区| 成人动漫一区二区| 精品福利一二区| 婷婷久久综合九色国产成人| caoporen国产精品视频| 337p日本欧洲亚洲大胆色噜噜| 一级做a爱片久久| 成人做爰69片免费看网站| 精品国精品国产| 日本少妇一区二区| 欧美色窝79yyyycom| 亚洲人妖av一区二区| 国产白丝精品91爽爽久久 | 亚洲国产精品精华液ab| 婷婷一区二区三区| 91毛片在线观看| 最新日韩av在线| 国产999精品久久| 国产偷v国产偷v亚洲高清| 久久精品国产一区二区三| 在线播放国产精品二区一二区四区| 亚洲四区在线观看| 大白屁股一区二区视频| 中文字幕欧美三区| 成人免费毛片app| 国产性做久久久久久| 国产一区不卡在线| 欧美不卡123| 国产在线精品不卡| 久久精品人人做人人爽97| 国产乱码精品一区二区三区五月婷 | 日本不卡一二三区黄网| 欧美另类videos死尸| 亚洲成人免费影院| 欧美美女一区二区| 丝袜美腿亚洲色图| 精品日韩av一区二区| 麻豆精品视频在线观看视频| 日韩欧美国产午夜精品| 国内欧美视频一区二区| 欧美精品一区二| 国产不卡视频在线播放| 国产精品电影一区二区| 欧洲日韩一区二区三区| 午夜精品福利一区二区蜜股av | 美女视频黄频大全不卡视频在线播放| 日韩欧美激情一区| 国产激情视频一区二区三区欧美 | 欧美亚洲国产bt| 全国精品久久少妇| 久久久久久久综合狠狠综合| av电影一区二区| 亚洲成人1区2区| 久久品道一品道久久精品| 99精品欧美一区二区三区小说 | 国产精品18久久久久久vr| 中文字幕免费在线观看视频一区| 99久久er热在这里只有精品66| 亚洲自拍偷拍麻豆| 精品日韩一区二区| 91在线观看免费视频| 欧美aaaaa成人免费观看视频| 久久久国产精品午夜一区ai换脸| 色综合夜色一区| 免费一级欧美片在线观看| 国产精品成人免费在线| 欧美精品在线视频| 高清久久久久久| 日韩国产欧美视频| 1区2区3区精品视频| 日韩美女视频在线| 色狠狠一区二区| 国产一区二区三区精品视频| 亚洲乱码一区二区三区在线观看| 日韩一区二区在线观看视频| 99精品视频在线观看| 国产一区二区美女| 午夜精品在线看| 亚洲欧美日韩久久| 欧美极品美女视频| 精品国产三级电影在线观看| 日本久久电影网| 国产成人精品免费视频网站| 亚洲成人一区在线| 亚洲精品五月天| 国产视频一区在线观看| 日韩精品一区国产麻豆| 欧美日韩亚洲高清一区二区| 91麻豆精品在线观看| 大尺度一区二区| 国产寡妇亲子伦一区二区| 久久综合综合久久综合| 视频一区中文字幕| 夜夜操天天操亚洲| 亚洲免费高清视频在线| 国产精品视频一二| 久久久久久久网| www久久精品| 日韩精品在线看片z| 欧美一区二区人人喊爽| 91精品国产免费久久综合| 欧美在线制服丝袜| 欧美性色综合网| 91成人国产精品| 色欧美88888久久久久久影院| 99久久精品国产毛片| 91丨porny丨国产入口| 成人精品免费网站| 国产激情偷乱视频一区二区三区 | 国产精品毛片高清在线完整版| 久久精品夜色噜噜亚洲a∨| 精品久久久网站| 国产蜜臀97一区二区三区| 国产午夜精品在线观看| 国产精品情趣视频| **网站欧美大片在线观看| 综合电影一区二区三区| 亚洲欧洲综合另类在线| 亚洲自拍另类综合| 日韩黄色在线观看| 精一区二区三区| 国产高清精品在线| 99精品欧美一区二区蜜桃免费 | 国内精品伊人久久久久av一坑| 激情综合色丁香一区二区| 国产高清不卡一区二区| 成人黄色在线视频| 欧美性猛片xxxx免费看久爱| 欧美精品一区二区在线播放| 精品国产欧美一区二区| 久久久久久久久久久黄色| 自拍偷在线精品自拍偷无码专区| 一级精品视频在线观看宜春院| 水野朝阳av一区二区三区| 精品一区二区久久| 99久精品国产| 日韩欧美一区在线| 中文字幕视频一区二区三区久| 亚洲成av人综合在线观看| 国产一区二区三区免费| 成人国产精品免费观看| 欧美在线观看视频一区二区| 亚洲精品一线二线三线| 亚洲另类中文字| 精品一区二区在线免费观看| 午夜激情综合网| 亚洲一区二区三区四区五区中文| 日韩国产欧美在线视频| 99在线视频精品| 日韩欧美一级在线播放| 国产精品蜜臀av| 日本中文字幕不卡| 成人av午夜电影| 精品福利在线导航| 亚洲高清一区二区三区| 99视频精品全部免费在线|