188 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			188 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C
		
	
	
	
| /* SPDX-License-Identifier: GPL-2.0+ */
 | |
| /*
 | |
|  * Copyright (C) 2015-2016 Marvell International Ltd.
 | |
|  */
 | |
| 
 | |
| #ifndef _COMPHY_H_
 | |
| #define _COMPHY_H_
 | |
| 
 | |
| #include <dt-bindings/comphy/comphy_data.h>
 | |
| #include <fdtdec.h>
 | |
| 
 | |
| #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)
 | |
| 
 | |
| /* ToDo: Get this address via DT */
 | |
| #define MVEBU_CP0_REGS_BASE			0xF2000000UL
 | |
| 
 | |
| #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
 | |
| #define MAX_UTMI_PHY_COUNT			3
 | |
| 
 | |
| 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 comphy_map {
 | |
| 	u32 type;
 | |
| 	u32 speed;
 | |
| 	u32 invert;
 | |
| 	bool clk_src;
 | |
| 	bool end_point;
 | |
| };
 | |
| 
 | |
| struct chip_serdes_phy_config {
 | |
| 	struct comphy_mux_data *mux_data;
 | |
| 	int (*ptr_comphy_chip_init)(struct chip_serdes_phy_config *,
 | |
| 				    struct comphy_map *);
 | |
| 	void __iomem *comphy_base_addr;
 | |
| 	void __iomem *hpipe3_base_addr;
 | |
| 	u32 comphy_lanes_count;
 | |
| 	u32 comphy_mux_bitcount;
 | |
| 	const fdt32_t *comphy_mux_lane_order;
 | |
| 	u32 cp_index;
 | |
| };
 | |
| 
 | |
| /* Register helper functions */
 | |
| 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));
 | |
| }
 | |
| 
 | |
| /* 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
 | |
| 
 | |
| #ifdef CONFIG_ARMADA_8K
 | |
| int comphy_cp110_init(struct chip_serdes_phy_config *ptr_chip_cfg,
 | |
| 		      struct comphy_map *serdes_map);
 | |
| #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;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| 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);
 | |
| 
 | |
| #endif /* _COMPHY_H_ */
 | |
| 
 |