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

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

?? io-unit.c

?? 嵌入式系統(tǒng)設(shè)計(jì)與實(shí)例開(kāi)發(fā)源碼
?? C
字號(hào):
/* $Id: io-unit.c,v 1.23 2001/02/13 01:16:43 davem Exp $ * io-unit.c:  IO-UNIT specific routines for memory management. * * Copyright (C) 1997,1998 Jakub Jelinek    (jj@sunsite.mff.cuni.cz) */ #include <linux/config.h>#include <linux/kernel.h>#include <linux/init.h>#include <linux/slab.h>#include <linux/spinlock.h>#include <asm/scatterlist.h>#include <asm/pgalloc.h>#include <asm/pgtable.h>#include <asm/sbus.h>#include <asm/io.h>#include <asm/io-unit.h>#include <asm/mxcc.h>#include <asm/bitops.h>/* #define IOUNIT_DEBUG */#ifdef IOUNIT_DEBUG#define IOD(x) printk(x)#else#define IOD(x) do { } while (0)#endif#define IOPERM        (IOUPTE_CACHE | IOUPTE_WRITE | IOUPTE_VALID)#define MKIOPTE(phys) __iopte((((phys)>>4) & IOUPTE_PAGE) | IOPERM)void __initiounit_init(int sbi_node, int io_node, struct sbus_bus *sbus){	iopte_t *xpt, *xptend;	struct iounit_struct *iounit;	struct linux_prom_registers iommu_promregs[PROMREG_MAX];	struct resource r;	iounit = kmalloc(sizeof(struct iounit_struct), GFP_ATOMIC);	memset(iounit, 0, sizeof(*iounit));	iounit->limit[0] = IOUNIT_BMAP1_START;	iounit->limit[1] = IOUNIT_BMAP2_START;	iounit->limit[2] = IOUNIT_BMAPM_START;	iounit->limit[3] = IOUNIT_BMAPM_END;	iounit->rotor[1] = IOUNIT_BMAP2_START;	iounit->rotor[2] = IOUNIT_BMAPM_START;	prom_getproperty(sbi_node, "reg", (void *) iommu_promregs,			 sizeof(iommu_promregs));	prom_apply_generic_ranges(io_node, 0, iommu_promregs, 3);	memset(&r, 0, sizeof(r));	r.flags = iommu_promregs[2].which_io;	r.start = iommu_promregs[2].phys_addr;	xpt = (iopte_t *) sbus_ioremap(&r, 0, PAGE_SIZE * 16, "XPT");	if(!xpt) panic("Cannot map External Page Table.");		sbus->iommu = (struct iommu_struct *)iounit;	iounit->page_table = xpt;		for (xptend = iounit->page_table + (16 * PAGE_SIZE) / sizeof(iopte_t);	     xpt < xptend;)	     	*xpt++ = 0;}/* One has to hold iounit->lock to call this */static unsigned long iounit_get_area(struct iounit_struct *iounit, unsigned long vaddr, int size){	int i, j, k, npages;	unsigned long rotor, scan, limit;	iopte_t iopte;        npages = ((vaddr & ~PAGE_MASK) + size + (PAGE_SIZE-1)) >> PAGE_SHIFT;	/* A tiny bit of magic ingredience :) */	switch (npages) {	case 1: i = 0x0231; break;	case 2: i = 0x0132; break;	default: i = 0x0213; break;	}		IOD(("iounit_get_area(%08lx,%d[%d])=", vaddr, size, npages));	next:	j = (i & 15);	rotor = iounit->rotor[j - 1];	limit = iounit->limit[j];	scan = rotor;nexti:	scan = find_next_zero_bit(iounit->bmap, limit, scan);	if (scan + npages > limit) {		if (limit != rotor) {			limit = rotor;			scan = iounit->limit[j - 1];			goto nexti;		}		i >>= 4;		if (!(i & 15))			panic("iounit_get_area: Couldn't find free iopte slots for (%08lx,%d)\n", vaddr, size);		goto next;	}	for (k = 1, scan++; k < npages; k++)		if (test_bit(scan++, iounit->bmap))			goto nexti;	iounit->rotor[j - 1] = (scan < limit) ? scan : iounit->limit[j - 1];	scan -= npages;	iopte = MKIOPTE(__pa(vaddr & PAGE_MASK));	vaddr = IOUNIT_DMA_BASE + (scan << PAGE_SHIFT) + (vaddr & ~PAGE_MASK);	for (k = 0; k < npages; k++, iopte = __iopte(iopte_val(iopte) + 0x100), scan++) {		set_bit(scan, iounit->bmap);		iounit->page_table[scan] = iopte;	}	IOD(("%08lx\n", vaddr));	return vaddr;}static __u32 iounit_get_scsi_one(char *vaddr, unsigned long len, struct sbus_bus *sbus){	unsigned long ret, flags;	struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu;		spin_lock_irqsave(&iounit->lock, flags);	ret = iounit_get_area(iounit, (unsigned long)vaddr, len);	spin_unlock_irqrestore(&iounit->lock, flags);	return ret;}static void iounit_get_scsi_sgl(struct scatterlist *sg, int sz, struct sbus_bus *sbus){	unsigned long flags;	struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu;	/* FIXME: Cache some resolved pages - often several sg entries are to the same page */	spin_lock_irqsave(&iounit->lock, flags);	for (; sz >= 0; sz--) {		sg[sz].dvma_address = iounit_get_area(iounit, (unsigned long)sg[sz].address, sg[sz].length);		sg[sz].dvma_length = sg[sz].length;	}	spin_unlock_irqrestore(&iounit->lock, flags);}static void iounit_release_scsi_one(__u32 vaddr, unsigned long len, struct sbus_bus *sbus){	unsigned long flags;	struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu;		spin_lock_irqsave(&iounit->lock, flags);	len = ((vaddr & ~PAGE_MASK) + len + (PAGE_SIZE-1)) >> PAGE_SHIFT;	vaddr = (vaddr - IOUNIT_DMA_BASE) >> PAGE_SHIFT;	IOD(("iounit_release %08lx-%08lx\n", (long)vaddr, (long)len+vaddr));	for (len += vaddr; vaddr < len; vaddr++)		clear_bit(vaddr, iounit->bmap);	spin_unlock_irqrestore(&iounit->lock, flags);}static void iounit_release_scsi_sgl(struct scatterlist *sg, int sz, struct sbus_bus *sbus){	unsigned long flags;	unsigned long vaddr, len;	struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu;	spin_lock_irqsave(&iounit->lock, flags);	for (; sz >= 0; sz--) {		len = ((sg[sz].dvma_address & ~PAGE_MASK) + sg[sz].length + (PAGE_SIZE-1)) >> PAGE_SHIFT;		vaddr = (sg[sz].dvma_address - IOUNIT_DMA_BASE) >> PAGE_SHIFT;		IOD(("iounit_release %08lx-%08lx\n", (long)vaddr, (long)len+vaddr));		for (len += vaddr; vaddr < len; vaddr++)			clear_bit(vaddr, iounit->bmap);	}	spin_unlock_irqrestore(&iounit->lock, flags);}#ifdef CONFIG_SBUSstatic void iounit_map_dma_area(unsigned long va, __u32 addr, int len){	unsigned long page, end;	pgprot_t dvma_prot;	iopte_t *iopte;	struct sbus_bus *sbus;	dvma_prot = __pgprot(SRMMU_CACHE | SRMMU_ET_PTE | SRMMU_PRIV);	end = PAGE_ALIGN((addr + len));	while(addr < end) {		page = va;		{			pgd_t *pgdp;			pmd_t *pmdp;			pte_t *ptep;			long i;			pgdp = pgd_offset(init_task.mm, addr);			pmdp = pmd_offset(pgdp, addr);			ptep = pte_offset(pmdp, addr);			set_pte(ptep, pte_val(mk_pte(virt_to_page(page), dvma_prot)));						i = ((addr - IOUNIT_DMA_BASE) >> PAGE_SHIFT);			for_each_sbus(sbus) {				struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu;				iopte = (iopte_t *)(iounit->page_table + i);				*iopte = __iopte(MKIOPTE(__pa(page)));			}		}		addr += PAGE_SIZE;		va += PAGE_SIZE;	}	flush_cache_all();	flush_tlb_all();}static void iounit_unmap_dma_area(unsigned long addr, int len){	/* XXX Somebody please fill this in */}/* XXX We do not pass sbus device here, bad. */static unsigned long iounit_translate_dvma(unsigned long addr){	struct sbus_bus *sbus = sbus_root;	/* They are all the same */	struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu;	int i;	iopte_t *iopte;	i = ((addr - IOUNIT_DMA_BASE) >> PAGE_SHIFT);	iopte = (iopte_t *)(iounit->page_table + i);	return (iopte_val(*iopte) & 0xFFFFFFF0) << 4; /* XXX sun4d guru, help */}#endifstatic char *iounit_lockarea(char *vaddr, unsigned long len){/* FIXME: Write this */	return vaddr;}static void iounit_unlockarea(char *vaddr, unsigned long len){/* FIXME: Write this */}void __init ld_mmu_iounit(void){	BTFIXUPSET_CALL(mmu_lockarea, iounit_lockarea, BTFIXUPCALL_RETO0);	BTFIXUPSET_CALL(mmu_unlockarea, iounit_unlockarea, BTFIXUPCALL_NOP);	BTFIXUPSET_CALL(mmu_get_scsi_one, iounit_get_scsi_one, BTFIXUPCALL_NORM);	BTFIXUPSET_CALL(mmu_get_scsi_sgl, iounit_get_scsi_sgl, BTFIXUPCALL_NORM);	BTFIXUPSET_CALL(mmu_release_scsi_one, iounit_release_scsi_one, BTFIXUPCALL_NORM);	BTFIXUPSET_CALL(mmu_release_scsi_sgl, iounit_release_scsi_sgl, BTFIXUPCALL_NORM);#ifdef CONFIG_SBUS	BTFIXUPSET_CALL(mmu_map_dma_area, iounit_map_dma_area, BTFIXUPCALL_NORM);	BTFIXUPSET_CALL(mmu_unmap_dma_area, iounit_unmap_dma_area, BTFIXUPCALL_NORM);	BTFIXUPSET_CALL(mmu_translate_dvma, iounit_translate_dvma, BTFIXUPCALL_NORM);#endif}__u32 iounit_map_dma_init(struct sbus_bus *sbus, int size){	int i, j, k, npages;	unsigned long rotor, scan, limit;	unsigned long flags;	__u32 ret;	struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu;        npages = (size + (PAGE_SIZE-1)) >> PAGE_SHIFT;	i = 0x0213;	spin_lock_irqsave(&iounit->lock, flags);next:	j = (i & 15);	rotor = iounit->rotor[j - 1];	limit = iounit->limit[j];	scan = rotor;nexti:	scan = find_next_zero_bit(iounit->bmap, limit, scan);	if (scan + npages > limit) {		if (limit != rotor) {			limit = rotor;			scan = iounit->limit[j - 1];			goto nexti;		}		i >>= 4;		if (!(i & 15))			panic("iounit_map_dma_init: Couldn't find free iopte slots for %d bytes\n", size);		goto next;	}	for (k = 1, scan++; k < npages; k++)		if (test_bit(scan++, iounit->bmap))			goto nexti;	iounit->rotor[j - 1] = (scan < limit) ? scan : iounit->limit[j - 1];	scan -= npages;	ret = IOUNIT_DMA_BASE + (scan << PAGE_SHIFT);	for (k = 0; k < npages; k++, scan++)		set_bit(scan, iounit->bmap);	spin_unlock_irqrestore(&iounit->lock, flags);	return ret;}__u32 iounit_map_dma_page(__u32 vaddr, void *addr, struct sbus_bus *sbus){	int scan = (vaddr - IOUNIT_DMA_BASE) >> PAGE_SHIFT;	struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu;		iounit->page_table[scan] = MKIOPTE(__pa(((unsigned long)addr) & PAGE_MASK));	return vaddr + (((unsigned long)addr) & ~PAGE_MASK);}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99re在线视频这里只有精品| 色婷婷av一区二区三区大白胸| 午夜精品久久久久久| 亚洲精品国产一区二区三区四区在线 | 日本美女视频一区二区| 亚洲图片一区二区| 日韩精品91亚洲二区在线观看| 亚洲无线码一区二区三区| 亚洲h精品动漫在线观看| 亚洲成人免费观看| 日韩激情一二三区| 久久se精品一区精品二区| 麻豆91免费观看| 国内精品自线一区二区三区视频| 狠狠色综合色综合网络| 粉嫩av一区二区三区| 99精品国产99久久久久久白柏| 91黄视频在线| 9191成人精品久久| 久久精品视频网| 亚洲视频一区二区在线| 天天做天天摸天天爽国产一区| 秋霞午夜鲁丝一区二区老狼| 国内成+人亚洲+欧美+综合在线| 国产69精品久久久久毛片| 97se亚洲国产综合自在线| 欧美亚洲精品一区| 欧美大片国产精品| 国产精品美女久久久久久久| 一区二区三区影院| 男人的天堂久久精品| 国产成人综合网站| 91精品91久久久中77777| 欧美一卡二卡在线观看| 久久精品欧美日韩| 亚洲在线观看免费| 精品一区二区三区久久久| 成人性生交大片免费看在线播放 | 久久久综合视频| 亚洲另类春色国产| 免费高清视频精品| 成人精品一区二区三区四区| 欧美在线观看你懂的| 欧美成人性战久久| 亚洲视频一二三区| 精品一区二区三区香蕉蜜桃| 97国产一区二区| 欧美videos中文字幕| 亚洲激情在线激情| 国产麻豆精品在线| 精品视频一区 二区 三区| 久久亚洲捆绑美女| 亚洲成av人片一区二区梦乃| 国产成人在线电影| 91麻豆精品国产| 日韩一区在线免费观看| 久久99国产精品久久99| 一本色道a无线码一区v| 亚洲精品在线免费播放| 亚洲一区二三区| 成人丝袜18视频在线观看| 日韩欧美在线观看一区二区三区| 最新日韩av在线| 国产精品亚洲专一区二区三区| 欧美图片一区二区三区| 中文在线免费一区三区高中清不卡| 天天操天天综合网| 色综合天天综合网天天看片| 久久精品在这里| 日本欧美大码aⅴ在线播放| 91国产福利在线| 中文字幕av在线一区二区三区| 加勒比av一区二区| 欧美精品免费视频| 一区二区三区中文免费| 成人精品视频一区二区三区尤物| 欧美一级精品大片| 亚洲大片免费看| 91亚洲国产成人精品一区二三| 久久久精品tv| 久久精品免费看| 91精品国产入口| 亚洲午夜激情网站| 色八戒一区二区三区| 最新高清无码专区| 不卡一区在线观看| 国产精品免费视频网站| 国产黄色精品网站| 久久影院午夜论| 久久精品99久久久| 日韩一卡二卡三卡| 日日夜夜精品视频免费| 欧美午夜理伦三级在线观看| 亚洲麻豆国产自偷在线| 99re这里只有精品6| ...中文天堂在线一区| av电影天堂一区二区在线 | 国产精品一区二区在线观看不卡| 日韩视频免费直播| 青娱乐精品视频在线| 欧美电影一区二区三区| 日韩电影在线观看电影| 欧美一级理论性理论a| 麻豆91精品91久久久的内涵| 日韩精品综合一本久道在线视频| 日韩精品乱码av一区二区| 337p亚洲精品色噜噜狠狠| 日日摸夜夜添夜夜添亚洲女人| 777午夜精品视频在线播放| 日韩激情视频网站| 精品福利一二区| 国产成人免费9x9x人网站视频| 久久综合狠狠综合久久综合88 | 成人妖精视频yjsp地址| ...av二区三区久久精品| 色菇凉天天综合网| 亚洲18影院在线观看| 91精品国产综合久久久久久漫画 | 亚洲精品日韩综合观看成人91| 一本大道久久a久久综合 | 99re免费视频精品全部| 亚洲精品视频在线观看网站| 欧美视频在线观看一区| 丝袜美腿亚洲综合| 精品剧情v国产在线观看在线| 国产麻豆成人传媒免费观看| 国产精品美女久久福利网站| 日本久久精品电影| 免播放器亚洲一区| 中文字幕精品在线不卡| 日本国产一区二区| 久久精品国产一区二区三区免费看 | 在线视频国产一区| 日本欧美大码aⅴ在线播放| 久久精品综合网| 欧美艳星brazzers| 久国产精品韩国三级视频| 国产精品视频麻豆| 欧美日韩一区国产| 国产乱码精品一区二区三区av| 亚洲欧洲另类国产综合| 91精品国产91热久久久做人人| 韩国av一区二区三区| 亚洲免费在线观看| 欧美精品一区二区久久久| 春色校园综合激情亚洲| 视频在线观看一区二区三区| 久久久夜色精品亚洲| 91热门视频在线观看| 另类的小说在线视频另类成人小视频在线| 久久精品亚洲精品国产欧美 | 久久免费电影网| 欧美丝袜自拍制服另类| 国产一区二区中文字幕| 一区二区三区国产精品| 精品99久久久久久| 欧美日产在线观看| 99久久婷婷国产| 狠狠狠色丁香婷婷综合激情| 一区二区在线观看免费视频播放| 精品剧情在线观看| 欧美午夜理伦三级在线观看| 国产99久久精品| 日韩电影免费在线看| 亚洲天堂免费在线观看视频| 精品国产乱码久久| 欧美理论片在线| 成人高清伦理免费影院在线观看| 日韩成人av影视| 亚洲女同女同女同女同女同69| xf在线a精品一区二区视频网站| 91久久精品一区二区三区| 成人网男人的天堂| 国产美女精品在线| 日本午夜一区二区| 亚洲午夜在线视频| 国产精品麻豆网站| 欧美大黄免费观看| 欧美精品色综合| 欧美午夜精品免费| 一本一道综合狠狠老| 粉嫩绯色av一区二区在线观看 | 日本高清免费不卡视频| 国产成a人亚洲精| 极品美女销魂一区二区三区 | 成人国产电影网| 国产精品亚洲一区二区三区妖精 | 欧美人与z0zoxxxx视频| 91丨porny丨首页| 成人a级免费电影| 国产成人午夜精品5599| 精品一区二区久久久| 三级久久三级久久久| 偷窥少妇高潮呻吟av久久免费 | 色婷婷久久99综合精品jk白丝| 成人av在线电影| 成人黄色777网| jlzzjlzz亚洲女人18| 成人综合在线观看| 国产99精品国产|