ramips: add v4.9 support
[librecmc/librecmc.git] / target / linux / ramips / files-4.9 / drivers / net / ethernet / mtk / gsw_mt7620.h
1 /*   This program is free software; you can redistribute it and/or modify
2  *   it under the terms of the GNU General Public License as published by
3  *   the Free Software Foundation; version 2 of the License
4  *
5  *   This program is distributed in the hope that it will be useful,
6  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
7  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
8  *   GNU General Public License for more details.
9  *
10  *   Copyright (C) 2009-2015 John Crispin <blogic@openwrt.org>
11  *   Copyright (C) 2009-2015 Felix Fietkau <nbd@nbd.name>
12  *   Copyright (C) 2013-2015 Michael Lee <igvtee@gmail.com>
13  */
14
15 #ifndef _RALINK_GSW_MT7620_H__
16 #define _RALINK_GSW_MT7620_H__
17
18 #define GSW_REG_PHY_TIMEOUT     (5 * HZ)
19
20 #ifdef CONFIG_SOC_MT7621
21 #define MT7620A_GSW_REG_PIAC    0x0004
22 #else
23 #define MT7620A_GSW_REG_PIAC    0x7004
24 #endif
25
26 #define GSW_NUM_VLANS           16
27 #define GSW_NUM_VIDS            4096
28 #define GSW_NUM_PORTS           7
29 #define GSW_PORT6               6
30
31 #define GSW_MDIO_ACCESS         BIT(31)
32 #define GSW_MDIO_READ           BIT(19)
33 #define GSW_MDIO_WRITE          BIT(18)
34 #define GSW_MDIO_START          BIT(16)
35 #define GSW_MDIO_ADDR_SHIFT     20
36 #define GSW_MDIO_REG_SHIFT      25
37
38 #define GSW_REG_MIB_CNT_EN      0x4000
39
40 #define GSW_REG_PORT_PMCR(x)    (0x3000 + (x * 0x100))
41 #define GSW_REG_PORT_STATUS(x)  (0x3008 + (x * 0x100))
42 #define GSW_REG_SMACCR0         0x3fE4
43 #define GSW_REG_SMACCR1         0x3fE8
44 #define GSW_REG_CKGCR           0x3ff0
45
46 #define GSW_REG_IMR             0x7008
47 #define GSW_REG_ISR             0x700c
48 #define GSW_REG_GPC1            0x7014
49
50 #define SYSC_REG_CHIP_REV_ID    0x0c
51 #define SYSC_REG_CFG1           0x14
52 #define RST_CTRL_MCM            BIT(2)
53 #define SYSC_PAD_RGMII2_MDIO    0x58
54 #define SYSC_GPIO_MODE          0x60
55
56 #define PORT_IRQ_ST_CHG         0x7f
57
58 #ifdef CONFIG_SOC_MT7621
59 #define ESW_PHY_POLLING         0x0000
60 #else
61 #define ESW_PHY_POLLING         0x7000
62 #endif
63
64 #define PMCR_IPG                BIT(18)
65 #define PMCR_MAC_MODE           BIT(16)
66 #define PMCR_FORCE              BIT(15)
67 #define PMCR_TX_EN              BIT(14)
68 #define PMCR_RX_EN              BIT(13)
69 #define PMCR_BACKOFF            BIT(9)
70 #define PMCR_BACKPRES           BIT(8)
71 #define PMCR_RX_FC              BIT(5)
72 #define PMCR_TX_FC              BIT(4)
73 #define PMCR_SPEED(_x)          (_x << 2)
74 #define PMCR_DUPLEX             BIT(1)
75 #define PMCR_LINK               BIT(0)
76
77 #define PHY_AN_EN               BIT(31)
78 #define PHY_PRE_EN              BIT(30)
79 #define PMY_MDC_CONF(_x)        ((_x & 0x3f) << 24)
80
81
82 enum {
83         /* Global attributes. */
84         GSW_ATTR_ENABLE_VLAN,
85         /* Port attributes. */
86         GSW_ATTR_PORT_UNTAG,
87 };
88
89 enum {
90         PORT4_EPHY = 0,
91         PORT4_EXT,
92 };
93
94 struct mt7620_gsw {
95         struct device           *dev;
96         void __iomem            *base;
97         int                     irq;
98         int                     port4;
99         unsigned long int       autopoll;
100 };
101
102 void mtk_switch_w32(struct mt7620_gsw *gsw, u32 val, unsigned reg);
103 u32 mtk_switch_r32(struct mt7620_gsw *gsw, unsigned reg);
104 int mtk_gsw_init(struct fe_priv *priv);
105
106 int mt7620_mdio_write(struct mii_bus *bus, int phy_addr, int phy_reg, u16 val);
107 int mt7620_mdio_read(struct mii_bus *bus, int phy_addr, int phy_reg);
108 void mt7620_mdio_link_adjust(struct fe_priv *priv, int port);
109 int mt7620_has_carrier(struct fe_priv *priv);
110 void mt7620_print_link_state(struct fe_priv *priv, int port, int link,
111                              int speed, int duplex);
112
113 void mt7530_mdio_w32(struct mt7620_gsw *gsw, u32 reg, u32 val);
114 u32 mt7530_mdio_r32(struct mt7620_gsw *gsw, u32 reg);
115
116 u32 _mt7620_mii_write(struct mt7620_gsw *gsw, u32 phy_addr,
117                              u32 phy_register, u32 write_data);
118 u32 _mt7620_mii_read(struct mt7620_gsw *gsw, int phy_addr, int phy_reg);
119 void mt7620_handle_carrier(struct fe_priv *priv);
120
121 #endif