ARM: tegra: colibri_t20: fix nand pinmux
[platform/kernel/u-boot.git] / arch / x86 / cpu / quark / mrc_util.h
1 /*
2  * Copyright (C) 2013, Intel Corporation
3  * Copyright (C) 2015, Bin Meng <bmeng.cn@gmail.com>
4  *
5  * Ported from Intel released Quark UEFI BIOS
6  * QuarkSocPkg/QuarkNorthCluster/MemoryInit/Pei
7  *
8  * SPDX-License-Identifier:     Intel
9  */
10
11 #ifndef _MRC_UTIL_H_
12 #define _MRC_UTIL_H_
13
14 /* Turn on this macro to enable MRC debugging output */
15 #undef  MRC_DEBUG
16
17 /* MRC Debug Support */
18 #define DPF             debug_cond
19
20 /* debug print type */
21
22 #ifdef MRC_DEBUG
23 #define D_ERROR         0x0001
24 #define D_INFO          0x0002
25 #define D_REGRD         0x0004
26 #define D_REGWR         0x0008
27 #define D_FCALL         0x0010
28 #define D_TRN           0x0020
29 #define D_TIME          0x0040
30 #else
31 #define D_ERROR         0
32 #define D_INFO          0
33 #define D_REGRD         0
34 #define D_REGWR         0
35 #define D_FCALL         0
36 #define D_TRN           0
37 #define D_TIME          0
38 #endif
39
40 #define ENTERFN(...)    debug_cond(D_FCALL, "<%s>\n", __func__)
41 #define LEAVEFN(...)    debug_cond(D_FCALL, "</%s>\n", __func__)
42 #define REPORTFN(...)   debug_cond(D_FCALL, "<%s/>\n", __func__)
43
44 /* Generic Register Bits */
45 #define BIT0            0x00000001
46 #define BIT1            0x00000002
47 #define BIT2            0x00000004
48 #define BIT3            0x00000008
49 #define BIT4            0x00000010
50 #define BIT5            0x00000020
51 #define BIT6            0x00000040
52 #define BIT7            0x00000080
53 #define BIT8            0x00000100
54 #define BIT9            0x00000200
55 #define BIT10           0x00000400
56 #define BIT11           0x00000800
57 #define BIT12           0x00001000
58 #define BIT13           0x00002000
59 #define BIT14           0x00004000
60 #define BIT15           0x00008000
61 #define BIT16           0x00010000
62 #define BIT17           0x00020000
63 #define BIT18           0x00040000
64 #define BIT19           0x00080000
65 #define BIT20           0x00100000
66 #define BIT21           0x00200000
67 #define BIT22           0x00400000
68 #define BIT23           0x00800000
69 #define BIT24           0x01000000
70 #define BIT25           0x02000000
71 #define BIT26           0x04000000
72 #define BIT27           0x08000000
73 #define BIT28           0x10000000
74 #define BIT29           0x20000000
75 #define BIT30           0x40000000
76 #define BIT31           0x80000000
77
78 /* Message Bus Port */
79 #define MEM_CTLR        0x01
80 #define HOST_BRIDGE     0x03
81 #define MEM_MGR         0x05
82 #define HTE             0x11
83 #define DDRPHY          0x12
84
85 /* number of sample points */
86 #define SAMPLE_CNT      3
87 /* number of PIs to increment per sample */
88 #define SAMPLE_DLY      26
89
90 enum {
91         /* indicates to decrease delays when looking for edge */
92         BACKWARD,
93         /* indicates to increase delays when looking for edge */
94         FORWARD
95 };
96
97 enum {
98         RCVN,
99         WDQS,
100         WDQX,
101         RDQS,
102         VREF,
103         WCMD,
104         WCTL,
105         WCLK,
106         MAX_ALGOS,
107 };
108
109 void mrc_write_mask(u32 unit, u32 addr, u32 data, u32 mask);
110 void mrc_alt_write_mask(u32 unit, u32 addr, u32 data, u32 mask);
111 void mrc_post_code(uint8_t major, uint8_t minor);
112 void delay_n(uint32_t ns);
113 void delay_u(uint32_t ms);
114 void select_mem_mgr(void);
115 void select_hte(void);
116 void dram_init_command(uint32_t data);
117 void dram_wake_command(void);
118 void training_message(uint8_t channel, uint8_t rank, uint8_t byte_lane);
119
120 void set_rcvn(uint8_t channel, uint8_t rank,
121               uint8_t byte_lane, uint32_t pi_count);
122 uint32_t get_rcvn(uint8_t channel, uint8_t rank, uint8_t byte_lane);
123 void set_rdqs(uint8_t channel, uint8_t rank,
124               uint8_t byte_lane, uint32_t pi_count);
125 uint32_t get_rdqs(uint8_t channel, uint8_t rank, uint8_t byte_lane);
126 void set_wdqs(uint8_t channel, uint8_t rank,
127               uint8_t byte_lane, uint32_t pi_count);
128 uint32_t get_wdqs(uint8_t channel, uint8_t rank, uint8_t byte_lane);
129 void set_wdq(uint8_t channel, uint8_t rank,
130              uint8_t byte_lane, uint32_t pi_count);
131 uint32_t get_wdq(uint8_t channel, uint8_t rank, uint8_t byte_lane);
132 void set_wcmd(uint8_t channel, uint32_t pi_count);
133 uint32_t get_wcmd(uint8_t channel);
134 void set_wclk(uint8_t channel, uint8_t rank, uint32_t pi_count);
135 uint32_t get_wclk(uint8_t channel, uint8_t rank);
136 void set_wctl(uint8_t channel, uint8_t rank, uint32_t pi_count);
137 uint32_t get_wctl(uint8_t channel, uint8_t rank);
138 void set_vref(uint8_t channel, uint8_t byte_lane, uint32_t setting);
139 uint32_t get_vref(uint8_t channel, uint8_t byte_lane);
140
141 uint32_t get_addr(uint8_t channel, uint8_t rank);
142 uint32_t sample_dqs(struct mrc_params *mrc_params, uint8_t channel,
143                     uint8_t rank, bool rcvn);
144 void find_rising_edge(struct mrc_params *mrc_params, uint32_t delay[],
145                       uint8_t channel, uint8_t rank, bool rcvn);
146 uint32_t byte_lane_mask(struct mrc_params *mrc_params);
147 uint32_t check_rw_coarse(struct mrc_params *mrc_params, uint32_t address);
148 uint32_t check_bls_ex(struct mrc_params *mrc_params, uint32_t address);
149 void lfsr32(uint32_t *lfsr_ptr);
150 void clear_pointers(void);
151 void print_timings(struct mrc_params *mrc_params);
152
153 #endif /* _MRC_UTIL_H_ */