1 /*
2  * Copyright (c) 2019 Intel Corporation
3  * Copyright (c) 2021 Microchip Technology Inc.
4  *
5  * SPDX-License-Identifier: Apache-2.0
6  */
7 
8 #define DT_DRV_COMPAT microchip_xec_espi_v2
9 
10 #include <zephyr/kernel.h>
11 #include <soc.h>
12 #include <errno.h>
13 #include <zephyr/drivers/espi.h>
14 #include <zephyr/drivers/clock_control/mchp_xec_clock_control.h>
15 #include <zephyr/drivers/interrupt_controller/intc_mchp_xec_ecia.h>
16 #include <zephyr/dt-bindings/interrupt-controller/mchp-xec-ecia.h>
17 #include <zephyr/logging/log.h>
18 #include <zephyr/sys/sys_io.h>
19 #include <zephyr/sys/util.h>
20 #include <zephyr/irq.h>
21 #include "espi_utils.h"
22 #include "espi_mchp_xec_v2.h"
23 
24 /* Minimum delay before acknowledging a virtual wire */
25 #define ESPI_XEC_VWIRE_ACK_DELAY	10ul
26 
27 /* Maximum timeout to transmit a virtual wire packet.
28  * 10 ms expressed in multiples of 100us
29  */
30 #define ESPI_XEC_VWIRE_SEND_TIMEOUT	100ul
31 
32 #define VW_MAX_GIRQS			2ul
33 
34 /* 200ms */
35 #define MAX_OOB_TIMEOUT			200ul
36 /* 1s */
37 #define MAX_FLASH_TIMEOUT		1000ul
38 
39 /* While issuing flash erase command, it should be ensured that the transfer
40  * length specified is non-zero.
41  */
42 #define ESPI_FLASH_ERASE_DUMMY		0x01ul
43 
44 /* OOB maximum address configuration */
45 #define ESPI_XEC_OOB_ADDR_MSW		0x1ffful
46 #define ESPI_XEC_OOB_ADDR_LSW		0xfffful
47 
48 /* OOB Rx length */
49 #define ESPI_XEC_OOB_RX_LEN		0x7f00ul
50 
51 /* Espi peripheral has 3 uart ports */
52 #define ESPI_PERIPHERAL_UART_PORT0	0
53 #define ESPI_PERIPHERAL_UART_PORT1	1
54 
55 #define UART_DEFAULT_IRQ_POS		2u
56 #define UART_DEFAULT_IRQ		BIT(UART_DEFAULT_IRQ_POS)
57 
58 LOG_MODULE_REGISTER(espi, CONFIG_ESPI_LOG_LEVEL);
59 
60 #define ESPI_XEC_REG_BASE(dev)						\
61 	((struct espi_iom_regs *)ESPI_XEC_CONFIG(dev)->base_addr)
62 
63 #define ESPI_XEC_MSVW_REG_BASE(dev)					\
64 	((struct espi_msvw_ar_regs *)(ESPI_XEC_CONFIG(dev)->vw_base_addr))
65 
66 #define ESPI_XEC_SMVW_REG_OFS	0x200
67 
68 #define ESPI_XEC_SMVW_REG_BASE(dev)					\
69 	((struct espi_smvw_ar_regs *)					\
70 	(ESPI_XEC_CONFIG(dev)->vw_base_addr + ESPI_XEC_SMVW_REG_OFS))
71 
72 /* PCR */
73 #define XEC_PCR_REG_BASE						\
74 	((struct pcr_regs *)(DT_REG_ADDR(DT_NODELABEL(pcr))))
75 
76 /* Microchip canonical virtual wire mapping
77  * ------------------------------------------------------------------------|
78  * VW Idx | VW reg | SRC_ID3      | SRC_ID2      | SRC_ID1   | SRC_ID0     |
79  * ------------------------------------------------------------------------|
80  * System Event Virtual Wires
81  * ------------------------------------------------------------------------|
82  *  2h    | MSVW00 | res          | SLP_S5#      | SLP_S4#   | SLP_S3#     |
83  *  3h    | MSVW01 | res          | OOB_RST_WARN | PLTRST#   | SUS_STAT#   |
84  *  4h    | SMVW00 | PME#         | WAKE#        | res       | OOB_RST_ACK |
85  *  5h    | SMVW01 | SLV_BOOT_STS | ERR_NONFATAL | ERR_FATAL | SLV_BT_DONE |
86  *  6h    | SMVW02 | HOST_RST_ACK | RCIN#        | SMI#      | SCI#        |
87  *  7h    | MSVW02 | res          | NMIOUT#      | SMIOUT#   | HOS_RST_WARN|
88  * ------------------------------------------------------------------------|
89  * Platform specific virtual wires
90  * ------------------------------------------------------------------------|
91  *  40h   | SMVW03 | res          | res          | DNX_ACK   | SUS_ACK#    |
92  *  41h   | MSVW03 | SLP_A#       | res          | SUS_PDNACK| SUS_WARN#   |
93  *  42h   | MSVW04 | res          | res          | SLP_WLAN# | SLP_LAN#    |
94  *  43h   | MSVW05 | generic      | generic      | generic   | generic     |
95  *  44h   | MSVW06 | generic      | generic      | generic   | generic     |
96  *  45h   | SMVW04 | generic      | generic      | generic   | generic     |
97  *  46h   | SMVW05 | generic      | generic      | generic   | generic     |
98  *  47h   | MSVW07 | res          | res          | res       | HOST_C10    |
99  *  4Ah   | MSVW08 | res          | res          | DNX_WARN  | res         |
100  * These are configurable by overriding device tree vw routing             |
101  *  50h   | SMVW06 | ocb_3        | ocb_2        | ocb_1     | ocb_0       |
102  *  51h   | SMVW07 | gpio_7       | gpio_6       | gpio_5    | gpio_4      |
103  *  52h   | SMVW08 | gpio_11      | gpio_10      | gpio_9    | gpio_8      |
104  */
105 static const struct xec_signal vw_tbl[] = {
106 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_SLP_S3, vw_slp_s3_n),
107 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_SLP_S4, vw_slp_s4_n),
108 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_SLP_S5, vw_slp_s5_n),
109 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_OOB_RST_WARN, vw_oob_rst_warn),
110 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_PLTRST, vw_pltrst_n),
111 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_SUS_STAT, vw_sus_stat_n),
112 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_HOST_RST_WARN, vw_host_rst_warn),
113 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_NMIOUT, vw_nmiout_n),
114 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_SMIOUT, vw_smiout_n),
115 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_SLP_A, vw_slp_a_n),
116 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_SUS_PWRDN_ACK, vw_sus_pwrdn_ack),
117 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_SUS_WARN, vw_sus_warn_n),
118 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_SLP_WLAN, vw_slp_wlan_n),
119 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_SLP_LAN, vw_slp_lan_n),
120 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_HOST_C10, vw_host_c10),
121 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_DNX_WARN, vw_dnx_warn),
122 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_PME, vw_pme_n),
123 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_WAKE, vw_wake_n),
124 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_OOB_RST_ACK, vw_oob_rst_ack),
125 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_BOOT_STS, vw_target_boot_status),
126 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_ERR_NON_FATAL, vw_error_non_fatal),
127 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_ERR_FATAL, vw_error_fatal),
128 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_BOOT_DONE, vw_target_boot_done),
129 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_HOST_RST_ACK, vw_host_rst_ack),
130 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_RST_CPU_INIT, vw_rcin_n),
131 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_SMI, vw_smi_n),
132 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_SCI, vw_sci_n),
133 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_DNX_ACK, vw_dnx_ack),
134 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_SUS_ACK, vw_sus_ack_n),
135 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_GPIO_0, vw_t2c_gpio_0),
136 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_GPIO_1, vw_t2c_gpio_1),
137 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_GPIO_2, vw_t2c_gpio_2),
138 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_GPIO_3, vw_t2c_gpio_3),
139 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_GPIO_4, vw_t2c_gpio_4),
140 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_GPIO_5, vw_t2c_gpio_5),
141 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_GPIO_6, vw_t2c_gpio_6),
142 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_GPIO_7, vw_t2c_gpio_7),
143 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_GPIO_8, vw_t2c_gpio_8),
144 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_GPIO_9, vw_t2c_gpio_9),
145 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_GPIO_10, vw_t2c_gpio_10),
146 	MCHP_DT_ESPI_VW_ENTRY(ESPI_VWIRE_SIGNAL_TARGET_GPIO_11, vw_t2c_gpio_11),
147 };
148 
149 /* Buffer size are expressed in bytes */
150 #ifdef CONFIG_ESPI_OOB_CHANNEL
151 static uint32_t target_rx_mem[CONFIG_ESPI_OOB_BUFFER_SIZE >> 2];
152 static uint32_t target_tx_mem[CONFIG_ESPI_OOB_BUFFER_SIZE >> 2];
153 #endif
154 #ifdef CONFIG_ESPI_FLASH_CHANNEL
155 static uint32_t target_mem[CONFIG_ESPI_FLASH_BUFFER_SIZE >> 2];
156 #endif
157 
xec_msvw_addr(const struct device * dev,uint8_t vw_index)158 static inline uintptr_t xec_msvw_addr(const struct device *dev,
159 				      uint8_t vw_index)
160 {
161 	uintptr_t vwbase = ESPI_XEC_CONFIG(dev)->vw_base_addr;
162 
163 	return vwbase + vw_index * sizeof(struct espi_msvw_reg);
164 }
165 
xec_smvw_addr(const struct device * dev,uint8_t vw_index)166 static inline uintptr_t xec_smvw_addr(const struct device *dev,
167 				      uint8_t vw_index)
168 {
169 	uintptr_t vwbase = ESPI_XEC_CONFIG(dev)->vw_base_addr;
170 
171 	vwbase += ESPI_XEC_SMVW_REG_OFS;
172 	return vwbase + vw_index * sizeof(struct espi_smvw_reg);
173 }
174 
espi_xec_configure(const struct device * dev,struct espi_cfg * cfg)175 static int espi_xec_configure(const struct device *dev, struct espi_cfg *cfg)
176 {
177 	struct espi_iom_regs *iom_regs = ESPI_XEC_REG_BASE(dev);
178 	uint8_t iomode = 0;
179 	uint8_t cap0 = iom_regs->CAP0;
180 	uint8_t cap1 = iom_regs->CAP1;
181 	uint8_t cur_iomode = (cap1 & MCHP_ESPI_GBL_CAP1_IO_MODE_MASK) >>
182 			   MCHP_ESPI_GBL_CAP1_IO_MODE_POS;
183 
184 	/* Set frequency */
185 	cap1 &= ~MCHP_ESPI_GBL_CAP1_MAX_FREQ_MASK;
186 
187 	switch (cfg->max_freq) {
188 	case 20:
189 		cap1 |= MCHP_ESPI_GBL_CAP1_MAX_FREQ_20M;
190 		break;
191 	case 25:
192 		cap1 |= MCHP_ESPI_GBL_CAP1_MAX_FREQ_25M;
193 		break;
194 	case 33:
195 		cap1 |= MCHP_ESPI_GBL_CAP1_MAX_FREQ_33M;
196 		break;
197 	case 50:
198 		cap1 |= MCHP_ESPI_GBL_CAP1_MAX_FREQ_50M;
199 		break;
200 	case 66:
201 		cap1 |= MCHP_ESPI_GBL_CAP1_MAX_FREQ_66M;
202 		break;
203 	default:
204 		return -EINVAL;
205 	}
206 
207 	/* Set IO mode */
208 	iomode = (cfg->io_caps >> 1);
209 	if (iomode > 3) {
210 		return -EINVAL;
211 	}
212 
213 	if (iomode != cur_iomode) {
214 		cap1 &= ~(MCHP_ESPI_GBL_CAP1_IO_MODE_MASK0 <<
215 			MCHP_ESPI_GBL_CAP1_IO_MODE_POS);
216 		cap1 |= (iomode << MCHP_ESPI_GBL_CAP1_IO_MODE_POS);
217 	}
218 
219 	/* Validate and translate eSPI API channels to MEC capabilities */
220 	cap0 &= ~MCHP_ESPI_GBL_CAP0_MASK;
221 	if (cfg->channel_caps & ESPI_CHANNEL_PERIPHERAL) {
222 		if (IS_ENABLED(CONFIG_ESPI_PERIPHERAL_CHANNEL)) {
223 			cap0 |= MCHP_ESPI_GBL_CAP0_PC_SUPP;
224 		} else {
225 			return -EINVAL;
226 		}
227 	}
228 
229 	if (cfg->channel_caps & ESPI_CHANNEL_VWIRE) {
230 		if (IS_ENABLED(CONFIG_ESPI_VWIRE_CHANNEL)) {
231 			cap0 |= MCHP_ESPI_GBL_CAP0_VW_SUPP;
232 		} else {
233 			return -EINVAL;
234 		}
235 	}
236 
237 	if (cfg->channel_caps & ESPI_CHANNEL_OOB) {
238 		if (IS_ENABLED(CONFIG_ESPI_OOB_CHANNEL)) {
239 			cap0 |= MCHP_ESPI_GBL_CAP0_OOB_SUPP;
240 		} else {
241 			return -EINVAL;
242 		}
243 	}
244 
245 	if (cfg->channel_caps & ESPI_CHANNEL_FLASH) {
246 		if (IS_ENABLED(CONFIG_ESPI_FLASH_CHANNEL)) {
247 			cap0 |= MCHP_ESPI_GBL_CAP0_FC_SUPP;
248 		} else {
249 			LOG_ERR("Flash channel not supported");
250 			return -EINVAL;
251 		}
252 	}
253 
254 	iom_regs->CAP0 = cap0;
255 	iom_regs->CAP1 = cap1;
256 
257 	/* Activate the eSPI block *.
258 	 * Need to guarantee that this register is configured before RSMRST#
259 	 * de-assertion and after pinmux
260 	 */
261 	iom_regs->ACTV = 1;
262 	LOG_DBG("eSPI block activated successfully");
263 
264 	return 0;
265 }
266 
espi_xec_channel_ready(const struct device * dev,enum espi_channel ch)267 static bool espi_xec_channel_ready(const struct device *dev,
268 				   enum espi_channel ch)
269 {
270 	struct espi_iom_regs *iom_regs = ESPI_XEC_REG_BASE(dev);
271 	bool sts;
272 
273 	switch (ch) {
274 	case ESPI_CHANNEL_PERIPHERAL:
275 		sts = iom_regs->PCRDY & MCHP_ESPI_PC_READY;
276 		break;
277 	case ESPI_CHANNEL_VWIRE:
278 		sts = iom_regs->VWRDY & MCHP_ESPI_VW_READY;
279 		break;
280 	case ESPI_CHANNEL_OOB:
281 		sts = iom_regs->OOBRDY & MCHP_ESPI_OOB_READY;
282 		break;
283 	case ESPI_CHANNEL_FLASH:
284 		sts = iom_regs->FCRDY & MCHP_ESPI_FC_READY;
285 		break;
286 	default:
287 		sts = false;
288 		break;
289 	}
290 
291 	return sts;
292 }
293 
espi_xec_send_vwire(const struct device * dev,enum espi_vwire_signal signal,uint8_t level)294 static int espi_xec_send_vwire(const struct device *dev,
295 			       enum espi_vwire_signal signal, uint8_t level)
296 {
297 	struct xec_signal signal_info = vw_tbl[signal];
298 	uint8_t xec_id = signal_info.xec_reg_idx;
299 	uint8_t src_id = signal_info.bit;
300 	uint8_t dir;
301 	uintptr_t regaddr;
302 
303 	if ((src_id >= ESPI_VWIRE_SRC_ID_MAX) ||
304 	    (xec_id >= ESPI_MSVW_IDX_MAX)) {
305 		return -EINVAL;
306 	}
307 
308 	if (!(signal_info.flags & BIT(MCHP_DT_ESPI_VW_FLAG_STATUS_POS))) {
309 		return -EIO; /* VW not enabled */
310 	}
311 
312 	dir = (signal_info.flags >> MCHP_DT_ESPI_VW_FLAG_DIR_POS) & BIT(0);
313 
314 	if (dir == ESPI_CONTROLLER_TO_TARGET) {
315 		regaddr = xec_msvw_addr(dev, xec_id);
316 
317 		sys_write8(level, regaddr + MSVW_BI_SRC0 + src_id);
318 	}
319 
320 	if (dir == ESPI_TARGET_TO_CONTROLLER) {
321 		regaddr = xec_smvw_addr(dev, xec_id);
322 
323 		sys_write8(level, regaddr + SMVW_BI_SRC0 + src_id);
324 
325 		/* Ensure eSPI virtual wire packet is transmitted
326 		 * There is no interrupt, so need to poll register
327 		 */
328 		uint8_t rd_cnt = ESPI_XEC_VWIRE_SEND_TIMEOUT;
329 
330 		while (sys_read8(regaddr + SMVW_BI_SRC_CHG) && rd_cnt--) {
331 			k_busy_wait(100);
332 		}
333 	}
334 
335 	return 0;
336 }
337 
espi_xec_receive_vwire(const struct device * dev,enum espi_vwire_signal signal,uint8_t * level)338 static int espi_xec_receive_vwire(const struct device *dev,
339 				  enum espi_vwire_signal signal,
340 				  uint8_t *level)
341 {
342 	struct xec_signal signal_info = vw_tbl[signal];
343 	uint8_t xec_id = signal_info.xec_reg_idx;
344 	uint8_t src_id = signal_info.bit;
345 	uint8_t dir;
346 	uintptr_t regaddr;
347 
348 	if ((src_id >= ESPI_VWIRE_SRC_ID_MAX) ||
349 	    (xec_id >= ESPI_SMVW_IDX_MAX) || (level == NULL)) {
350 		return -EINVAL;
351 	}
352 
353 	if (!(signal_info.flags & BIT(MCHP_DT_ESPI_VW_FLAG_STATUS_POS))) {
354 		return -EIO; /* VW not enabled */
355 	}
356 
357 	dir = (signal_info.flags >> MCHP_DT_ESPI_VW_FLAG_DIR_POS) & BIT(0);
358 
359 	if (dir == ESPI_CONTROLLER_TO_TARGET) {
360 		regaddr = xec_msvw_addr(dev, xec_id);
361 		*level = sys_read8(regaddr + MSVW_BI_SRC0 + src_id) & BIT(0);
362 	}
363 
364 	if (dir == ESPI_TARGET_TO_CONTROLLER) {
365 		regaddr = xec_smvw_addr(dev, xec_id);
366 		*level = sys_read8(regaddr + SMVW_BI_SRC0 + src_id) & BIT(0);
367 	}
368 
369 	return 0;
370 }
371 
372 #ifdef CONFIG_ESPI_OOB_CHANNEL
espi_xec_send_oob(const struct device * dev,struct espi_oob_packet * pckt)373 static int espi_xec_send_oob(const struct device *dev,
374 			     struct espi_oob_packet *pckt)
375 {
376 	int ret;
377 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
378 	struct espi_xec_data *const data = ESPI_XEC_DATA(dev);
379 	uint8_t err_mask = MCHP_ESPI_OOB_TX_STS_IBERR |
380 			MCHP_ESPI_OOB_TX_STS_OVRUN |
381 			MCHP_ESPI_OOB_TX_STS_BADREQ;
382 
383 	LOG_DBG("%s", __func__);
384 
385 	if (!(regs->OOBTXSTS & MCHP_ESPI_OOB_TX_STS_CHEN)) {
386 		LOG_ERR("OOB channel is disabled");
387 		return -EIO;
388 	}
389 
390 	if (regs->OOBTXSTS & MCHP_ESPI_OOB_TX_STS_BUSY) {
391 		LOG_ERR("OOB channel is busy");
392 		return -EBUSY;
393 	}
394 
395 	if (pckt->len > CONFIG_ESPI_OOB_BUFFER_SIZE) {
396 		LOG_ERR("insufficient space");
397 		return -EINVAL;
398 	}
399 
400 	memcpy(target_tx_mem, pckt->buf, pckt->len);
401 
402 	regs->OOBTXL = pckt->len;
403 	regs->OOBTXC = MCHP_ESPI_OOB_TX_CTRL_START;
404 	LOG_DBG("%s %d", __func__, regs->OOBTXL);
405 
406 	/* Wait until ISR or timeout */
407 	ret = k_sem_take(&data->tx_lock, K_MSEC(MAX_OOB_TIMEOUT));
408 	if (ret == -EAGAIN) {
409 		return -ETIMEDOUT;
410 	}
411 
412 	if (regs->OOBTXSTS & err_mask) {
413 		LOG_ERR("Tx failed %x", regs->OOBTXSTS);
414 		regs->OOBTXSTS = err_mask;
415 		return -EIO;
416 	}
417 
418 	return 0;
419 }
420 
espi_xec_receive_oob(const struct device * dev,struct espi_oob_packet * pckt)421 static int espi_xec_receive_oob(const struct device *dev,
422 				struct espi_oob_packet *pckt)
423 {
424 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
425 	uint8_t err_mask = MCHP_ESPI_OOB_RX_STS_IBERR |
426 			MCHP_ESPI_OOB_RX_STS_OVRUN;
427 
428 	if (regs->OOBRXSTS & err_mask) {
429 		return -EIO;
430 	}
431 
432 #ifndef CONFIG_ESPI_OOB_CHANNEL_RX_ASYNC
433 	int ret;
434 	struct espi_xec_data *data = (struct espi_xec_data *)(dev->data);
435 
436 	/* Wait until ISR or timeout */
437 	ret = k_sem_take(&data->rx_lock, K_MSEC(MAX_OOB_TIMEOUT));
438 	if (ret == -EAGAIN) {
439 		return -ETIMEDOUT;
440 	}
441 #endif
442 	/* Check if buffer passed to driver can fit the received buffer */
443 	uint32_t rcvd_len = regs->OOBRXL & MCHP_ESPI_OOB_RX_LEN_MASK;
444 
445 	if (rcvd_len > pckt->len) {
446 		LOG_ERR("space rcvd %d vs %d", rcvd_len, pckt->len);
447 		return -EIO;
448 	}
449 
450 	pckt->len = rcvd_len;
451 	memcpy(pckt->buf, target_rx_mem, pckt->len);
452 	memset(target_rx_mem, 0, pckt->len);
453 
454 	/* Only after data has been copied from SRAM, indicate channel
455 	 * is available for next packet
456 	 */
457 	regs->OOBRXC |= MCHP_ESPI_OOB_RX_CTRL_AVAIL;
458 
459 	return 0;
460 }
461 #endif /* CONFIG_ESPI_OOB_CHANNEL */
462 
463 #ifdef CONFIG_ESPI_FLASH_CHANNEL
espi_xec_flash_read(const struct device * dev,struct espi_flash_packet * pckt)464 static int espi_xec_flash_read(const struct device *dev,
465 			       struct espi_flash_packet *pckt)
466 {
467 	int ret;
468 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
469 	struct espi_xec_data *data = (struct espi_xec_data *)(dev->data);
470 	uint32_t err_mask = MCHP_ESPI_FC_STS_IBERR |
471 			MCHP_ESPI_FC_STS_FAIL |
472 			MCHP_ESPI_FC_STS_OVFL |
473 			MCHP_ESPI_FC_STS_BADREQ;
474 
475 	LOG_DBG("%s", __func__);
476 
477 	if (!(regs->FCSTS & MCHP_ESPI_FC_STS_CHAN_EN)) {
478 		LOG_ERR("Flash channel is disabled");
479 		return -EIO;
480 	}
481 
482 	if (pckt->len > CONFIG_ESPI_FLASH_BUFFER_SIZE) {
483 		LOG_ERR("Invalid size request");
484 		return -EINVAL;
485 	}
486 
487 	regs->FCFA[1] = 0;
488 	regs->FCFA[0] = pckt->flash_addr;
489 	regs->FCBA[1] = 0;
490 	regs->FCBA[0] = (uint32_t)&target_mem[0];
491 	regs->FCLEN = pckt->len;
492 	regs->FCCTL = MCHP_ESPI_FC_CTRL_FUNC(MCHP_ESPI_FC_CTRL_RD0);
493 	regs->FCCTL |= MCHP_ESPI_FC_CTRL_START;
494 
495 	/* Wait until ISR or timeout */
496 	ret = k_sem_take(&data->flash_lock, K_MSEC(MAX_FLASH_TIMEOUT));
497 	if (ret == -EAGAIN) {
498 		LOG_ERR("%s timeout", __func__);
499 		return -ETIMEDOUT;
500 	}
501 
502 	if (regs->FCSTS & err_mask) {
503 		LOG_ERR("%s error %x", __func__, err_mask);
504 		regs->FCSTS = err_mask;
505 		return -EIO;
506 	}
507 
508 	memcpy(pckt->buf, target_mem, pckt->len);
509 
510 	return 0;
511 }
512 
espi_xec_flash_write(const struct device * dev,struct espi_flash_packet * pckt)513 static int espi_xec_flash_write(const struct device *dev,
514 				struct espi_flash_packet *pckt)
515 {
516 	int ret;
517 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
518 	uint32_t err_mask = MCHP_ESPI_FC_STS_IBERR |
519 			MCHP_ESPI_FC_STS_OVRUN |
520 			MCHP_ESPI_FC_STS_FAIL |
521 			MCHP_ESPI_FC_STS_BADREQ;
522 
523 	struct espi_xec_data *data = (struct espi_xec_data *)(dev->data);
524 
525 	LOG_DBG("%s", __func__);
526 
527 	if (sizeof(target_mem) < pckt->len) {
528 		LOG_ERR("Packet length is too big");
529 		return -ENOMEM;
530 	}
531 
532 	if (!(regs->FCSTS & MCHP_ESPI_FC_STS_CHAN_EN)) {
533 		LOG_ERR("Flash channel is disabled");
534 		return -EIO;
535 	}
536 
537 	if ((regs->FCCFG & MCHP_ESPI_FC_CFG_BUSY)) {
538 		LOG_ERR("Flash channel is busy");
539 		return -EBUSY;
540 	}
541 
542 	memcpy(target_mem, pckt->buf, pckt->len);
543 
544 	regs->FCFA[1] = 0;
545 	regs->FCFA[0] = pckt->flash_addr;
546 	regs->FCBA[1] = 0;
547 	regs->FCBA[0] = (uint32_t)&target_mem[0];
548 	regs->FCLEN = pckt->len;
549 	regs->FCCTL = MCHP_ESPI_FC_CTRL_FUNC(MCHP_ESPI_FC_CTRL_WR0);
550 	regs->FCCTL |= MCHP_ESPI_FC_CTRL_START;
551 
552 	/* Wait until ISR or timeout */
553 	ret = k_sem_take(&data->flash_lock, K_MSEC(MAX_FLASH_TIMEOUT));
554 	if (ret == -EAGAIN) {
555 		LOG_ERR("%s timeout", __func__);
556 		return -ETIMEDOUT;
557 	}
558 
559 	if (regs->FCSTS & err_mask) {
560 		LOG_ERR("%s err: %x", __func__, err_mask);
561 		regs->FCSTS = err_mask;
562 		return -EIO;
563 	}
564 
565 	return 0;
566 }
567 
espi_xec_flash_erase(const struct device * dev,struct espi_flash_packet * pckt)568 static int espi_xec_flash_erase(const struct device *dev,
569 				struct espi_flash_packet *pckt)
570 {
571 	int ret;
572 	uint32_t status;
573 	uint32_t err_mask = MCHP_ESPI_FC_STS_IBERR |
574 			MCHP_ESPI_FC_STS_OVRUN |
575 			MCHP_ESPI_FC_STS_FAIL |
576 			MCHP_ESPI_FC_STS_BADREQ;
577 
578 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
579 	struct espi_xec_data *data = (struct espi_xec_data *)(dev->data);
580 
581 	LOG_DBG("%s", __func__);
582 
583 	if (!(regs->FCSTS & MCHP_ESPI_FC_STS_CHAN_EN)) {
584 		LOG_ERR("Flash channel is disabled");
585 		return -EIO;
586 	}
587 
588 	if ((regs->FCCFG & MCHP_ESPI_FC_CFG_BUSY)) {
589 		LOG_ERR("Flash channel is busy");
590 		return -EBUSY;
591 	}
592 
593 	/* Clear status register */
594 	status = regs->FCSTS;
595 	regs->FCSTS = status;
596 
597 	regs->FCFA[1] = 0;
598 	regs->FCFA[0] = pckt->flash_addr;
599 	regs->FCLEN = ESPI_FLASH_ERASE_DUMMY;
600 	regs->FCCTL = MCHP_ESPI_FC_CTRL_FUNC(MCHP_ESPI_FC_CTRL_ERS0);
601 	regs->FCCTL |= MCHP_ESPI_FC_CTRL_START;
602 
603 	/* Wait until ISR or timeout */
604 	ret = k_sem_take(&data->flash_lock, K_MSEC(MAX_FLASH_TIMEOUT));
605 	if (ret == -EAGAIN) {
606 		LOG_ERR("%s timeout", __func__);
607 		return -ETIMEDOUT;
608 	}
609 
610 	if (regs->FCSTS & err_mask) {
611 		LOG_ERR("%s err: %x", __func__, err_mask);
612 		regs->FCSTS = err_mask;
613 		return -EIO;
614 	}
615 
616 	return 0;
617 }
618 #endif /* CONFIG_ESPI_FLASH_CHANNEL */
619 
espi_xec_manage_callback(const struct device * dev,struct espi_callback * callback,bool set)620 static int espi_xec_manage_callback(const struct device *dev,
621 				    struct espi_callback *callback, bool set)
622 {
623 	struct espi_xec_data *const data = ESPI_XEC_DATA(dev);
624 
625 	return espi_manage_callback(&data->callbacks, callback, set);
626 }
627 
628 #ifdef CONFIG_ESPI_AUTOMATIC_BOOT_DONE_ACKNOWLEDGE
send_slave_bootdone(const struct device * dev)629 static void send_slave_bootdone(const struct device *dev)
630 {
631 	int ret;
632 	uint8_t boot_done;
633 
634 	ret = espi_xec_receive_vwire(dev, ESPI_VWIRE_SIGNAL_TARGET_BOOT_DONE,
635 				     &boot_done);
636 	if (!ret && !boot_done) {
637 		/* SLAVE_BOOT_DONE & SLAVE_LOAD_STS have to be sent together */
638 		espi_xec_send_vwire(dev, ESPI_VWIRE_SIGNAL_TARGET_BOOT_STS, 1);
639 		espi_xec_send_vwire(dev, ESPI_VWIRE_SIGNAL_TARGET_BOOT_DONE, 1);
640 	}
641 }
642 #endif
643 
644 #ifdef CONFIG_ESPI_OOB_CHANNEL
espi_init_oob(const struct device * dev)645 static void espi_init_oob(const struct device *dev)
646 {
647 	struct espi_xec_config *const cfg = ESPI_XEC_CONFIG(dev);
648 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
649 
650 	/* Enable OOB Tx/Rx interrupts */
651 	mchp_xec_ecia_girq_src_en(cfg->irq_info_list[oob_up_girq_idx].gid,
652 				  cfg->irq_info_list[oob_up_girq_idx].gpos);
653 	mchp_xec_ecia_girq_src_en(cfg->irq_info_list[oob_dn_girq_idx].gid,
654 				  cfg->irq_info_list[oob_dn_girq_idx].gpos);
655 
656 	regs->OOBTXA[1] = 0;
657 	regs->OOBRXA[1] = 0;
658 	regs->OOBTXA[0] = (uint32_t)&target_tx_mem[0];
659 	regs->OOBRXA[0] = (uint32_t)&target_rx_mem[0];
660 	regs->OOBRXL = 0x00FF0000;
661 
662 	/* Enable OOB Tx channel enable change status interrupt */
663 	regs->OOBTXIEN |= MCHP_ESPI_OOB_TX_IEN_CHG_EN |
664 			  MCHP_ESPI_OOB_TX_IEN_DONE;
665 
666 	/* Enable Rx channel to receive data any time
667 	 * there are case where OOB is not initiated by a previous OOB Tx
668 	 */
669 	regs->OOBRXIEN |= MCHP_ESPI_OOB_RX_IEN;
670 	regs->OOBRXC |= MCHP_ESPI_OOB_RX_CTRL_AVAIL;
671 }
672 #endif
673 
674 #ifdef CONFIG_ESPI_FLASH_CHANNEL
espi_init_flash(const struct device * dev)675 static void espi_init_flash(const struct device *dev)
676 {
677 	struct espi_xec_config *const cfg = ESPI_XEC_CONFIG(dev);
678 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
679 
680 	LOG_DBG("%s", __func__);
681 
682 	/* Need to clear status done when ROM boots in MAF */
683 	LOG_DBG("%s ESPI_FC_REGS->CFG %X", __func__, regs->FCCFG);
684 	regs->FCSTS = MCHP_ESPI_FC_STS_DONE;
685 
686 	/* Enable interrupts */
687 	mchp_xec_ecia_girq_src_en(cfg->irq_info_list[fc_girq_idx].gid,
688 				  cfg->irq_info_list[fc_girq_idx].gpos);
689 	regs->FCIEN |= MCHP_ESPI_FC_IEN_CHG_EN;
690 	regs->FCIEN |= MCHP_ESPI_FC_IEN_DONE;
691 }
692 #endif
693 
espi_bus_init(const struct device * dev)694 static void espi_bus_init(const struct device *dev)
695 {
696 	struct espi_xec_config *const cfg = ESPI_XEC_CONFIG(dev);
697 
698 	/* Enable bus interrupts */
699 	mchp_xec_ecia_girq_src_en(cfg->irq_info_list[pc_girq_idx].gid,
700 				  cfg->irq_info_list[pc_girq_idx].gpos);
701 	mchp_xec_ecia_girq_src_en(cfg->irq_info_list[rst_girq_idx].gid,
702 				  cfg->irq_info_list[rst_girq_idx].gpos);
703 	mchp_xec_ecia_girq_src_en(cfg->irq_info_list[vw_ch_en_girq_idx].gid,
704 				  cfg->irq_info_list[vw_ch_en_girq_idx].gpos);
705 }
706 
707 /* Clear specified eSPI bus GIRQ status */
xec_espi_bus_intr_clr(const struct device * dev,enum xec_espi_girq_idx idx)708 static int xec_espi_bus_intr_clr(const struct device *dev,
709 				 enum xec_espi_girq_idx idx)
710 {
711 	struct espi_xec_config *const cfg = ESPI_XEC_CONFIG(dev);
712 
713 	if (idx >= max_girq_idx) {
714 		return -EINVAL;
715 	}
716 
717 	mchp_xec_ecia_girq_src_clr(cfg->irq_info_list[idx].gid,
718 				   cfg->irq_info_list[idx].gpos);
719 
720 	return 0;
721 }
722 
723 /* Enable/disable specified eSPI bus GIRQ */
xec_espi_bus_intr_ctl(const struct device * dev,enum xec_espi_girq_idx idx,uint8_t enable)724 static int xec_espi_bus_intr_ctl(const struct device *dev,
725 				 enum xec_espi_girq_idx idx,
726 				 uint8_t enable)
727 {
728 	struct espi_xec_config *const cfg = ESPI_XEC_CONFIG(dev);
729 
730 	if (idx >= max_girq_idx) {
731 		return -EINVAL;
732 	}
733 
734 	if (enable) {
735 		mchp_xec_ecia_girq_src_en(cfg->irq_info_list[idx].gid,
736 					  cfg->irq_info_list[idx].gpos);
737 	} else {
738 		mchp_xec_ecia_girq_src_dis(cfg->irq_info_list[idx].gid,
739 					   cfg->irq_info_list[idx].gpos);
740 	}
741 
742 	return 0;
743 }
744 
espi_rst_isr(const struct device * dev)745 static void espi_rst_isr(const struct device *dev)
746 {
747 	uint8_t rst_sts;
748 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
749 	struct espi_xec_data *const data = ESPI_XEC_DATA(dev);
750 	struct espi_event evt = { ESPI_BUS_RESET, 0, 0 };
751 
752 #ifdef ESPI_XEC_V2_DEBUG
753 	data->espi_rst_count++;
754 #endif
755 
756 	rst_sts = regs->ERIS;
757 
758 	/* eSPI reset status register is clear on write register */
759 	regs->ERIS = MCHP_ESPI_RST_ISTS;
760 	/* clear GIRQ latched status */
761 	xec_espi_bus_intr_clr(dev, rst_girq_idx);
762 
763 	if (rst_sts & MCHP_ESPI_RST_ISTS) {
764 		if (rst_sts & MCHP_ESPI_RST_ISTS_PIN_RO_HI) {
765 			evt.evt_data = 1;
766 		} else {
767 			evt.evt_data = 0;
768 		}
769 
770 		espi_send_callbacks(&data->callbacks, dev, evt);
771 #ifdef CONFIG_ESPI_OOB_CHANNEL
772 		espi_init_oob(dev);
773 #endif
774 #ifdef CONFIG_ESPI_FLASH_CHANNEL
775 		espi_init_flash(dev);
776 #endif
777 		espi_bus_init(dev);
778 	}
779 }
780 
781 /* Configure sub devices BAR address if not using default I/O based address
782  * then make its BAR valid.
783  * Refer to microchip eSPI I/O base addresses for default values
784  */
config_sub_devices(const struct device * dev)785 static void config_sub_devices(const struct device *dev)
786 {
787 	xec_host_dev_init(dev);
788 }
789 
configure_sirq(const struct device * dev)790 static void configure_sirq(const struct device *dev)
791 {
792 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
793 
794 #ifdef CONFIG_ESPI_PERIPHERAL_UART
795 	switch (CONFIG_ESPI_PERIPHERAL_UART_SOC_MAPPING) {
796 	case ESPI_PERIPHERAL_UART_PORT0:
797 		regs->SIRQ[SIRQ_UART0] = UART_DEFAULT_IRQ;
798 		break;
799 	case ESPI_PERIPHERAL_UART_PORT1:
800 		regs->SIRQ[SIRQ_UART1] = UART_DEFAULT_IRQ;
801 		break;
802 	}
803 #endif
804 #ifdef CONFIG_ESPI_PERIPHERAL_8042_KBC
805 	regs->SIRQ[SIRQ_KBC_KIRQ] = 1;
806 	regs->SIRQ[SIRQ_KBC_MIRQ] = 12;
807 #endif
808 }
809 
setup_espi_io_config(const struct device * dev,uint16_t host_address)810 static void setup_espi_io_config(const struct device *dev,
811 				 uint16_t host_address)
812 {
813 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
814 
815 	regs->IOHBAR[IOB_IOC] = (host_address << 16) |
816 				MCHP_ESPI_IO_BAR_HOST_VALID;
817 
818 	config_sub_devices(dev);
819 	configure_sirq(dev);
820 
821 	regs->PCSTS = MCHP_ESPI_PC_STS_EN_CHG |
822 		      MCHP_ESPI_PC_STS_BM_EN_CHG_POS;
823 	regs->PCIEN |= MCHP_ESPI_PC_IEN_EN_CHG;
824 	regs->PCRDY = 1;
825 }
826 
827 /*
828  * Write the interrupt select field of the specified MSVW source.
829  * Each MSVW controls 4 virtual wires.
830  */
xec_espi_vw_intr_ctrl(const struct device * dev,uint8_t msvw_idx,uint8_t src_id,uint8_t intr_mode)831 static int xec_espi_vw_intr_ctrl(const struct device *dev, uint8_t msvw_idx,
832 				 uint8_t src_id, uint8_t intr_mode)
833 {
834 	struct espi_msvw_ar_regs *regs = ESPI_XEC_MSVW_REG_BASE(dev);
835 
836 
837 	if ((msvw_idx >= ESPI_NUM_MSVW) || (src_id > 3)) {
838 		return -EINVAL;
839 	}
840 
841 	uintptr_t msvw_addr = (uintptr_t)&regs->MSVW[msvw_idx];
842 
843 	sys_write8(intr_mode, msvw_addr + MSVW_BI_IRQ_SEL0 + src_id);
844 
845 	return 0;
846 }
847 
espi_pc_isr(const struct device * dev)848 static void espi_pc_isr(const struct device *dev)
849 {
850 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
851 	uint32_t status = regs->PCSTS;
852 	struct espi_event evt = { .evt_type = ESPI_BUS_EVENT_CHANNEL_READY,
853 				  .evt_details = ESPI_CHANNEL_PERIPHERAL,
854 				  .evt_data = 0 };
855 	struct espi_xec_data *data = (struct espi_xec_data *)(dev->data);
856 
857 	LOG_DBG("%s %x", __func__, status);
858 	if (status & MCHP_ESPI_PC_STS_BUS_ERR) {
859 		LOG_ERR("%s bus error", __func__);
860 		regs->PCSTS = MCHP_ESPI_PC_STS_BUS_ERR;
861 	}
862 
863 	if (status & MCHP_ESPI_PC_STS_EN_CHG) {
864 		if (status & MCHP_ESPI_PC_STS_EN) {
865 			setup_espi_io_config(dev, MCHP_ESPI_IOBAR_INIT_DFLT);
866 		}
867 
868 		regs->PCSTS = MCHP_ESPI_PC_STS_EN_CHG;
869 	}
870 
871 	if (status & MCHP_ESPI_PC_STS_BM_EN_CHG) {
872 		if (status & MCHP_ESPI_PC_STS_BM_EN) {
873 			evt.evt_data = ESPI_PC_EVT_BUS_MASTER_ENABLE;
874 			LOG_WRN("%s BM change %x", __func__, status);
875 			espi_send_callbacks(&data->callbacks, dev, evt);
876 		}
877 
878 		regs->PCSTS = MCHP_ESPI_PC_STS_BM_EN_CHG;
879 	}
880 
881 	xec_espi_bus_intr_clr(dev, pc_girq_idx);
882 }
883 
espi_vw_chan_en_isr(const struct device * dev)884 static void espi_vw_chan_en_isr(const struct device *dev)
885 {
886 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
887 	struct espi_xec_data *const data = ESPI_XEC_DATA(dev);
888 	struct espi_event evt = { .evt_type = ESPI_BUS_EVENT_CHANNEL_READY,
889 				  .evt_details = ESPI_CHANNEL_VWIRE,
890 				  .evt_data = 0 };
891 	uint32_t status = regs->VWSTS;
892 
893 	if (status & MCHP_ESPI_VW_EN_STS_RO) {
894 		regs->VWRDY = 1;
895 		evt.evt_data = 1;
896 		/* VW channel interrupt can disabled at this point */
897 		xec_espi_bus_intr_ctl(dev, vw_ch_en_girq_idx, 0);
898 
899 #ifdef CONFIG_ESPI_AUTOMATIC_BOOT_DONE_ACKNOWLEDGE
900 		send_slave_bootdone(dev);
901 #endif
902 	}
903 
904 	espi_send_callbacks(&data->callbacks, dev, evt);
905 
906 	xec_espi_bus_intr_clr(dev, vw_ch_en_girq_idx);
907 }
908 
909 #ifdef CONFIG_ESPI_OOB_CHANNEL
espi_oob_down_isr(const struct device * dev)910 static void espi_oob_down_isr(const struct device *dev)
911 {
912 	uint32_t status;
913 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
914 	struct espi_xec_data *const data = ESPI_XEC_DATA(dev);
915 #ifdef CONFIG_ESPI_OOB_CHANNEL_RX_ASYNC
916 	struct espi_event evt = { .evt_type = ESPI_BUS_EVENT_OOB_RECEIVED,
917 				  .evt_details = 0,
918 				  .evt_data = 0 };
919 #endif
920 
921 	status = regs->OOBRXSTS;
922 
923 	LOG_DBG("%s %x", __func__, status);
924 	if (status & MCHP_ESPI_OOB_RX_STS_DONE) {
925 		/* Register is write-on-clear, ensure only 1 bit is affected */
926 		regs->OOBRXSTS = MCHP_ESPI_OOB_RX_STS_DONE;
927 
928 #ifndef CONFIG_ESPI_OOB_CHANNEL_RX_ASYNC
929 		k_sem_give(&data->rx_lock);
930 #else
931 		evt.evt_details = regs->OOBRXL &
932 				  MCHP_ESPI_OOB_RX_LEN_MASK;
933 		espi_send_callbacks(&data->callbacks, dev, evt);
934 #endif
935 	}
936 
937 	xec_espi_bus_intr_clr(dev, oob_dn_girq_idx);
938 }
939 
espi_oob_up_isr(const struct device * dev)940 static void espi_oob_up_isr(const struct device *dev)
941 {
942 	uint32_t status;
943 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
944 	struct espi_xec_data *const data = ESPI_XEC_DATA(dev);
945 	struct espi_event evt = { .evt_type = ESPI_BUS_EVENT_CHANNEL_READY,
946 				  .evt_details = ESPI_CHANNEL_OOB,
947 				  .evt_data = 0
948 				};
949 
950 	status = regs->OOBTXSTS;
951 	LOG_DBG("%s sts:%x", __func__, status);
952 
953 	if (status & MCHP_ESPI_OOB_TX_STS_DONE) {
954 		/* Register is write-on-clear, ensure only 1 bit is affected */
955 		status = regs->OOBTXSTS = MCHP_ESPI_OOB_TX_STS_DONE;
956 		k_sem_give(&data->tx_lock);
957 	}
958 
959 	if (status & MCHP_ESPI_OOB_TX_STS_CHG_EN) {
960 		if (status & MCHP_ESPI_OOB_TX_STS_CHEN) {
961 			espi_init_oob(dev);
962 			/* Indicate OOB channel is ready to eSPI host */
963 			regs->OOBRDY = 1;
964 			evt.evt_data = 1;
965 		}
966 
967 		status = regs->OOBTXSTS = MCHP_ESPI_OOB_TX_STS_CHG_EN;
968 		espi_send_callbacks(&data->callbacks, dev, evt);
969 	}
970 
971 	xec_espi_bus_intr_clr(dev, oob_up_girq_idx);
972 }
973 #endif
974 
975 #ifdef CONFIG_ESPI_FLASH_CHANNEL
espi_flash_isr(const struct device * dev)976 static void espi_flash_isr(const struct device *dev)
977 {
978 	uint32_t status;
979 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
980 	struct espi_xec_data *const data = ESPI_XEC_DATA(dev);
981 	struct espi_event evt = { .evt_type = ESPI_BUS_EVENT_CHANNEL_READY,
982 				  .evt_details = ESPI_CHANNEL_FLASH,
983 				  .evt_data = 0,
984 				};
985 
986 	status = regs->FCSTS;
987 	LOG_DBG("%s %x", __func__, status);
988 
989 	if (status & MCHP_ESPI_FC_STS_DONE) {
990 		/* Ensure to clear only relevant bit */
991 		regs->FCSTS = MCHP_ESPI_FC_STS_DONE;
992 
993 		k_sem_give(&data->flash_lock);
994 	}
995 
996 	if (status & MCHP_ESPI_FC_STS_CHAN_EN_CHG) {
997 		/* Ensure to clear only relevant bit */
998 		regs->FCSTS = MCHP_ESPI_FC_STS_CHAN_EN_CHG;
999 
1000 		if (status & MCHP_ESPI_FC_STS_CHAN_EN) {
1001 			espi_init_flash(dev);
1002 			/* Indicate flash channel is ready to eSPI master */
1003 			regs->FCRDY = MCHP_ESPI_FC_READY;
1004 			evt.evt_data = 1;
1005 		}
1006 
1007 		espi_send_callbacks(&data->callbacks, dev, evt);
1008 	}
1009 
1010 	xec_espi_bus_intr_clr(dev, fc_girq_idx);
1011 }
1012 #endif
1013 
1014 /* Send callbacks if enabled and track eSPI host system state */
notify_system_state(const struct device * dev,enum espi_vwire_signal signal)1015 static void notify_system_state(const struct device *dev,
1016 				enum espi_vwire_signal signal)
1017 {
1018 	struct espi_xec_data *const data = ESPI_XEC_DATA(dev);
1019 	struct espi_event evt = { ESPI_BUS_EVENT_VWIRE_RECEIVED, 0, 0 };
1020 	uint8_t status = 0;
1021 
1022 	espi_xec_receive_vwire(dev, signal, &status);
1023 	evt.evt_details = signal;
1024 	evt.evt_data = status;
1025 	espi_send_callbacks(&data->callbacks, dev, evt);
1026 }
1027 
notify_host_warning(const struct device * dev,enum espi_vwire_signal signal)1028 static void notify_host_warning(const struct device *dev,
1029 				enum espi_vwire_signal signal)
1030 {
1031 	uint8_t status;
1032 
1033 	espi_xec_receive_vwire(dev, signal, &status);
1034 
1035 	if (!IS_ENABLED(CONFIG_ESPI_AUTOMATIC_WARNING_ACKNOWLEDGE)) {
1036 		struct espi_xec_data *const data = ESPI_XEC_DATA(dev);
1037 		struct espi_event evt = {ESPI_BUS_EVENT_VWIRE_RECEIVED, 0, 0 };
1038 
1039 		evt.evt_details = signal;
1040 		evt.evt_data = status;
1041 		espi_send_callbacks(&data->callbacks, dev, evt);
1042 	} else {
1043 		k_busy_wait(ESPI_XEC_VWIRE_ACK_DELAY);
1044 		/* Some flows are dependent on awareness of client's driver
1045 		 * about these warnings in such cases these automatic response
1046 		 * should not be enabled.
1047 		 */
1048 		switch (signal) {
1049 		case ESPI_VWIRE_SIGNAL_HOST_RST_WARN:
1050 			espi_xec_send_vwire(dev,
1051 					    ESPI_VWIRE_SIGNAL_HOST_RST_ACK,
1052 					    status);
1053 			break;
1054 		case ESPI_VWIRE_SIGNAL_SUS_WARN:
1055 			espi_xec_send_vwire(dev, ESPI_VWIRE_SIGNAL_SUS_ACK,
1056 					    status);
1057 			break;
1058 		case ESPI_VWIRE_SIGNAL_OOB_RST_WARN:
1059 			espi_xec_send_vwire(dev, ESPI_VWIRE_SIGNAL_OOB_RST_ACK,
1060 					    status);
1061 			break;
1062 		case ESPI_VWIRE_SIGNAL_DNX_WARN:
1063 			espi_xec_send_vwire(dev, ESPI_VWIRE_SIGNAL_DNX_ACK,
1064 					    status);
1065 			break;
1066 		default:
1067 			break;
1068 		}
1069 	}
1070 }
1071 
notify_vw_status(const struct device * dev,enum espi_vwire_signal signal)1072 static void notify_vw_status(const struct device *dev,
1073 				enum espi_vwire_signal signal)
1074 {
1075 	struct espi_xec_data *const data = ESPI_XEC_DATA(dev);
1076 	struct espi_event evt = { ESPI_BUS_EVENT_VWIRE_RECEIVED, 0, 0 };
1077 	uint8_t status = 0;
1078 
1079 	espi_xec_receive_vwire(dev, signal, &status);
1080 	evt.evt_details = signal;
1081 	evt.evt_data = status;
1082 	espi_send_callbacks(&data->callbacks, dev, evt);
1083 }
1084 
1085 /*
1086  * VW handlers must have signature
1087  * typedef void (*mchp_xec_ecia_callback_t) (int girq_id, int src, void *user)
1088  * where parameter user is a pointer to const struct device
1089  * These handlers are registered to their respective GIRQ child device of the
1090  * ECIA driver.
1091  */
1092 
vw_slp3_handler(int girq_id,int src,void * user)1093 static void vw_slp3_handler(int girq_id, int src, void *user)
1094 {
1095 	const struct device *dev = (const struct device *)user;
1096 
1097 	notify_system_state(dev, ESPI_VWIRE_SIGNAL_SLP_S3);
1098 }
1099 
vw_slp4_handler(int girq_id,int src,void * user)1100 static void vw_slp4_handler(int girq_id, int src, void *user)
1101 {
1102 	const struct device *dev = (const struct device *)user;
1103 
1104 	notify_system_state(dev, ESPI_VWIRE_SIGNAL_SLP_S4);
1105 }
1106 
vw_slp5_handler(int girq_id,int src,void * user)1107 static void vw_slp5_handler(int girq_id, int src, void *user)
1108 {
1109 	const struct device *dev = (const struct device *)user;
1110 
1111 	notify_system_state(dev, ESPI_VWIRE_SIGNAL_SLP_S5);
1112 }
1113 
vw_host_rst_warn_handler(int girq_id,int src,void * user)1114 static void vw_host_rst_warn_handler(int girq_id, int src, void *user)
1115 {
1116 	const struct device *dev = (const struct device *)user;
1117 
1118 	notify_host_warning(dev, ESPI_VWIRE_SIGNAL_HOST_RST_WARN);
1119 }
1120 
vw_sus_warn_handler(int girq_id,int src,void * user)1121 static void vw_sus_warn_handler(int girq_id, int src, void *user)
1122 {
1123 	const struct device *dev = (const struct device *)user;
1124 
1125 	notify_host_warning(dev, ESPI_VWIRE_SIGNAL_SUS_WARN);
1126 }
1127 
vw_oob_rst_handler(int girq_id,int src,void * user)1128 static void vw_oob_rst_handler(int girq_id, int src, void *user)
1129 {
1130 	const struct device *dev = (const struct device *)user;
1131 
1132 	notify_host_warning(dev, ESPI_VWIRE_SIGNAL_OOB_RST_WARN);
1133 }
1134 
vw_sus_pwrdn_ack_handler(int girq_id,int src,void * user)1135 static void vw_sus_pwrdn_ack_handler(int girq_id, int src, void *user)
1136 {
1137 	const struct device *dev = (const struct device *)user;
1138 
1139 	notify_vw_status(dev, ESPI_VWIRE_SIGNAL_SUS_PWRDN_ACK);
1140 }
1141 
vw_sus_slp_a_handler(int girq_id,int src,void * user)1142 static void vw_sus_slp_a_handler(int girq_id, int src, void *user)
1143 {
1144 	const struct device *dev = (const struct device *)user;
1145 
1146 	notify_vw_status(dev, ESPI_VWIRE_SIGNAL_SLP_A);
1147 }
1148 
vw_sus_dnx_warn_handler(int girq_id,int src,void * user)1149 static void vw_sus_dnx_warn_handler(int girq_id, int src, void *user)
1150 {
1151 	const struct device *dev = (const struct device *)user;
1152 
1153 	notify_host_warning(dev, ESPI_VWIRE_SIGNAL_DNX_WARN);
1154 }
1155 
vw_pltrst_handler(int girq_id,int src,void * user)1156 static void vw_pltrst_handler(int girq_id, int src, void *user)
1157 {
1158 	const struct device *dev = (const struct device *)user;
1159 	struct espi_xec_data *const data = ESPI_XEC_DATA(dev);
1160 	struct espi_event evt = { ESPI_BUS_EVENT_VWIRE_RECEIVED,
1161 		ESPI_VWIRE_SIGNAL_PLTRST, 0
1162 	};
1163 	uint8_t status = 0;
1164 
1165 	espi_xec_receive_vwire(dev, ESPI_VWIRE_SIGNAL_PLTRST, &status);
1166 	if (status) {
1167 		setup_espi_io_config(dev, MCHP_ESPI_IOBAR_INIT_DFLT);
1168 	}
1169 
1170 	evt.evt_data = status;
1171 	espi_send_callbacks(&data->callbacks, dev, evt);
1172 }
1173 
vw_sus_stat_handler(int girq_id,int src,void * user)1174 static void vw_sus_stat_handler(int girq_id, int src, void *user)
1175 {
1176 	const struct device *dev = (const struct device *)user;
1177 
1178 	notify_host_warning(dev, ESPI_VWIRE_SIGNAL_SUS_STAT);
1179 }
1180 
vw_slp_wlan_handler(int girq_id,int src,void * user)1181 static void vw_slp_wlan_handler(int girq_id, int src, void *user)
1182 {
1183 	const struct device *dev = (const struct device *)user;
1184 
1185 	notify_vw_status(dev, ESPI_VWIRE_SIGNAL_SLP_WLAN);
1186 }
1187 
vw_slp_lan_handler(int girq_id,int src,void * user)1188 static void vw_slp_lan_handler(int girq_id, int src, void *user)
1189 {
1190 	const struct device *dev = (const struct device *)user;
1191 
1192 	notify_vw_status(dev, ESPI_VWIRE_SIGNAL_SLP_LAN);
1193 }
1194 
vw_host_c10_handler(int girq_id,int src,void * user)1195 static void vw_host_c10_handler(int girq_id, int src, void *user)
1196 {
1197 	const struct device *dev = (const struct device *)user;
1198 
1199 	notify_vw_status(dev, ESPI_VWIRE_SIGNAL_HOST_C10);
1200 }
1201 
vw_nmiout_handler(int girq_id,int src,void * user)1202 static void vw_nmiout_handler(int girq_id, int src, void *user)
1203 {
1204 	const struct device *dev = (const struct device *)user;
1205 
1206 	notify_vw_status(dev, ESPI_VWIRE_SIGNAL_NMIOUT);
1207 }
1208 
vw_smiout_handler(int girq_id,int src,void * user)1209 static void vw_smiout_handler(int girq_id, int src, void *user)
1210 {
1211 	const struct device *dev = (const struct device *)user;
1212 
1213 	notify_vw_status(dev, ESPI_VWIRE_SIGNAL_SMIOUT);
1214 }
1215 
1216 const struct espi_vw_isr m2s_vwires_isr[] = {
1217 	{ESPI_VWIRE_SIGNAL_SLP_S3, MCHP_MSVW00_GIRQ,
1218 	 MCHP_MSVW00_SRC0_GIRQ_POS, vw_slp3_handler},
1219 	{ESPI_VWIRE_SIGNAL_SLP_S4, MCHP_MSVW00_GIRQ,
1220 	 MCHP_MSVW00_SRC1_GIRQ_POS, vw_slp4_handler},
1221 	{ESPI_VWIRE_SIGNAL_SLP_S5, MCHP_MSVW00_GIRQ,
1222 	 MCHP_MSVW00_SRC2_GIRQ_POS, vw_slp5_handler},
1223 	{ESPI_VWIRE_SIGNAL_OOB_RST_WARN, MCHP_MSVW01_GIRQ,
1224 	 MCHP_MSVW01_SRC2_GIRQ_POS, vw_oob_rst_handler},
1225 	{ESPI_VWIRE_SIGNAL_PLTRST, MCHP_MSVW01_GIRQ,
1226 	 MCHP_MSVW01_SRC1_GIRQ_POS, vw_pltrst_handler},
1227 	{ESPI_VWIRE_SIGNAL_SUS_STAT, MCHP_MSVW01_GIRQ,
1228 	 MCHP_MSVW01_SRC0_GIRQ_POS, vw_sus_stat_handler},
1229 	{ESPI_VWIRE_SIGNAL_HOST_RST_WARN, MCHP_MSVW02_GIRQ,
1230 	 MCHP_MSVW02_SRC0_GIRQ_POS, vw_host_rst_warn_handler},
1231 	{ESPI_VWIRE_SIGNAL_NMIOUT, MCHP_MSVW02_GIRQ,
1232 	 MCHP_MSVW02_SRC1_GIRQ_POS, vw_nmiout_handler},
1233 	{ESPI_VWIRE_SIGNAL_SMIOUT, MCHP_MSVW02_GIRQ,
1234 	 MCHP_MSVW02_SRC2_GIRQ_POS, vw_smiout_handler},
1235 	{ESPI_VWIRE_SIGNAL_SLP_A, MCHP_MSVW03_GIRQ,
1236 	 MCHP_MSVW03_SRC3_GIRQ_POS, vw_sus_slp_a_handler},
1237 	{ESPI_VWIRE_SIGNAL_SUS_PWRDN_ACK, MCHP_MSVW03_GIRQ,
1238 	 MCHP_MSVW03_SRC1_GIRQ_POS, vw_sus_pwrdn_ack_handler},
1239 	{ESPI_VWIRE_SIGNAL_SUS_WARN, MCHP_MSVW03_GIRQ,
1240 	 MCHP_MSVW03_SRC0_GIRQ_POS, vw_sus_warn_handler},
1241 	{ESPI_VWIRE_SIGNAL_SLP_WLAN, MCHP_MSVW04_GIRQ,
1242 	 MCHP_MSVW04_SRC1_GIRQ_POS, vw_slp_wlan_handler},
1243 	{ESPI_VWIRE_SIGNAL_SLP_LAN, MCHP_MSVW04_GIRQ,
1244 	 MCHP_MSVW04_SRC0_GIRQ_POS, vw_slp_lan_handler},
1245 	{ESPI_VWIRE_SIGNAL_HOST_C10, MCHP_MSVW07_GIRQ,
1246 	 MCHP_MSVW07_SRC0_GIRQ_POS, vw_host_c10_handler},
1247 	{ESPI_VWIRE_SIGNAL_DNX_WARN, MCHP_MSVW08_GIRQ,
1248 	 MCHP_MSVW08_SRC1_GIRQ_POS, vw_sus_dnx_warn_handler},
1249 };
1250 
1251 static int espi_xec_init(const struct device *dev);
1252 
1253 static DEVICE_API(espi, espi_xec_driver_api) = {
1254 	.config = espi_xec_configure,
1255 	.get_channel_status = espi_xec_channel_ready,
1256 	.send_vwire = espi_xec_send_vwire,
1257 	.receive_vwire = espi_xec_receive_vwire,
1258 #ifdef CONFIG_ESPI_OOB_CHANNEL
1259 	.send_oob = espi_xec_send_oob,
1260 	.receive_oob = espi_xec_receive_oob,
1261 #endif
1262 #ifdef CONFIG_ESPI_FLASH_CHANNEL
1263 	.flash_read = espi_xec_flash_read,
1264 	.flash_write = espi_xec_flash_write,
1265 	.flash_erase = espi_xec_flash_erase,
1266 #endif
1267 	.manage_callback = espi_xec_manage_callback,
1268 	.read_lpc_request = espi_xec_read_lpc_request,
1269 	.write_lpc_request = espi_xec_write_lpc_request,
1270 };
1271 
1272 static struct espi_xec_data espi_xec_data_var;
1273 
1274 /* n = node-id, p = property, i = index */
1275 #define XEC_IRQ_INFO(n, p, i)						    \
1276 	{								    \
1277 		.gid = MCHP_XEC_ECIA_GIRQ(DT_PROP_BY_IDX(n, p, i)),	    \
1278 		.gpos = MCHP_XEC_ECIA_GIRQ_POS(DT_PROP_BY_IDX(n, p, i)),    \
1279 		.anid = MCHP_XEC_ECIA_NVIC_AGGR(DT_PROP_BY_IDX(n, p, i)),   \
1280 		.dnid = MCHP_XEC_ECIA_NVIC_DIRECT(DT_PROP_BY_IDX(n, p, i)), \
1281 	},
1282 
1283 static const struct espi_xec_irq_info espi_xec_irq_info_0[] = {
1284 	DT_FOREACH_PROP_ELEM(DT_NODELABEL(espi0), girqs, XEC_IRQ_INFO)
1285 };
1286 
1287 /* pin control structure(s) */
1288 PINCTRL_DT_INST_DEFINE(0);
1289 
1290 static const struct espi_xec_config espi_xec_config = {
1291 	.base_addr = DT_INST_REG_ADDR(0),
1292 	.vw_base_addr = DT_INST_REG_ADDR_BY_NAME(0, vw),
1293 	.pcr_idx = DT_INST_PROP_BY_IDX(0, pcrs, 0),
1294 	.pcr_bitpos = DT_INST_PROP_BY_IDX(0, pcrs, 1),
1295 	.irq_info_size = ARRAY_SIZE(espi_xec_irq_info_0),
1296 	.irq_info_list = espi_xec_irq_info_0,
1297 	.pcfg = PINCTRL_DT_INST_DEV_CONFIG_GET(0),
1298 };
1299 
1300 DEVICE_DT_INST_DEFINE(0, &espi_xec_init, NULL,
1301 		    &espi_xec_data_var, &espi_xec_config,
1302 		    PRE_KERNEL_2, CONFIG_ESPI_INIT_PRIORITY,
1303 		    &espi_xec_driver_api);
1304 
1305 /*
1306  * Connect ESPI bus interrupt handlers: ESPI_RESET and channels.
1307  * MEC172x hardware fixed SAF interrupt routing bug. SAF driver
1308  * will connect its direct mode interrupt handler(s) on this GIRQ.
1309  */
espi_xec_connect_irqs(const struct device * dev)1310 static void espi_xec_connect_irqs(const struct device *dev)
1311 {
1312 	ARG_UNUSED(dev);
1313 
1314 	/* eSPI Reset */
1315 	IRQ_CONNECT(DT_INST_IRQ_BY_IDX(0, 7, irq),
1316 		    DT_INST_IRQ_BY_IDX(0, 7, priority),
1317 		    espi_rst_isr,
1318 		    DEVICE_DT_INST_GET(0), 0);
1319 	irq_enable(DT_INST_IRQ_BY_IDX(0, 7, irq));
1320 
1321 	/* eSPI Virtual wire channel enable change ISR */
1322 	IRQ_CONNECT(DT_INST_IRQ_BY_IDX(0, 8, irq),
1323 		    DT_INST_IRQ_BY_IDX(0, 8, priority),
1324 		    espi_vw_chan_en_isr,
1325 		    DEVICE_DT_INST_GET(0), 0);
1326 	irq_enable(DT_INST_IRQ_BY_IDX(0, 8, irq));
1327 
1328 	/* eSPI Peripheral Channel */
1329 	IRQ_CONNECT(DT_INST_IRQ_BY_IDX(0, 0, irq),
1330 		    DT_INST_IRQ_BY_IDX(0, 0, priority),
1331 		    espi_pc_isr,
1332 		    DEVICE_DT_INST_GET(0), 0);
1333 	irq_enable(DT_INST_IRQ_BY_IDX(0, 0, irq));
1334 
1335 #ifdef CONFIG_ESPI_OOB_CHANNEL
1336 	/* eSPI OOB Upstream direction */
1337 	IRQ_CONNECT(DT_INST_IRQ_BY_IDX(0, 4, irq),
1338 		    DT_INST_IRQ_BY_IDX(0, 4, priority),
1339 		    espi_oob_up_isr,
1340 		    DEVICE_DT_INST_GET(0), 0);
1341 	irq_enable(DT_INST_IRQ_BY_IDX(0, 4, irq));
1342 
1343 	/* eSPI OOB Channel Downstream direction */
1344 	IRQ_CONNECT(DT_INST_IRQ_BY_IDX(0, 5, irq),
1345 		    DT_INST_IRQ_BY_IDX(0, 5, priority),
1346 		    espi_oob_down_isr,
1347 		    DEVICE_DT_INST_GET(0), 0);
1348 	irq_enable(DT_INST_IRQ_BY_IDX(0, 5, irq));
1349 #endif
1350 
1351 #ifdef CONFIG_ESPI_FLASH_CHANNEL
1352 	IRQ_CONNECT(DT_INST_IRQ_BY_IDX(0, 6, irq),
1353 		    DT_INST_IRQ_BY_IDX(0, 6, priority),
1354 		    espi_flash_isr,
1355 		    DEVICE_DT_INST_GET(0), 0);
1356 	irq_enable(DT_INST_IRQ_BY_IDX(0, 6, irq));
1357 #endif
1358 }
1359 
1360 /* MSVW is a 96-bit register and SMVW is a 64-bit register.
1361  * Each MSVW/SMVW controls a group of 4 eSPI virtual wires.
1362  * Host index located in b[7:0]
1363  * Reset source located in b[9:8]
1364  * Reset VW values SRC[3:0] located in b[15:12].
1365  * MSVW current VW state values located in bits[64, 72, 80, 88]
1366  * SMVW current VW state values located in bits[32, 40, 48, 56]
1367  */
xec_vw_cfg_properties(const struct xec_signal * p,uint32_t regaddr,uint8_t dir)1368 static void xec_vw_cfg_properties(const struct xec_signal *p, uint32_t regaddr, uint8_t dir)
1369 {
1370 	uint32_t src_ofs = 4u;
1371 	uint8_t src_pos = (8u * p->bit);
1372 	uint8_t rst_state = (p->flags >> MCHP_DT_ESPI_VW_FLAG_RST_STATE_POS)
1373 				& MCHP_DT_ESPI_VW_FLAG_RST_STATE_MSK0;
1374 	uint8_t rst_src = rst_src = (p->flags >> MCHP_DT_ESPI_VW_FLAG_RST_SRC_POS)
1375 				& MCHP_DT_ESPI_VW_FLAG_RST_SRC_MSK0;
1376 
1377 	if (dir) {
1378 		src_ofs = 8u;
1379 	}
1380 
1381 	if (rst_state || rst_src) { /* change reset source or state ? */
1382 		sys_write8(0, regaddr); /* disable register */
1383 
1384 		uint8_t temp = sys_read8(regaddr + 1u);
1385 
1386 		if (rst_state) { /* change reset state and default value of this vwire? */
1387 			rst_state--;
1388 			if (rst_state) {
1389 				temp |= BIT(p->bit + 4u);
1390 				sys_set_bit(regaddr + src_ofs, src_pos);
1391 			} else {
1392 				temp |= ~BIT(p->bit + 4u);
1393 				sys_clear_bit(regaddr + src_ofs, src_pos);
1394 			}
1395 		}
1396 
1397 		if (rst_src) { /* change reset source of all vwires in this group? */
1398 			rst_src--;
1399 			temp = (temp & ~0x3u) | (rst_src & 0x3u);
1400 		}
1401 
1402 		sys_write8(temp, regaddr + 1u);
1403 	}
1404 
1405 	if (sys_read8(regaddr) != p->host_idx) {
1406 		sys_write8(p->host_idx, regaddr);
1407 	}
1408 }
1409 
1410 /* Check each VW register set host index is present.
1411  * Some VW's power up with the host index and others do not.
1412  * NOTE: Virtual wires are in groups of 4. Disabling one wire in a group
1413  * will disable all wires in the group. We do not implement disabling.
1414  */
xec_vw_config(const struct device * dev)1415 static void xec_vw_config(const struct device *dev)
1416 {
1417 	for (int i = ESPI_VWIRE_SIGNAL_TARGET_GPIO_0; i < ARRAY_SIZE(vw_tbl); i++) {
1418 		const struct xec_signal *p = &vw_tbl[i];
1419 		uint32_t regaddr = xec_smvw_addr(dev, p->xec_reg_idx);
1420 		uint8_t dir = (p->flags >> MCHP_DT_ESPI_VW_FLAG_DIR_POS) & BIT(0);
1421 		uint8_t en = (p->flags & BIT(MCHP_DT_ESPI_VW_FLAG_STATUS_POS));
1422 
1423 		if (dir) {
1424 			regaddr = xec_msvw_addr(dev, p->xec_reg_idx);
1425 		}
1426 
1427 		if (en) {
1428 			xec_vw_cfg_properties(p, regaddr, dir);
1429 		}
1430 	}
1431 }
1432 
xec_register_vw_handlers(const struct device * dev)1433 static int xec_register_vw_handlers(const struct device *dev)
1434 {
1435 	for (int i = 0; i < ARRAY_SIZE(m2s_vwires_isr); i++) {
1436 		const struct espi_vw_isr *vwi = &m2s_vwires_isr[i];
1437 		struct xec_signal signal_info = vw_tbl[vwi->signal];
1438 		uint8_t xec_id = signal_info.xec_reg_idx;
1439 		uint8_t en = (signal_info.flags & BIT(MCHP_DT_ESPI_VW_FLAG_STATUS_POS));
1440 
1441 		if (!en) {
1442 			LOG_INF("VW %d not enabled, skipping", vwi->signal);
1443 			continue;
1444 		}
1445 
1446 		/* enables interrupt in eSPI MSVWn register */
1447 		xec_espi_vw_intr_ctrl(dev, xec_id, signal_info.bit,
1448 				      MSVW_IRQ_SEL_EDGE_BOTH);
1449 
1450 		/* register handler */
1451 		int ret = mchp_xec_ecia_set_callback(vwi->girq_id, vwi->girq_pos,
1452 						     vwi->the_isr, (void *)dev);
1453 		if (ret) {
1454 			return -EIO;
1455 		}
1456 
1457 		mchp_xec_ecia_girq_src_en(vwi->girq_id, vwi->girq_pos);
1458 	}
1459 
1460 	return 0;
1461 }
1462 
1463 /*
1464  * Initialize eSPI hardware and associated peripherals blocks using eSPI
1465  * as their host interface.
1466  * We change VW capabilities reported to match the number of VWires the
1467  * driver is supporting.
1468  * A VW packet on the bus contains VW count followed by the VW groups.
1469  * The VW count is a zero based 6-bit value: (0 - 63) specifying the number of
1470  * groups in the packet.
1471  * A VW group consists of two bytes: VW host index and VW data. Each group
1472  * contains the state of 4 virtual wires.
1473  * The total supported virtual wires is 64 * 4 = 256.
1474  * MEC172x supports 11 MSVW groups and 11 SMVW groups.
1475  * NOTE: While ESPI_nRESET is active most of the eSPI hardware is held
1476  * in reset state.
1477  */
espi_xec_init(const struct device * dev)1478 static int espi_xec_init(const struct device *dev)
1479 {
1480 	struct espi_xec_config *const cfg = ESPI_XEC_CONFIG(dev);
1481 	struct espi_iom_regs *regs = ESPI_XEC_REG_BASE(dev);
1482 	struct espi_xec_data *const data = ESPI_XEC_DATA(dev);
1483 	struct pcr_regs *pcr = XEC_PCR_REG_BASE;
1484 	int ret;
1485 
1486 	ret = pinctrl_apply_state(cfg->pcfg, PINCTRL_STATE_DEFAULT);
1487 	if (ret != 0) {
1488 		LOG_ERR("XEC eSPI V2 pinctrl setup failed (%d)", ret);
1489 		return ret;
1490 	}
1491 
1492 #ifdef ESPI_XEC_V2_DEBUG
1493 	data->espi_rst_count = 0;
1494 #endif
1495 	/* clear eSPI PCR sleep enable */
1496 	z_mchp_xec_pcr_periph_sleep(cfg->pcr_idx, cfg->pcr_bitpos, 0);
1497 
1498 	/* Configure eSPI_PLTRST# to cause nSIO_RESET reset
1499 	 * NOTE: this is also clearing bit 0(PWR_INV) causing the internal
1500 	 * RESET_VCC to de-assert. Host facing peripherals will no longer
1501 	 * be held in reset.
1502 	 */
1503 	pcr->PWR_RST_CTRL = MCHP_PCR_PR_CTRL_USE_ESPI_PLTRST;
1504 	regs->PLTSRC = MCHP_ESPI_PLTRST_SRC_IS_VW;
1505 
1506 	/* Configure the channels and its capabilities based on build config */
1507 	regs->CAP0 |= MCHP_ESPI_GBL_CAP0_VW_SUPP | MCHP_ESPI_GBL_CAP0_PC_SUPP;
1508 
1509 	regs->CAPVW = MAX(ESPI_NUM_MSVW, ESPI_NUM_SMVW);
1510 	regs->CAPPC |= MCHP_ESPI_PC_CAP_MAX_PLD_SZ_64;
1511 
1512 #ifdef CONFIG_ESPI_OOB_CHANNEL
1513 	regs->CAP0 |= MCHP_ESPI_GBL_CAP0_OOB_SUPP;
1514 	regs->CAPOOB |= MCHP_ESPI_OOB_CAP_MAX_PLD_SZ_73;
1515 
1516 	k_sem_init(&data->tx_lock, 0, 1);
1517 #ifndef CONFIG_ESPI_OOB_CHANNEL_RX_ASYNC
1518 	k_sem_init(&data->rx_lock, 0, 1);
1519 #endif /* CONFIG_ESPI_OOB_CHANNEL_RX_ASYNC */
1520 #else
1521 	regs->CAP0 &= ~MCHP_ESPI_GBL_CAP0_OOB_SUPP;
1522 #endif
1523 
1524 #ifdef CONFIG_ESPI_FLASH_CHANNEL
1525 	regs->CAP0 |= MCHP_ESPI_GBL_CAP0_FC_SUPP |
1526 		      MCHP_ESPI_FC_CAP_MAX_PLD_SZ_64;
1527 	regs->CAPFC |= MCHP_ESPI_FC_CAP_SHARE_MAF_SAF |
1528 		       MCHP_ESPI_FC_CAP_MAX_RD_SZ_64;
1529 
1530 	k_sem_init(&data->flash_lock, 0, 1);
1531 #else
1532 	regs->CAP0 &= ~MCHP_ESPI_GBL_CAP0_FC_SUPP;
1533 #endif
1534 
1535 	/* Clear reset interrupt status and enable interrupts */
1536 	regs->ERIS = MCHP_ESPI_RST_ISTS;
1537 	regs->ERIE |= MCHP_ESPI_RST_IEN;
1538 	regs->PCSTS = MCHP_ESPI_PC_STS_EN_CHG;
1539 	regs->PCIEN |= MCHP_ESPI_PC_IEN_EN_CHG;
1540 
1541 	xec_vw_config(dev);
1542 
1543 	/* register VWire handlers with their aggregated GIRQs
1544 	 * in the ECIA driver
1545 	 */
1546 	ret = xec_register_vw_handlers(dev);
1547 	if (ret) {
1548 		LOG_ERR("XEX eSPI V2 register VW handlers error %d", ret);
1549 		return ret;
1550 	}
1551 
1552 	/* Enable interrupts for each logical channel enable assertion */
1553 	xec_espi_bus_intr_ctl(dev, pc_girq_idx, 1);
1554 	xec_espi_bus_intr_ctl(dev, vw_ch_en_girq_idx, 1);
1555 	xec_espi_bus_intr_ctl(dev, rst_girq_idx, 1);
1556 
1557 #ifdef CONFIG_ESPI_OOB_CHANNEL
1558 	espi_init_oob(dev);
1559 #endif
1560 #ifdef CONFIG_ESPI_FLASH_CHANNEL
1561 	espi_init_flash(dev);
1562 #endif
1563 
1564 	espi_xec_connect_irqs(dev);
1565 
1566 	ret = xec_host_dev_connect_irqs(dev);
1567 
1568 	return ret;
1569 }
1570