aboutsummaryrefslogtreecommitdiffstats
path: root/sam/applications/sam_e1/idt82v2081_regs.h
blob: a9bee8e821612e8764ef232891628b55872dd185 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
#ifndef _IDT82_REGS_H
#define _IDT82_REGS_H

/* Section 4.1 of Data Sheet */
enum idt82v2081_reg {
	IDT_REG_ID,	/* control */
	IDT_REG_RST,
	IDT_REG_GCF,
	IDT_REG_TERM,
	IDT_REG_JACF,
	IDT_REG_TCF0,	/* Tx path control */
	IDT_REG_TCF1,
	IDT_REG_TCF2,
	IDT_REG_TCF3,
	IDT_REG_TCF4,
	IDT_REG_RCF0,	/* Rx path control */
	IDT_REG_RCF1,
	IDT_REG_RCF2,
	IDT_REG_MAINT0,	/* Net Diag Ctrl */
	IDT_REG_MAINT1,
	IDT_REG_MAINT2,
	IDT_REG_MAINT3,
	IDT_REG_MAINT4,
	IDT_REG_MAINT5,
	IDT_REG_MAINT6,
	IDT_REG_INTM0,	/* Interrupt Control */
	IDT_REG_INTM1,
	IDT_REG_INTES,
	IDT_REG_STAT0,	/* Line Status */
	IDT_REG_STAT1,
	IDT_REG_INTS0,	/* Interrupt Status */
	IDT_REG_INTS1,
	IDT_REG_CNT0,	/* Counter */
	IDT_REG_CNT1,
};

#define IDT_GCF_T1E1_E1 	(0 << 2)
#define IDT_GCF_T1E1_T1 	(1 << 2)
#define IDT_GCF_T1E1_MASK 	(1 << 2)

#define IDT_TERM_T_SHIFT	3
#define IDT_TERM_T_MASK		(7 << IDT_TERM_T_SHIFT)
#define IDT_TERM_R_SHIFT	0
#define IDT_TERM_R_MASK		(7 << IDT_TERM_R_SHIFT)

#define IDT_TCF1_PULS_MASK	0xF

#define IDT_TCF2_SCAL_MASK	0x3F

#define IDT_RCF2_MG_MASK	3
#define IDT_RCF2_UPDW_SHIFT	2
#define IDT_RCF2_UPDW_MASK	(3 << IDT_TERM_INT_75)
#define IDT_RCF2_SLICE_SHIFT	4
#define IDT_RCF2_SLICE_MASK	(3 << IDT_RCF2_SLICE_SHIFT)

#define IDT_INTM0_EQ		(1 << 7)	/* equalizer out of range */
#define IDT_INTM0_IBLBA		(1 << 6)	/* in-band LB act detect */
#define IDT_INTM0_IBLBD		(1 << 5)	/* in-band LB deact detect */
#define IDT_INTM0_PRBS		(1 << 4)	/* prbs sync signal detect */
#define IDT_INTM0_TCLK		(1 << 3)	/* tclk loss */
#define IDT_INTM0_DF		(1 << 2)	/* driver failure */
#define IDT_INTM0_AIS		(1 << 1)	/* Alarm Indication Signal */
#define IDT_INTM0_LOS		(1 << 0)	/* Loss Of Signal */

#define IDT_INTM1_DAC_OV	(1 << 7)	/* DAC arithmetic overflow */
#define	IDT_INTM1_JA_OV		(1 << 6)	/* JA overflow */
#define IDT_INTM1_JA_UD		(1 << 5)	/* JA underflow */
#define IDT_INTM1_ERR		(1 << 4)	/* PRBS/QRBS logic error detect */
#define IDT_INTM1_EXZ		(1 << 3)	/* Receive excess zeros */
#define IDT_INTM1_CV		(1 << 2)	/* Receive error */
#define IDT_INTM1_TIMER		(1 << 1)	/* One second timer expiration */
#define IDT_INTM1_CNT		(1 << 0)	/* Counter overflow */

/* STAT0 == INTES == INTS0 == INTM0 */

/* INTS1 == INTM1 */

#define IDT_STAT1_RLP		(1 << 5)
#define IDT_STAT1_ATT_MASK	0x1F

#endif /* _IDT82_REGS_H */