drivers/wifi: Remove unnecessary data structure copy
[coreboot2.git] / src / soc / mediatek / common / pmif_spi.c
blob0ed44a041fdceab8c7bbc4cac4054a9684dddc25
1 /* SPDX-License-Identifier: GPL-2.0-only */
3 #include <console/console.h>
4 #include <device/mmio.h>
5 #include <soc/infracfg.h>
6 #include <soc/pll.h>
7 #include <soc/pmif_spi.h>
8 #include <soc/pmif_sw.h>
9 #include <timer.h>
11 /* PMIF, SPI_MODE_CTRL */
12 DEFINE_BIT(SPI_MODE_CTRL_VLD_SRCLK_EN_CTRL, 5)
13 DEFINE_BIT(SPI_MODE_CTRL_PMIF_RDY, 9)
14 DEFINE_BIT(SPI_MODE_CTRL_SRCLK_EN, 10)
15 DEFINE_BIT(SPI_MODE_CTRL_SRVOL_EN, 11)
17 /* PMIF, SLEEP_PROTECTION_CTRL */
18 DEFINE_BITFIELD(SPM_SLEEP_REQ_SEL, 1, 0)
19 DEFINE_BITFIELD(SCP_SLEEP_REQ_SEL, 10, 9)
21 /* PMIF, OTHER_INF_EN */
22 DEFINE_BITFIELD(INTGPSADCINF_EN, 5, 4)
24 /* PMIF, STAUPD_CTRL */
25 DEFINE_BITFIELD(STAUPD_CTRL_PRD, 3, 0)
26 DEFINE_BIT(STAUPD_CTRL_PMIC0_SIG_STA, 4)
27 DEFINE_BIT(STAUPD_CTRL_PMIC0_EINT_STA, 6)
29 /* SPIMST, Manual_Mode_Access */
30 DEFINE_BITFIELD(MAN_ACC_SPI_OP, 12, 8)
31 DEFINE_BIT(MAN_ACC_SPI_RW, 13)
33 static void pmif_spi_config(struct pmif *arb)
35 /* Set srclk_en always valid regardless of ulposc_sel_for_scp */
36 SET32_BITFIELDS(&arb->mtk_pmif->spi_mode_ctrl, SPI_MODE_CTRL_VLD_SRCLK_EN_CTRL, 0);
38 /* Set SPI mode controlled by srclk_en and srvol_en instead of pmif_rdy */
39 SET32_BITFIELDS(&arb->mtk_pmif->spi_mode_ctrl,
40 SPI_MODE_CTRL_SRCLK_EN, 1,
41 SPI_MODE_CTRL_SRVOL_EN, 1,
42 SPI_MODE_CTRL_PMIF_RDY, 0);
44 SET32_BITFIELDS(&arb->mtk_pmif->sleep_protection_ctrl, SPM_SLEEP_REQ_SEL, 0,
45 SCP_SLEEP_REQ_SEL, 0);
47 /* Enable SWINF for AP */
48 write32(&arb->mtk_pmif->inf_en, PMIF_SPI_AP);
50 /* Enable arbitration for SWINF for AP */
51 write32(&arb->mtk_pmif->arb_en, PMIF_SPI_AP);
53 /* Enable PMIF_SPI Command Issue */
54 write32(&arb->mtk_pmif->cmdissue_en, 1);
57 static int check_idle(void *addr, u32 expected)
59 u32 reg_rdata;
60 struct stopwatch sw;
62 stopwatch_init_usecs_expire(&sw, PMIF_WAIT_IDLE_US);
63 do {
64 reg_rdata = read32(addr);
65 if (stopwatch_expired(&sw))
66 return E_TIMEOUT;
67 } while ((reg_rdata & expected) != 0);
69 return 0;
72 static int reset_spislv(void)
74 u32 pmicspi_mst_dio_en_backup;
76 write32(&mtk_pmicspi_mst->wrap_en, 0);
77 write32(&mtk_pmicspi_mst->mux_sel, 1);
78 write32(&mtk_pmicspi_mst->man_en, 1);
79 pmicspi_mst_dio_en_backup = read32(&mtk_pmicspi_mst->dio_en);
80 write32(&mtk_pmicspi_mst->dio_en, 0);
82 SET32_BITFIELDS(&mtk_pmicspi_mst->man_acc, MAN_ACC_SPI_RW, OP_WR,
83 MAN_ACC_SPI_OP, OP_CSL);
84 /* Reset counter */
85 SET32_BITFIELDS(&mtk_pmicspi_mst->man_acc, MAN_ACC_SPI_RW, OP_WR,
86 MAN_ACC_SPI_OP, OP_OUTS);
87 SET32_BITFIELDS(&mtk_pmicspi_mst->man_acc, MAN_ACC_SPI_RW, OP_WR,
88 MAN_ACC_SPI_OP, OP_CSH);
90 * In order to pull CSN signal to PMIC,
91 * PMIC will count it then reset spi slave
93 SET32_BITFIELDS(&mtk_pmicspi_mst->man_acc, MAN_ACC_SPI_RW, OP_WR,
94 MAN_ACC_SPI_OP, OP_OUTS);
95 SET32_BITFIELDS(&mtk_pmicspi_mst->man_acc, MAN_ACC_SPI_RW, OP_WR,
96 MAN_ACC_SPI_OP, OP_OUTS);
97 SET32_BITFIELDS(&mtk_pmicspi_mst->man_acc, MAN_ACC_SPI_RW, OP_WR,
98 MAN_ACC_SPI_OP, OP_OUTS);
99 SET32_BITFIELDS(&mtk_pmicspi_mst->man_acc, MAN_ACC_SPI_RW, OP_WR,
100 MAN_ACC_SPI_OP, OP_OUTS);
102 /* Wait for PMIC SPI Master to be idle */
103 if (check_idle(&mtk_pmicspi_mst->other_busy_sta_0, SPIMST_STA)) {
104 printk(BIOS_ERR, "[%s] spi master busy, timeout\n", __func__);
105 return E_TIMEOUT;
108 write32(&mtk_pmicspi_mst->man_en, 0);
109 write32(&mtk_pmicspi_mst->mux_sel, 0);
110 write32(&mtk_pmicspi_mst->wrap_en, 1);
111 write32(&mtk_pmicspi_mst->dio_en, pmicspi_mst_dio_en_backup);
113 return 0;
116 static void init_reg_clock(struct pmif *arb)
118 pmif_spi_iocfg();
120 /* Configure SPI protocol */
121 write32(&mtk_pmicspi_mst->ext_ck_write, 1);
122 write32(&mtk_pmicspi_mst->ext_ck_read, 0);
123 write32(&mtk_pmicspi_mst->cshext_write, 0);
124 write32(&mtk_pmicspi_mst->cshext_read, 0);
125 write32(&mtk_pmicspi_mst->cslext_write, 0);
126 write32(&mtk_pmicspi_mst->cslext_read, 0x100);
128 /* Set Read Dummy Cycle Number (Slave Clock is 18MHz) */
129 arb->write(arb, DEFAULT_SLVID, PMIC_DEW_RDDMY_NO, DUMMY_READ_CYCLES);
130 write32(&mtk_pmicspi_mst->rddmy, DUMMY_READ_CYCLES);
132 /* Enable DIO mode */
133 arb->write(arb, DEFAULT_SLVID, PMIC_DEW_DIO_EN, 0x1);
135 /* Wait for completion of sending the commands */
136 if (check_idle(&arb->mtk_pmif->inf_busy_sta, PMIF_SPI_AP)) {
137 printk(BIOS_ERR, "[%s] pmif channel busy, timeout\n", __func__);
138 return;
141 if (check_idle(&arb->mtk_pmif->other_busy_sta_0, PMIF_CMD_STA)) {
142 printk(BIOS_ERR, "[%s] pmif cmd busy, timeout\n", __func__);
143 return;
146 if (check_idle(&mtk_pmicspi_mst->other_busy_sta_0, SPIMST_STA)) {
147 printk(BIOS_ERR, "[%s] spi master busy, timeout\n", __func__);
148 return;
151 write32(&mtk_pmicspi_mst->dio_en, 1);
154 static void init_spislv(struct pmif *arb)
156 /* Turn on SPI IO filter function */
157 arb->write(arb, DEFAULT_SLVID, PMIC_FILTER_CON0, SPI_FILTER);
158 /* Turn on SPI IO SMT function to improve noise immunity */
159 arb->write(arb, DEFAULT_SLVID, PMIC_SMT_CON1, SPI_SMT);
160 /* Turn off SPI IO pull function for power saving */
161 arb->write(arb, DEFAULT_SLVID, PMIC_GPIO_PULLEN0_CLR, SPI_PULL_DISABLE);
162 /* Enable SPI access in SODI-3.0 and Suspend modes */
163 arb->write(arb, DEFAULT_SLVID, PMIC_RG_SPI_CON0, 0x2);
164 /* Set SPI IO driving strength to 4 mA */
165 arb->write(arb, DEFAULT_SLVID, PMIC_DRV_CON1, SPI_DRIVING);
168 static int init_sistrobe(struct pmif *arb)
170 u32 rdata = 0;
171 int si_sample_ctrl;
172 /* Random data for testing */
173 const u32 test_data[30] = {
174 0x6996, 0x9669, 0x6996, 0x9669, 0x6996, 0x9669, 0x6996,
175 0x9669, 0x6996, 0x9669, 0x5AA5, 0xA55A, 0x5AA5, 0xA55A,
176 0x5AA5, 0xA55A, 0x5AA5, 0xA55A, 0x5AA5, 0xA55A, 0x1B27,
177 0x1B27, 0x1B27, 0x1B27, 0x1B27, 0x1B27, 0x1B27, 0x1B27,
178 0x1B27, 0x1B27
181 for (si_sample_ctrl = 0; si_sample_ctrl < 16; si_sample_ctrl++) {
182 write32(&mtk_pmicspi_mst->si_sampling_ctrl, si_sample_ctrl << 5);
184 arb->read(arb, DEFAULT_SLVID, PMIC_DEW_READ_TEST, &rdata);
185 if (rdata == DEFAULT_VALUE_READ_TEST)
186 break;
189 if (si_sample_ctrl == 16)
190 return E_CLK_EDGE;
192 if (si_sample_ctrl == 15)
193 return E_CLK_LAST_SETTING;
196 * Add the delay time of SPI data from PMIC to align the start boundary
197 * to current sampling clock edge.
199 for (int si_dly = 0; si_dly < 10; si_dly++) {
200 arb->write(arb, DEFAULT_SLVID, PMIC_RG_SPI_CON2, si_dly);
202 int start_boundary_found = 0;
203 for (int i = 0; i < ARRAY_SIZE(test_data); i++) {
204 arb->write(arb, DEFAULT_SLVID, PMIC_DEW_WRITE_TEST, test_data[i]);
205 arb->read(arb, DEFAULT_SLVID, PMIC_DEW_WRITE_TEST, &rdata);
206 if ((rdata & 0x7fff) != (test_data[i] & 0x7fff)) {
207 start_boundary_found = 1;
208 break;
211 if (start_boundary_found == 1)
212 break;
216 * Change the sampling clock edge to the next one which is the middle
217 * of SPI data window.
219 write32(&mtk_pmicspi_mst->si_sampling_ctrl, ++si_sample_ctrl << 5);
221 /* Read Test */
222 arb->read(arb, DEFAULT_SLVID, PMIC_DEW_READ_TEST, &rdata);
223 if (rdata != DEFAULT_VALUE_READ_TEST) {
224 printk(BIOS_ERR, "[%s] Failed for read test, data = %#x.\n",
225 __func__, rdata);
226 return E_READ_TEST_FAIL;
229 return 0;
232 static void init_staupd(struct pmif *arb)
234 /* Unlock SPI Slave registers */
235 arb->write(arb, DEFAULT_SLVID, PMIC_SPISLV_KEY, 0xbade);
237 /* Enable CRC of PMIC 0 */
238 arb->write(arb, DEFAULT_SLVID, PMIC_DEW_CRC_EN, 0x1);
240 /* Wait for completion of sending the commands */
241 if (check_idle(&arb->mtk_pmif->inf_busy_sta, PMIF_SPI_AP)) {
242 printk(BIOS_ERR, "[%s] pmif channel busy, timeout\n", __func__);
243 return;
246 if (check_idle(&arb->mtk_pmif->other_busy_sta_0, PMIF_CMD_STA)) {
247 printk(BIOS_ERR, "[%s] pmif cmd busy, timeout\n", __func__);
248 return;
251 if (check_idle(&mtk_pmicspi_mst->other_busy_sta_0, SPIMST_STA)) {
252 printk(BIOS_ERR, "[%s] spi master busy, timeout\n", __func__);
253 return;
256 /* Configure CRC of PMIC Interface */
257 write32(&arb->mtk_pmif->crc_ctrl, 0x1);
258 write32(&arb->mtk_pmif->sig_mode, 0x0);
260 /* Lock SPI Slave registers */
261 arb->write(arb, DEFAULT_SLVID, PMIC_SPISLV_KEY, 0x0);
263 /* Set up PMIC Siganature */
264 write32(&arb->mtk_pmif->pmic_sig_addr, PMIC_DEW_CRC_VAL);
266 /* Set up PMIC EINT */
267 write32(&arb->mtk_pmif->pmic_eint_sta_addr, PMIC_INT_STA);
269 SET32_BITFIELDS(&arb->mtk_pmif->staupd_ctrl,
270 STAUPD_CTRL_PRD, 5,
271 STAUPD_CTRL_PMIC0_SIG_STA, 1,
272 STAUPD_CTRL_PMIC0_EINT_STA, 1);
275 int pmif_spi_init(struct pmif *arb)
277 pmif_spi_config(arb);
279 /* Reset spislv */
280 if (reset_spislv())
281 return E_SPI_INIT_RESET_SPI;
283 /* Enable WRAP */
284 write32(&mtk_pmicspi_mst->wrap_en, 0x1);
286 /* SPI Waveform Configuration */
287 init_reg_clock(arb);
289 /* SPI Slave Configuration */
290 init_spislv(arb);
292 /* Input data calibration flow; */
293 if (init_sistrobe(arb)) {
294 printk(BIOS_ERR, "[%s] data calibration fail\n", __func__);
295 return E_SPI_INIT_SIDLY;
298 /* Lock SPISLV Registers */
299 arb->write(arb, DEFAULT_SLVID, PMIC_SPISLV_KEY, 0x0);
302 * Status update function initialization
303 * 1. Check signature using CRC (CRC 0 only)
304 * 2. Update EINT
305 * 3. Read back AUXADC thermal data for GPS
307 init_staupd(arb);
309 /* Configure PMIF Timer */
310 write32(&arb->mtk_pmif->timer_ctrl, 0x3);
312 /* Enable interfaces and arbitration */
313 write32(&arb->mtk_pmif->inf_en, PMIF_SPI_HW_INF | PMIF_SPI_MD |
314 PMIF_SPI_AP_SECURE | PMIF_SPI_AP);
316 write32(&arb->mtk_pmif->arb_en, PMIF_SPI_HW_INF | PMIF_SPI_MD | PMIF_SPI_AP_SECURE |
317 PMIF_SPI_AP | PMIF_SPI_STAUPD | PMIF_SPI_TSX_HW | PMIF_SPI_DCXO_HW);
319 /* Enable GPS AUXADC HW 0 and 1 */
320 SET32_BITFIELDS(&arb->mtk_pmif->other_inf_en, INTGPSADCINF_EN, 0x3);
322 /* Set INIT_DONE */
323 write32(&arb->mtk_pmif->init_done, 0x1);
325 return 0;