xref: /linux/drivers/net/wireless/microchip/wilc1000/sdio.c (revision 5cfe477f6a3f9a4d9b2906d442964f2115b0403f)
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * Copyright (c) 2012 - 2018 Microchip Technology Inc., and its subsidiaries.
4  * All rights reserved.
5  */
6 
7 #include <linux/clk.h>
8 #include <linux/mmc/sdio_func.h>
9 #include <linux/mmc/sdio_ids.h>
10 #include <linux/mmc/host.h>
11 #include <linux/mmc/sdio.h>
12 #include <linux/of_irq.h>
13 
14 #include "netdev.h"
15 #include "cfg80211.h"
16 
17 #define SDIO_MODALIAS "wilc1000_sdio"
18 
19 static const struct sdio_device_id wilc_sdio_ids[] = {
20 	{ SDIO_DEVICE(SDIO_VENDOR_ID_MICROCHIP_WILC, SDIO_DEVICE_ID_MICROCHIP_WILC1000) },
21 	{ },
22 };
23 
24 #define WILC_SDIO_BLOCK_SIZE 512
25 
26 struct wilc_sdio {
27 	bool irq_gpio;
28 	u32 block_size;
29 	int has_thrpt_enh3;
30 };
31 
32 struct sdio_cmd52 {
33 	u32 read_write:		1;
34 	u32 function:		3;
35 	u32 raw:		1;
36 	u32 address:		17;
37 	u32 data:		8;
38 };
39 
40 struct sdio_cmd53 {
41 	u32 read_write:		1;
42 	u32 function:		3;
43 	u32 block_mode:		1;
44 	u32 increment:		1;
45 	u32 address:		17;
46 	u32 count:		9;
47 	u8 *buffer;
48 	u32 block_size;
49 };
50 
51 static const struct wilc_hif_func wilc_hif_sdio;
52 
53 static void wilc_sdio_interrupt(struct sdio_func *func)
54 {
55 	sdio_release_host(func);
56 	wilc_handle_isr(sdio_get_drvdata(func));
57 	sdio_claim_host(func);
58 }
59 
60 static int wilc_sdio_cmd52(struct wilc *wilc, struct sdio_cmd52 *cmd)
61 {
62 	struct sdio_func *func = container_of(wilc->dev, struct sdio_func, dev);
63 	int ret;
64 	u8 data;
65 
66 	sdio_claim_host(func);
67 
68 	func->num = cmd->function;
69 	if (cmd->read_write) {  /* write */
70 		if (cmd->raw) {
71 			sdio_writeb(func, cmd->data, cmd->address, &ret);
72 			data = sdio_readb(func, cmd->address, &ret);
73 			cmd->data = data;
74 		} else {
75 			sdio_writeb(func, cmd->data, cmd->address, &ret);
76 		}
77 	} else {        /* read */
78 		data = sdio_readb(func, cmd->address, &ret);
79 		cmd->data = data;
80 	}
81 
82 	sdio_release_host(func);
83 
84 	if (ret)
85 		dev_err(&func->dev, "%s..failed, err(%d)\n", __func__, ret);
86 	return ret;
87 }
88 
89 static int wilc_sdio_cmd53(struct wilc *wilc, struct sdio_cmd53 *cmd)
90 {
91 	struct sdio_func *func = container_of(wilc->dev, struct sdio_func, dev);
92 	int size, ret;
93 
94 	sdio_claim_host(func);
95 
96 	func->num = cmd->function;
97 	func->cur_blksize = cmd->block_size;
98 	if (cmd->block_mode)
99 		size = cmd->count * cmd->block_size;
100 	else
101 		size = cmd->count;
102 
103 	if (cmd->read_write) {  /* write */
104 		ret = sdio_memcpy_toio(func, cmd->address,
105 				       (void *)cmd->buffer, size);
106 	} else {        /* read */
107 		ret = sdio_memcpy_fromio(func, (void *)cmd->buffer,
108 					 cmd->address,  size);
109 	}
110 
111 	sdio_release_host(func);
112 
113 	if (ret)
114 		dev_err(&func->dev, "%s..failed, err(%d)\n", __func__,  ret);
115 
116 	return ret;
117 }
118 
119 static int wilc_sdio_probe(struct sdio_func *func,
120 			   const struct sdio_device_id *id)
121 {
122 	struct wilc *wilc;
123 	int ret;
124 	struct wilc_sdio *sdio_priv;
125 
126 	sdio_priv = kzalloc(sizeof(*sdio_priv), GFP_KERNEL);
127 	if (!sdio_priv)
128 		return -ENOMEM;
129 
130 	ret = wilc_cfg80211_init(&wilc, &func->dev, WILC_HIF_SDIO,
131 				 &wilc_hif_sdio);
132 	if (ret)
133 		goto free;
134 
135 	if (IS_ENABLED(CONFIG_WILC1000_HW_OOB_INTR)) {
136 		struct device_node *np = func->card->dev.of_node;
137 		int irq_num = of_irq_get(np, 0);
138 
139 		if (irq_num > 0) {
140 			wilc->dev_irq_num = irq_num;
141 			sdio_priv->irq_gpio = true;
142 		}
143 	}
144 
145 	sdio_set_drvdata(func, wilc);
146 	wilc->bus_data = sdio_priv;
147 	wilc->dev = &func->dev;
148 
149 	wilc->rtc_clk = devm_clk_get_optional(&func->card->dev, "rtc");
150 	if (IS_ERR(wilc->rtc_clk)) {
151 		ret = PTR_ERR(wilc->rtc_clk);
152 		goto dispose_irq;
153 	}
154 	clk_prepare_enable(wilc->rtc_clk);
155 
156 	dev_info(&func->dev, "Driver Initializing success\n");
157 	return 0;
158 
159 dispose_irq:
160 	irq_dispose_mapping(wilc->dev_irq_num);
161 	wilc_netdev_cleanup(wilc);
162 free:
163 	kfree(sdio_priv);
164 	return ret;
165 }
166 
167 static void wilc_sdio_remove(struct sdio_func *func)
168 {
169 	struct wilc *wilc = sdio_get_drvdata(func);
170 	struct wilc_sdio *sdio_priv = wilc->bus_data;
171 
172 	clk_disable_unprepare(wilc->rtc_clk);
173 	wilc_netdev_cleanup(wilc);
174 	kfree(sdio_priv);
175 }
176 
177 static int wilc_sdio_reset(struct wilc *wilc)
178 {
179 	struct sdio_cmd52 cmd;
180 	int ret;
181 	struct sdio_func *func = dev_to_sdio_func(wilc->dev);
182 
183 	cmd.read_write = 1;
184 	cmd.function = 0;
185 	cmd.raw = 0;
186 	cmd.address = SDIO_CCCR_ABORT;
187 	cmd.data = WILC_SDIO_CCCR_ABORT_RESET;
188 	ret = wilc_sdio_cmd52(wilc, &cmd);
189 	if (ret) {
190 		dev_err(&func->dev, "Fail cmd 52, reset cmd ...\n");
191 		return ret;
192 	}
193 	return 0;
194 }
195 
196 static int wilc_sdio_suspend(struct device *dev)
197 {
198 	struct sdio_func *func = dev_to_sdio_func(dev);
199 	struct wilc *wilc = sdio_get_drvdata(func);
200 	int ret;
201 
202 	dev_info(dev, "sdio suspend\n");
203 	chip_wakeup(wilc);
204 
205 	if (!IS_ERR(wilc->rtc_clk))
206 		clk_disable_unprepare(wilc->rtc_clk);
207 
208 	if (wilc->suspend_event) {
209 		host_sleep_notify(wilc);
210 		chip_allow_sleep(wilc);
211 	}
212 
213 	ret = wilc_sdio_reset(wilc);
214 	if (ret) {
215 		dev_err(&func->dev, "Fail reset sdio\n");
216 		return ret;
217 	}
218 	sdio_claim_host(func);
219 
220 	return 0;
221 }
222 
223 static int wilc_sdio_enable_interrupt(struct wilc *dev)
224 {
225 	struct sdio_func *func = container_of(dev->dev, struct sdio_func, dev);
226 	int ret = 0;
227 
228 	sdio_claim_host(func);
229 	ret = sdio_claim_irq(func, wilc_sdio_interrupt);
230 	sdio_release_host(func);
231 
232 	if (ret < 0) {
233 		dev_err(&func->dev, "can't claim sdio_irq, err(%d)\n", ret);
234 		ret = -EIO;
235 	}
236 	return ret;
237 }
238 
239 static void wilc_sdio_disable_interrupt(struct wilc *dev)
240 {
241 	struct sdio_func *func = container_of(dev->dev, struct sdio_func, dev);
242 	int ret;
243 
244 	sdio_claim_host(func);
245 	ret = sdio_release_irq(func);
246 	if (ret < 0)
247 		dev_err(&func->dev, "can't release sdio_irq, err(%d)\n", ret);
248 	sdio_release_host(func);
249 }
250 
251 /********************************************
252  *
253  *      Function 0
254  *
255  ********************************************/
256 
257 static int wilc_sdio_set_func0_csa_address(struct wilc *wilc, u32 adr)
258 {
259 	struct sdio_func *func = dev_to_sdio_func(wilc->dev);
260 	struct sdio_cmd52 cmd;
261 	int ret;
262 
263 	/**
264 	 *      Review: BIG ENDIAN
265 	 **/
266 	cmd.read_write = 1;
267 	cmd.function = 0;
268 	cmd.raw = 0;
269 	cmd.address = WILC_SDIO_FBR_CSA_REG;
270 	cmd.data = (u8)adr;
271 	ret = wilc_sdio_cmd52(wilc, &cmd);
272 	if (ret) {
273 		dev_err(&func->dev, "Failed cmd52, set %04x data...\n",
274 			cmd.address);
275 		return ret;
276 	}
277 
278 	cmd.address = WILC_SDIO_FBR_CSA_REG + 1;
279 	cmd.data = (u8)(adr >> 8);
280 	ret = wilc_sdio_cmd52(wilc, &cmd);
281 	if (ret) {
282 		dev_err(&func->dev, "Failed cmd52, set %04x data...\n",
283 			cmd.address);
284 		return ret;
285 	}
286 
287 	cmd.address = WILC_SDIO_FBR_CSA_REG + 2;
288 	cmd.data = (u8)(adr >> 16);
289 	ret = wilc_sdio_cmd52(wilc, &cmd);
290 	if (ret) {
291 		dev_err(&func->dev, "Failed cmd52, set %04x data...\n",
292 			cmd.address);
293 		return ret;
294 	}
295 
296 	return 0;
297 }
298 
299 static int wilc_sdio_set_block_size(struct wilc *wilc, u8 func_num,
300 				    u32 block_size)
301 {
302 	struct sdio_func *func = dev_to_sdio_func(wilc->dev);
303 	struct sdio_cmd52 cmd;
304 	int ret;
305 
306 	cmd.read_write = 1;
307 	cmd.function = 0;
308 	cmd.raw = 0;
309 	cmd.address = SDIO_FBR_BASE(func_num) + SDIO_CCCR_BLKSIZE;
310 	cmd.data = (u8)block_size;
311 	ret = wilc_sdio_cmd52(wilc, &cmd);
312 	if (ret) {
313 		dev_err(&func->dev, "Failed cmd52, set %04x data...\n",
314 			cmd.address);
315 		return ret;
316 	}
317 
318 	cmd.address = SDIO_FBR_BASE(func_num) + SDIO_CCCR_BLKSIZE +  1;
319 	cmd.data = (u8)(block_size >> 8);
320 	ret = wilc_sdio_cmd52(wilc, &cmd);
321 	if (ret) {
322 		dev_err(&func->dev, "Failed cmd52, set %04x data...\n",
323 			cmd.address);
324 		return ret;
325 	}
326 
327 	return 0;
328 }
329 
330 /********************************************
331  *
332  *      Sdio interfaces
333  *
334  ********************************************/
335 static int wilc_sdio_write_reg(struct wilc *wilc, u32 addr, u32 data)
336 {
337 	struct sdio_func *func = dev_to_sdio_func(wilc->dev);
338 	struct wilc_sdio *sdio_priv = wilc->bus_data;
339 	int ret;
340 
341 	cpu_to_le32s(&data);
342 
343 	if (addr >= 0xf0 && addr <= 0xff) { /* only vendor specific registers */
344 		struct sdio_cmd52 cmd;
345 
346 		cmd.read_write = 1;
347 		cmd.function = 0;
348 		cmd.raw = 0;
349 		cmd.address = addr;
350 		cmd.data = data;
351 		ret = wilc_sdio_cmd52(wilc, &cmd);
352 		if (ret)
353 			dev_err(&func->dev,
354 				"Failed cmd 52, read reg (%08x) ...\n", addr);
355 	} else {
356 		struct sdio_cmd53 cmd;
357 
358 		/**
359 		 *      set the AHB address
360 		 **/
361 		ret = wilc_sdio_set_func0_csa_address(wilc, addr);
362 		if (ret)
363 			return ret;
364 
365 		cmd.read_write = 1;
366 		cmd.function = 0;
367 		cmd.address = WILC_SDIO_FBR_DATA_REG;
368 		cmd.block_mode = 0;
369 		cmd.increment = 1;
370 		cmd.count = 4;
371 		cmd.buffer = (u8 *)&data;
372 		cmd.block_size = sdio_priv->block_size;
373 		ret = wilc_sdio_cmd53(wilc, &cmd);
374 		if (ret)
375 			dev_err(&func->dev,
376 				"Failed cmd53, write reg (%08x)...\n", addr);
377 	}
378 
379 	return ret;
380 }
381 
382 static int wilc_sdio_write(struct wilc *wilc, u32 addr, u8 *buf, u32 size)
383 {
384 	struct sdio_func *func = dev_to_sdio_func(wilc->dev);
385 	struct wilc_sdio *sdio_priv = wilc->bus_data;
386 	u32 block_size = sdio_priv->block_size;
387 	struct sdio_cmd53 cmd;
388 	int nblk, nleft, ret;
389 
390 	cmd.read_write = 1;
391 	if (addr > 0) {
392 		/**
393 		 *      func 0 access
394 		 **/
395 		cmd.function = 0;
396 		cmd.address = WILC_SDIO_FBR_DATA_REG;
397 	} else {
398 		/**
399 		 *      func 1 access
400 		 **/
401 		cmd.function = 1;
402 		cmd.address = WILC_SDIO_F1_DATA_REG;
403 	}
404 
405 	size = ALIGN(size, 4);
406 	nblk = size / block_size;
407 	nleft = size % block_size;
408 
409 	if (nblk > 0) {
410 		cmd.block_mode = 1;
411 		cmd.increment = 1;
412 		cmd.count = nblk;
413 		cmd.buffer = buf;
414 		cmd.block_size = block_size;
415 		if (addr > 0) {
416 			ret = wilc_sdio_set_func0_csa_address(wilc, addr);
417 			if (ret)
418 				return ret;
419 		}
420 		ret = wilc_sdio_cmd53(wilc, &cmd);
421 		if (ret) {
422 			dev_err(&func->dev,
423 				"Failed cmd53 [%x], block send...\n", addr);
424 			return ret;
425 		}
426 		if (addr > 0)
427 			addr += nblk * block_size;
428 		buf += nblk * block_size;
429 	}
430 
431 	if (nleft > 0) {
432 		cmd.block_mode = 0;
433 		cmd.increment = 1;
434 		cmd.count = nleft;
435 		cmd.buffer = buf;
436 
437 		cmd.block_size = block_size;
438 
439 		if (addr > 0) {
440 			ret = wilc_sdio_set_func0_csa_address(wilc, addr);
441 			if (ret)
442 				return ret;
443 		}
444 		ret = wilc_sdio_cmd53(wilc, &cmd);
445 		if (ret) {
446 			dev_err(&func->dev,
447 				"Failed cmd53 [%x], bytes send...\n", addr);
448 			return ret;
449 		}
450 	}
451 
452 	return 0;
453 }
454 
455 static int wilc_sdio_read_reg(struct wilc *wilc, u32 addr, u32 *data)
456 {
457 	struct sdio_func *func = dev_to_sdio_func(wilc->dev);
458 	struct wilc_sdio *sdio_priv = wilc->bus_data;
459 	int ret;
460 
461 	if (addr >= 0xf0 && addr <= 0xff) { /* only vendor specific registers */
462 		struct sdio_cmd52 cmd;
463 
464 		cmd.read_write = 0;
465 		cmd.function = 0;
466 		cmd.raw = 0;
467 		cmd.address = addr;
468 		ret = wilc_sdio_cmd52(wilc, &cmd);
469 		if (ret) {
470 			dev_err(&func->dev,
471 				"Failed cmd 52, read reg (%08x) ...\n", addr);
472 			return ret;
473 		}
474 		*data = cmd.data;
475 	} else {
476 		struct sdio_cmd53 cmd;
477 
478 		ret = wilc_sdio_set_func0_csa_address(wilc, addr);
479 		if (ret)
480 			return ret;
481 
482 		cmd.read_write = 0;
483 		cmd.function = 0;
484 		cmd.address = WILC_SDIO_FBR_DATA_REG;
485 		cmd.block_mode = 0;
486 		cmd.increment = 1;
487 		cmd.count = 4;
488 		cmd.buffer = (u8 *)data;
489 
490 		cmd.block_size = sdio_priv->block_size;
491 		ret = wilc_sdio_cmd53(wilc, &cmd);
492 		if (ret) {
493 			dev_err(&func->dev,
494 				"Failed cmd53, read reg (%08x)...\n", addr);
495 			return ret;
496 		}
497 	}
498 
499 	le32_to_cpus(data);
500 	return 0;
501 }
502 
503 static int wilc_sdio_read(struct wilc *wilc, u32 addr, u8 *buf, u32 size)
504 {
505 	struct sdio_func *func = dev_to_sdio_func(wilc->dev);
506 	struct wilc_sdio *sdio_priv = wilc->bus_data;
507 	u32 block_size = sdio_priv->block_size;
508 	struct sdio_cmd53 cmd;
509 	int nblk, nleft, ret;
510 
511 	cmd.read_write = 0;
512 	if (addr > 0) {
513 		/**
514 		 *      func 0 access
515 		 **/
516 		cmd.function = 0;
517 		cmd.address = WILC_SDIO_FBR_DATA_REG;
518 	} else {
519 		/**
520 		 *      func 1 access
521 		 **/
522 		cmd.function = 1;
523 		cmd.address = WILC_SDIO_F1_DATA_REG;
524 	}
525 
526 	size = ALIGN(size, 4);
527 	nblk = size / block_size;
528 	nleft = size % block_size;
529 
530 	if (nblk > 0) {
531 		cmd.block_mode = 1;
532 		cmd.increment = 1;
533 		cmd.count = nblk;
534 		cmd.buffer = buf;
535 		cmd.block_size = block_size;
536 		if (addr > 0) {
537 			ret = wilc_sdio_set_func0_csa_address(wilc, addr);
538 			if (ret)
539 				return ret;
540 		}
541 		ret = wilc_sdio_cmd53(wilc, &cmd);
542 		if (ret) {
543 			dev_err(&func->dev,
544 				"Failed cmd53 [%x], block read...\n", addr);
545 			return ret;
546 		}
547 		if (addr > 0)
548 			addr += nblk * block_size;
549 		buf += nblk * block_size;
550 	}       /* if (nblk > 0) */
551 
552 	if (nleft > 0) {
553 		cmd.block_mode = 0;
554 		cmd.increment = 1;
555 		cmd.count = nleft;
556 		cmd.buffer = buf;
557 
558 		cmd.block_size = block_size;
559 
560 		if (addr > 0) {
561 			ret = wilc_sdio_set_func0_csa_address(wilc, addr);
562 			if (ret)
563 				return ret;
564 		}
565 		ret = wilc_sdio_cmd53(wilc, &cmd);
566 		if (ret) {
567 			dev_err(&func->dev,
568 				"Failed cmd53 [%x], bytes read...\n", addr);
569 			return ret;
570 		}
571 	}
572 
573 	return 0;
574 }
575 
576 /********************************************
577  *
578  *      Bus interfaces
579  *
580  ********************************************/
581 
582 static int wilc_sdio_deinit(struct wilc *wilc)
583 {
584 	return 0;
585 }
586 
587 static int wilc_sdio_init(struct wilc *wilc, bool resume)
588 {
589 	struct sdio_func *func = dev_to_sdio_func(wilc->dev);
590 	struct wilc_sdio *sdio_priv = wilc->bus_data;
591 	struct sdio_cmd52 cmd;
592 	int loop, ret;
593 	u32 chipid;
594 
595 	/**
596 	 *      function 0 csa enable
597 	 **/
598 	cmd.read_write = 1;
599 	cmd.function = 0;
600 	cmd.raw = 1;
601 	cmd.address = SDIO_FBR_BASE(func->num);
602 	cmd.data = SDIO_FBR_ENABLE_CSA;
603 	ret = wilc_sdio_cmd52(wilc, &cmd);
604 	if (ret) {
605 		dev_err(&func->dev, "Fail cmd 52, enable csa...\n");
606 		return ret;
607 	}
608 
609 	/**
610 	 *      function 0 block size
611 	 **/
612 	ret = wilc_sdio_set_block_size(wilc, 0, WILC_SDIO_BLOCK_SIZE);
613 	if (ret) {
614 		dev_err(&func->dev, "Fail cmd 52, set func 0 block size...\n");
615 		return ret;
616 	}
617 	sdio_priv->block_size = WILC_SDIO_BLOCK_SIZE;
618 
619 	/**
620 	 *      enable func1 IO
621 	 **/
622 	cmd.read_write = 1;
623 	cmd.function = 0;
624 	cmd.raw = 1;
625 	cmd.address = SDIO_CCCR_IOEx;
626 	cmd.data = WILC_SDIO_CCCR_IO_EN_FUNC1;
627 	ret = wilc_sdio_cmd52(wilc, &cmd);
628 	if (ret) {
629 		dev_err(&func->dev,
630 			"Fail cmd 52, set IOE register...\n");
631 		return ret;
632 	}
633 
634 	/**
635 	 *      make sure func 1 is up
636 	 **/
637 	cmd.read_write = 0;
638 	cmd.function = 0;
639 	cmd.raw = 0;
640 	cmd.address = SDIO_CCCR_IORx;
641 	loop = 3;
642 	do {
643 		cmd.data = 0;
644 		ret = wilc_sdio_cmd52(wilc, &cmd);
645 		if (ret) {
646 			dev_err(&func->dev,
647 				"Fail cmd 52, get IOR register...\n");
648 			return ret;
649 		}
650 		if (cmd.data == WILC_SDIO_CCCR_IO_EN_FUNC1)
651 			break;
652 	} while (loop--);
653 
654 	if (loop <= 0) {
655 		dev_err(&func->dev, "Fail func 1 is not ready...\n");
656 		return -EINVAL;
657 	}
658 
659 	/**
660 	 *      func 1 is ready, set func 1 block size
661 	 **/
662 	ret = wilc_sdio_set_block_size(wilc, 1, WILC_SDIO_BLOCK_SIZE);
663 	if (ret) {
664 		dev_err(&func->dev, "Fail set func 1 block size...\n");
665 		return ret;
666 	}
667 
668 	/**
669 	 *      func 1 interrupt enable
670 	 **/
671 	cmd.read_write = 1;
672 	cmd.function = 0;
673 	cmd.raw = 1;
674 	cmd.address = SDIO_CCCR_IENx;
675 	cmd.data = WILC_SDIO_CCCR_IEN_MASTER | WILC_SDIO_CCCR_IEN_FUNC1;
676 	ret = wilc_sdio_cmd52(wilc, &cmd);
677 	if (ret) {
678 		dev_err(&func->dev, "Fail cmd 52, set IEN register...\n");
679 		return ret;
680 	}
681 
682 	/**
683 	 *      make sure can read back chip id correctly
684 	 **/
685 	if (!resume) {
686 		int rev;
687 
688 		ret = wilc_sdio_read_reg(wilc, WILC_CHIPID, &chipid);
689 		if (ret) {
690 			dev_err(&func->dev, "Fail cmd read chip id...\n");
691 			return ret;
692 		}
693 		dev_err(&func->dev, "chipid (%08x)\n", chipid);
694 		rev = FIELD_GET(WILC_CHIP_REV_FIELD, chipid);
695 		if (rev > FIELD_GET(WILC_CHIP_REV_FIELD, WILC_1000_BASE_ID_2A))
696 			sdio_priv->has_thrpt_enh3 = 1;
697 		else
698 			sdio_priv->has_thrpt_enh3 = 0;
699 		dev_info(&func->dev, "has_thrpt_enh3 = %d...\n",
700 			 sdio_priv->has_thrpt_enh3);
701 	}
702 
703 	return 0;
704 }
705 
706 static int wilc_sdio_read_size(struct wilc *wilc, u32 *size)
707 {
708 	u32 tmp;
709 	struct sdio_cmd52 cmd;
710 
711 	/**
712 	 *      Read DMA count in words
713 	 **/
714 	cmd.read_write = 0;
715 	cmd.function = 0;
716 	cmd.raw = 0;
717 	cmd.address = WILC_SDIO_INTERRUPT_DATA_SZ_REG;
718 	cmd.data = 0;
719 	wilc_sdio_cmd52(wilc, &cmd);
720 	tmp = cmd.data;
721 
722 	cmd.address = WILC_SDIO_INTERRUPT_DATA_SZ_REG + 1;
723 	cmd.data = 0;
724 	wilc_sdio_cmd52(wilc, &cmd);
725 	tmp |= (cmd.data << 8);
726 
727 	*size = tmp;
728 	return 0;
729 }
730 
731 static int wilc_sdio_read_int(struct wilc *wilc, u32 *int_status)
732 {
733 	struct sdio_func *func = dev_to_sdio_func(wilc->dev);
734 	struct wilc_sdio *sdio_priv = wilc->bus_data;
735 	u32 tmp;
736 	u8 irq_flags;
737 	struct sdio_cmd52 cmd;
738 
739 	wilc_sdio_read_size(wilc, &tmp);
740 
741 	/**
742 	 *      Read IRQ flags
743 	 **/
744 	if (!sdio_priv->irq_gpio) {
745 		cmd.function = 1;
746 		cmd.address = WILC_SDIO_EXT_IRQ_FLAG_REG;
747 	} else {
748 		cmd.function = 0;
749 		cmd.address = WILC_SDIO_IRQ_FLAG_REG;
750 	}
751 	cmd.raw = 0;
752 	cmd.read_write = 0;
753 	cmd.data = 0;
754 	wilc_sdio_cmd52(wilc, &cmd);
755 	irq_flags = cmd.data;
756 	tmp |= FIELD_PREP(IRG_FLAGS_MASK, cmd.data);
757 
758 	if (FIELD_GET(UNHANDLED_IRQ_MASK, irq_flags))
759 		dev_err(&func->dev, "Unexpected interrupt (1) int=%lx\n",
760 			FIELD_GET(UNHANDLED_IRQ_MASK, irq_flags));
761 
762 	*int_status = tmp;
763 
764 	return 0;
765 }
766 
767 static int wilc_sdio_clear_int_ext(struct wilc *wilc, u32 val)
768 {
769 	struct sdio_func *func = dev_to_sdio_func(wilc->dev);
770 	struct wilc_sdio *sdio_priv = wilc->bus_data;
771 	int ret;
772 	int vmm_ctl;
773 
774 	if (sdio_priv->has_thrpt_enh3) {
775 		u32 reg = 0;
776 
777 		if (sdio_priv->irq_gpio)
778 			reg = val & (BIT(MAX_NUM_INT) - 1);
779 
780 		/* select VMM table 0 */
781 		if (val & SEL_VMM_TBL0)
782 			reg |= BIT(5);
783 		/* select VMM table 1 */
784 		if (val & SEL_VMM_TBL1)
785 			reg |= BIT(6);
786 		/* enable VMM */
787 		if (val & EN_VMM)
788 			reg |= BIT(7);
789 		if (reg) {
790 			struct sdio_cmd52 cmd;
791 
792 			cmd.read_write = 1;
793 			cmd.function = 0;
794 			cmd.raw = 0;
795 			cmd.address = WILC_SDIO_IRQ_CLEAR_FLAG_REG;
796 			cmd.data = reg;
797 
798 			ret = wilc_sdio_cmd52(wilc, &cmd);
799 			if (ret) {
800 				dev_err(&func->dev,
801 					"Failed cmd52, set (%02x) data (%d) ...\n",
802 					cmd.address, __LINE__);
803 				return ret;
804 			}
805 		}
806 		return 0;
807 	}
808 	if (sdio_priv->irq_gpio) {
809 		/* has_thrpt_enh2 uses register 0xf8 to clear interrupts. */
810 		/*
811 		 * Cannot clear multiple interrupts.
812 		 * Must clear each interrupt individually.
813 		 */
814 		u32 flags;
815 		int i;
816 
817 		flags = val & (BIT(MAX_NUM_INT) - 1);
818 		for (i = 0; i < NUM_INT_EXT && flags; i++) {
819 			if (flags & BIT(i)) {
820 				struct sdio_cmd52 cmd;
821 
822 				cmd.read_write = 1;
823 				cmd.function = 0;
824 				cmd.raw = 0;
825 				cmd.address = WILC_SDIO_IRQ_CLEAR_FLAG_REG;
826 				cmd.data = BIT(i);
827 
828 				ret = wilc_sdio_cmd52(wilc, &cmd);
829 				if (ret) {
830 					dev_err(&func->dev,
831 						"Failed cmd52, set (%02x) data (%d) ...\n",
832 						cmd.address, __LINE__);
833 					return ret;
834 				}
835 				flags &= ~BIT(i);
836 			}
837 		}
838 
839 		for (i = NUM_INT_EXT; i < MAX_NUM_INT && flags; i++) {
840 			if (flags & BIT(i)) {
841 				dev_err(&func->dev,
842 					"Unexpected interrupt cleared %d...\n",
843 					i);
844 				flags &= ~BIT(i);
845 			}
846 		}
847 	}
848 
849 	vmm_ctl = 0;
850 	/* select VMM table 0 */
851 	if (val & SEL_VMM_TBL0)
852 		vmm_ctl |= BIT(0);
853 	/* select VMM table 1 */
854 	if (val & SEL_VMM_TBL1)
855 		vmm_ctl |= BIT(1);
856 	/* enable VMM */
857 	if (val & EN_VMM)
858 		vmm_ctl |= BIT(2);
859 
860 	if (vmm_ctl) {
861 		struct sdio_cmd52 cmd;
862 
863 		cmd.read_write = 1;
864 		cmd.function = 0;
865 		cmd.raw = 0;
866 		cmd.address = WILC_SDIO_VMM_TBL_CTRL_REG;
867 		cmd.data = vmm_ctl;
868 		ret = wilc_sdio_cmd52(wilc, &cmd);
869 		if (ret) {
870 			dev_err(&func->dev,
871 				"Failed cmd52, set (%02x) data (%d) ...\n",
872 				cmd.address, __LINE__);
873 			return ret;
874 		}
875 	}
876 	return 0;
877 }
878 
879 static int wilc_sdio_sync_ext(struct wilc *wilc, int nint)
880 {
881 	struct sdio_func *func = dev_to_sdio_func(wilc->dev);
882 	struct wilc_sdio *sdio_priv = wilc->bus_data;
883 	u32 reg;
884 
885 	if (nint > MAX_NUM_INT) {
886 		dev_err(&func->dev, "Too many interrupts (%d)...\n", nint);
887 		return -EINVAL;
888 	}
889 
890 	/**
891 	 *      Disable power sequencer
892 	 **/
893 	if (wilc_sdio_read_reg(wilc, WILC_MISC, &reg)) {
894 		dev_err(&func->dev, "Failed read misc reg...\n");
895 		return -EINVAL;
896 	}
897 
898 	reg &= ~BIT(8);
899 	if (wilc_sdio_write_reg(wilc, WILC_MISC, reg)) {
900 		dev_err(&func->dev, "Failed write misc reg...\n");
901 		return -EINVAL;
902 	}
903 
904 	if (sdio_priv->irq_gpio) {
905 		u32 reg;
906 		int ret, i;
907 
908 		/**
909 		 *      interrupt pin mux select
910 		 **/
911 		ret = wilc_sdio_read_reg(wilc, WILC_PIN_MUX_0, &reg);
912 		if (ret) {
913 			dev_err(&func->dev, "Failed read reg (%08x)...\n",
914 				WILC_PIN_MUX_0);
915 			return ret;
916 		}
917 		reg |= BIT(8);
918 		ret = wilc_sdio_write_reg(wilc, WILC_PIN_MUX_0, reg);
919 		if (ret) {
920 			dev_err(&func->dev, "Failed write reg (%08x)...\n",
921 				WILC_PIN_MUX_0);
922 			return ret;
923 		}
924 
925 		/**
926 		 *      interrupt enable
927 		 **/
928 		ret = wilc_sdio_read_reg(wilc, WILC_INTR_ENABLE, &reg);
929 		if (ret) {
930 			dev_err(&func->dev, "Failed read reg (%08x)...\n",
931 				WILC_INTR_ENABLE);
932 			return ret;
933 		}
934 
935 		for (i = 0; (i < 5) && (nint > 0); i++, nint--)
936 			reg |= BIT((27 + i));
937 		ret = wilc_sdio_write_reg(wilc, WILC_INTR_ENABLE, reg);
938 		if (ret) {
939 			dev_err(&func->dev, "Failed write reg (%08x)...\n",
940 				WILC_INTR_ENABLE);
941 			return ret;
942 		}
943 		if (nint) {
944 			ret = wilc_sdio_read_reg(wilc, WILC_INTR2_ENABLE, &reg);
945 			if (ret) {
946 				dev_err(&func->dev,
947 					"Failed read reg (%08x)...\n",
948 					WILC_INTR2_ENABLE);
949 				return ret;
950 			}
951 
952 			for (i = 0; (i < 3) && (nint > 0); i++, nint--)
953 				reg |= BIT(i);
954 
955 			ret = wilc_sdio_write_reg(wilc, WILC_INTR2_ENABLE, reg);
956 			if (ret) {
957 				dev_err(&func->dev,
958 					"Failed write reg (%08x)...\n",
959 					WILC_INTR2_ENABLE);
960 				return ret;
961 			}
962 		}
963 	}
964 	return 0;
965 }
966 
967 /* Global sdio HIF function table */
968 static const struct wilc_hif_func wilc_hif_sdio = {
969 	.hif_init = wilc_sdio_init,
970 	.hif_deinit = wilc_sdio_deinit,
971 	.hif_read_reg = wilc_sdio_read_reg,
972 	.hif_write_reg = wilc_sdio_write_reg,
973 	.hif_block_rx = wilc_sdio_read,
974 	.hif_block_tx = wilc_sdio_write,
975 	.hif_read_int = wilc_sdio_read_int,
976 	.hif_clear_int_ext = wilc_sdio_clear_int_ext,
977 	.hif_read_size = wilc_sdio_read_size,
978 	.hif_block_tx_ext = wilc_sdio_write,
979 	.hif_block_rx_ext = wilc_sdio_read,
980 	.hif_sync_ext = wilc_sdio_sync_ext,
981 	.enable_interrupt = wilc_sdio_enable_interrupt,
982 	.disable_interrupt = wilc_sdio_disable_interrupt,
983 	.hif_reset = wilc_sdio_reset,
984 };
985 
986 static int wilc_sdio_resume(struct device *dev)
987 {
988 	struct sdio_func *func = dev_to_sdio_func(dev);
989 	struct wilc *wilc = sdio_get_drvdata(func);
990 
991 	dev_info(dev, "sdio resume\n");
992 	sdio_release_host(func);
993 	chip_wakeup(wilc);
994 	wilc_sdio_init(wilc, true);
995 
996 	if (wilc->suspend_event)
997 		host_wakeup_notify(wilc);
998 
999 	chip_allow_sleep(wilc);
1000 
1001 	return 0;
1002 }
1003 
1004 static const struct of_device_id wilc_of_match[] = {
1005 	{ .compatible = "microchip,wilc1000", },
1006 	{ /* sentinel */ }
1007 };
1008 MODULE_DEVICE_TABLE(of, wilc_of_match);
1009 
1010 static const struct dev_pm_ops wilc_sdio_pm_ops = {
1011 	.suspend = wilc_sdio_suspend,
1012 	.resume = wilc_sdio_resume,
1013 };
1014 
1015 static struct sdio_driver wilc_sdio_driver = {
1016 	.name		= SDIO_MODALIAS,
1017 	.id_table	= wilc_sdio_ids,
1018 	.probe		= wilc_sdio_probe,
1019 	.remove		= wilc_sdio_remove,
1020 	.drv = {
1021 		.pm = &wilc_sdio_pm_ops,
1022 		.of_match_table = wilc_of_match,
1023 	}
1024 };
1025 module_driver(wilc_sdio_driver,
1026 	      sdio_register_driver,
1027 	      sdio_unregister_driver);
1028 MODULE_LICENSE("GPL");
1029