mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-24 03:09:38 +07:00
dbcd6806af
GPIO PIN control and access is done by direct phy manipulation. Here we add an aq_phy module which is able to access phy registers via MDIO access mailbox. Access is controlled via HW semaphore. Co-developed-by: Nikita Danilov <nikita.danilov@aquantia.com> Signed-off-by: Nikita Danilov <nikita.danilov@aquantia.com> Signed-off-by: Dmitry Bezrukov <dmitry.bezrukov@aquantia.com> Signed-off-by: Igor Russkikh <igor.russkikh@aquantia.com> Reviewed-by: Andrew Lunn <andrew@lunn.ch> Signed-off-by: David S. Miller <davem@davemloft.net>
33 lines
815 B
C
33 lines
815 B
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/* aQuantia Corporation Network Driver
|
|
* Copyright (C) 2018-2019 aQuantia Corporation. All rights reserved
|
|
*/
|
|
|
|
#ifndef AQ_PHY_H
|
|
#define AQ_PHY_H
|
|
|
|
#include <linux/mdio.h>
|
|
|
|
#include "hw_atl/hw_atl_llh.h"
|
|
#include "hw_atl/hw_atl_llh_internal.h"
|
|
#include "aq_hw_utils.h"
|
|
#include "aq_hw.h"
|
|
|
|
#define HW_ATL_PHY_ID_MAX 32U
|
|
|
|
bool aq_mdio_busy_wait(struct aq_hw_s *aq_hw);
|
|
|
|
u16 aq_mdio_read_word(struct aq_hw_s *aq_hw, u16 mmd, u16 addr);
|
|
|
|
void aq_mdio_write_word(struct aq_hw_s *aq_hw, u16 mmd, u16 addr, u16 data);
|
|
|
|
u16 aq_phy_read_reg(struct aq_hw_s *aq_hw, u16 mmd, u16 address);
|
|
|
|
void aq_phy_write_reg(struct aq_hw_s *aq_hw, u16 mmd, u16 address, u16 data);
|
|
|
|
bool aq_phy_init_phy_id(struct aq_hw_s *aq_hw);
|
|
|
|
bool aq_phy_init(struct aq_hw_s *aq_hw);
|
|
|
|
#endif /* AQ_PHY_H */
|