xref: /openbmc/linux/drivers/soundwire/bus.c (revision 9eda7c1f)
1 // SPDX-License-Identifier: (GPL-2.0 OR BSD-3-Clause)
2 // Copyright(c) 2015-17 Intel Corporation.
3 
4 #include <linux/acpi.h>
5 #include <linux/delay.h>
6 #include <linux/mod_devicetable.h>
7 #include <linux/pm_runtime.h>
8 #include <linux/soundwire/sdw_registers.h>
9 #include <linux/soundwire/sdw.h>
10 #include "bus.h"
11 #include "sysfs_local.h"
12 
13 static DEFINE_IDA(sdw_ida);
14 
15 static int sdw_get_id(struct sdw_bus *bus)
16 {
17 	int rc = ida_alloc(&sdw_ida, GFP_KERNEL);
18 
19 	if (rc < 0)
20 		return rc;
21 
22 	bus->id = rc;
23 	return 0;
24 }
25 
26 /**
27  * sdw_bus_master_add() - add a bus Master instance
28  * @bus: bus instance
29  * @parent: parent device
30  * @fwnode: firmware node handle
31  *
32  * Initializes the bus instance, read properties and create child
33  * devices.
34  */
35 int sdw_bus_master_add(struct sdw_bus *bus, struct device *parent,
36 		       struct fwnode_handle *fwnode)
37 {
38 	struct sdw_master_prop *prop = NULL;
39 	int ret;
40 
41 	if (!parent) {
42 		pr_err("SoundWire parent device is not set\n");
43 		return -ENODEV;
44 	}
45 
46 	ret = sdw_get_id(bus);
47 	if (ret) {
48 		dev_err(parent, "Failed to get bus id\n");
49 		return ret;
50 	}
51 
52 	ret = sdw_master_device_add(bus, parent, fwnode);
53 	if (ret) {
54 		dev_err(parent, "Failed to add master device at link %d\n",
55 			bus->link_id);
56 		return ret;
57 	}
58 
59 	if (!bus->ops) {
60 		dev_err(bus->dev, "SoundWire Bus ops are not set\n");
61 		return -EINVAL;
62 	}
63 
64 	mutex_init(&bus->msg_lock);
65 	mutex_init(&bus->bus_lock);
66 	INIT_LIST_HEAD(&bus->slaves);
67 	INIT_LIST_HEAD(&bus->m_rt_list);
68 
69 	/*
70 	 * Initialize multi_link flag
71 	 * TODO: populate this flag by reading property from FW node
72 	 */
73 	bus->multi_link = false;
74 	if (bus->ops->read_prop) {
75 		ret = bus->ops->read_prop(bus);
76 		if (ret < 0) {
77 			dev_err(bus->dev,
78 				"Bus read properties failed:%d\n", ret);
79 			return ret;
80 		}
81 	}
82 
83 	sdw_bus_debugfs_init(bus);
84 
85 	/*
86 	 * Device numbers in SoundWire are 0 through 15. Enumeration device
87 	 * number (0), Broadcast device number (15), Group numbers (12 and
88 	 * 13) and Master device number (14) are not used for assignment so
89 	 * mask these and other higher bits.
90 	 */
91 
92 	/* Set higher order bits */
93 	*bus->assigned = ~GENMASK(SDW_BROADCAST_DEV_NUM, SDW_ENUM_DEV_NUM);
94 
95 	/* Set enumuration device number and broadcast device number */
96 	set_bit(SDW_ENUM_DEV_NUM, bus->assigned);
97 	set_bit(SDW_BROADCAST_DEV_NUM, bus->assigned);
98 
99 	/* Set group device numbers and master device number */
100 	set_bit(SDW_GROUP12_DEV_NUM, bus->assigned);
101 	set_bit(SDW_GROUP13_DEV_NUM, bus->assigned);
102 	set_bit(SDW_MASTER_DEV_NUM, bus->assigned);
103 
104 	/*
105 	 * SDW is an enumerable bus, but devices can be powered off. So,
106 	 * they won't be able to report as present.
107 	 *
108 	 * Create Slave devices based on Slaves described in
109 	 * the respective firmware (ACPI/DT)
110 	 */
111 	if (IS_ENABLED(CONFIG_ACPI) && ACPI_HANDLE(bus->dev))
112 		ret = sdw_acpi_find_slaves(bus);
113 	else if (IS_ENABLED(CONFIG_OF) && bus->dev->of_node)
114 		ret = sdw_of_find_slaves(bus);
115 	else
116 		ret = -ENOTSUPP; /* No ACPI/DT so error out */
117 
118 	if (ret) {
119 		dev_err(bus->dev, "Finding slaves failed:%d\n", ret);
120 		return ret;
121 	}
122 
123 	/*
124 	 * Initialize clock values based on Master properties. The max
125 	 * frequency is read from max_clk_freq property. Current assumption
126 	 * is that the bus will start at highest clock frequency when
127 	 * powered on.
128 	 *
129 	 * Default active bank will be 0 as out of reset the Slaves have
130 	 * to start with bank 0 (Table 40 of Spec)
131 	 */
132 	prop = &bus->prop;
133 	bus->params.max_dr_freq = prop->max_clk_freq * SDW_DOUBLE_RATE_FACTOR;
134 	bus->params.curr_dr_freq = bus->params.max_dr_freq;
135 	bus->params.curr_bank = SDW_BANK0;
136 	bus->params.next_bank = SDW_BANK1;
137 
138 	return 0;
139 }
140 EXPORT_SYMBOL(sdw_bus_master_add);
141 
142 static int sdw_delete_slave(struct device *dev, void *data)
143 {
144 	struct sdw_slave *slave = dev_to_sdw_dev(dev);
145 	struct sdw_bus *bus = slave->bus;
146 
147 	pm_runtime_disable(dev);
148 
149 	sdw_slave_debugfs_exit(slave);
150 
151 	mutex_lock(&bus->bus_lock);
152 
153 	if (slave->dev_num) /* clear dev_num if assigned */
154 		clear_bit(slave->dev_num, bus->assigned);
155 
156 	list_del_init(&slave->node);
157 	mutex_unlock(&bus->bus_lock);
158 
159 	device_unregister(dev);
160 	return 0;
161 }
162 
163 /**
164  * sdw_bus_master_delete() - delete the bus master instance
165  * @bus: bus to be deleted
166  *
167  * Remove the instance, delete the child devices.
168  */
169 void sdw_bus_master_delete(struct sdw_bus *bus)
170 {
171 	device_for_each_child(bus->dev, NULL, sdw_delete_slave);
172 	sdw_master_device_del(bus);
173 
174 	sdw_bus_debugfs_exit(bus);
175 	ida_free(&sdw_ida, bus->id);
176 }
177 EXPORT_SYMBOL(sdw_bus_master_delete);
178 
179 /*
180  * SDW IO Calls
181  */
182 
183 static inline int find_response_code(enum sdw_command_response resp)
184 {
185 	switch (resp) {
186 	case SDW_CMD_OK:
187 		return 0;
188 
189 	case SDW_CMD_IGNORED:
190 		return -ENODATA;
191 
192 	case SDW_CMD_TIMEOUT:
193 		return -ETIMEDOUT;
194 
195 	default:
196 		return -EIO;
197 	}
198 }
199 
200 static inline int do_transfer(struct sdw_bus *bus, struct sdw_msg *msg)
201 {
202 	int retry = bus->prop.err_threshold;
203 	enum sdw_command_response resp;
204 	int ret = 0, i;
205 
206 	for (i = 0; i <= retry; i++) {
207 		resp = bus->ops->xfer_msg(bus, msg);
208 		ret = find_response_code(resp);
209 
210 		/* if cmd is ok or ignored return */
211 		if (ret == 0 || ret == -ENODATA)
212 			return ret;
213 	}
214 
215 	return ret;
216 }
217 
218 static inline int do_transfer_defer(struct sdw_bus *bus,
219 				    struct sdw_msg *msg,
220 				    struct sdw_defer *defer)
221 {
222 	int retry = bus->prop.err_threshold;
223 	enum sdw_command_response resp;
224 	int ret = 0, i;
225 
226 	defer->msg = msg;
227 	defer->length = msg->len;
228 	init_completion(&defer->complete);
229 
230 	for (i = 0; i <= retry; i++) {
231 		resp = bus->ops->xfer_msg_defer(bus, msg, defer);
232 		ret = find_response_code(resp);
233 		/* if cmd is ok or ignored return */
234 		if (ret == 0 || ret == -ENODATA)
235 			return ret;
236 	}
237 
238 	return ret;
239 }
240 
241 static int sdw_reset_page(struct sdw_bus *bus, u16 dev_num)
242 {
243 	int retry = bus->prop.err_threshold;
244 	enum sdw_command_response resp;
245 	int ret = 0, i;
246 
247 	for (i = 0; i <= retry; i++) {
248 		resp = bus->ops->reset_page_addr(bus, dev_num);
249 		ret = find_response_code(resp);
250 		/* if cmd is ok or ignored return */
251 		if (ret == 0 || ret == -ENODATA)
252 			return ret;
253 	}
254 
255 	return ret;
256 }
257 
258 /**
259  * sdw_transfer() - Synchronous transfer message to a SDW Slave device
260  * @bus: SDW bus
261  * @msg: SDW message to be xfered
262  */
263 int sdw_transfer(struct sdw_bus *bus, struct sdw_msg *msg)
264 {
265 	int ret;
266 
267 	mutex_lock(&bus->msg_lock);
268 
269 	ret = do_transfer(bus, msg);
270 	if (ret != 0 && ret != -ENODATA)
271 		dev_err(bus->dev, "trf on Slave %d failed:%d\n",
272 			msg->dev_num, ret);
273 
274 	if (msg->page)
275 		sdw_reset_page(bus, msg->dev_num);
276 
277 	mutex_unlock(&bus->msg_lock);
278 
279 	return ret;
280 }
281 
282 /**
283  * sdw_transfer_defer() - Asynchronously transfer message to a SDW Slave device
284  * @bus: SDW bus
285  * @msg: SDW message to be xfered
286  * @defer: Defer block for signal completion
287  *
288  * Caller needs to hold the msg_lock lock while calling this
289  */
290 int sdw_transfer_defer(struct sdw_bus *bus, struct sdw_msg *msg,
291 		       struct sdw_defer *defer)
292 {
293 	int ret;
294 
295 	if (!bus->ops->xfer_msg_defer)
296 		return -ENOTSUPP;
297 
298 	ret = do_transfer_defer(bus, msg, defer);
299 	if (ret != 0 && ret != -ENODATA)
300 		dev_err(bus->dev, "Defer trf on Slave %d failed:%d\n",
301 			msg->dev_num, ret);
302 
303 	if (msg->page)
304 		sdw_reset_page(bus, msg->dev_num);
305 
306 	return ret;
307 }
308 
309 int sdw_fill_msg(struct sdw_msg *msg, struct sdw_slave *slave,
310 		 u32 addr, size_t count, u16 dev_num, u8 flags, u8 *buf)
311 {
312 	memset(msg, 0, sizeof(*msg));
313 	msg->addr = addr; /* addr is 16 bit and truncated here */
314 	msg->len = count;
315 	msg->dev_num = dev_num;
316 	msg->flags = flags;
317 	msg->buf = buf;
318 
319 	if (addr < SDW_REG_NO_PAGE) /* no paging area */
320 		return 0;
321 
322 	if (addr >= SDW_REG_MAX) { /* illegal addr */
323 		pr_err("SDW: Invalid address %x passed\n", addr);
324 		return -EINVAL;
325 	}
326 
327 	if (addr < SDW_REG_OPTIONAL_PAGE) { /* 32k but no page */
328 		if (slave && !slave->prop.paging_support)
329 			return 0;
330 		/* no need for else as that will fall-through to paging */
331 	}
332 
333 	/* paging mandatory */
334 	if (dev_num == SDW_ENUM_DEV_NUM || dev_num == SDW_BROADCAST_DEV_NUM) {
335 		pr_err("SDW: Invalid device for paging :%d\n", dev_num);
336 		return -EINVAL;
337 	}
338 
339 	if (!slave) {
340 		pr_err("SDW: No slave for paging addr\n");
341 		return -EINVAL;
342 	}
343 
344 	if (!slave->prop.paging_support) {
345 		dev_err(&slave->dev,
346 			"address %x needs paging but no support\n", addr);
347 		return -EINVAL;
348 	}
349 
350 	msg->addr_page1 = (addr >> SDW_REG_SHIFT(SDW_SCP_ADDRPAGE1_MASK));
351 	msg->addr_page2 = (addr >> SDW_REG_SHIFT(SDW_SCP_ADDRPAGE2_MASK));
352 	msg->addr |= BIT(15);
353 	msg->page = true;
354 
355 	return 0;
356 }
357 
358 /*
359  * Read/Write IO functions.
360  * no_pm versions can only be called by the bus, e.g. while enumerating or
361  * handling suspend-resume sequences.
362  * all clients need to use the pm versions
363  */
364 
365 static int
366 sdw_nread_no_pm(struct sdw_slave *slave, u32 addr, size_t count, u8 *val)
367 {
368 	struct sdw_msg msg;
369 	int ret;
370 
371 	ret = sdw_fill_msg(&msg, slave, addr, count,
372 			   slave->dev_num, SDW_MSG_FLAG_READ, val);
373 	if (ret < 0)
374 		return ret;
375 
376 	return sdw_transfer(slave->bus, &msg);
377 }
378 
379 static int
380 sdw_nwrite_no_pm(struct sdw_slave *slave, u32 addr, size_t count, u8 *val)
381 {
382 	struct sdw_msg msg;
383 	int ret;
384 
385 	ret = sdw_fill_msg(&msg, slave, addr, count,
386 			   slave->dev_num, SDW_MSG_FLAG_WRITE, val);
387 	if (ret < 0)
388 		return ret;
389 
390 	return sdw_transfer(slave->bus, &msg);
391 }
392 
393 static int sdw_write_no_pm(struct sdw_slave *slave, u32 addr, u8 value)
394 {
395 	return sdw_nwrite_no_pm(slave, addr, 1, &value);
396 }
397 
398 static int
399 sdw_bread_no_pm(struct sdw_bus *bus, u16 dev_num, u32 addr)
400 {
401 	struct sdw_msg msg;
402 	u8 buf;
403 	int ret;
404 
405 	ret = sdw_fill_msg(&msg, NULL, addr, 1, dev_num,
406 			   SDW_MSG_FLAG_READ, &buf);
407 	if (ret)
408 		return ret;
409 
410 	ret = sdw_transfer(bus, &msg);
411 	if (ret < 0)
412 		return ret;
413 
414 	return buf;
415 }
416 
417 static int
418 sdw_bwrite_no_pm(struct sdw_bus *bus, u16 dev_num, u32 addr, u8 value)
419 {
420 	struct sdw_msg msg;
421 	int ret;
422 
423 	ret = sdw_fill_msg(&msg, NULL, addr, 1, dev_num,
424 			   SDW_MSG_FLAG_WRITE, &value);
425 	if (ret)
426 		return ret;
427 
428 	return sdw_transfer(bus, &msg);
429 }
430 
431 static int
432 sdw_read_no_pm(struct sdw_slave *slave, u32 addr)
433 {
434 	u8 buf;
435 	int ret;
436 
437 	ret = sdw_nread_no_pm(slave, addr, 1, &buf);
438 	if (ret < 0)
439 		return ret;
440 	else
441 		return buf;
442 }
443 
444 /**
445  * sdw_nread() - Read "n" contiguous SDW Slave registers
446  * @slave: SDW Slave
447  * @addr: Register address
448  * @count: length
449  * @val: Buffer for values to be read
450  */
451 int sdw_nread(struct sdw_slave *slave, u32 addr, size_t count, u8 *val)
452 {
453 	int ret;
454 
455 	ret = pm_runtime_get_sync(slave->bus->dev);
456 	if (ret < 0 && ret != -EACCES) {
457 		pm_runtime_put_noidle(slave->bus->dev);
458 		return ret;
459 	}
460 
461 	ret = sdw_nread_no_pm(slave, addr, count, val);
462 
463 	pm_runtime_mark_last_busy(slave->bus->dev);
464 	pm_runtime_put(slave->bus->dev);
465 
466 	return ret;
467 }
468 EXPORT_SYMBOL(sdw_nread);
469 
470 /**
471  * sdw_nwrite() - Write "n" contiguous SDW Slave registers
472  * @slave: SDW Slave
473  * @addr: Register address
474  * @count: length
475  * @val: Buffer for values to be read
476  */
477 int sdw_nwrite(struct sdw_slave *slave, u32 addr, size_t count, u8 *val)
478 {
479 	int ret;
480 
481 	ret = pm_runtime_get_sync(slave->bus->dev);
482 	if (ret < 0 && ret != -EACCES) {
483 		pm_runtime_put_noidle(slave->bus->dev);
484 		return ret;
485 	}
486 
487 	ret = sdw_nwrite_no_pm(slave, addr, count, val);
488 
489 	pm_runtime_mark_last_busy(slave->bus->dev);
490 	pm_runtime_put(slave->bus->dev);
491 
492 	return ret;
493 }
494 EXPORT_SYMBOL(sdw_nwrite);
495 
496 /**
497  * sdw_read() - Read a SDW Slave register
498  * @slave: SDW Slave
499  * @addr: Register address
500  */
501 int sdw_read(struct sdw_slave *slave, u32 addr)
502 {
503 	u8 buf;
504 	int ret;
505 
506 	ret = sdw_nread(slave, addr, 1, &buf);
507 	if (ret < 0)
508 		return ret;
509 
510 	return buf;
511 }
512 EXPORT_SYMBOL(sdw_read);
513 
514 /**
515  * sdw_write() - Write a SDW Slave register
516  * @slave: SDW Slave
517  * @addr: Register address
518  * @value: Register value
519  */
520 int sdw_write(struct sdw_slave *slave, u32 addr, u8 value)
521 {
522 	return sdw_nwrite(slave, addr, 1, &value);
523 }
524 EXPORT_SYMBOL(sdw_write);
525 
526 /*
527  * SDW alert handling
528  */
529 
530 /* called with bus_lock held */
531 static struct sdw_slave *sdw_get_slave(struct sdw_bus *bus, int i)
532 {
533 	struct sdw_slave *slave = NULL;
534 
535 	list_for_each_entry(slave, &bus->slaves, node) {
536 		if (slave->dev_num == i)
537 			return slave;
538 	}
539 
540 	return NULL;
541 }
542 
543 static int sdw_compare_devid(struct sdw_slave *slave, struct sdw_slave_id id)
544 {
545 	if (slave->id.mfg_id != id.mfg_id ||
546 	    slave->id.part_id != id.part_id ||
547 	    slave->id.class_id != id.class_id ||
548 	    (slave->id.unique_id != SDW_IGNORED_UNIQUE_ID &&
549 	     slave->id.unique_id != id.unique_id))
550 		return -ENODEV;
551 
552 	return 0;
553 }
554 
555 /* called with bus_lock held */
556 static int sdw_get_device_num(struct sdw_slave *slave)
557 {
558 	int bit;
559 
560 	bit = find_first_zero_bit(slave->bus->assigned, SDW_MAX_DEVICES);
561 	if (bit == SDW_MAX_DEVICES) {
562 		bit = -ENODEV;
563 		goto err;
564 	}
565 
566 	/*
567 	 * Do not update dev_num in Slave data structure here,
568 	 * Update once program dev_num is successful
569 	 */
570 	set_bit(bit, slave->bus->assigned);
571 
572 err:
573 	return bit;
574 }
575 
576 static int sdw_assign_device_num(struct sdw_slave *slave)
577 {
578 	int ret, dev_num;
579 	bool new_device = false;
580 
581 	/* check first if device number is assigned, if so reuse that */
582 	if (!slave->dev_num) {
583 		if (!slave->dev_num_sticky) {
584 			mutex_lock(&slave->bus->bus_lock);
585 			dev_num = sdw_get_device_num(slave);
586 			mutex_unlock(&slave->bus->bus_lock);
587 			if (dev_num < 0) {
588 				dev_err(slave->bus->dev, "Get dev_num failed: %d\n",
589 					dev_num);
590 				return dev_num;
591 			}
592 			slave->dev_num = dev_num;
593 			slave->dev_num_sticky = dev_num;
594 			new_device = true;
595 		} else {
596 			slave->dev_num = slave->dev_num_sticky;
597 		}
598 	}
599 
600 	if (!new_device)
601 		dev_dbg(slave->bus->dev,
602 			"Slave already registered, reusing dev_num:%d\n",
603 			slave->dev_num);
604 
605 	/* Clear the slave->dev_num to transfer message on device 0 */
606 	dev_num = slave->dev_num;
607 	slave->dev_num = 0;
608 
609 	ret = sdw_write_no_pm(slave, SDW_SCP_DEVNUMBER, dev_num);
610 	if (ret < 0) {
611 		dev_err(&slave->dev, "Program device_num %d failed: %d\n",
612 			dev_num, ret);
613 		return ret;
614 	}
615 
616 	/* After xfer of msg, restore dev_num */
617 	slave->dev_num = slave->dev_num_sticky;
618 
619 	return 0;
620 }
621 
622 void sdw_extract_slave_id(struct sdw_bus *bus,
623 			  u64 addr, struct sdw_slave_id *id)
624 {
625 	dev_dbg(bus->dev, "SDW Slave Addr: %llx\n", addr);
626 
627 	id->sdw_version = SDW_VERSION(addr);
628 	id->unique_id = SDW_UNIQUE_ID(addr);
629 	id->mfg_id = SDW_MFG_ID(addr);
630 	id->part_id = SDW_PART_ID(addr);
631 	id->class_id = SDW_CLASS_ID(addr);
632 
633 	dev_dbg(bus->dev,
634 		"SDW Slave class_id %x, part_id %x, mfg_id %x, unique_id %x, version %x\n",
635 				id->class_id, id->part_id, id->mfg_id,
636 				id->unique_id, id->sdw_version);
637 }
638 
639 static int sdw_program_device_num(struct sdw_bus *bus)
640 {
641 	u8 buf[SDW_NUM_DEV_ID_REGISTERS] = {0};
642 	struct sdw_slave *slave, *_s;
643 	struct sdw_slave_id id;
644 	struct sdw_msg msg;
645 	bool found = false;
646 	int count = 0, ret;
647 	u64 addr;
648 
649 	/* No Slave, so use raw xfer api */
650 	ret = sdw_fill_msg(&msg, NULL, SDW_SCP_DEVID_0,
651 			   SDW_NUM_DEV_ID_REGISTERS, 0, SDW_MSG_FLAG_READ, buf);
652 	if (ret < 0)
653 		return ret;
654 
655 	do {
656 		ret = sdw_transfer(bus, &msg);
657 		if (ret == -ENODATA) { /* end of device id reads */
658 			dev_dbg(bus->dev, "No more devices to enumerate\n");
659 			ret = 0;
660 			break;
661 		}
662 		if (ret < 0) {
663 			dev_err(bus->dev, "DEVID read fail:%d\n", ret);
664 			break;
665 		}
666 
667 		/*
668 		 * Construct the addr and extract. Cast the higher shift
669 		 * bits to avoid truncation due to size limit.
670 		 */
671 		addr = buf[5] | (buf[4] << 8) | (buf[3] << 16) |
672 			((u64)buf[2] << 24) | ((u64)buf[1] << 32) |
673 			((u64)buf[0] << 40);
674 
675 		sdw_extract_slave_id(bus, addr, &id);
676 
677 		/* Now compare with entries */
678 		list_for_each_entry_safe(slave, _s, &bus->slaves, node) {
679 			if (sdw_compare_devid(slave, id) == 0) {
680 				found = true;
681 
682 				/*
683 				 * Assign a new dev_num to this Slave and
684 				 * not mark it present. It will be marked
685 				 * present after it reports ATTACHED on new
686 				 * dev_num
687 				 */
688 				ret = sdw_assign_device_num(slave);
689 				if (ret) {
690 					dev_err(slave->bus->dev,
691 						"Assign dev_num failed:%d\n",
692 						ret);
693 					return ret;
694 				}
695 
696 				break;
697 			}
698 		}
699 
700 		if (!found) {
701 			/* TODO: Park this device in Group 13 */
702 			dev_err(bus->dev, "Slave Entry not found\n");
703 		}
704 
705 		count++;
706 
707 		/*
708 		 * Check till error out or retry (count) exhausts.
709 		 * Device can drop off and rejoin during enumeration
710 		 * so count till twice the bound.
711 		 */
712 
713 	} while (ret == 0 && count < (SDW_MAX_DEVICES * 2));
714 
715 	return ret;
716 }
717 
718 static void sdw_modify_slave_status(struct sdw_slave *slave,
719 				    enum sdw_slave_status status)
720 {
721 	mutex_lock(&slave->bus->bus_lock);
722 
723 	dev_vdbg(&slave->dev,
724 		 "%s: changing status slave %d status %d new status %d\n",
725 		 __func__, slave->dev_num, slave->status, status);
726 
727 	if (status == SDW_SLAVE_UNATTACHED) {
728 		dev_dbg(&slave->dev,
729 			"%s: initializing completion for Slave %d\n",
730 			__func__, slave->dev_num);
731 
732 		init_completion(&slave->enumeration_complete);
733 		init_completion(&slave->initialization_complete);
734 
735 	} else if ((status == SDW_SLAVE_ATTACHED) &&
736 		   (slave->status == SDW_SLAVE_UNATTACHED)) {
737 		dev_dbg(&slave->dev,
738 			"%s: signaling completion for Slave %d\n",
739 			__func__, slave->dev_num);
740 
741 		complete(&slave->enumeration_complete);
742 	}
743 	slave->status = status;
744 	mutex_unlock(&slave->bus->bus_lock);
745 }
746 
747 static enum sdw_clk_stop_mode sdw_get_clk_stop_mode(struct sdw_slave *slave)
748 {
749 	enum sdw_clk_stop_mode mode;
750 
751 	/*
752 	 * Query for clock stop mode if Slave implements
753 	 * ops->get_clk_stop_mode, else read from property.
754 	 */
755 	if (slave->ops && slave->ops->get_clk_stop_mode) {
756 		mode = slave->ops->get_clk_stop_mode(slave);
757 	} else {
758 		if (slave->prop.clk_stop_mode1)
759 			mode = SDW_CLK_STOP_MODE1;
760 		else
761 			mode = SDW_CLK_STOP_MODE0;
762 	}
763 
764 	return mode;
765 }
766 
767 static int sdw_slave_clk_stop_callback(struct sdw_slave *slave,
768 				       enum sdw_clk_stop_mode mode,
769 				       enum sdw_clk_stop_type type)
770 {
771 	int ret;
772 
773 	if (slave->ops && slave->ops->clk_stop) {
774 		ret = slave->ops->clk_stop(slave, mode, type);
775 		if (ret < 0) {
776 			dev_err(&slave->dev,
777 				"Clk Stop type =%d failed: %d\n", type, ret);
778 			return ret;
779 		}
780 	}
781 
782 	return 0;
783 }
784 
785 static int sdw_slave_clk_stop_prepare(struct sdw_slave *slave,
786 				      enum sdw_clk_stop_mode mode,
787 				      bool prepare)
788 {
789 	bool wake_en;
790 	u32 val = 0;
791 	int ret;
792 
793 	wake_en = slave->prop.wake_capable;
794 
795 	if (prepare) {
796 		val = SDW_SCP_SYSTEMCTRL_CLK_STP_PREP;
797 
798 		if (mode == SDW_CLK_STOP_MODE1)
799 			val |= SDW_SCP_SYSTEMCTRL_CLK_STP_MODE1;
800 
801 		if (wake_en)
802 			val |= SDW_SCP_SYSTEMCTRL_WAKE_UP_EN;
803 	} else {
804 		val = sdw_read_no_pm(slave, SDW_SCP_SYSTEMCTRL);
805 
806 		val &= ~(SDW_SCP_SYSTEMCTRL_CLK_STP_PREP);
807 	}
808 
809 	ret = sdw_write_no_pm(slave, SDW_SCP_SYSTEMCTRL, val);
810 
811 	if (ret != 0)
812 		dev_err(&slave->dev,
813 			"Clock Stop prepare failed for slave: %d", ret);
814 
815 	return ret;
816 }
817 
818 static int sdw_bus_wait_for_clk_prep_deprep(struct sdw_bus *bus, u16 dev_num)
819 {
820 	int retry = bus->clk_stop_timeout;
821 	int val;
822 
823 	do {
824 		val = sdw_bread_no_pm(bus, dev_num, SDW_SCP_STAT) &
825 			SDW_SCP_STAT_CLK_STP_NF;
826 		if (!val) {
827 			dev_info(bus->dev, "clock stop prep/de-prep done slave:%d",
828 				 dev_num);
829 			return 0;
830 		}
831 
832 		usleep_range(1000, 1500);
833 		retry--;
834 	} while (retry);
835 
836 	dev_err(bus->dev, "clock stop prep/de-prep failed slave:%d",
837 		dev_num);
838 
839 	return -ETIMEDOUT;
840 }
841 
842 /**
843  * sdw_bus_prep_clk_stop: prepare Slave(s) for clock stop
844  *
845  * @bus: SDW bus instance
846  *
847  * Query Slave for clock stop mode and prepare for that mode.
848  */
849 int sdw_bus_prep_clk_stop(struct sdw_bus *bus)
850 {
851 	enum sdw_clk_stop_mode slave_mode;
852 	bool simple_clk_stop = true;
853 	struct sdw_slave *slave;
854 	bool is_slave = false;
855 	int ret = 0;
856 
857 	/*
858 	 * In order to save on transition time, prepare
859 	 * each Slave and then wait for all Slave(s) to be
860 	 * prepared for clock stop.
861 	 */
862 	list_for_each_entry(slave, &bus->slaves, node) {
863 		if (!slave->dev_num)
864 			continue;
865 
866 		if (slave->status != SDW_SLAVE_ATTACHED &&
867 		    slave->status != SDW_SLAVE_ALERT)
868 			continue;
869 
870 		/* Identify if Slave(s) are available on Bus */
871 		is_slave = true;
872 
873 		slave_mode = sdw_get_clk_stop_mode(slave);
874 		slave->curr_clk_stop_mode = slave_mode;
875 
876 		ret = sdw_slave_clk_stop_callback(slave, slave_mode,
877 						  SDW_CLK_PRE_PREPARE);
878 		if (ret < 0) {
879 			dev_err(&slave->dev,
880 				"pre-prepare failed:%d", ret);
881 			return ret;
882 		}
883 
884 		ret = sdw_slave_clk_stop_prepare(slave,
885 						 slave_mode, true);
886 		if (ret < 0) {
887 			dev_err(&slave->dev,
888 				"pre-prepare failed:%d", ret);
889 			return ret;
890 		}
891 
892 		if (slave_mode == SDW_CLK_STOP_MODE1)
893 			simple_clk_stop = false;
894 	}
895 
896 	if (is_slave && !simple_clk_stop) {
897 		ret = sdw_bus_wait_for_clk_prep_deprep(bus,
898 						       SDW_BROADCAST_DEV_NUM);
899 		if (ret < 0)
900 			return ret;
901 	}
902 
903 	/* Don't need to inform slaves if there is no slave attached */
904 	if (!is_slave)
905 		return ret;
906 
907 	/* Inform slaves that prep is done */
908 	list_for_each_entry(slave, &bus->slaves, node) {
909 		if (!slave->dev_num)
910 			continue;
911 
912 		if (slave->status != SDW_SLAVE_ATTACHED &&
913 		    slave->status != SDW_SLAVE_ALERT)
914 			continue;
915 
916 		slave_mode = slave->curr_clk_stop_mode;
917 
918 		if (slave_mode == SDW_CLK_STOP_MODE1) {
919 			ret = sdw_slave_clk_stop_callback(slave,
920 							  slave_mode,
921 							  SDW_CLK_POST_PREPARE);
922 
923 			if (ret < 0) {
924 				dev_err(&slave->dev,
925 					"post-prepare failed:%d", ret);
926 			}
927 		}
928 	}
929 
930 	return ret;
931 }
932 EXPORT_SYMBOL(sdw_bus_prep_clk_stop);
933 
934 /**
935  * sdw_bus_clk_stop: stop bus clock
936  *
937  * @bus: SDW bus instance
938  *
939  * After preparing the Slaves for clock stop, stop the clock by broadcasting
940  * write to SCP_CTRL register.
941  */
942 int sdw_bus_clk_stop(struct sdw_bus *bus)
943 {
944 	int ret;
945 
946 	/*
947 	 * broadcast clock stop now, attached Slaves will ACK this,
948 	 * unattached will ignore
949 	 */
950 	ret = sdw_bwrite_no_pm(bus, SDW_BROADCAST_DEV_NUM,
951 			       SDW_SCP_CTRL, SDW_SCP_CTRL_CLK_STP_NOW);
952 	if (ret < 0) {
953 		if (ret == -ENODATA)
954 			dev_dbg(bus->dev,
955 				"ClockStopNow Broadcast msg ignored %d", ret);
956 		else
957 			dev_err(bus->dev,
958 				"ClockStopNow Broadcast msg failed %d", ret);
959 		return ret;
960 	}
961 
962 	return 0;
963 }
964 EXPORT_SYMBOL(sdw_bus_clk_stop);
965 
966 /**
967  * sdw_bus_exit_clk_stop: Exit clock stop mode
968  *
969  * @bus: SDW bus instance
970  *
971  * This De-prepares the Slaves by exiting Clock Stop Mode 0. For the Slaves
972  * exiting Clock Stop Mode 1, they will be de-prepared after they enumerate
973  * back.
974  */
975 int sdw_bus_exit_clk_stop(struct sdw_bus *bus)
976 {
977 	enum sdw_clk_stop_mode mode;
978 	bool simple_clk_stop = true;
979 	struct sdw_slave *slave;
980 	bool is_slave = false;
981 	int ret;
982 
983 	/*
984 	 * In order to save on transition time, de-prepare
985 	 * each Slave and then wait for all Slave(s) to be
986 	 * de-prepared after clock resume.
987 	 */
988 	list_for_each_entry(slave, &bus->slaves, node) {
989 		if (!slave->dev_num)
990 			continue;
991 
992 		if (slave->status != SDW_SLAVE_ATTACHED &&
993 		    slave->status != SDW_SLAVE_ALERT)
994 			continue;
995 
996 		/* Identify if Slave(s) are available on Bus */
997 		is_slave = true;
998 
999 		mode = slave->curr_clk_stop_mode;
1000 
1001 		if (mode == SDW_CLK_STOP_MODE1) {
1002 			simple_clk_stop = false;
1003 			continue;
1004 		}
1005 
1006 		ret = sdw_slave_clk_stop_callback(slave, mode,
1007 						  SDW_CLK_PRE_DEPREPARE);
1008 		if (ret < 0)
1009 			dev_warn(&slave->dev,
1010 				 "clk stop deprep failed:%d", ret);
1011 
1012 		ret = sdw_slave_clk_stop_prepare(slave, mode,
1013 						 false);
1014 
1015 		if (ret < 0)
1016 			dev_warn(&slave->dev,
1017 				 "clk stop deprep failed:%d", ret);
1018 	}
1019 
1020 	if (is_slave && !simple_clk_stop)
1021 		sdw_bus_wait_for_clk_prep_deprep(bus, SDW_BROADCAST_DEV_NUM);
1022 
1023 	/*
1024 	 * Don't need to call slave callback function if there is no slave
1025 	 * attached
1026 	 */
1027 	if (!is_slave)
1028 		return 0;
1029 
1030 	list_for_each_entry(slave, &bus->slaves, node) {
1031 		if (!slave->dev_num)
1032 			continue;
1033 
1034 		if (slave->status != SDW_SLAVE_ATTACHED &&
1035 		    slave->status != SDW_SLAVE_ALERT)
1036 			continue;
1037 
1038 		mode = slave->curr_clk_stop_mode;
1039 		sdw_slave_clk_stop_callback(slave, mode,
1040 					    SDW_CLK_POST_DEPREPARE);
1041 	}
1042 
1043 	return 0;
1044 }
1045 EXPORT_SYMBOL(sdw_bus_exit_clk_stop);
1046 
1047 int sdw_configure_dpn_intr(struct sdw_slave *slave,
1048 			   int port, bool enable, int mask)
1049 {
1050 	u32 addr;
1051 	int ret;
1052 	u8 val = 0;
1053 
1054 	addr = SDW_DPN_INTMASK(port);
1055 
1056 	/* Set/Clear port ready interrupt mask */
1057 	if (enable) {
1058 		val |= mask;
1059 		val |= SDW_DPN_INT_PORT_READY;
1060 	} else {
1061 		val &= ~(mask);
1062 		val &= ~SDW_DPN_INT_PORT_READY;
1063 	}
1064 
1065 	ret = sdw_update(slave, addr, (mask | SDW_DPN_INT_PORT_READY), val);
1066 	if (ret < 0)
1067 		dev_err(slave->bus->dev,
1068 			"SDW_DPN_INTMASK write failed:%d\n", val);
1069 
1070 	return ret;
1071 }
1072 
1073 static int sdw_slave_set_frequency(struct sdw_slave *slave)
1074 {
1075 	u32 mclk_freq = slave->bus->prop.mclk_freq;
1076 	u32 curr_freq = slave->bus->params.curr_dr_freq >> 1;
1077 	unsigned int scale;
1078 	u8 scale_index;
1079 	u8 base;
1080 	int ret;
1081 
1082 	/*
1083 	 * frequency base and scale registers are required for SDCA
1084 	 * devices. They may also be used for 1.2+/non-SDCA devices,
1085 	 * but we will need a DisCo property to cover this case
1086 	 */
1087 	if (!slave->id.class_id)
1088 		return 0;
1089 
1090 	if (!mclk_freq) {
1091 		dev_err(&slave->dev,
1092 			"no bus MCLK, cannot set SDW_SCP_BUS_CLOCK_BASE\n");
1093 		return -EINVAL;
1094 	}
1095 
1096 	/*
1097 	 * map base frequency using Table 89 of SoundWire 1.2 spec.
1098 	 * The order of the tests just follows the specification, this
1099 	 * is not a selection between possible values or a search for
1100 	 * the best value but just a mapping.  Only one case per platform
1101 	 * is relevant.
1102 	 * Some BIOS have inconsistent values for mclk_freq but a
1103 	 * correct root so we force the mclk_freq to avoid variations.
1104 	 */
1105 	if (!(19200000 % mclk_freq)) {
1106 		mclk_freq = 19200000;
1107 		base = SDW_SCP_BASE_CLOCK_19200000_HZ;
1108 	} else if (!(24000000 % mclk_freq)) {
1109 		mclk_freq = 24000000;
1110 		base = SDW_SCP_BASE_CLOCK_24000000_HZ;
1111 	} else if (!(24576000 % mclk_freq)) {
1112 		mclk_freq = 24576000;
1113 		base = SDW_SCP_BASE_CLOCK_24576000_HZ;
1114 	} else if (!(22579200 % mclk_freq)) {
1115 		mclk_freq = 22579200;
1116 		base = SDW_SCP_BASE_CLOCK_22579200_HZ;
1117 	} else if (!(32000000 % mclk_freq)) {
1118 		mclk_freq = 32000000;
1119 		base = SDW_SCP_BASE_CLOCK_32000000_HZ;
1120 	} else {
1121 		dev_err(&slave->dev,
1122 			"Unsupported clock base, mclk %d\n",
1123 			mclk_freq);
1124 		return -EINVAL;
1125 	}
1126 
1127 	if (mclk_freq % curr_freq) {
1128 		dev_err(&slave->dev,
1129 			"mclk %d is not multiple of bus curr_freq %d\n",
1130 			mclk_freq, curr_freq);
1131 		return -EINVAL;
1132 	}
1133 
1134 	scale = mclk_freq / curr_freq;
1135 
1136 	/*
1137 	 * map scale to Table 90 of SoundWire 1.2 spec - and check
1138 	 * that the scale is a power of two and maximum 64
1139 	 */
1140 	scale_index = ilog2(scale);
1141 
1142 	if (BIT(scale_index) != scale || scale_index > 6) {
1143 		dev_err(&slave->dev,
1144 			"No match found for scale %d, bus mclk %d curr_freq %d\n",
1145 			scale, mclk_freq, curr_freq);
1146 		return -EINVAL;
1147 	}
1148 	scale_index++;
1149 
1150 	ret = sdw_write(slave, SDW_SCP_BUS_CLOCK_BASE, base);
1151 	if (ret < 0) {
1152 		dev_err(&slave->dev,
1153 			"SDW_SCP_BUS_CLOCK_BASE write failed:%d\n", ret);
1154 		return ret;
1155 	}
1156 
1157 	/* initialize scale for both banks */
1158 	ret = sdw_write(slave, SDW_SCP_BUSCLOCK_SCALE_B0, scale_index);
1159 	if (ret < 0) {
1160 		dev_err(&slave->dev,
1161 			"SDW_SCP_BUSCLOCK_SCALE_B0 write failed:%d\n", ret);
1162 		return ret;
1163 	}
1164 	ret = sdw_write(slave, SDW_SCP_BUSCLOCK_SCALE_B1, scale_index);
1165 	if (ret < 0)
1166 		dev_err(&slave->dev,
1167 			"SDW_SCP_BUSCLOCK_SCALE_B1 write failed:%d\n", ret);
1168 
1169 	dev_dbg(&slave->dev,
1170 		"Configured bus base %d, scale %d, mclk %d, curr_freq %d\n",
1171 		base, scale_index, mclk_freq, curr_freq);
1172 
1173 	return ret;
1174 }
1175 
1176 static int sdw_initialize_slave(struct sdw_slave *slave)
1177 {
1178 	struct sdw_slave_prop *prop = &slave->prop;
1179 	int ret;
1180 	u8 val;
1181 
1182 	ret = sdw_slave_set_frequency(slave);
1183 	if (ret < 0)
1184 		return ret;
1185 
1186 	/*
1187 	 * Set bus clash, parity and SCP implementation
1188 	 * defined interrupt mask
1189 	 * TODO: Read implementation defined interrupt mask
1190 	 * from Slave property
1191 	 */
1192 	val = SDW_SCP_INT1_IMPL_DEF | SDW_SCP_INT1_BUS_CLASH |
1193 					SDW_SCP_INT1_PARITY;
1194 
1195 	/* Enable SCP interrupts */
1196 	ret = sdw_update(slave, SDW_SCP_INTMASK1, val, val);
1197 	if (ret < 0) {
1198 		dev_err(slave->bus->dev,
1199 			"SDW_SCP_INTMASK1 write failed:%d\n", ret);
1200 		return ret;
1201 	}
1202 
1203 	/* No need to continue if DP0 is not present */
1204 	if (!slave->prop.dp0_prop)
1205 		return 0;
1206 
1207 	/* Enable DP0 interrupts */
1208 	val = prop->dp0_prop->imp_def_interrupts;
1209 	val |= SDW_DP0_INT_PORT_READY | SDW_DP0_INT_BRA_FAILURE;
1210 
1211 	ret = sdw_update(slave, SDW_DP0_INTMASK, val, val);
1212 	if (ret < 0)
1213 		dev_err(slave->bus->dev,
1214 			"SDW_DP0_INTMASK read failed:%d\n", ret);
1215 	return ret;
1216 }
1217 
1218 static int sdw_handle_dp0_interrupt(struct sdw_slave *slave, u8 *slave_status)
1219 {
1220 	u8 clear = 0, impl_int_mask;
1221 	int status, status2, ret, count = 0;
1222 
1223 	status = sdw_read(slave, SDW_DP0_INT);
1224 	if (status < 0) {
1225 		dev_err(slave->bus->dev,
1226 			"SDW_DP0_INT read failed:%d\n", status);
1227 		return status;
1228 	}
1229 
1230 	do {
1231 		if (status & SDW_DP0_INT_TEST_FAIL) {
1232 			dev_err(&slave->dev, "Test fail for port 0\n");
1233 			clear |= SDW_DP0_INT_TEST_FAIL;
1234 		}
1235 
1236 		/*
1237 		 * Assumption: PORT_READY interrupt will be received only for
1238 		 * ports implementing Channel Prepare state machine (CP_SM)
1239 		 */
1240 
1241 		if (status & SDW_DP0_INT_PORT_READY) {
1242 			complete(&slave->port_ready[0]);
1243 			clear |= SDW_DP0_INT_PORT_READY;
1244 		}
1245 
1246 		if (status & SDW_DP0_INT_BRA_FAILURE) {
1247 			dev_err(&slave->dev, "BRA failed\n");
1248 			clear |= SDW_DP0_INT_BRA_FAILURE;
1249 		}
1250 
1251 		impl_int_mask = SDW_DP0_INT_IMPDEF1 |
1252 			SDW_DP0_INT_IMPDEF2 | SDW_DP0_INT_IMPDEF3;
1253 
1254 		if (status & impl_int_mask) {
1255 			clear |= impl_int_mask;
1256 			*slave_status = clear;
1257 		}
1258 
1259 		/* clear the interrupt */
1260 		ret = sdw_write(slave, SDW_DP0_INT, clear);
1261 		if (ret < 0) {
1262 			dev_err(slave->bus->dev,
1263 				"SDW_DP0_INT write failed:%d\n", ret);
1264 			return ret;
1265 		}
1266 
1267 		/* Read DP0 interrupt again */
1268 		status2 = sdw_read(slave, SDW_DP0_INT);
1269 		if (status2 < 0) {
1270 			dev_err(slave->bus->dev,
1271 				"SDW_DP0_INT read failed:%d\n", status2);
1272 			return status2;
1273 		}
1274 		status &= status2;
1275 
1276 		count++;
1277 
1278 		/* we can get alerts while processing so keep retrying */
1279 	} while (status != 0 && count < SDW_READ_INTR_CLEAR_RETRY);
1280 
1281 	if (count == SDW_READ_INTR_CLEAR_RETRY)
1282 		dev_warn(slave->bus->dev, "Reached MAX_RETRY on DP0 read\n");
1283 
1284 	return ret;
1285 }
1286 
1287 static int sdw_handle_port_interrupt(struct sdw_slave *slave,
1288 				     int port, u8 *slave_status)
1289 {
1290 	u8 clear = 0, impl_int_mask;
1291 	int status, status2, ret, count = 0;
1292 	u32 addr;
1293 
1294 	if (port == 0)
1295 		return sdw_handle_dp0_interrupt(slave, slave_status);
1296 
1297 	addr = SDW_DPN_INT(port);
1298 	status = sdw_read(slave, addr);
1299 	if (status < 0) {
1300 		dev_err(slave->bus->dev,
1301 			"SDW_DPN_INT read failed:%d\n", status);
1302 
1303 		return status;
1304 	}
1305 
1306 	do {
1307 		if (status & SDW_DPN_INT_TEST_FAIL) {
1308 			dev_err(&slave->dev, "Test fail for port:%d\n", port);
1309 			clear |= SDW_DPN_INT_TEST_FAIL;
1310 		}
1311 
1312 		/*
1313 		 * Assumption: PORT_READY interrupt will be received only
1314 		 * for ports implementing CP_SM.
1315 		 */
1316 		if (status & SDW_DPN_INT_PORT_READY) {
1317 			complete(&slave->port_ready[port]);
1318 			clear |= SDW_DPN_INT_PORT_READY;
1319 		}
1320 
1321 		impl_int_mask = SDW_DPN_INT_IMPDEF1 |
1322 			SDW_DPN_INT_IMPDEF2 | SDW_DPN_INT_IMPDEF3;
1323 
1324 		if (status & impl_int_mask) {
1325 			clear |= impl_int_mask;
1326 			*slave_status = clear;
1327 		}
1328 
1329 		/* clear the interrupt */
1330 		ret = sdw_write(slave, addr, clear);
1331 		if (ret < 0) {
1332 			dev_err(slave->bus->dev,
1333 				"SDW_DPN_INT write failed:%d\n", ret);
1334 			return ret;
1335 		}
1336 
1337 		/* Read DPN interrupt again */
1338 		status2 = sdw_read(slave, addr);
1339 		if (status2 < 0) {
1340 			dev_err(slave->bus->dev,
1341 				"SDW_DPN_INT read failed:%d\n", status2);
1342 			return status2;
1343 		}
1344 		status &= status2;
1345 
1346 		count++;
1347 
1348 		/* we can get alerts while processing so keep retrying */
1349 	} while (status != 0 && count < SDW_READ_INTR_CLEAR_RETRY);
1350 
1351 	if (count == SDW_READ_INTR_CLEAR_RETRY)
1352 		dev_warn(slave->bus->dev, "Reached MAX_RETRY on port read");
1353 
1354 	return ret;
1355 }
1356 
1357 static int sdw_handle_slave_alerts(struct sdw_slave *slave)
1358 {
1359 	struct sdw_slave_intr_status slave_intr;
1360 	u8 clear = 0, bit, port_status[15] = {0};
1361 	int port_num, stat, ret, count = 0;
1362 	unsigned long port;
1363 	bool slave_notify = false;
1364 	u8 buf, buf2[2], _buf, _buf2[2];
1365 
1366 	sdw_modify_slave_status(slave, SDW_SLAVE_ALERT);
1367 
1368 	ret = pm_runtime_get_sync(&slave->dev);
1369 	if (ret < 0 && ret != -EACCES) {
1370 		dev_err(&slave->dev, "Failed to resume device: %d\n", ret);
1371 		pm_runtime_put_noidle(slave->bus->dev);
1372 		return ret;
1373 	}
1374 
1375 	/* Read Instat 1, Instat 2 and Instat 3 registers */
1376 	ret = sdw_read(slave, SDW_SCP_INT1);
1377 	if (ret < 0) {
1378 		dev_err(slave->bus->dev,
1379 			"SDW_SCP_INT1 read failed:%d\n", ret);
1380 		goto io_err;
1381 	}
1382 	buf = ret;
1383 
1384 	ret = sdw_nread(slave, SDW_SCP_INTSTAT2, 2, buf2);
1385 	if (ret < 0) {
1386 		dev_err(slave->bus->dev,
1387 			"SDW_SCP_INT2/3 read failed:%d\n", ret);
1388 		goto io_err;
1389 	}
1390 
1391 	do {
1392 		/*
1393 		 * Check parity, bus clash and Slave (impl defined)
1394 		 * interrupt
1395 		 */
1396 		if (buf & SDW_SCP_INT1_PARITY) {
1397 			dev_err(&slave->dev, "Parity error detected\n");
1398 			clear |= SDW_SCP_INT1_PARITY;
1399 		}
1400 
1401 		if (buf & SDW_SCP_INT1_BUS_CLASH) {
1402 			dev_err(&slave->dev, "Bus clash error detected\n");
1403 			clear |= SDW_SCP_INT1_BUS_CLASH;
1404 		}
1405 
1406 		/*
1407 		 * When bus clash or parity errors are detected, such errors
1408 		 * are unlikely to be recoverable errors.
1409 		 * TODO: In such scenario, reset bus. Make this configurable
1410 		 * via sysfs property with bus reset being the default.
1411 		 */
1412 
1413 		if (buf & SDW_SCP_INT1_IMPL_DEF) {
1414 			dev_dbg(&slave->dev, "Slave impl defined interrupt\n");
1415 			clear |= SDW_SCP_INT1_IMPL_DEF;
1416 			slave_notify = true;
1417 		}
1418 
1419 		/* Check port 0 - 3 interrupts */
1420 		port = buf & SDW_SCP_INT1_PORT0_3;
1421 
1422 		/* To get port number corresponding to bits, shift it */
1423 		port = port >> SDW_REG_SHIFT(SDW_SCP_INT1_PORT0_3);
1424 		for_each_set_bit(bit, &port, 8) {
1425 			sdw_handle_port_interrupt(slave, bit,
1426 						  &port_status[bit]);
1427 		}
1428 
1429 		/* Check if cascade 2 interrupt is present */
1430 		if (buf & SDW_SCP_INT1_SCP2_CASCADE) {
1431 			port = buf2[0] & SDW_SCP_INTSTAT2_PORT4_10;
1432 			for_each_set_bit(bit, &port, 8) {
1433 				/* scp2 ports start from 4 */
1434 				port_num = bit + 3;
1435 				sdw_handle_port_interrupt(slave,
1436 						port_num,
1437 						&port_status[port_num]);
1438 			}
1439 		}
1440 
1441 		/* now check last cascade */
1442 		if (buf2[0] & SDW_SCP_INTSTAT2_SCP3_CASCADE) {
1443 			port = buf2[1] & SDW_SCP_INTSTAT3_PORT11_14;
1444 			for_each_set_bit(bit, &port, 8) {
1445 				/* scp3 ports start from 11 */
1446 				port_num = bit + 10;
1447 				sdw_handle_port_interrupt(slave,
1448 						port_num,
1449 						&port_status[port_num]);
1450 			}
1451 		}
1452 
1453 		/* Update the Slave driver */
1454 		if (slave_notify && slave->ops &&
1455 		    slave->ops->interrupt_callback) {
1456 			slave_intr.control_port = clear;
1457 			memcpy(slave_intr.port, &port_status,
1458 			       sizeof(slave_intr.port));
1459 
1460 			slave->ops->interrupt_callback(slave, &slave_intr);
1461 		}
1462 
1463 		/* Ack interrupt */
1464 		ret = sdw_write(slave, SDW_SCP_INT1, clear);
1465 		if (ret < 0) {
1466 			dev_err(slave->bus->dev,
1467 				"SDW_SCP_INT1 write failed:%d\n", ret);
1468 			goto io_err;
1469 		}
1470 
1471 		/*
1472 		 * Read status again to ensure no new interrupts arrived
1473 		 * while servicing interrupts.
1474 		 */
1475 		ret = sdw_read(slave, SDW_SCP_INT1);
1476 		if (ret < 0) {
1477 			dev_err(slave->bus->dev,
1478 				"SDW_SCP_INT1 read failed:%d\n", ret);
1479 			goto io_err;
1480 		}
1481 		_buf = ret;
1482 
1483 		ret = sdw_nread(slave, SDW_SCP_INTSTAT2, 2, _buf2);
1484 		if (ret < 0) {
1485 			dev_err(slave->bus->dev,
1486 				"SDW_SCP_INT2/3 read failed:%d\n", ret);
1487 			goto io_err;
1488 		}
1489 
1490 		/* Make sure no interrupts are pending */
1491 		buf &= _buf;
1492 		buf2[0] &= _buf2[0];
1493 		buf2[1] &= _buf2[1];
1494 		stat = buf || buf2[0] || buf2[1];
1495 
1496 		/*
1497 		 * Exit loop if Slave is continuously in ALERT state even
1498 		 * after servicing the interrupt multiple times.
1499 		 */
1500 		count++;
1501 
1502 		/* we can get alerts while processing so keep retrying */
1503 	} while (stat != 0 && count < SDW_READ_INTR_CLEAR_RETRY);
1504 
1505 	if (count == SDW_READ_INTR_CLEAR_RETRY)
1506 		dev_warn(slave->bus->dev, "Reached MAX_RETRY on alert read\n");
1507 
1508 io_err:
1509 	pm_runtime_mark_last_busy(&slave->dev);
1510 	pm_runtime_put_autosuspend(&slave->dev);
1511 
1512 	return ret;
1513 }
1514 
1515 static int sdw_update_slave_status(struct sdw_slave *slave,
1516 				   enum sdw_slave_status status)
1517 {
1518 	unsigned long time;
1519 
1520 	if (!slave->probed) {
1521 		/*
1522 		 * the slave status update is typically handled in an
1523 		 * interrupt thread, which can race with the driver
1524 		 * probe, e.g. when a module needs to be loaded.
1525 		 *
1526 		 * make sure the probe is complete before updating
1527 		 * status.
1528 		 */
1529 		time = wait_for_completion_timeout(&slave->probe_complete,
1530 				msecs_to_jiffies(DEFAULT_PROBE_TIMEOUT));
1531 		if (!time) {
1532 			dev_err(&slave->dev, "Probe not complete, timed out\n");
1533 			return -ETIMEDOUT;
1534 		}
1535 	}
1536 
1537 	if (!slave->ops || !slave->ops->update_status)
1538 		return 0;
1539 
1540 	return slave->ops->update_status(slave, status);
1541 }
1542 
1543 /**
1544  * sdw_handle_slave_status() - Handle Slave status
1545  * @bus: SDW bus instance
1546  * @status: Status for all Slave(s)
1547  */
1548 int sdw_handle_slave_status(struct sdw_bus *bus,
1549 			    enum sdw_slave_status status[])
1550 {
1551 	enum sdw_slave_status prev_status;
1552 	struct sdw_slave *slave;
1553 	bool attached_initializing;
1554 	int i, ret = 0;
1555 
1556 	/* first check if any Slaves fell off the bus */
1557 	for (i = 1; i <= SDW_MAX_DEVICES; i++) {
1558 		mutex_lock(&bus->bus_lock);
1559 		if (test_bit(i, bus->assigned) == false) {
1560 			mutex_unlock(&bus->bus_lock);
1561 			continue;
1562 		}
1563 		mutex_unlock(&bus->bus_lock);
1564 
1565 		slave = sdw_get_slave(bus, i);
1566 		if (!slave)
1567 			continue;
1568 
1569 		if (status[i] == SDW_SLAVE_UNATTACHED &&
1570 		    slave->status != SDW_SLAVE_UNATTACHED)
1571 			sdw_modify_slave_status(slave, SDW_SLAVE_UNATTACHED);
1572 	}
1573 
1574 	if (status[0] == SDW_SLAVE_ATTACHED) {
1575 		dev_dbg(bus->dev, "Slave attached, programming device number\n");
1576 		ret = sdw_program_device_num(bus);
1577 		if (ret)
1578 			dev_err(bus->dev, "Slave attach failed: %d\n", ret);
1579 		/*
1580 		 * programming a device number will have side effects,
1581 		 * so we deal with other devices at a later time
1582 		 */
1583 		return ret;
1584 	}
1585 
1586 	/* Continue to check other slave statuses */
1587 	for (i = 1; i <= SDW_MAX_DEVICES; i++) {
1588 		mutex_lock(&bus->bus_lock);
1589 		if (test_bit(i, bus->assigned) == false) {
1590 			mutex_unlock(&bus->bus_lock);
1591 			continue;
1592 		}
1593 		mutex_unlock(&bus->bus_lock);
1594 
1595 		slave = sdw_get_slave(bus, i);
1596 		if (!slave)
1597 			continue;
1598 
1599 		attached_initializing = false;
1600 
1601 		switch (status[i]) {
1602 		case SDW_SLAVE_UNATTACHED:
1603 			if (slave->status == SDW_SLAVE_UNATTACHED)
1604 				break;
1605 
1606 			sdw_modify_slave_status(slave, SDW_SLAVE_UNATTACHED);
1607 			break;
1608 
1609 		case SDW_SLAVE_ALERT:
1610 			ret = sdw_handle_slave_alerts(slave);
1611 			if (ret)
1612 				dev_err(bus->dev,
1613 					"Slave %d alert handling failed: %d\n",
1614 					i, ret);
1615 			break;
1616 
1617 		case SDW_SLAVE_ATTACHED:
1618 			if (slave->status == SDW_SLAVE_ATTACHED)
1619 				break;
1620 
1621 			prev_status = slave->status;
1622 			sdw_modify_slave_status(slave, SDW_SLAVE_ATTACHED);
1623 
1624 			if (prev_status == SDW_SLAVE_ALERT)
1625 				break;
1626 
1627 			attached_initializing = true;
1628 
1629 			ret = sdw_initialize_slave(slave);
1630 			if (ret)
1631 				dev_err(bus->dev,
1632 					"Slave %d initialization failed: %d\n",
1633 					i, ret);
1634 
1635 			break;
1636 
1637 		default:
1638 			dev_err(bus->dev, "Invalid slave %d status:%d\n",
1639 				i, status[i]);
1640 			break;
1641 		}
1642 
1643 		ret = sdw_update_slave_status(slave, status[i]);
1644 		if (ret)
1645 			dev_err(slave->bus->dev,
1646 				"Update Slave status failed:%d\n", ret);
1647 		if (attached_initializing)
1648 			complete(&slave->initialization_complete);
1649 	}
1650 
1651 	return ret;
1652 }
1653 EXPORT_SYMBOL(sdw_handle_slave_status);
1654 
1655 void sdw_clear_slave_status(struct sdw_bus *bus, u32 request)
1656 {
1657 	struct sdw_slave *slave;
1658 	int i;
1659 
1660 	/* Check all non-zero devices */
1661 	for (i = 1; i <= SDW_MAX_DEVICES; i++) {
1662 		mutex_lock(&bus->bus_lock);
1663 		if (test_bit(i, bus->assigned) == false) {
1664 			mutex_unlock(&bus->bus_lock);
1665 			continue;
1666 		}
1667 		mutex_unlock(&bus->bus_lock);
1668 
1669 		slave = sdw_get_slave(bus, i);
1670 		if (!slave)
1671 			continue;
1672 
1673 		if (slave->status != SDW_SLAVE_UNATTACHED)
1674 			sdw_modify_slave_status(slave, SDW_SLAVE_UNATTACHED);
1675 
1676 		/* keep track of request, used in pm_runtime resume */
1677 		slave->unattach_request = request;
1678 	}
1679 }
1680 EXPORT_SYMBOL(sdw_clear_slave_status);
1681