aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/stmmac.h
diff options
context:
space:
mode:
authorGiuseppe CAVALLARO <peppe.cavallaro@st.com>2012-04-04 00:33:26 -0400
committerDavid S. Miller <davem@davemloft.net>2012-04-04 18:39:24 -0400
commit18f05d64ec36e27892cc0f55be707762aae053a1 (patch)
tree2800ef8ec49ef318ffe16b93db4b15cebc1f39ca /include/linux/stmmac.h
parentba1377ffe90a04d9a1d526067909d24e3cf7a3f7 (diff)
stmmac: extend CSR Clock Range programming
The CSR Clock Range has been reworked and new macros has been added in the platform header to allow the CSR Clock Range selection in the GMII Address Register. The previous work didn't add the other fields that can be used to achieve MDC clock of frequency higher than the IEEE 802.3 specified frequency limit of 2.5 MHz and program a clock divider of lower value. On such platforms, these are used indeed so this patch adds them. Signed-off-by: Giuseppe Cavallaro <peppe.cavallaro@st.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux/stmmac.h')
-rw-r--r--include/linux/stmmac.h33
1 files changed, 17 insertions, 16 deletions
diff --git a/include/linux/stmmac.h b/include/linux/stmmac.h
index 4aef9baff12b..cf6403186359 100644
--- a/include/linux/stmmac.h
+++ b/include/linux/stmmac.h
@@ -37,28 +37,29 @@
37 * This could also be configured at run time using CPU freq framework. */ 37 * This could also be configured at run time using CPU freq framework. */
38 38
39/* MDC Clock Selection define*/ 39/* MDC Clock Selection define*/
40#define STMMAC_CSR_60_100M 0 /* MDC = clk_scr_i/42 */ 40#define STMMAC_CSR_60_100M 0x0 /* MDC = clk_scr_i/42 */
41#define STMMAC_CSR_100_150M 1 /* MDC = clk_scr_i/62 */ 41#define STMMAC_CSR_100_150M 0x1 /* MDC = clk_scr_i/62 */
42#define STMMAC_CSR_20_35M 2 /* MDC = clk_scr_i/16 */ 42#define STMMAC_CSR_20_35M 0x2 /* MDC = clk_scr_i/16 */
43#define STMMAC_CSR_35_60M 3 /* MDC = clk_scr_i/26 */ 43#define STMMAC_CSR_35_60M 0x3 /* MDC = clk_scr_i/26 */
44#define STMMAC_CSR_150_250M 4 /* MDC = clk_scr_i/102 */ 44#define STMMAC_CSR_150_250M 0x4 /* MDC = clk_scr_i/102 */
45#define STMMAC_CSR_250_300M 5 /* MDC = clk_scr_i/122 */ 45#define STMMAC_CSR_250_300M 0x5 /* MDC = clk_scr_i/122 */
46 46
47/* FIXME: The MDC clock could be set higher than the IEEE 802.3 47/* The MDC clock could be set higher than the IEEE 802.3
48 * specified frequency limit 0f 2.5 MHz, by programming a clock divider 48 * specified frequency limit 0f 2.5 MHz, by programming a clock divider
49 * of value different than the above defined values. The resultant MDIO 49 * of value different than the above defined values. The resultant MDIO
50 * clock frequency of 12.5 MHz is applicable for the interfacing chips 50 * clock frequency of 12.5 MHz is applicable for the interfacing chips
51 * supporting higher MDC clocks. 51 * supporting higher MDC clocks.
52 * The MDC clock selection macros need to be defined for MDC clock rate 52 * The MDC clock selection macros need to be defined for MDC clock rate
53 * of 12.5 MHz, corresponding to the following selection. 53 * of 12.5 MHz, corresponding to the following selection.
54 * 1000 clk_csr_i/4 54 */
55 * 1001 clk_csr_i/6 55#define STMMAC_CSR_I_4 0x8 /* clk_csr_i/4 */
56 * 1010 clk_csr_i/8 56#define STMMAC_CSR_I_6 0x9 /* clk_csr_i/6 */
57 * 1011 clk_csr_i/10 57#define STMMAC_CSR_I_8 0xA /* clk_csr_i/8 */
58 * 1100 clk_csr_i/12 58#define STMMAC_CSR_I_10 0xB /* clk_csr_i/10 */
59 * 1101 clk_csr_i/14 59#define STMMAC_CSR_I_12 0xC /* clk_csr_i/12 */
60 * 1110 clk_csr_i/16 60#define STMMAC_CSR_I_14 0xD /* clk_csr_i/14 */
61 * 1111 clk_csr_i/18 */ 61#define STMMAC_CSR_I_16 0xE /* clk_csr_i/16 */
62#define STMMAC_CSR_I_18 0xF /* clk_csr_i/18 */
62 63
63/* AXI DMA Burst length suported */ 64/* AXI DMA Burst length suported */
64#define DMA_AXI_BLEN_4 (1 << 1) 65#define DMA_AXI_BLEN_4 (1 << 1)