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

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

?? io.c

?? h內核
?? C
字號:
/* * linux/arch/sh/kernel/io_hs7751rvoip.c * * Copyright (C) 2001  Ian da Silva, Jeremy Siegel * Based largely on io_se.c. * * I/O routine for Renesas Technology sales HS7751RVoIP * * Initial version only to support LAN access; some * placeholder code from io_hs7751rvoip.c left in with the * expectation of later SuperIO and PCMCIA access. */#include <linux/config.h>#include <linux/kernel.h>#include <linux/types.h>#include <asm/io.h>#include <asm/hs7751rvoip/hs7751rvoip.h>#include <asm/addrspace.h>#include <linux/module.h>#include <linux/pci.h>#include "../../../drivers/pci/pci-sh7751.h"extern void *area5_io8_base;	/* Area 5 8bit I/O Base address */extern void *area6_io8_base;	/* Area 6 8bit I/O Base address */extern void *area5_io16_base;	/* Area 5 16bit I/O Base address */extern void *area6_io16_base;	/* Area 6 16bit I/O Base address *//* * The 7751R HS7751RVoIP uses the built-in PCI controller (PCIC) * of the 7751R processor, and has a SuperIO accessible via the PCI. * The board also includes a PCMCIA controller on its memory bus, * like the other Solution Engine boards. */#define PCIIOBR		(volatile long *)PCI_REG(SH7751_PCIIOBR)#define PCIMBR          (volatile long *)PCI_REG(SH7751_PCIMBR)#define PCI_IO_AREA	SH7751_PCI_IO_BASE#define PCI_MEM_AREA	SH7751_PCI_CONFIG_BASE#define PCI_IOMAP(adr)	(PCI_IO_AREA + (adr & ~SH7751_PCIIOBR_MASK))#if defined(CONFIG_HS7751RVOIP_CODEC)#define CODEC_IO_BASE	0x1000#endif#define maybebadio(name,port) \  printk("bad PC-like io %s for port 0x%lx at 0x%08x\n", \	 #name, (port), (__u32) __builtin_return_address(0))static inline void delay(void){	ctrl_inw(0xa0000000);}static inline unsigned long port2adr(unsigned int port){	if ((0x1f0 <= port && port < 0x1f8) || port == 0x3f6)		if (port == 0x3f6)			return ((unsigned long)area5_io16_base + 0x0c);		else			return ((unsigned long)area5_io16_base + 0x800 + ((port-0x1f0) << 1));	else		maybebadio(port2adr, (unsigned long)port);	return port;}/* The 7751R HS7751RVoIP seems to have everything hooked *//* up pretty normally (nothing on high-bytes only...) so this *//* shouldn't be needed */static inline int shifted_port(unsigned long port){	/* For IDE registers, value is not shifted */	if ((0x1f0 <= port && port < 0x1f8) || port == 0x3f6)		return 0;	else		return 1;}#if defined(CONFIG_HS7751RVOIP_CODEC)static inline intcodec_port(unsigned long port){	if (CODEC_IO_BASE <= port && port < (CODEC_IO_BASE+0x20))		return 1;	else		return 0;}#endif/* In case someone configures the kernel w/o PCI support: in that *//* scenario, don't ever bother to check for PCI-window addresses *//* NOTE: WINDOW CHECK MAY BE A BIT OFF, HIGH PCIBIOS_MIN_IO WRAPS? */#if defined(CONFIG_PCI)#define CHECK_SH7751_PCIIO(port) \  ((port >= PCIBIOS_MIN_IO) && (port < (PCIBIOS_MIN_IO + SH7751_PCI_IO_SIZE)))#else#define CHECK_SH7751_PCIIO(port) (0)#endif/* * General outline: remap really low stuff [eventually] to SuperIO, * stuff in PCI IO space (at or above window at pci.h:PCIBIOS_MIN_IO) * is mapped through the PCI IO window.  Stuff with high bits (PXSEG) * should be way beyond the window, and is used  w/o translation for * compatibility. */unsigned char hs7751rvoip_inb(unsigned long port){	if (PXSEG(port))		return *(volatile unsigned char *)port;#if defined(CONFIG_HS7751RVOIP_CODEC)	else if (codec_port(port))		return *(volatile unsigned char *)((unsigned long)area6_io8_base+(port-CODEC_IO_BASE));#endif	else if (CHECK_SH7751_PCIIO(port) || shifted_port(port))		return *(volatile unsigned char *)PCI_IOMAP(port);	else		return (*(volatile unsigned short *)port2adr(port) & 0xff);}unsigned char hs7751rvoip_inb_p(unsigned long port){	unsigned char v;        if (PXSEG(port))                v = *(volatile unsigned char *)port;#if defined(CONFIG_HS7751RVOIP_CODEC)	else if (codec_port(port))		v = *(volatile unsigned char *)((unsigned long)area6_io8_base+(port-CODEC_IO_BASE));#endif	else if (CHECK_SH7751_PCIIO(port) || shifted_port(port))                v = *(volatile unsigned char *)PCI_IOMAP(port);	else		v = (*(volatile unsigned short *)port2adr(port) & 0xff);	delay();	return v;}unsigned short hs7751rvoip_inw(unsigned long port){        if (PXSEG(port))                return *(volatile unsigned short *)port;	else if (CHECK_SH7751_PCIIO(port) || shifted_port(port))                return *(volatile unsigned short *)PCI_IOMAP(port);	else		maybebadio(inw, port);	return 0;}unsigned int hs7751rvoip_inl(unsigned long port){        if (PXSEG(port))                return *(volatile unsigned long *)port;	else if (CHECK_SH7751_PCIIO(port) || shifted_port(port))                return *(volatile unsigned long *)PCI_IOMAP(port);	else		maybebadio(inl, port);	return 0;}void hs7751rvoip_outb(unsigned char value, unsigned long port){        if (PXSEG(port))                *(volatile unsigned char *)port = value;#if defined(CONFIG_HS7751RVOIP_CODEC)	else if (codec_port(port))		*(volatile unsigned cjar *)((unsigned long)area6_io8_base+(port-CODEC_IO_BASE)) = value;#endif	else if (CHECK_SH7751_PCIIO(port) || shifted_port(port))        	*(unsigned char *)PCI_IOMAP(port) = value;	else		*(volatile unsigned short *)port2adr(port) = value;}void hs7751rvoip_outb_p(unsigned char value, unsigned long port){        if (PXSEG(port))                *(volatile unsigned char *)port = value;#if defined(CONFIG_HS7751RVOIP_CODEC)	else if (codec_port(port))		*(volatile unsigned cjar *)((unsigned long)area6_io8_base+(port-CODEC_IO_BASE)) = value;#endif	else if (CHECK_SH7751_PCIIO(port) || shifted_port(port))        	*(unsigned char *)PCI_IOMAP(port) = value;	else		*(volatile unsigned short *)port2adr(port) = value;	delay();}void hs7751rvoip_outw(unsigned short value, unsigned long port){        if (PXSEG(port))                *(volatile unsigned short *)port = value;	else if (CHECK_SH7751_PCIIO(port) || shifted_port(port))        	*(unsigned short *)PCI_IOMAP(port) = value;	else		maybebadio(outw, port);}void hs7751rvoip_outl(unsigned int value, unsigned long port){        if (PXSEG(port))                *(volatile unsigned long *)port = value;	else if (CHECK_SH7751_PCIIO(port) || shifted_port(port))        	*((unsigned long *)PCI_IOMAP(port)) = value;	else		maybebadio(outl, port);}void hs7751rvoip_insb(unsigned long port, void *addr, unsigned long count){	if (PXSEG(port))		while (count--) *((unsigned char *) addr)++ = *(volatile unsigned char *)port;#if defined(CONFIG_HS7751RVOIP_CODEC)	else if (codec_port(port))		while (count--) *((unsigned char *) addr)++ = *(volatile unsigned char *)((unsigned long)area6_io8_base+(port-CODEC_IO_BASE));#endif	else if (CHECK_SH7751_PCIIO(port) || shifted_port(port)) {		volatile __u8 *bp = (__u8 *)PCI_IOMAP(port);		while (count--) *((volatile unsigned char *) addr)++ = *bp;	} else {		volatile __u16 *p = (volatile unsigned short *)port2adr(port);		while (count--) *((unsigned char *) addr)++ = *p & 0xff;	}}void hs7751rvoip_insw(unsigned long port, void *addr, unsigned long count){	volatile __u16 *p;	if (PXSEG(port))		p = (volatile unsigned short *)port;	else if (CHECK_SH7751_PCIIO(port) || shifted_port(port))		p = (volatile unsigned short *)PCI_IOMAP(port);	else		p = (volatile unsigned short *)port2adr(port);	while (count--) *((__u16 *) addr)++ = *p;}void hs7751rvoip_insl(unsigned long port, void *addr, unsigned long count){	if (CHECK_SH7751_PCIIO(port) || shifted_port(port)) {		volatile __u32 *p = (__u32 *)PCI_IOMAP(port);		while (count--) *((__u32 *) addr)++ = *p;	} else		maybebadio(insl, port);}void hs7751rvoip_outsb(unsigned long port, const void *addr, unsigned long count){	if (PXSEG(port))		while (count--) *(volatile unsigned char *)port = *((unsigned char *) addr)++;#if defined(CONFIG_HS7751RVOIP_CODEC)	else if (codec_port(port))		while (count--) *(volatile unsigned char *)((unsigned long)area6_io8_base+(port-CODEC_IO_BASE)) = *((unsigned char *) addr)++;#endif	else if (CHECK_SH7751_PCIIO(port) || shifted_port(port)) {		volatile __u8 *bp = (__u8 *)PCI_IOMAP(port);		while (count--) *bp = *((volatile unsigned char *) addr)++;	} else {		volatile __u16 *p = (volatile unsigned short *)port2adr(port);		while (count--) *p = *((unsigned char *) addr)++;	}}void hs7751rvoip_outsw(unsigned long port, const void *addr, unsigned long count){	volatile __u16 *p;	if (PXSEG(port))		p = (volatile unsigned short *)port;	else if (CHECK_SH7751_PCIIO(port) || shifted_port(port))		p = (volatile unsigned short *)PCI_IOMAP(port);	else		p = (volatile unsigned short *)port2adr(port);	while (count--) *p = *((__u16 *) addr)++;}void hs7751rvoip_outsl(unsigned long port, const void *addr, unsigned long count){	if (CHECK_SH7751_PCIIO(port) || shifted_port(port)) {		volatile __u32 *p = (__u32 *)PCI_IOMAP(port);		while (count--) *p = *((__u32 *) addr)++;	} else		maybebadio(outsl, port);}void *hs7751rvoip_ioremap(unsigned long offset, unsigned long size){	if (offset >= 0xfd000000)		return (void *)offset;	else		return (void *)P2SEGADDR(offset);}EXPORT_SYMBOL(hs7751rvoip_ioremap);unsigned long hs7751rvoip_isa_port2addr(unsigned long offset){	return port2adr(offset);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产女人18水真多18精品一级做| 夜色激情一区二区| 亚洲精品国产无天堂网2021| 日韩精品国产欧美| 波多野结衣精品在线| 91精品国产色综合久久不卡蜜臀 | 亚洲精品乱码久久久久久黑人| 日本欧美肥老太交大片| 色婷婷精品大在线视频| 中文字幕免费在线观看视频一区| 蜜桃av噜噜一区二区三区小说| 91久久免费观看| 中文字幕av资源一区| 久久69国产一区二区蜜臀| 欧美色综合天天久久综合精品| 欧美国产精品中文字幕| 国产最新精品精品你懂的| 3d动漫精品啪啪一区二区竹菊| 亚洲少妇屁股交4| 成人小视频在线观看| 久久影院视频免费| 久久99国产乱子伦精品免费| 7777精品久久久大香线蕉| 亚洲午夜av在线| 色国产精品一区在线观看| 最新日韩在线视频| va亚洲va日韩不卡在线观看| 国产精品毛片久久久久久久| 国产成都精品91一区二区三| 国产日韩欧美麻豆| 国产一区二区三区在线观看精品 | 加勒比av一区二区| 日韩女同互慰一区二区| 日韩精品电影一区亚洲| 欧美揉bbbbb揉bbbbb| 亚洲一二三四在线| 欧美电影一区二区三区| 日韩电影免费在线看| 日韩欧美中文一区二区| 精彩视频一区二区三区| 国产欧美综合色| 99精品视频免费在线观看| 亚洲欧洲制服丝袜| 欧美日韩免费视频| 日韩精品视频网站| 久久午夜老司机| 99视频一区二区| 亚洲综合一二三区| 337p亚洲精品色噜噜噜| 美国一区二区三区在线播放| 国产日韩欧美一区二区三区乱码| 成人av电影在线观看| 亚洲最快最全在线视频| 91精品一区二区三区久久久久久 | 精品国产乱码久久久久久老虎 | 精品理论电影在线| 国产精品69久久久久水密桃| 中文字幕一区二区三区视频| 欧美亚洲国产一区在线观看网站| 肉丝袜脚交视频一区二区| 精品99一区二区三区| 成人国产亚洲欧美成人综合网| 亚洲制服丝袜av| 亚洲精品一线二线三线无人区| www.亚洲国产| 日韩主播视频在线| 国产午夜精品一区二区三区四区| 91女神在线视频| 日本亚洲电影天堂| 国产精品久久久久久妇女6080| 欧美三区免费完整视频在线观看| 久久99久久精品| 亚洲女厕所小便bbb| 久久久久久久综合色一本| 在线观看av一区| 国内不卡的二区三区中文字幕| 一区二区三区日本| 久久综合视频网| 欧美日韩一卡二卡| 91在线一区二区| 国产麻豆精品theporn| 一区二区三区不卡在线观看 | 欧美tickling挠脚心丨vk| 成人动漫av在线| 极品少妇一区二区| 亚洲一区二区三区免费视频| 中文字幕制服丝袜一区二区三区| 日韩午夜三级在线| 欧美视频完全免费看| av中文字幕在线不卡| 精品亚洲国产成人av制服丝袜| 一区二区三区四区蜜桃| 亚洲欧洲在线观看av| 久久久不卡网国产精品二区| 日韩一区二区电影在线| 欧美日韩一二三| 97se亚洲国产综合自在线不卡 | 日本不卡不码高清免费观看 | 国产精品免费久久久久| 欧美一级黄色录像| 3d动漫精品啪啪1区2区免费 | av一区二区三区在线| 国产一区二区h| 久久精品国产精品亚洲精品| 日韩电影在线看| 美女精品一区二区| 日韩精品欧美成人高清一区二区| 一区二区三区欧美视频| 一区二区三区四区国产精品| 亚洲免费观看在线观看| 亚洲婷婷国产精品电影人久久| 欧美国产丝袜视频| 国产精品麻豆一区二区 | 久久亚洲欧美国产精品乐播 | 久久精工是国产品牌吗| 日韩高清不卡在线| 轻轻草成人在线| 日韩 欧美一区二区三区| 亚洲mv在线观看| 日本在线播放一区二区三区| 亚洲mv在线观看| 强制捆绑调教一区二区| 久久 天天综合| 国产成人午夜精品5599| 成av人片一区二区| 91久久免费观看| 日韩视频中午一区| 久久久久久久久久久久久女国产乱 | 久久久电影一区二区三区| 国产精品乱码一区二区三区软件| 亚洲国产精品成人综合| 亚洲欧洲99久久| 亚洲午夜久久久久久久久久久| 五月天网站亚洲| 韩国在线一区二区| 不卡高清视频专区| 欧美日韩国产首页| 久久综合色一综合色88| 亚洲视频一区二区在线| 亚洲电影在线播放| 狠狠网亚洲精品| 色天使色偷偷av一区二区| 欧美片网站yy| 国产日韩欧美亚洲| 亚洲大尺度视频在线观看| 激情综合色播五月| 91网址在线看| 日韩精品综合一本久道在线视频| 日本一区二区免费在线观看视频| 亚洲精品高清视频在线观看| 丝袜国产日韩另类美女| 国产成人午夜99999| 精品视频一区三区九区| 久久午夜羞羞影院免费观看| 一区二区高清免费观看影视大全| 美女视频一区二区| 日本韩国一区二区三区视频| 日韩一区二区三区四区五区六区| 亚洲欧美在线观看| 狠狠狠色丁香婷婷综合激情| 色综合中文综合网| 日韩欧美的一区二区| 亚洲日本丝袜连裤袜办公室| 亚洲国产综合在线| 国产成人免费视频精品含羞草妖精| 91美女蜜桃在线| 国产欧美精品区一区二区三区| 亚洲高清免费观看| 91色porny在线视频| 国产午夜一区二区三区| 日本中文字幕不卡| 欧美日韩午夜精品| 亚洲欧洲美洲综合色网| 激情亚洲综合在线| 911精品产国品一二三产区| 一区在线中文字幕| 成人av在线看| 日本一区二区三区高清不卡| 麻豆91免费观看| 欧美日本在线一区| 亚洲乱码中文字幕| 成人va在线观看| 国产欧美日韩精品在线| 麻豆国产欧美一区二区三区| 欧美日韩国产高清一区二区三区| 亚洲少妇中出一区| 不卡的av电影| 中文字幕在线一区二区三区| 国产乱人伦精品一区二区在线观看| 欧美福利视频一区| 丝袜脚交一区二区| 欧美日韩国产综合一区二区三区| 樱花草国产18久久久久| 91视频你懂的| 亚洲日本青草视频在线怡红院| 成人免费毛片app| 亚洲婷婷在线视频| 色婷婷久久综合| 一个色在线综合| 欧美视频在线观看一区二区|