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

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

?? phy_device.c

?? linux-2.6.15.6
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * drivers/net/phy/phy_device.c * * Framework for finding and configuring PHYs. * Also contains generic PHY driver * * Author: Andy Fleming * * Copyright (c) 2004 Freescale Semiconductor, Inc. * * 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. * */#include <linux/config.h>#include <linux/kernel.h>#include <linux/sched.h>#include <linux/string.h>#include <linux/errno.h>#include <linux/unistd.h>#include <linux/slab.h>#include <linux/interrupt.h>#include <linux/init.h>#include <linux/delay.h>#include <linux/netdevice.h>#include <linux/etherdevice.h>#include <linux/skbuff.h>#include <linux/spinlock.h>#include <linux/mm.h>#include <linux/module.h>#include <linux/mii.h>#include <linux/ethtool.h>#include <linux/phy.h>#include <asm/io.h>#include <asm/irq.h>#include <asm/uaccess.h>MODULE_DESCRIPTION("PHY library");MODULE_AUTHOR("Andy Fleming");MODULE_LICENSE("GPL");static struct phy_driver genphy_driver;extern int mdio_bus_init(void);extern void mdio_bus_exit(void);/* get_phy_device * * description: Reads the ID registers of the PHY at addr on the *   bus, then allocates and returns the phy_device to *   represent it. */struct phy_device * get_phy_device(struct mii_bus *bus, int addr){	int phy_reg;	u32 phy_id;	struct phy_device *dev = NULL;	/* Grab the bits from PHYIR1, and put them	 * in the upper half */	phy_reg = bus->read(bus, addr, MII_PHYSID1);	if (phy_reg < 0)		return ERR_PTR(phy_reg);	phy_id = (phy_reg & 0xffff) << 16;	/* Grab the bits from PHYIR2, and put them in the lower half */	phy_reg = bus->read(bus, addr, MII_PHYSID2);	if (phy_reg < 0)		return ERR_PTR(phy_reg);	phy_id |= (phy_reg & 0xffff);	/* If the phy_id is all Fs, there is no device there */	if (0xffffffff == phy_id)		return NULL;	/* Otherwise, we allocate the device, and initialize the	 * default values */	dev = kcalloc(1, sizeof(*dev), GFP_KERNEL);	if (NULL == dev)		return ERR_PTR(-ENOMEM);	dev->speed = 0;	dev->duplex = -1;	dev->pause = dev->asym_pause = 0;	dev->link = 1;	dev->autoneg = AUTONEG_ENABLE;	dev->addr = addr;	dev->phy_id = phy_id;	dev->bus = bus;	dev->state = PHY_DOWN;	spin_lock_init(&dev->lock);	return dev;}/* phy_prepare_link: * * description: Tells the PHY infrastructure to handle the *   gory details on monitoring link status (whether through *   polling or an interrupt), and to call back to the *   connected device driver when the link status changes. *   If you want to monitor your own link state, don't call *   this function */void phy_prepare_link(struct phy_device *phydev,		void (*handler)(struct net_device *)){	phydev->adjust_link = handler;}/* phy_connect: * * description: Convenience function for connecting ethernet *   devices to PHY devices.  The default behavior is for *   the PHY infrastructure to handle everything, and only notify *   the connected driver when the link status changes.  If you *   don't want, or can't use the provided functionality, you may *   choose to call only the subset of functions which provide *   the desired functionality. */struct phy_device * phy_connect(struct net_device *dev, const char *phy_id,		void (*handler)(struct net_device *), u32 flags){	struct phy_device *phydev;	phydev = phy_attach(dev, phy_id, flags);	if (IS_ERR(phydev))		return phydev;	phy_prepare_link(phydev, handler);	phy_start_machine(phydev, NULL);	if (phydev->irq > 0)		phy_start_interrupts(phydev);	return phydev;}EXPORT_SYMBOL(phy_connect);void phy_disconnect(struct phy_device *phydev){	if (phydev->irq > 0)		phy_stop_interrupts(phydev);	phy_stop_machine(phydev);		phydev->adjust_link = NULL;	phy_detach(phydev);}EXPORT_SYMBOL(phy_disconnect);/* phy_attach: * *   description: Called by drivers to attach to a particular PHY *     device. The phy_device is found, and properly hooked up *     to the phy_driver.  If no driver is attached, then the *     genphy_driver is used.  The phy_device is given a ptr to *     the attaching device, and given a callback for link status *     change.  The phy_device is returned to the attaching *     driver. */static int phy_compare_id(struct device *dev, void *data){	return strcmp((char *)data, dev->bus_id) ? 0 : 1;}struct phy_device *phy_attach(struct net_device *dev,		const char *phy_id, u32 flags){	struct bus_type *bus = &mdio_bus_type;	struct phy_device *phydev;	struct device *d;	/* Search the list of PHY devices on the mdio bus for the	 * PHY with the requested name */	d = bus_find_device(bus, NULL, (void *)phy_id, phy_compare_id);	if (d) {		phydev = to_phy_device(d);	} else {		printk(KERN_ERR "%s not found\n", phy_id);		return ERR_PTR(-ENODEV);	}	/* Assume that if there is no driver, that it doesn't	 * exist, and we should use the genphy driver. */	if (NULL == d->driver) {		int err;		down_write(&d->bus->subsys.rwsem);		d->driver = &genphy_driver.driver;		err = d->driver->probe(d);		if (err < 0)			return ERR_PTR(err);		device_bind_driver(d);		up_write(&d->bus->subsys.rwsem);	}	if (phydev->attached_dev) {		printk(KERN_ERR "%s: %s already attached\n",				dev->name, phy_id);		return ERR_PTR(-EBUSY);	}	phydev->attached_dev = dev;	phydev->dev_flags = flags;	return phydev;}EXPORT_SYMBOL(phy_attach);void phy_detach(struct phy_device *phydev){	phydev->attached_dev = NULL;	/* If the device had no specific driver before (i.e. - it	 * was using the generic driver), we unbind the device	 * from the generic driver so that there's a chance a	 * real driver could be loaded */	if (phydev->dev.driver == &genphy_driver.driver) {		down_write(&phydev->dev.bus->subsys.rwsem);		device_release_driver(&phydev->dev);		up_write(&phydev->dev.bus->subsys.rwsem);	}}EXPORT_SYMBOL(phy_detach);/* Generic PHY support and helper functions *//* genphy_config_advert * * description: Writes MII_ADVERTISE with the appropriate values, *   after sanitizing the values to make sure we only advertise *   what is supported */int genphy_config_advert(struct phy_device *phydev){	u32 advertise;	int adv;	int err;	/* Only allow advertising what	 * this PHY supports */	phydev->advertising &= phydev->supported;	advertise = phydev->advertising;	/* Setup standard advertisement */	adv = phy_read(phydev, MII_ADVERTISE);	if (adv < 0)		return adv;	adv &= ~(ADVERTISE_ALL | ADVERTISE_100BASE4 | ADVERTISE_PAUSE_CAP | 		 ADVERTISE_PAUSE_ASYM);	if (advertise & ADVERTISED_10baseT_Half)		adv |= ADVERTISE_10HALF;	if (advertise & ADVERTISED_10baseT_Full)		adv |= ADVERTISE_10FULL;	if (advertise & ADVERTISED_100baseT_Half)		adv |= ADVERTISE_100HALF;	if (advertise & ADVERTISED_100baseT_Full)		adv |= ADVERTISE_100FULL;	if (advertise & ADVERTISED_Pause)		adv |= ADVERTISE_PAUSE_CAP;	if (advertise & ADVERTISED_Asym_Pause)		adv |= ADVERTISE_PAUSE_ASYM;	err = phy_write(phydev, MII_ADVERTISE, adv);	if (err < 0)		return err;	/* Configure gigabit if it's supported */	if (phydev->supported & (SUPPORTED_1000baseT_Half |				SUPPORTED_1000baseT_Full)) {		adv = phy_read(phydev, MII_CTRL1000);		if (adv < 0)			return adv;		adv &= ~(ADVERTISE_1000FULL | ADVERTISE_1000HALF);		if (advertise & SUPPORTED_1000baseT_Half)			adv |= ADVERTISE_1000HALF;		if (advertise & SUPPORTED_1000baseT_Full)			adv |= ADVERTISE_1000FULL;		err = phy_write(phydev, MII_CTRL1000, adv);		if (err < 0)			return err;	}	return adv;}EXPORT_SYMBOL(genphy_config_advert);/* genphy_setup_forced * * description: Configures MII_BMCR to force speed/duplex *   to the values in phydev. Assumes that the values are valid. *   Please see phy_sanitize_settings() */int genphy_setup_forced(struct phy_device *phydev){	int ctl = BMCR_RESET;	phydev->pause = phydev->asym_pause = 0;	if (SPEED_1000 == phydev->speed)		ctl |= BMCR_SPEED1000;	else if (SPEED_100 == phydev->speed)		ctl |= BMCR_SPEED100;	if (DUPLEX_FULL == phydev->duplex)		ctl |= BMCR_FULLDPLX;		ctl = phy_write(phydev, MII_BMCR, ctl);	if (ctl < 0)		return ctl;	/* We just reset the device, so we'd better configure any	 * settings the PHY requires to operate */	if (phydev->drv->config_init)		ctl = phydev->drv->config_init(phydev);	return ctl;}/* Enable and Restart Autonegotiation */int genphy_restart_aneg(struct phy_device *phydev){	int ctl;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品婷婷午夜在线观看| 欧美日韩高清一区二区不卡| 国产亚洲精品精华液| 韩日av一区二区| 久久综合av免费| voyeur盗摄精品| 亚洲柠檬福利资源导航| 日本韩国精品在线| 首页亚洲欧美制服丝腿| 91精品国产黑色紧身裤美女| 粉嫩久久99精品久久久久久夜 | 欧美亚洲高清一区| 亚洲h在线观看| 日韩欧美色综合网站| 国产成人综合自拍| 国产精品久久久久一区二区三区 | 久久久久久99久久久精品网站| 国产一区二区在线观看免费| 国产精品无遮挡| 精品视频一区三区九区| 久久精品99国产精品日本| 久久久99免费| 欧美性大战xxxxx久久久| 黄色日韩三级电影| 18成人在线观看| 91精品国产综合久久精品图片| 国产毛片精品视频| 亚洲一区二区三区四区在线免费观看| 欧美一区二区三区视频在线观看| 国产剧情在线观看一区二区| 亚洲精品成人悠悠色影视| 日韩精品在线一区二区| 成人avav影音| 蜜臀av一区二区| 亚洲激情男女视频| 精品国产污网站| 91福利精品视频| 国产一区二区在线视频| 亚洲国产精品一区二区久久恐怖片| 久久这里只有精品视频网| 色婷婷综合久久久久中文 | 亚洲a一区二区| 国产精品女主播在线观看| 91精品国产手机| 91国产丝袜在线播放| 国产精品1024| 裸体健美xxxx欧美裸体表演| 亚洲精选免费视频| 欧美极品aⅴ影院| 欧美变态tickle挠乳网站| 欧美制服丝袜第一页| 高清beeg欧美| 国产精品一区二区在线观看网站| 婷婷激情综合网| 亚洲人成网站影音先锋播放| 国产日产精品1区| 日韩久久免费av| 91精品国产乱码| 欧美日韩国产综合久久 | 亚洲成人免费在线观看| 欧美高清在线视频| 久久综合给合久久狠狠狠97色69| 欧美精品久久一区二区三区| 91豆麻精品91久久久久久| 懂色av一区二区三区免费观看| 麻豆91精品91久久久的内涵| 日本午夜精品视频在线观看| 日韩在线一区二区三区| 亚洲成在线观看| 亚洲综合图片区| 一区二区三区视频在线看| 中文字幕亚洲不卡| 中文字幕中文字幕一区| 国产精品久久毛片av大全日韩| 专区另类欧美日韩| 国产精品久久久久久一区二区三区| 国产女同互慰高潮91漫画| 久久久国产一区二区三区四区小说 | 欧美电影一区二区三区| 在线视频国内自拍亚洲视频| 色婷婷久久99综合精品jk白丝| 色综合 综合色| 在线观看日韩毛片| 欧美久久久一区| 欧美一区二区三区成人| 3atv在线一区二区三区| 51精品国自产在线| 日韩一区二区精品在线观看| 精品理论电影在线| 久久久久九九视频| 国产精品传媒入口麻豆| 亚洲欧美一区二区三区国产精品| 亚洲另类春色校园小说| 婷婷国产在线综合| 久久66热re国产| 成人国产一区二区三区精品| 91美女蜜桃在线| 欧美伦理影视网| 欧美videossexotv100| 中文字幕国产一区| 亚洲视频免费在线观看| 亚洲高清久久久| 日本不卡视频在线观看| 国产成人啪免费观看软件| 色狠狠综合天天综合综合| 91麻豆精品国产| 国产亲近乱来精品视频| 亚洲一二三级电影| 狠狠久久亚洲欧美| 日本国产一区二区| 欧美精品一区二区三区蜜臀| 亚洲特级片在线| 青青草原综合久久大伊人精品优势 | 欧美日韩国产免费| 久久久精品中文字幕麻豆发布| 综合激情网...| 麻豆一区二区三| 成人av动漫网站| 日韩免费在线观看| 亚洲男同性恋视频| 经典三级一区二区| 欧美影片第一页| 国产欧美一区二区精品仙草咪 | 日韩中文字幕区一区有砖一区| 国产精品一区二区在线看| 欧美午夜在线观看| 欧美国产精品劲爆| 婷婷国产在线综合| av在线播放成人| 精品久久国产老人久久综合| 夜夜嗨av一区二区三区| 国产精品综合一区二区| 欧美巨大另类极品videosbest| 国产欧美日韩精品在线| 免费成人美女在线观看| 91黄视频在线| 国产精品色哟哟| 精品一区二区三区视频在线观看| 色老头久久综合| 国产欧美一区二区三区网站| 青青青爽久久午夜综合久久午夜| 色婷婷综合久久久中文字幕| 中文字幕va一区二区三区| 久久福利视频一区二区| 欧美军同video69gay| 一区二区三区中文在线观看| 成人理论电影网| 久久免费美女视频| 久久超碰97人人做人人爱| 欧美精品亚洲一区二区在线播放| 综合欧美一区二区三区| 成人av中文字幕| 国产亚洲一二三区| 国内外成人在线| 欧美刺激午夜性久久久久久久| 亚洲第一二三四区| 欧美色图片你懂的| 一区二区三区欧美| 色88888久久久久久影院按摩| 中文字幕精品一区二区精品绿巨人 | 色噜噜狠狠成人网p站| 国产精品毛片久久久久久久| 国产成人免费视频| 国产亚洲一二三区| 国产精品99久久久久久有的能看| 久久先锋影音av鲁色资源网| 久久66热偷产精品| 久久蜜桃一区二区| 国产91富婆露脸刺激对白| 国产亚洲欧美在线| 国产不卡在线播放| 国产精品五月天| 99久久精品情趣| 亚洲欧美激情插 | 日韩一区二区三区精品视频| 日韩精品欧美成人高清一区二区| 欧美丰满少妇xxxxx高潮对白| 五月婷婷综合激情| 91精品国产乱码| 国产一区不卡视频| 国产精品女人毛片| 色婷婷久久久综合中文字幕| 亚洲不卡一区二区三区| 在线播放一区二区三区| 麻豆中文一区二区| 国产片一区二区三区| 91丨九色丨蝌蚪丨老版| 亚洲国产精品久久久久秋霞影院| 555www色欧美视频| 国产乱妇无码大片在线观看| 国产精品不卡一区二区三区| 欧美亚一区二区| 麻豆久久一区二区| 国产精品久久久久影院| 欧美日韩精品一二三区| 激情综合网av| 亚洲丝袜另类动漫二区| 欧美日本在线播放| 国产在线精品一区二区| 亚洲精品中文字幕在线观看|