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

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

?? pciba.c

?? 根據添加了fs2410平臺的arch目錄
?? C
?? 第 1 頁 / 共 4 頁
字號:
    pciba_bus_unlock(bus);}static                  pciba_map_tpciba_map_pop_hdl(pciba_bus_t bus, __psunsigned_t handle){    pciba_map_h             hdl;    pciba_map_t             map;    pciba_bus_lock(bus);    for (hdl = &bus->maps; map = *hdl; hdl = &map->next)	if (map->handle == handle) {	    *hdl = map->next;	    break;	}    pciba_bus_unlock(bus);#if DEBUG_PCIBA    printk("pciba_map_pop_va(bus=0x%x, handle=0x%x) returns map=0x%x\n",	   bus, handle, map);#endif    return map;}/* ================================================================ *            driver teardown, unregister and unload */intpciba_unload(void){#if DEBUG_PCIBA    printk("pciba_unload()\n");#endif    if (atomic_read(&pciba_prevent_unload))	return -1;    pciio_iterate("pciba_", pciba_unload_me);    return 0;}intpciba_unreg(void){#if DEBUG_PCIBA    printf("pciba_unreg()\n");#endif    if (atomic_read(&pciba_prevent_unload))	return -1;    pciio_driver_unregister("pciba_");    return 0;}intpciba_detach(devfs_handle_t conn){    devfs_handle_t          base;    pciba_bus_t             bus;    devfs_handle_t          gconn;    devfs_handle_t          gbase;    pciio_info_t            pciio_info;    devfs_handle_t          master;    arbitrary_info_t        ainfo;    int			    ret;#if DEBUG_PCIBA    printf("pciba_detach(%v)\n", conn);#endif    if ((GRAPH_SUCCESS !=	 hwgraph_traverse(conn, ".guest", &gconn)) ||	(conn == gconn))	gconn = GRAPH_VERTEX_NONE;    if (gconn != GRAPH_VERTEX_NONE) {	pciba_sub_detach(gconn, PCIBA_EDGE_LBL_CFG);	pciba_sub_detach(gconn, PCIBA_EDGE_LBL_DMA);	pciba_sub_detach(gconn, PCIBA_EDGE_LBL_ROM);#if ULI	pciba_sub_detach(gconn, PCIBA_EDGE_LBL_INTR);#endif	if (GRAPH_SUCCESS == hwgraph_edge_remove(conn, PCIBA_EDGE_LBL_BASE, &gbase)) {	    pciba_sub_detach(gconn, PCIBA_EDGE_LBL_MEM);	    pciba_sub_detach(gconn, PCIBA_EDGE_LBL_IO);	    pciba_sub_detach(gbase, "0");	    pciba_sub_detach(gbase, "1");	    pciba_sub_detach(gbase, "2");	    pciba_sub_detach(gbase, "3");	    pciba_sub_detach(gbase, "4");	    pciba_sub_detach(gbase, "5");	    hwgraph_vertex_unref(gbase);	    if (GRAPH_SUCCESS != (ret = hwgraph_vertex_destroy(gbase))) {#if defined(SUPPORT_PRINTING_V_FORMAT)		PRINT_WARNING("pciba: hwgraph_vertex_destroy(%v/base) failed (%d)",			conn, ret);#else		PRINT_WARNING("pciba: hwgraph_vertex_destroy(0x%x/base) failed (%d)",			conn, ret);#endif#if DEBUG_REFCT		printk("\tretained refct %d\n", hwgraph_vertex_refct(gbase));#endif	    }	}    }    pciba_sub_detach(conn, PCIBA_EDGE_LBL_CFG);    pciba_sub_detach(conn, PCIBA_EDGE_LBL_DMA);    pciba_sub_detach(conn, PCIBA_EDGE_LBL_ROM);#if ULI    pciba_sub_detach(conn, PCIBA_EDGE_LBL_INTR);#endif    if (GRAPH_SUCCESS == hwgraph_edge_remove(conn, PCIBA_EDGE_LBL_BASE, &base)) {	pciba_sub_detach(conn, PCIBA_EDGE_LBL_MEM);	pciba_sub_detach(conn, PCIBA_EDGE_LBL_IO);	pciba_sub_detach(base, "0");	pciba_sub_detach(base, "1");	pciba_sub_detach(base, "2");	pciba_sub_detach(base, "3");	pciba_sub_detach(base, "4");	pciba_sub_detach(base, "5");	hwgraph_vertex_unref(base);	if (GRAPH_SUCCESS != (ret = hwgraph_vertex_destroy(base))) {#if defined(SUPPORT_PRINTING_V_FORMAT)	    PRINT_WARNING(CE_WARN, "pciba: hwgraph_vertex_destroy(%v/base) failed (%d)",		    conn, ret);#else	    PRINT_WARNING(CE_WARN, "pciba: hwgraph_vertex_destroy(0x%x/base) failed (%d)",		    conn, ret);#endif#if DEBUG_REFCT	    printk("\tretained refct %d\n", hwgraph_vertex_refct(base));#endif	}    }    bus = pciba_find_bus(conn, 0);    if (bus && !--(bus->refct)) {	pciio_info = pciio_info_get(conn);	master = pciio_info_master_get(pciio_info);	pciba_sub_detach(master, PCIBA_EDGE_LBL_IO);	pciba_sub_detach(master, PCIBA_EDGE_LBL_MEM);	pciba_sub_detach(master, PCIBA_EDGE_LBL_CFG);	hwgraph_info_remove_LBL(master, PCIBA_INFO_LBL_BUS, &ainfo);#if DEBUG_PCIBA	printf("pcbia_detach: DEL(bus) at %v\n", master);#endif	DEL(bus);    }     return 0;}static voidpciba_sub_detach1(devfs_handle_t conn,		  char *name,		  char *suf){    devfs_handle_t         vhdl;    pciba_soft_t            soft;    pciba_comm_t	    comm;    int			    ret;    char		nbuf[128];    if (suf && *suf) {	strcpy(nbuf, name);	name = nbuf;	strcat(name, suf);    }    if ((GRAPH_SUCCESS == hwgraph_edge_remove(conn, name, &vhdl)) &&	((soft = pciba_soft_get(vhdl)) != NULL)) {#if DEBUG_PCIBA#if defined(SUPPORT_PRINTING_V_FORMAT)	prink("pciba_sub_detach(%v,%s)\n", conn, name);#else	prink("pciba_sub_detach(0x%x,%s)\n", conn, name);#endif#endif	hwgraph_vertex_unref(soft->vhdl);#if DEBUG_REFCT	printk("\tadjusted refct %d (soft ref: %d)\n",		hwgraph_vertex_refct(vhdl),		soft->refct);#endif	if (!--(soft->refct)) {	    comm = soft->comm;	    if (!--(comm->refct)) {		DEL(comm);	    }	    pciba_soft_set(vhdl, 0);	    DEL(soft);	    hwgraph_vertex_unref(vhdl);	    if (GRAPH_SUCCESS != (ret = hwgraph_vertex_destroy(vhdl))) {#if defined(SUPPORT_PRINTING_V_FORMAT)		PRINT_WARNING("pciba: hwgraph_vertex_destroy(0x%x/%s) failed (%d)",			conn, name, ret);#else		PRINT_WARNING("pciba: hwgraph_vertex_destroy(%v/%s) failed (%d)",			conn, name, ret);#endif#if DEBUG_REFCT		printk("\tretained refct %d\n", hwgraph_vertex_refct(vhdl));#endif	    }	}    }}static voidpciba_sub_detach(devfs_handle_t conn,		 char *name){    pciba_sub_detach1(conn, name, "");    pciba_sub_detach1(conn, name, "_le");    pciba_sub_detach1(conn, name, "_be");}static voidpciba_unload_me(devfs_handle_t pconn_vhdl){    devfs_handle_t         c_vhdl;#if DEBUG_PCIBA    printf("pciba_unload_me(%v)\n", pconn_vhdl);#endif    if (GRAPH_SUCCESS !=	hwgraph_traverse(pconn_vhdl, PCIBA_EDGE_LBL_CFG, &c_vhdl))	return;    hwgraph_vertex_unref(c_vhdl);}/* ================================================================ *            standard unix entry points *//*ARGSUSED */intpciba_open(dev_t *devp, int flag, int otyp, struct cred *crp){#if DEBUG_PCIBA    printf("pciba_open(%V)\n", *devp);#endif    return 0;}/*ARGSUSED */intpciba_close(dev_t dev){    devfs_handle_t         vhdl = dev_to_vhdl(dev);    pciba_soft_t            soft = pciba_soft_get(vhdl);#if DEBUG_PCIBA    printf("pciba_close(%V)\n", dev);#endif    /* if there is pending DMA for this device, hit the     * device over the head with a baseball bat and     * release the system memory resources.     */    if (soft && soft->comm->dmap) {	pciba_dma_t             next;	pciba_dma_t             dmap;	pciba_soft_lock(soft);	if (dmap = soft->comm->dmap) {	    soft->comm->dmap = 0;	    pciio_reset(soft->comm->conn);	    do {		if (!dmap->kaddr)		    break;		if (!dmap->paddr)		    break;		if (dmap->bytes < NBPP)		    break;		next = dmap->next;		kvpfree(dmap->kaddr, dmap->bytes / NBPP);		dmap->paddr = 0;		dmap->bytes = 0;		DEL(dmap);	    } while (dmap = next);	}	pciba_soft_unlock(soft);    }    return 0;}/* ARGSUSED */intpciba_read(dev_t dev, cred_t *crp){#if DEBUG_PCIBA    printf("pciba_read(%V)\n", dev);#endif    return EINVAL;}/* ARGSUSED */intpciba_write(dev_t dev, cred_t *crp){#if DEBUG_PCIBA    printf("pciba_write(%V)\n", dev);#endif    return EINVAL;}/*ARGSUSED */intpciba_ioctl(dev_t dev, int cmd, void *uarg, int mode, cred_t *crp, int *rvalp){    devfs_handle_t          vhdl;    pciba_soft_t            soft;    pciio_space_t           space;    ioctl_arg_buffer_t      arg;    int                     psize;    int                     err = 0;#if ULI    char		    abi = get_current_abi();    pciio_intr_t            intr=0;    device_desc_t           desc;    cpuid_t                 intrcpu;    unsigned                lines;    struct uli             *uli = 0;#endif    unsigned                flags;    void                   *kaddr = 0;    iopaddr_t               paddr;    pciba_dma_h             dmah;    pciba_dma_t             dmap = 0;    pciio_dmamap_t          dmamap = 0;    size_t                  bytes;    int                     pages;    pciaddr_t               daddr;#if DEBUG_PCIBA    printf("pciba_ioctl(%V,0x%x)\n", dev, cmd);#endif    psize = (cmd >> 16) & IOCPARM_MASK;#if ULI    ASSERT(sizeof(struct uliargs) > 8);	/* prevent CFG access conflict */    ASSERT(sizeof(struct uliargs) <= IOCPARM_MASK);#endif    arg.ca = uarg;    if ((psize > 0) && (cmd & (IOC_OUT | IOC_IN))) {	if (psize > sizeof(arg))	    err = EINVAL;		/* "bad parameter size */	else {	    if (cmd & IOC_OUT)		bzero(arg.data, psize);	    if ((cmd & IOC_IN) &&		(copyin(uarg, arg.data, psize) < 0))		err = EFAULT;		/* "parameter copyin failed" */	}    }    vhdl = dev_to_vhdl(dev);    soft = pciba_soft_get(vhdl);    space = soft->space;    if (err == 0) {	err = EINVAL;			/* "invalid ioctl for this vertex" */	switch (space) {#if ULI	case PCIIO_SPACE_NONE:		/* the "intr" vertex */	    /* PCIIOCSETULI: set up user interrupts.	     */	    lines = cmd & 15;	    if (ABI_IS_64BIT(abi)) {		if (cmd != PCIIOCSETULI(lines)) {		    err = EINVAL;		/* "invalid ioctl for this vertex" */		    break;		}	    }	    else {		struct uliargs uliargs;		if (cmd != PCIIOCSETULI32(lines)) {		    err = EINVAL;		/* "invalid ioctl for this vertex" */		    break;		}				uliargs32_to_uliargs(&arg.uli32, &uliargs);		arg.uli = uliargs;	    }	    desc = device_desc_dup(soft->comm->conn);	    device_desc_flags_set(desc, (device_desc_flags_get(desc) |					 D_INTR_NOTHREAD));	    device_desc_intr_swlevel_set(desc, INTR_SWLEVEL_NOTHREAD_DEFAULT);	    device_desc_intr_name_set(desc, "PCIBA");	    device_desc_default_set(soft->comm->conn, desc);	    /* When designating interrupts, the slot number	     * is taken from the connection point.	     * Bits 0..3 are used to select INTA..INTD; more	     * than one bit can be specified. These should	     * be constructed using PCIIO_INTR_LINE_[ABCD].	     */	    intr = pciio_intr_alloc		(soft->comm->conn, desc, lines, soft->vhdl);	    if (intr == 0) {		err = ENOMEM;		/* "insufficient resources" */		break;	    }	    intrcpu = cpuvertex_to_cpuid(pciio_intr_cpu_get(intr));	    if (err = new_uli(&arg.uli, &uli, intrcpu)) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆精品在线看| 久久久久久99久久久精品网站| 国模一区二区三区白浆| 蜜臀久久久99精品久久久久久| 麻豆精品视频在线观看视频| 琪琪久久久久日韩精品| 久国产精品韩国三级视频| 日韩精品一区二区在线观看| 久久久精品一品道一区| 成人国产亚洲欧美成人综合网| 中文字幕中文在线不卡住| 91麻豆国产自产在线观看| 亚洲精品国产无天堂网2021| 欧美二区三区91| 激情欧美日韩一区二区| 一区二区中文字幕在线| 欧美精品精品一区| 国产一区二区在线视频| 亚洲摸摸操操av| 日韩欧美综合在线| 不卡视频一二三| 日韩精品亚洲一区二区三区免费| 精品久久久久一区二区国产| 91免费在线播放| 美女视频第一区二区三区免费观看网站| 久久精品夜色噜噜亚洲a∨| 一本色道久久综合亚洲精品按摩| 五月综合激情婷婷六月色窝| 国产欧美一区二区三区在线看蜜臀| 91社区在线播放| 久久99精品一区二区三区 | 夜夜夜精品看看| 日韩欧美www| 色八戒一区二区三区| 青青草97国产精品免费观看| 中文字幕日韩av资源站| 精品久久人人做人人爱| 欧美系列日韩一区| 成人精品鲁一区一区二区| 天天综合天天做天天综合| 国产精品久久久久aaaa| 精品精品国产高清a毛片牛牛| 日本精品一区二区三区高清| 国产精品一区二区在线观看网站| 亚洲一区视频在线观看视频| 国产日韩高清在线| 欧美一级生活片| 色噜噜夜夜夜综合网| 激情文学综合网| 亚州成人在线电影| 亚洲欧美另类小说| 国产欧美日韩久久| 日韩视频123| 欧美日免费三级在线| 色哟哟一区二区在线观看| 国产69精品久久99不卡| 久久精品国产99久久6| 日韩在线一二三区| 狠狠色狠狠色合久久伊人| 一区二区三区在线看| 国产精品久久久久久久久久免费看| 日韩欧美你懂的| 欧美日韩高清影院| 欧美色视频在线| 欧美在线播放高清精品| 色域天天综合网| 色婷婷av一区二区三区大白胸| 成人爱爱电影网址| 成人午夜视频免费看| 国产成人鲁色资源国产91色综| 国产在线乱码一区二区三区| 日韩av电影免费观看高清完整版 | 欧美一区二区三区性视频| 欧美日韩在线播放一区| 欧美在线|欧美| 欧美日韩久久不卡| 欧美日韩亚洲不卡| 欧美精品日韩综合在线| 欧美人伦禁忌dvd放荡欲情| 欧美日韩高清一区二区不卡| 欧美日韩免费一区二区三区| 欧美色倩网站大全免费| 9191国产精品| 欧美一区二区三区的| 91精品午夜视频| 日韩午夜电影av| 日韩欧美国产不卡| 久久免费美女视频| 国产精品每日更新| 亚洲一区在线观看网站| 天天av天天翘天天综合网 | 日本韩国欧美在线| 欧美日韩中文精品| 91精品国产全国免费观看| 日韩一区二区三区视频| 国产欧美一区在线| 亚洲人被黑人高潮完整版| 亚洲国产婷婷综合在线精品| 日本va欧美va瓶| 韩国av一区二区三区在线观看| 国产一区二区精品久久| 99国产精品99久久久久久| 欧美亚洲精品一区| 日韩写真欧美这视频| 亚洲国产成人自拍| 亚洲一区在线看| 国产一区二区久久| 色婷婷久久久亚洲一区二区三区| 欧美一区二区三区在线观看视频| 久久精品综合网| 亚洲综合男人的天堂| 男男gaygay亚洲| 99v久久综合狠狠综合久久| 91精品国产日韩91久久久久久| 久久精品综合网| 亚洲成av人在线观看| 国产成人免费视频网站高清观看视频 | 亚洲一线二线三线久久久| 久久精品国产99国产| 在线亚洲一区观看| xfplay精品久久| 亚洲福利视频一区二区| 国产99久久久国产精品潘金| 欧美三级午夜理伦三级中视频| 久久精品免视看| 日韩成人一区二区三区在线观看| 成人午夜激情视频| 日韩一二在线观看| 一区二区三区在线免费观看| 国产精品主播直播| 777欧美精品| 亚洲一区二区三区视频在线播放| 国产在线乱码一区二区三区| 欧美高清www午色夜在线视频| 亚洲欧洲日韩女同| 国产一区啦啦啦在线观看| 欧美色电影在线| 综合久久久久久久| 国产一区美女在线| 91精品国产手机| 亚洲一区中文在线| 91视频一区二区| 国产日本欧美一区二区| 激情五月播播久久久精品| 在线成人午夜影院| 亚洲午夜三级在线| 91亚洲国产成人精品一区二区三 | 亚洲一二三区不卡| 91麻豆高清视频| 国产精品成人在线观看| 久久精品国产在热久久| 欧美二区在线观看| 午夜精品福利久久久| 99精品在线观看视频| 久久精品亚洲精品国产欧美kt∨| 免费人成精品欧美精品| 欧美久久高跟鞋激| 亚洲一区二区三区四区五区中文| 99久久久久免费精品国产| 国产精品超碰97尤物18| 成人av午夜影院| 中文字幕日韩精品一区| 不卡的av在线| 亚洲狼人国产精品| 91久久精品网| 五月婷婷色综合| 91麻豆精品国产自产在线观看一区| 亚洲不卡av一区二区三区| 欧美日韩一级片网站| 亚洲mv大片欧洲mv大片精品| 欧美日韩久久一区| 肉色丝袜一区二区| 日韩三级免费观看| 精品一区二区三区蜜桃| 久久先锋影音av鲁色资源网| 国产美女精品一区二区三区| 亚洲国产成人一区二区三区| 成人av片在线观看| 亚洲日本青草视频在线怡红院 | 亚洲精品视频在线观看免费| 色哟哟一区二区在线观看| 亚洲一区二区三区爽爽爽爽爽| 欧美日本一区二区| 国产在线精品一区二区不卡了| 国产色婷婷亚洲99精品小说| 91麻豆免费看| 日韩精品91亚洲二区在线观看| 久久亚洲春色中文字幕久久久| 成人av在线资源网| 香蕉久久夜色精品国产使用方法 | 欧美精品一区二区不卡| 国产一区二区网址| 亚洲女爱视频在线| 91麻豆精品国产自产在线| 国产一区二区三区免费看 | 成人高清av在线| 亚洲一区二区三区四区五区中文| 日韩精品一区二区三区老鸭窝| 国产69精品久久久久777| 一区二区三区av电影|