mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-02-04 07:14:34 +08:00
88 lines
1.8 KiB
C
88 lines
1.8 KiB
C
/*
|
|
* Copyright (c) 2006-2020, RT-Thread Development Team
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
* Change Logs:
|
|
* Date Author Notes
|
|
* 2020-10-14 wangqiang the first version
|
|
*/
|
|
|
|
#ifndef __PHY_H__
|
|
#define __PHY_H__
|
|
|
|
#include <rtthread.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C"
|
|
{
|
|
#endif
|
|
|
|
/* Defines the PHY link speed. This is align with the speed for MAC. */
|
|
enum phy_speed
|
|
{
|
|
PHY_SPEED_10M = 0U, /* PHY 10M speed. */
|
|
PHY_SPEED_100M /* PHY 100M speed. */
|
|
};
|
|
|
|
/* Defines the PHY link duplex. */
|
|
enum phy_duplex
|
|
{
|
|
PHY_HALF_DUPLEX = 0U, /* PHY half duplex. */
|
|
PHY_FULL_DUPLEX /* PHY full duplex. */
|
|
};
|
|
|
|
/*! @brief Defines the PHY loopback mode. */
|
|
enum phy_loop
|
|
{
|
|
PHY_LOCAL_LOOP = 0U, /* PHY local loopback. */
|
|
PHY_REMOTE_LOOP /* PHY remote loopback. */
|
|
};
|
|
|
|
|
|
struct rt_phy_msg
|
|
{
|
|
rt_uint32_t reg;
|
|
rt_uint32_t value;
|
|
};
|
|
|
|
typedef struct rt_phy_msg rt_phy_msg_t;
|
|
|
|
|
|
struct rt_phy_device
|
|
{
|
|
struct rt_device parent;
|
|
struct rt_mdio_bus *bus;
|
|
rt_uint32_t addr;
|
|
struct rt_phy_ops *ops;
|
|
};
|
|
|
|
typedef struct rt_phy_device rt_phy_t;
|
|
|
|
|
|
enum {
|
|
PHY_STATUS_OK = 0,
|
|
PHY_STATUS_FAIL,
|
|
PHY_STATUS_TIMEOUT,
|
|
};
|
|
|
|
typedef rt_int32_t rt_phy_status;
|
|
|
|
struct rt_phy_ops
|
|
{
|
|
rt_phy_status (*init)(void *object, rt_uint32_t phy_addr, rt_uint32_t src_clock_hz);
|
|
rt_phy_status (*read)(rt_uint32_t reg, rt_uint32_t *data);
|
|
rt_phy_status (*write)(rt_uint32_t reg, rt_uint32_t data);
|
|
rt_phy_status (*loopback)(rt_uint32_t mode, rt_uint32_t speed, rt_bool_t enable);
|
|
rt_phy_status (*get_link_status)(rt_bool_t *status);
|
|
rt_phy_status (*get_link_speed_duplex)(rt_uint32_t *speed, rt_uint32_t *duplex);
|
|
};
|
|
|
|
rt_err_t rt_hw_phy_register(struct rt_phy_device *phy, const char *name);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* __PHY_H__*/
|