Root/target/linux/generic-2.6/files/drivers/net/phy/adm6996.h

1/*
2 * ADM6996 switch driver
3 *
4 * Copyright (c) 2008 Felix Fietkau <nbd@openwrt.org>
5 *
6 * This program is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License v2 as published by the
8 * Free Software Foundation
9 */
10#ifndef __ADM6996_H
11#define __ADM6996_H
12
13#define ADM_PHY_PORTS 5
14#define ADM_CPU_PORT 5
15#define ADM_WAN_PORT 0 /* FIXME: dynamic ? */
16
17enum admreg {
18    ADM_EEPROM_BASE = 0x0,
19        ADM_P0_CFG = ADM_EEPROM_BASE + 1,
20        ADM_P1_CFG = ADM_EEPROM_BASE + 3,
21        ADM_P2_CFG = ADM_EEPROM_BASE + 5,
22        ADM_P3_CFG = ADM_EEPROM_BASE + 7,
23        ADM_P4_CFG = ADM_EEPROM_BASE + 8,
24        ADM_P5_CFG = ADM_EEPROM_BASE + 9,
25    ADM_EEPROM_EXT_BASE = 0x40,
26    ADM_COUNTER_BASE = 0xa0,
27        ADM_SIG0 = ADM_COUNTER_BASE + 0,
28        ADM_SIG1 = ADM_COUNTER_BASE + 1,
29    ADM_PHY_BASE = 0x200,
30#define ADM_PHY_PORT(n) (ADM_PHY_BASE + (0x20 * n))
31};
32
33/* Chip identification patterns */
34#define ADM_SIG0_MASK 0xfff0
35#define ADM_SIG0_VAL 0x1020
36#define ADM_SIG1_MASK 0xffff
37#define ADM_SIG1_VAL 0x0007
38
39enum {
40    ADM_PHYCFG_COLTST = (1 << 7), /* Enable collision test */
41    ADM_PHYCFG_DPLX = (1 << 8), /* Enable full duplex */
42    ADM_PHYCFG_ANEN_RST = (1 << 9), /* Restart auto negotiation (self clear) */
43    ADM_PHYCFG_ISO = (1 << 10), /* Isolate PHY */
44    ADM_PHYCFG_PDN = (1 << 11), /* Power down PHY */
45    ADM_PHYCFG_ANEN = (1 << 12), /* Enable auto negotiation */
46    ADM_PHYCFG_SPEED_100 = (1 << 13), /* Enable 100 Mbit/s */
47    ADM_PHYCFG_LPBK = (1 << 14), /* Enable loopback operation */
48    ADM_PHYCFG_RST = (1 << 15), /* Reset the port (self clear) */
49    ADM_PHYCFG_INIT = (
50        ADM_PHYCFG_RST |
51        ADM_PHYCFG_SPEED_100 |
52        ADM_PHYCFG_ANEN |
53        ADM_PHYCFG_ANEN_RST
54    )
55};
56
57enum {
58    ADM_PORTCFG_FC = (1 << 0), /* Enable 802.x flow control */
59    ADM_PORTCFG_AN = (1 << 1), /* Enable auto-negotiation */
60    ADM_PORTCFG_SPEED_100 = (1 << 2), /* Enable 100 Mbit/s */
61    ADM_PORTCFG_DPLX = (1 << 3), /* Enable full duplex */
62    ADM_PORTCFG_OT = (1 << 4), /* Output tagged packets */
63    ADM_PORTCFG_PD = (1 << 5), /* Port disable */
64    ADM_PORTCFG_TV_PRIO = (1 << 6), /* 0 = VLAN based priority
65                                          * 1 = TOS based priority */
66    ADM_PORTCFG_PPE = (1 << 7), /* Port based priority enable */
67    ADM_PORTCFG_PP_S = (1 << 8), /* Port based priority, 2 bits */
68    ADM_PORTCFG_PVID_BASE = (1 << 10), /* Primary VLAN id, 4 bits */
69    ADM_PORTCFG_FSE = (1 << 14), /* Fx select enable */
70    ADM_PORTCFG_CAM = (1 << 15), /* Crossover Auto MDIX */
71
72    ADM_PORTCFG_INIT = (
73        ADM_PORTCFG_FC |
74        ADM_PORTCFG_AN |
75        ADM_PORTCFG_SPEED_100 |
76        ADM_PORTCFG_DPLX |
77        ADM_PORTCFG_CAM
78    ),
79    ADM_PORTCFG_CPU = (
80        ADM_PORTCFG_FC |
81        ADM_PORTCFG_SPEED_100 |
82        ADM_PORTCFG_OT |
83        ADM_PORTCFG_DPLX
84    ),
85};
86
87#define ADM_PORTCFG_PPID(N) ((n & 0x3) << 8)
88#define ADM_PORTCFG_PVID(n) ((n & 0xf) << 10)
89
90static const u8 adm_portcfg[] = {
91    [0] = ADM_P0_CFG,
92    [1] = ADM_P1_CFG,
93    [2] = ADM_P2_CFG,
94    [3] = ADM_P3_CFG,
95    [4] = ADM_P4_CFG,
96    [5] = ADM_P5_CFG,
97};
98
99/*
100 * Split the register address in phy id and register
101 * it will get combined again by the mdio bus op
102 */
103#define PHYADDR(_reg) ((_reg >> 5) & 0xff), (_reg & 0x1f)
104
105#endif
106

Archive Download this file



interactive