2018-05-06 21:58:06 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0+ */
|
2016-05-23 09:12:05 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015-2016 Marvell International Ltd.
|
|
|
|
*/
|
|
|
|
|
2018-08-17 10:58:51 +00:00
|
|
|
#ifndef _COMPHY_CORE_H_
|
|
|
|
#define _COMPHY_CORE_H_
|
2016-05-23 09:12:05 +00:00
|
|
|
|
|
|
|
#include <fdtdec.h>
|
2018-08-17 10:58:51 +00:00
|
|
|
#include <mvebu/comphy.h>
|
2016-05-23 09:12:05 +00:00
|
|
|
|
|
|
|
#if defined(DEBUG)
|
|
|
|
#define debug_enter() printf("----> Enter %s\n", __func__);
|
|
|
|
#define debug_exit() printf("<---- Exit %s\n", __func__);
|
|
|
|
#else
|
|
|
|
#define debug_enter()
|
|
|
|
#define debug_exit()
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* COMPHY registers */
|
|
|
|
#define COMMON_PHY_CFG1_REG 0x0
|
|
|
|
#define COMMON_PHY_CFG1_PWR_UP_OFFSET 1
|
|
|
|
#define COMMON_PHY_CFG1_PWR_UP_MASK \
|
|
|
|
(0x1 << COMMON_PHY_CFG1_PWR_UP_OFFSET)
|
|
|
|
#define COMMON_PHY_CFG1_PIPE_SELECT_OFFSET 2
|
|
|
|
#define COMMON_PHY_CFG1_PIPE_SELECT_MASK \
|
|
|
|
(0x1 << COMMON_PHY_CFG1_PIPE_SELECT_OFFSET)
|
|
|
|
#define COMMON_PHY_CFG1_PWR_ON_RESET_OFFSET 13
|
|
|
|
#define COMMON_PHY_CFG1_PWR_ON_RESET_MASK \
|
|
|
|
(0x1 << COMMON_PHY_CFG1_PWR_ON_RESET_OFFSET)
|
|
|
|
#define COMMON_PHY_CFG1_CORE_RSTN_OFFSET 14
|
|
|
|
#define COMMON_PHY_CFG1_CORE_RSTN_MASK \
|
|
|
|
(0x1 << COMMON_PHY_CFG1_CORE_RSTN_OFFSET)
|
|
|
|
#define COMMON_PHY_PHY_MODE_OFFSET 15
|
|
|
|
#define COMMON_PHY_PHY_MODE_MASK \
|
|
|
|
(0x1 << COMMON_PHY_PHY_MODE_OFFSET)
|
|
|
|
|
|
|
|
#define COMMON_PHY_CFG6_REG 0x14
|
|
|
|
#define COMMON_PHY_CFG6_IF_40_SEL_OFFSET 18
|
|
|
|
#define COMMON_PHY_CFG6_IF_40_SEL_MASK \
|
|
|
|
(0x1 << COMMON_PHY_CFG6_IF_40_SEL_OFFSET)
|
|
|
|
|
|
|
|
#define COMMON_SELECTOR_PHY_OFFSET 0x140
|
|
|
|
#define COMMON_SELECTOR_PIPE_OFFSET 0x144
|
|
|
|
|
|
|
|
#define COMMON_PHY_SD_CTRL1 0x148
|
|
|
|
#define COMMON_PHY_SD_CTRL1_COMPHY_0_4_PORT_OFFSET 0
|
|
|
|
#define COMMON_PHY_SD_CTRL1_COMPHY_0_4_PORT_MASK 0xFFFF
|
|
|
|
#define COMMON_PHY_SD_CTRL1_PCIE_X4_EN_OFFSET 24
|
|
|
|
#define COMMON_PHY_SD_CTRL1_PCIE_X4_EN_MASK \
|
|
|
|
(0x1 << COMMON_PHY_SD_CTRL1_PCIE_X4_EN_OFFSET)
|
|
|
|
#define COMMON_PHY_SD_CTRL1_PCIE_X2_EN_OFFSET 25
|
|
|
|
#define COMMON_PHY_SD_CTRL1_PCIE_X2_EN_MASK \
|
|
|
|
(0x1 << COMMON_PHY_SD_CTRL1_PCIE_X2_EN_OFFSET)
|
|
|
|
#define COMMON_PHY_SD_CTRL1_RXAUI1_OFFSET 26
|
|
|
|
#define COMMON_PHY_SD_CTRL1_RXAUI1_MASK \
|
|
|
|
(0x1 << COMMON_PHY_SD_CTRL1_RXAUI1_OFFSET)
|
|
|
|
#define COMMON_PHY_SD_CTRL1_RXAUI0_OFFSET 27
|
|
|
|
#define COMMON_PHY_SD_CTRL1_RXAUI0_MASK \
|
|
|
|
(0x1 << COMMON_PHY_SD_CTRL1_RXAUI0_OFFSET)
|
|
|
|
|
2016-08-30 14:48:20 +00:00
|
|
|
/* ToDo: Get this address via DT */
|
|
|
|
#define MVEBU_CP0_REGS_BASE 0xF2000000UL
|
|
|
|
|
2016-05-23 09:12:05 +00:00
|
|
|
#define DFX_DEV_GEN_CTRL12 (MVEBU_CP0_REGS_BASE + 0x400280)
|
|
|
|
#define DFX_DEV_GEN_PCIE_CLK_SRC_OFFSET 7
|
|
|
|
#define DFX_DEV_GEN_PCIE_CLK_SRC_MASK \
|
|
|
|
(0x3 << DFX_DEV_GEN_PCIE_CLK_SRC_OFFSET)
|
|
|
|
|
|
|
|
#define MAX_LANE_OPTIONS 10
|
2016-10-25 16:16:25 +00:00
|
|
|
#define MAX_UTMI_PHY_COUNT 3
|
2016-05-23 09:12:05 +00:00
|
|
|
|
|
|
|
struct comphy_mux_options {
|
|
|
|
u32 type;
|
|
|
|
u32 mux_value;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct comphy_mux_data {
|
|
|
|
u32 max_lane_values;
|
|
|
|
struct comphy_mux_options mux_values[MAX_LANE_OPTIONS];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct chip_serdes_phy_config {
|
|
|
|
struct comphy_mux_data *mux_data;
|
|
|
|
int (*ptr_comphy_chip_init)(struct chip_serdes_phy_config *,
|
|
|
|
struct comphy_map *);
|
2021-03-23 10:57:57 +00:00
|
|
|
int (*rx_training)(struct chip_serdes_phy_config *, u32);
|
2016-05-23 09:12:05 +00:00
|
|
|
void __iomem *comphy_base_addr;
|
|
|
|
void __iomem *hpipe3_base_addr;
|
|
|
|
u32 comphy_lanes_count;
|
|
|
|
u32 comphy_mux_bitcount;
|
2018-04-24 15:21:21 +00:00
|
|
|
const fdt32_t *comphy_mux_lane_order;
|
2017-04-24 15:45:32 +00:00
|
|
|
u32 cp_index;
|
2017-08-21 13:58:21 +00:00
|
|
|
struct comphy_map comphy_map_data[MAX_LANE_OPTIONS];
|
2016-05-23 09:12:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Register helper functions */
|
2018-04-24 15:21:28 +00:00
|
|
|
static inline void reg_set_silent(void __iomem *addr, u32 data, u32 mask)
|
|
|
|
{
|
|
|
|
u32 reg_data;
|
|
|
|
|
|
|
|
reg_data = readl(addr);
|
|
|
|
reg_data &= ~mask;
|
|
|
|
reg_data |= data;
|
|
|
|
writel(reg_data, addr);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void reg_set(void __iomem *addr, u32 data, u32 mask)
|
|
|
|
{
|
|
|
|
debug("Write to address = %#010lx, data = %#010x (mask = %#010x) - ",
|
|
|
|
(unsigned long)addr, data, mask);
|
|
|
|
debug("old value = %#010x ==> ", readl(addr));
|
|
|
|
reg_set_silent(addr, data, mask);
|
|
|
|
debug("new value %#010x\n", readl(addr));
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void reg_set_silent16(void __iomem *addr, u16 data, u16 mask)
|
|
|
|
{
|
|
|
|
u16 reg_data;
|
|
|
|
|
|
|
|
reg_data = readw(addr);
|
|
|
|
reg_data &= ~mask;
|
|
|
|
reg_data |= data;
|
|
|
|
writew(reg_data, addr);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void reg_set16(void __iomem *addr, u16 data, u16 mask)
|
|
|
|
{
|
|
|
|
debug("Write to address = %#010lx, data = %#06x (mask = %#06x) - ",
|
|
|
|
(unsigned long)addr, data, mask);
|
|
|
|
debug("old value = %#06x ==> ", readw(addr));
|
|
|
|
reg_set_silent16(addr, data, mask);
|
|
|
|
debug("new value %#06x\n", readw(addr));
|
|
|
|
}
|
2016-05-23 09:12:05 +00:00
|
|
|
|
|
|
|
/* SoC specific init functions */
|
|
|
|
#ifdef CONFIG_ARMADA_3700
|
|
|
|
int comphy_a3700_init(struct chip_serdes_phy_config *ptr_chip_cfg,
|
|
|
|
struct comphy_map *serdes_map);
|
|
|
|
#else
|
|
|
|
static inline int comphy_a3700_init(struct chip_serdes_phy_config *ptr_chip_cfg,
|
|
|
|
struct comphy_map *serdes_map)
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* This function should never be called in this configuration, so
|
|
|
|
* lets return an error here.
|
|
|
|
*/
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
#endif
|
2016-08-30 14:48:20 +00:00
|
|
|
|
|
|
|
#ifdef CONFIG_ARMADA_8K
|
2016-05-23 09:12:05 +00:00
|
|
|
int comphy_cp110_init(struct chip_serdes_phy_config *ptr_chip_cfg,
|
|
|
|
struct comphy_map *serdes_map);
|
2021-03-23 10:57:57 +00:00
|
|
|
int comphy_cp110_sfi_rx_training(struct chip_serdes_phy_config *ptr_chip_cfg,
|
|
|
|
u32 lane);
|
2016-08-30 14:48:20 +00:00
|
|
|
#else
|
|
|
|
static inline int comphy_cp110_init(struct chip_serdes_phy_config *ptr_chip_cfg,
|
|
|
|
struct comphy_map *serdes_map)
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* This function should never be called in this configuration, so
|
|
|
|
* lets return an error here.
|
|
|
|
*/
|
|
|
|
return -1;
|
|
|
|
}
|
2021-03-23 10:57:57 +00:00
|
|
|
|
|
|
|
static inline int comphy_cp110_sfi_rx_training(
|
|
|
|
struct chip_serdes_phy_config *ptr_chip_cfg,
|
|
|
|
u32 lane)
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* This function should never be called in this configuration, so
|
|
|
|
* lets return an error here.
|
|
|
|
*/
|
|
|
|
return -1;
|
|
|
|
}
|
2016-08-30 14:48:20 +00:00
|
|
|
#endif
|
2016-05-23 09:12:05 +00:00
|
|
|
|
|
|
|
void comphy_dedicated_phys_init(void);
|
|
|
|
|
|
|
|
/* MUX function */
|
|
|
|
void comphy_mux_init(struct chip_serdes_phy_config *ptr_chip_cfg,
|
|
|
|
struct comphy_map *comphy_map_data,
|
|
|
|
void __iomem *selector_base);
|
|
|
|
|
|
|
|
void comphy_pcie_config_set(u32 comphy_max_count,
|
|
|
|
struct comphy_map *serdes_map);
|
|
|
|
void comphy_pcie_config_detect(u32 comphy_max_count,
|
|
|
|
struct comphy_map *serdes_map);
|
|
|
|
void comphy_pcie_unit_general_config(u32 pex_index);
|
|
|
|
|
2018-08-17 10:58:51 +00:00
|
|
|
#endif /* _COMPHY_CORE_H_ */
|
2016-05-23 09:12:05 +00:00
|
|
|
|