162 lines
4.6 KiB
C
Raw Normal View History

/*
* Copyright (c) 2021 hpmicro
*
* SPDX-License-Identifier: BSD-3-Clause
*
*/
#ifndef ETH_PHY_PORT_H
#define ETH_PHY_PORT_H
#include "hpm_ioc_regs.h"
#include <rtdevice.h>
#ifndef PHY_AUTO_NEGO
#define PHY_AUTO_NEGO (1U)
#endif
#ifndef PHY_MDIO_CSR_CLK_FREQ
#define PHY_MDIO_CSR_CLK_FREQ (200000000U)
#endif
enum phy_link_status
{
PHY_LINK_DOWN = 0U,
PHY_LINK_UP
};
typedef struct {
rt_uint32_t phy_speed;
rt_uint32_t phy_duplex;
} phy_info_t;
typedef struct {
rt_uint32_t phy_link;
rt_phy_t phy;
phy_info_t phy_info;
} phy_device_t;
#ifdef BSP_USING_ETH0
#define RGMII (1U)
/* DP83867 name and ID */
#define PHY_NAME ("DP83867")
#define PHY_ID1 (0x2000U)
#define PHY_ID2 (0x28U)
/* PHY_DP83867 basic control register */
#define PHY_BASIC_CONTROL_REG (0x00U)
#define PHY_RESET_MASK (1U << 15)
#define PHY_AUTO_NEGOTIATION_MASK (1U << 12)
/* PHY_DP83867 basic status register */
#define PHY_BASIC_STATUS_REG (0x01U)
#define PHY_LINKED_STATUS_MASK (1U << 2)
#define PHY_AUTONEGO_COMPLETE_MASK (1U << 5)
/* PHY_DP83867 ID one register */
#define PHY_ID1_REG (0x02U)
/* PHY_DP83867 ID two register */
#define PHY_ID2_REG (0x03U)
/* PHY_DP83867 auto-negotiate advertise register */
#define PHY_AUTONEG_ADVERTISE_REG (0x04U)
/* PHY_DP83867 status register */
#define PHY_STATUS_REG (0x11U)
#define PHY_100M_MASK (1UL << 14)
#define PHY_1000M_MASK (1UL << 15)
#define PHY_FULL_DUPLEX_MASK (1UL << 13)
#define PHY_STATUS_SPEED_100M(SR) ((SR) & PHY_100M_MASK)
#define PHY_STATUS_SPEED_1000M(SR) ((SR) & PHY_1000M_MASK)
#define PHY_STATUS_FULL_DUPLEX(SR) ((SR) & PHY_FULL_DUPLEX_MASK)
#define PHY_SPEED_SEL_SHIFT (14U)
/* PHY_DP83867 interrupt control register */
#define PHY_INTERTUPT_CTRL_REG (0x12U)
/* PHY_DP83867 interrupt status register */
#define PHY_INTERRUPT_STATUS_REG (0x13U)
/* PHY register index */
typedef enum {
PHY_BASIC_CONTROL_REG_IDX = 0,
PHY_BASIC_STATUS_REG_IDX,
PHY_ID1_REG_IDX,
PHY_ID2_REG_IDX,
PHY_AUTONEG_ADVERTISE_REG_IDX,
PHY_STATUS_REG_IDX,
PHY_INTERRUPT_FLAG_REG_IDX,
PHY_INTERRUPT_MASK_REG_IDX
} phy_reg_idx_t;
/* ETH0 PHY register list */
#define PHY0_REG_LIST PHY_BASIC_CONTROL_REG,\
PHY_BASIC_STATUS_REG,\
PHY_ID1_REG,\
PHY_ID2_REG,\
PHY_AUTONEG_ADVERTISE_REG,\
PHY_STATUS_REG,\
PHY_INTERTUPT_CTRL_REG,\
PHY_INTERRUPT_STATUS_REG
#else
#define RMII (1U)
/* DP83848 name and ID */
#define PHY_NAME ("DP83848")
#define PHY_ID1 (0x2000U)
#define PHY_ID2 (0x17U)
/* DP83848 basic control register */
#define PHY_BASIC_CONTROL_REG (0x00U)
#define PHY_RESET_MASK (1U << 15)
#define PHY_AUTO_NEGOTIATION_MASK (1U << 12)
/* DP83848 basic status register */
#define PHY_BASIC_STATUS_REG (0x01U)
#define PHY_LINKED_STATUS_MASK (1U << 2)
#define PHY_AUTONEGO_COMPLETE_MASK (1U << 5)
/* DP83848 ID one register */
#define PHY_ID1_REG (0x02U)
/* DP83848 ID two register */
#define PHY_ID2_REG (0x03U)
/* DP83848 auto-negotiate advertise register */
#define PHY_AUTONEG_ADVERTISE_REG (0x04U)
/* DP83848 status register */
#define PHY_STATUS_REG (0x10U)
#define PHY_10M_MASK (1UL << 1)
#define PHY_FULL_DUPLEX_MASK (1UL << 2)
#define PHY_STATUS_SPEED_10M(SR) ((SR) & PHY_10M_MASK)
#define PHY_STATUS_FULL_DUPLEX(SR) ((SR) & PHY_FULL_DUPLEX_MASK)
/* PHY register index */
typedef enum {
PHY_BASIC_CONTROL_REG_IDX = 0,
PHY_BASIC_STATUS_REG_IDX,
PHY_ID1_REG_IDX,
PHY_ID2_REG_IDX,
PHY_AUTONEG_ADVERTISE_REG_IDX,
PHY_STATUS_REG_IDX,
} phy_reg_idx_t;
/* ETH0 PHY register list */
#define PHY1_REG_LIST PHY_BASIC_CONTROL_REG,\
PHY_BASIC_STATUS_REG,\
PHY_ID1_REG,\
PHY_ID2_REG,\
PHY_AUTONEG_ADVERTISE_REG,\
PHY_STATUS_REG
#endif
#endif