久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

Linux 下訪問PHY芯片寄存器

 XeonGate 2020-01-17
https://blog.csdn.net/han_dawei/article/details/9427033
Linux smi/mdio總線通信
韓大衛(wèi)@吉林師范大學(xué)
下面代碼描述了在用戶層訪問smimdio總線, 讀寫phy芯片寄存器的通用代碼,。Linux內(nèi)核2.6以上通用,。
將下面代碼編譯后,將可執(zhí)行文件a.out 重命名為mdio

mdio eth0 1  		讀取phy寄存器1的數(shù)值
mdio eth0 0 0x1120  	0x1120寫入 phy寄存器1

eth0 mac層控制器的名稱,, 一般為eth0 mgmt0,。
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. #include <linux/mii.h>
  5. #include <sys/types.h>
  6. #include <sys/socket.h>
  7. #include <sys/ioctl.h>
  8. #include <net/if.h>
  9. #include <linux/sockios.h>
  10. #include <linux/types.h>
  11. #include <netinet/in.h>
  12. #define reteck(ret) \
  13. if(ret < 0){ \
  14. printf("%m! \"%s\" : line: %d\n", __func__, __LINE__); \
  15. goto lab; \
  16. }
  17. #define help() \
  18. printf("mdio:\n"); \
  19. printf("read operation: mdio reg_addr\n"); \
  20. printf("write operation: mdio reg_addr value\n"); \
  21. printf("For example:\n"); \
  22. printf("mdio eth0 1\n"); \
  23. printf("mdio eth0 0 0x12\n\n"); \
  24. exit(0);
  25. int sockfd;
  26. int main(int argc, char *argv[]){
  27. if(argc == 1 || !strcmp(argv[1], "-h")){
  28. help();
  29. }
  30. struct mii_ioctl_data *mii = NULL;
  31. struct ifreq ifr;
  32. int ret;
  33. memset(&ifr, 0, sizeof(ifr));
  34. strncpy(ifr.ifr_name, argv[1], IFNAMSIZ - 1);
  35. sockfd = socket(PF_LOCAL, SOCK_DGRAM, 0);
  36. reteck(sockfd);
  37. //get phy address in smi bus
  38. ret = ioctl(sockfd, SIOCGMIIPHY, &ifr);
  39. reteck(ret);
  40. mii = (struct mii_ioctl_data*)&ifr.ifr_data;
  41. if(argc == 3){
  42. mii->reg_num = (uint16_t)strtoul(argv[2], NULL, 0);
  43. ret = ioctl(sockfd, SIOCGMIIREG, &ifr);
  44. reteck(ret);
  45. printf("read phy addr: 0x%x reg: 0x%x value : 0x%x\n\n", mii->phy_id, mii->reg_num, mii->val_out);
  46. }else if(argc == 4){
  47. mii->reg_num = (uint16_t)strtoul(argv[2], NULL, 0);
  48. mii->val_in = (uint16_t)strtoul(argv[3], NULL, 0);
  49. ret = ioctl(sockfd, SIOCSMIIREG, &ifr);
  50. reteck(ret);
  51. printf("write phy addr: 0x%x reg: 0x%x value : 0x%x\n\n", mii->phy_id, mii->reg_num, mii->val_in);
  52. }
  53. lab:
  54. close(sockfd);
  55. return 0;
  56. }

很多人在read操作里面判斷phylink狀態(tài),

if(mii->val_out& 0x0004){

printf("linkup\n");

}else{

printf("linkdown\n");

}

其實(shí)這個做法是比較通用可行的,。

解釋一下,,關(guān)于mii->val_out& 0x0004

大多數(shù)phy芯片的寄存器0為控制寄存器, 寄存器1 為狀態(tài)寄存器, 

寄存器34Identifiier Register
,, 這里的內(nèi)容為phy芯片產(chǎn)商的識別碼,。

舉個實(shí)例,marvell 88E1116,, 無論是光口模式還是電口模式,, 寄存器1都是 Status register 

一般寄存器有16bit, 第2bitlink 狀態(tài), 第5bit為自動協(xié)商,, 

一般這個狀態(tài)寄存器的數(shù)值為: 0x796d

意思是:

14bit : 有能力實(shí)現(xiàn)全雙工100BASE-X工作模式

13bit :  有能力實(shí)現(xiàn)半雙工 100BASE-X工作模式

12bit :  有能力實(shí)現(xiàn)全雙工 10BASE-T工作模式

11 bit :  有能力實(shí)現(xiàn)半雙工 10BASE-T工作模式

8bit : 擴(kuò)展信息描述在寄存器15.

6bit :  MF報頭抑制

5bit : 自動協(xié)商完成

3bit : 有能力自動協(xié)商

2bit link 狀態(tài): up

0bit : 有擴(kuò)展寄存器

                                    

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn),。請注意甄別內(nèi)容中的聯(lián)系方式,、誘導(dǎo)購買等信息,謹(jǐn)防詐騙,。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,,請點(diǎn)擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多