⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 athrs26_phy.h

📁 linux下atheros的ag7100驱动
💻 H
字号:
#ifndef _ATHRS26_PHY_H#define _ATHRS26_PHY_H/*****************//* PHY Registers *//*****************/#define ATHR_PHY_CONTROL                 0#define ATHR_PHY_STATUS                  1#define ATHR_PHY_ID1                     2#define ATHR_PHY_ID2                     3#define ATHR_AUTONEG_ADVERT              4#define ATHR_LINK_PARTNER_ABILITY        5#define ATHR_AUTONEG_EXPANSION           6#define ATHR_NEXT_PAGE_TRANSMIT          7#define ATHR_LINK_PARTNER_NEXT_PAGE      8#define ATHR_1000BASET_CONTROL           9#define ATHR_1000BASET_STATUS            10#define ATHR_PHY_SPEC_CONTROL            16#define ATHR_PHY_SPEC_STATUS             17#define ATHR_DEBUG_PORT_ADDRESS          29#define ATHR_DEBUG_PORT_DATA             30/* ATHR_PHY_CONTROL fields */#define ATHR_CTRL_SOFTWARE_RESET                    0x8000#define ATHR_CTRL_SPEED_LSB                         0x2000#define ATHR_CTRL_AUTONEGOTIATION_ENABLE            0x1000#define ATHR_CTRL_RESTART_AUTONEGOTIATION           0x0200#define ATHR_CTRL_SPEED_FULL_DUPLEX                 0x0100#define ATHR_CTRL_SPEED_MSB                         0x0040#define ATHR_RESET_DONE(phy_control)                   \    (((phy_control) & (ATHR_CTRL_SOFTWARE_RESET)) == 0)    /* Phy status fields */#define ATHR_STATUS_AUTO_NEG_DONE                   0x0020#define ATHR_AUTONEG_DONE(ip_phy_status)                   \    (((ip_phy_status) &                                  \        (ATHR_STATUS_AUTO_NEG_DONE)) ==                    \        (ATHR_STATUS_AUTO_NEG_DONE))/* Link Partner ability */#define ATHR_LINK_100BASETX_FULL_DUPLEX       0x0100#define ATHR_LINK_100BASETX                   0x0080#define ATHR_LINK_10BASETX_FULL_DUPLEX        0x0040#define ATHR_LINK_10BASETX                    0x0020/* Advertisement register. */#define ATHR_ADVERTISE_NEXT_PAGE              0x8000#define ATHR_ADVERTISE_ASYM_PAUSE             0x0800#define ATHR_ADVERTISE_PAUSE                  0x0400#define ATHR_ADVERTISE_100FULL                0x0100#define ATHR_ADVERTISE_100HALF                0x0080  #define ATHR_ADVERTISE_10FULL                 0x0040  #define ATHR_ADVERTISE_10HALF                 0x0020  #define ATHR_ADVERTISE_ALL (ATHR_ADVERTISE_ASYM_PAUSE | ATHR_ADVERTISE_PAUSE | \                            ATHR_ADVERTISE_10HALF | ATHR_ADVERTISE_10FULL | \                            ATHR_ADVERTISE_100HALF | ATHR_ADVERTISE_100FULL)                       /* 1000BASET_CONTROL */#define ATHR_ADVERTISE_1000FULL               0x0200/* Phy Specific status fields */#define ATHER_STATUS_LINK_MASK                0xC000#define ATHER_STATUS_LINK_SHIFT               14#define ATHER_STATUS_FULL_DEPLEX              0x2000#define ATHR_STATUS_LINK_PASS                 0x0400 #define ATHR_STATUS_RESOVLED                  0x0800/*phy debug port  register */#define ATHER_DEBUG_SERDES_REG                5/* Serdes debug fields */#define ATHER_SERDES_BEACON                   0x0100#ifndef BOOL#define BOOL    int#endif#define HEADER_LEN   2#define HEADER_MAX_DATA  10#undef S26_VER_1_0/* before define HEADER_REG_CONF, please make sure you also enable s26's *//* HEADER_EN on CPU port in bootloader, or the configuration will fail */#ifndef CONFIG_AR9100#undef HEADER_REG_CONF#else#define HEADER_REG_CONF 1#endif#ifdef HEADER_REG_CONF#define HEADER_EN#endiftypedef enum {    NORMAL_PACKET,     RESERVED0,    MIB_1ST,     RESERVED1,    RESERVED2,    READ_WRITE_REG,    READ_WRITE_REG_ACK,    RESERVED3				        } AT_HEADER_TYPE;typedef struct {    uint16_t    reserved0;     uint16_t    priority;      uint16_t    type ;         uint16_t    broadcast;     uint16_t    from_cpu;      uint16_t    reserved1;     uint16_t    port_num;  }at_header_t;typedef struct {    uint64_t    reg_addr;	    uint64_t    reserved0;	    uint64_t    cmd_len;		    uint64_t    reserved1; 	    uint64_t    cmd; 		    uint64_t    reserved2;	    uint64_t    seq_num;  }reg_cmd_t;typedef struct {    uint8_t data[HEADER_MAX_DATA];    uint8_t len;    uint32_t seq;} cmd_resp_t;int header_receive_skb(struct sk_buff *skb);void athrs26_reg_dev(ag7100_mac_t **mac);#define header_xmit(skb, dev) ag7100_hard_start(skb, dev) //dev_queue_xmit(skb)void athrs26_reg_init(void);int athrs26_phy_is_up(int unit);int athrs26_phy_is_fdx(int unit);int athrs26_phy_speed(int unit);BOOL athrs26_phy_setup(int unit);void athrs26_phy_off(ag7100_mac_t *mac);void athrs26_phy_on(ag7100_mac_t *mac);void athrs26_mac_speed_set(ag7100_mac_t *mac, ag7100_phy_speed_t speed);#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -