xref: /illumos-gate/usr/src/uts/common/io/1394/s1394_dev_disc.c (revision 8a2b682e57a046b828f37bcde1776f131ef4629f)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License, Version 1.0 only
6  * (the "License").  You may not use this file except in compliance
7  * with the License.
8  *
9  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10  * or http://www.opensolaris.org/os/licensing.
11  * See the License for the specific language governing permissions
12  * and limitations under the License.
13  *
14  * When distributing Covered Code, include this CDDL HEADER in each
15  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16  * If applicable, add the following below this CDDL HEADER, with the
17  * fields enclosed by brackets "[]" replaced with your own identifying
18  * information: Portions Copyright [yyyy] [name of copyright owner]
19  *
20  * CDDL HEADER END
21  */
22 /*
23  * Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
24  * Use is subject to license terms.
25  */
26 
27 /*
28  * Copyright 2019 Joyent, Inc.
29  */
30 
31 /*
32  * s1394_dev_disc.c
33  *    1394 Services Layer Device Discovery Routines
34  *    This file contains the bus reset thread code, bus manager routines and
35  *    various routines that are used to implement remote Config ROM reading.
36  *
37  *    FUTURE:
38  *    Rescan the bus if invalid nodes are seen.
39  *    Investigate taskq for reading phase2 config rom reads.
40  *    If we are reading the entire bus info blk, we should attempt
41  *    a block read and fallback to quad reads if this fails.
42  */
43 
44 #include <sys/conf.h>
45 #include <sys/sysmacros.h>
46 #include <sys/ddi.h>
47 #include <sys/sunddi.h>
48 #include <sys/cmn_err.h>
49 #include <sys/sunndi.h>
50 #include <sys/modctl.h>
51 #include <sys/ddi_impldefs.h>
52 #include <sys/types.h>
53 #include <sys/kmem.h>
54 #include <sys/kstat.h>
55 #include <sys/varargs.h>
56 
57 #include <sys/tnf_probe.h>
58 
59 #include <sys/1394/t1394.h>
60 #include <sys/1394/s1394.h>
61 #include <sys/1394/h1394.h>
62 #include <sys/1394/ieee1394.h>
63 #include <sys/1394/ieee1212.h>
64 
65 /* hcmd_ret_t */
66 typedef enum {
67 	S1394_HCMD_INVALID,
68 	S1394_HCMD_NODE_DONE,
69 	S1394_HCMD_NODE_EXPECT_MORE,
70 	S1394_HCMD_LOCK_FAILED
71 } hcmd_ret_t;
72 
73 #define	QUAD_TO_CFGROM_ADDR(b, n, q, addr) {			\
74 	uint64_t bl = (b);					\
75 	uint64_t nl = (n);					\
76 	addr = ((bl) << IEEE1394_ADDR_BUS_ID_SHIFT) |		\
77 		((nl) << IEEE1394_ADDR_PHY_ID_SHIFT);		\
78 	addr += IEEE1394_CONFIG_ROM_ADDR + ((q) << 2);		\
79 }
80 
81 #define	CFGROM_READ_PAUSE(d)						\
82 	((s1394_cfgrom_read_delay_ms == 0) ? (void) 0 :			\
83 	delay(drv_usectohz((d) * 1000)))
84 
85 #define	BUMP_CFGROM_READ_DELAY(n)					\
86 	(n)->cfgrom_read_delay += s1394_cfgrom_read_delay_incr
87 
88 #define	CFGROM_GET_READ_DELAY(n, d)					\
89 	((d) = (n)->cfgrom_read_delay)
90 
91 #define	SETUP_QUAD_READ(n, reset_fails, quadlet, cnt)			\
92 {									\
93 	int i = (reset_fails);						\
94 	if (i != 0) {							\
95 		(n)->cfgrom_read_fails = 0;				\
96 		(n)->cfgrom_read_delay = (uchar_t)s1394_cfgrom_read_delay_ms; \
97 	}								\
98 	(n)->cfgrom_quad_to_read = (quadlet);				\
99 	(n)->cfgrom_quad_read_cnt = (cnt);				\
100 }
101 
102 static void s1394_wait_for_events(s1394_hal_t *hal, int firsttime);
103 
104 static int s1394_wait_for_cfgrom_callbacks(s1394_hal_t *hal, uint_t wait_gen,
105     hcmd_ret_t(*handle_cmd_fn)(s1394_hal_t *hal, cmd1394_cmd_t *cmd));
106 
107 static void s1394_flush_cmplq(s1394_hal_t *hal);
108 
109 static void s1394_br_thread_exit(s1394_hal_t *hal);
110 
111 static void s1394_target_bus_reset_notifies(s1394_hal_t *hal,
112     t1394_localinfo_t *localinfo);
113 
114 static int s1394_alloc_cfgrom(s1394_hal_t *hal, s1394_node_t *node,
115     s1394_status_t *status);
116 
117 static int s1394_cfgrom_scan_phase1(s1394_hal_t *hal);
118 
119 static hcmd_ret_t s1394_br_thread_handle_cmd_phase1(s1394_hal_t *hal,
120     cmd1394_cmd_t *cmd);
121 
122 static int s1394_cfgrom_scan_phase2(s1394_hal_t *hal);
123 
124 static hcmd_ret_t s1394_br_thread_handle_cmd_phase2(s1394_hal_t *hal,
125     cmd1394_cmd_t *cmd);
126 
127 static int s1394_read_config_quadlet(s1394_hal_t *hal, cmd1394_cmd_t *cmd,
128     s1394_status_t *status);
129 
130 static void s1394_cfgrom_read_callback(cmd1394_cmd_t *cmd);
131 
132 static void s1394_get_quad_info(cmd1394_cmd_t *cmd, uint32_t *node_num,
133     uint32_t *quadlet, uint32_t *data);
134 
135 static int s1394_match_GUID(s1394_hal_t *hal, s1394_node_t *nnode);
136 
137 static int s1394_match_all_GUIDs(s1394_hal_t *hal);
138 
139 static void s1394_become_bus_mgr(void *arg);
140 
141 static void s1394_become_bus_mgr_callback(cmd1394_cmd_t *cmd);
142 
143 static int s1394_bus_mgr_processing(s1394_hal_t *hal);
144 
145 static int s1394_do_bus_mgr_processing(s1394_hal_t *hal);
146 
147 static void s1394_bus_mgr_timers_stop(s1394_hal_t *hal,
148     timeout_id_t *bus_mgr_query_tid, timeout_id_t *bus_mgr_tid);
149 
150 static void s1394_bus_mgr_timers_start(s1394_hal_t *hal,
151     timeout_id_t *bus_mgr_query_tid, timeout_id_t *bus_mgr_tid);
152 
153 static int s1394_cycle_master_capable(s1394_hal_t *hal);
154 
155 static int s1394_do_phy_config_pkt(s1394_hal_t *hal, int new_root,
156     int new_gap_cnt, uint32_t IRM_flags);
157 
158 static void s1394_phy_config_callback(cmd1394_cmd_t *cmd);
159 
160 static int s1394_calc_next_quad(s1394_hal_t *hal, s1394_node_t *node,
161     uint32_t quadlet, uint32_t *nextquadp);
162 
163 static int s1394_cfgrom_read_retry_cnt = 3;	/* 1 + 3 retries */
164 static int s1394_cfgrom_read_delay_ms = 20;	/* start with 20ms */
165 static int s1394_cfgrom_read_delay_incr = 10;	/* 10ms increments */
166 static int s1394_enable_crc_validation = 0;
167 static int s1394_turn_off_dir_stack = 0;
168 static int s1394_crcsz_is_cfgsz = 0;
169 static int s1394_enable_rio_pass1_workarounds = 0;
170 
171 /*
172  * s1394_br_thread()
173  *    is the bus reset thread. Its sole purpose is to read/reread config roms
174  *    as appropriate and do bus reset time things (bus manager processing,
175  *    isoch resource reallocation etc.).
176  */
177 void
178 s1394_br_thread(s1394_hal_t *hal)
179 {
180 	TNF_PROBE_0_DEBUG(s1394_br_thread_enter, S1394_TNF_SL_HOTPLUG_STACK,
181 	    "");
182 
183 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
184 
185 	/* Initialize the Bus Mgr timers */
186 	hal->bus_mgr_timeout_id = 0;
187 	hal->bus_mgr_query_timeout_id = 0;
188 
189 	/* Initialize the cmpletion Q */
190 	mutex_enter(&hal->br_cmplq_mutex);
191 	hal->br_cmplq_head = hal->br_cmplq_tail = NULL;
192 	mutex_exit(&hal->br_cmplq_mutex);
193 
194 	s1394_wait_for_events(hal, 1);
195 
196 	for (;;) {
197 		ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
198 
199 		TNF_PROBE_0_DEBUG(s1394_br_thread_wait,
200 		    S1394_TNF_SL_HOTPLUG_STACK, "");
201 
202 		s1394_wait_for_events(hal, 0);
203 
204 		ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
205 
206 		TNF_PROBE_1_DEBUG(s1394_br_thread_restart,
207 		    S1394_TNF_SL_HOTPLUG_STACK, "",
208 		    tnf_int, hal_instance, ddi_get_instance(hal->halinfo.dip));
209 
210 		/* stop bus manager timeouts, if needed */
211 		s1394_bus_mgr_timers_stop(hal, &hal->bus_mgr_query_timeout_id,
212 		    &hal->bus_mgr_timeout_id);
213 
214 		s1394_flush_cmplq(hal);
215 
216 		/* start timers for checking bus manager, if needed */
217 		s1394_bus_mgr_timers_start(hal, &hal->bus_mgr_query_timeout_id,
218 		    &hal->bus_mgr_timeout_id);
219 
220 		/* Try to reallocate all isoch resources */
221 		s1394_isoch_rsrc_realloc(hal);
222 
223 		if (s1394_cfgrom_scan_phase1(hal) != DDI_SUCCESS) {
224 			TNF_PROBE_0_DEBUG(br_thread_phase1_restart,
225 			    S1394_TNF_SL_HOTPLUG_STACK, "");
226 			continue;
227 		}
228 
229 		TNF_PROBE_1_DEBUG(s1394_br_thread_phase1_done,
230 		    S1394_TNF_SL_HOTPLUG_STACK, "",
231 		    tnf_int, hal_instance, ddi_get_instance(hal->halinfo.dip));
232 
233 		if (s1394_bus_mgr_processing(hal) != DDI_SUCCESS) {
234 			TNF_PROBE_0_DEBUG(br_thread_bus_mgr_restart,
235 			    S1394_TNF_SL_HOTPLUG_STACK, "");
236 			continue;
237 		}
238 
239 		TNF_PROBE_1_DEBUG(s1394_br_thread_bus_mgr_proc_done,
240 		    S1394_TNF_SL_HOTPLUG_STACK, "",
241 		    tnf_int, hal_instance, ddi_get_instance(hal->halinfo.dip));
242 
243 		ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
244 
245 		if (s1394_cfgrom_scan_phase2(hal) != DDI_SUCCESS) {
246 			TNF_PROBE_0_DEBUG(br_thread_phase2_restart,
247 			    S1394_TNF_SL_HOTPLUG_STACK, "");
248 			continue;
249 		}
250 
251 		TNF_PROBE_1_DEBUG(s1394_br_thread_done,
252 		    S1394_TNF_SL_HOTPLUG_STACK, "",
253 		    tnf_int, hal_instance, ddi_get_instance(hal->halinfo.dip));
254 
255 		ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
256 	}
257 }
258 
259 /*
260  * s1394_wait_for_events()
261  *    blocks waiting for a cv_signal on the bus reset condition variable.
262  *    Used by the bus reset thread for synchronizing with the bus reset/
263  *    self id interrupt callback from the hal. Does CPR initialization
264  *    first time it is called. If services layer sees a valid self id
265  *    buffer, it builds the topology tree and signals the bus reset thread
266  *    to read the config roms as appropriate (indicated by BR_THR_CFGROM_SCAN).
267  *    If the services layer wishes to kill the bus reset thread, it signals
268  *    this by signaling a BR_THR_GO_AWAY event.
269  */
270 static void
271 s1394_wait_for_events(s1394_hal_t *hal, int firsttime)
272 {
273 	uint_t event;
274 
275 	TNF_PROBE_0_DEBUG(s1394_wait_for_events_enter,
276 	    S1394_TNF_SL_HOTPLUG_STACK, "");
277 
278 	ASSERT(MUTEX_NOT_HELD(&hal->br_thread_mutex));
279 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
280 
281 	if (firsttime)
282 		CALLB_CPR_INIT(&hal->hal_cprinfo, &hal->br_thread_mutex,
283 		    callb_generic_cpr, "s1394_br_thread");
284 
285 	/* Check and wait for a BUS RESET */
286 	mutex_enter(&hal->br_thread_mutex);
287 	while ((event = hal->br_thread_ev_type) == 0) {
288 		CALLB_CPR_SAFE_BEGIN(&hal->hal_cprinfo);
289 		cv_wait(&hal->br_thread_cv, &hal->br_thread_mutex);
290 		CALLB_CPR_SAFE_END(&hal->hal_cprinfo, &hal->br_thread_mutex);
291 	}
292 
293 	if (event & BR_THR_GO_AWAY) {
294 		TNF_PROBE_1(s1394_wait_for_events, S1394_TNF_SL_HOTPLUG_STACK,
295 		    "", tnf_string, msg, "Go away set");
296 		s1394_br_thread_exit(hal);
297 		TNF_PROBE_0_DEBUG(s1394_wait_for_events_exit,
298 		    S1394_TNF_SL_HOTPLUG_STACK, "");
299 		/*NOTREACHED*/
300 		return;
301 	}
302 
303 	if (firsttime) {
304 		TNF_PROBE_0_DEBUG(s1394_wait_for_events_exit,
305 		    S1394_TNF_SL_HOTPLUG_STACK, "");
306 		mutex_exit(&hal->br_thread_mutex);
307 		return;
308 	}
309 
310 	mutex_enter(&hal->topology_tree_mutex);
311 	if (event & BR_THR_CFGROM_SCAN) {
312 		TNF_PROBE_2_DEBUG(s1394_wait_for_events_scan,
313 		    S1394_TNF_SL_HOTPLUG_STACK, "",
314 		    tnf_int, br_thread_gen, hal->br_cfgrom_read_gen,
315 		    tnf_int, hal_generation, hal->generation_count);
316 	}
317 	hal->br_cfgrom_read_gen = hal->generation_count;
318 
319 	hal->br_thread_ev_type &= ~BR_THR_CFGROM_SCAN;
320 	mutex_exit(&hal->topology_tree_mutex);
321 	mutex_exit(&hal->br_thread_mutex);
322 
323 	TNF_PROBE_0_DEBUG(s1394_wait_for_events_exit,
324 	    S1394_TNF_SL_HOTPLUG_STACK, "");
325 }
326 
327 /*
328  * s1394_wait_for_cfgrom_callbacks()
329  *    Waits for completed config rom reads. Takes each completion off the
330  *    completion queue and passes it to the "completion handler" function
331  *    that was passed in as an argument. Further processing of the completion
332  *    queue depends on the return status of the completion handler. If there
333  *    is a bus reset while waiting for completions or if the services layer
334  *    signals BR_THR_GO_AWAY, quits waiting for completions and returns
335  *    non-zero. Also returns non-zero if completion handler returns
336  *    S1394_HCMD_LOCK_FAILED.  Returns 0 if config roms for all nodes have
337  *    been dealt with.
338  */
339 static int
340 s1394_wait_for_cfgrom_callbacks(s1394_hal_t *hal, uint_t wait_gen,
341     hcmd_ret_t(*handle_cmd_fn)(s1394_hal_t *hal, cmd1394_cmd_t *cmd))
342 {
343 	cmd1394_cmd_t *cmd;
344 	s1394_cmd_priv_t *s_priv;
345 	int ret, done = 0;
346 	hcmd_ret_t cmdret;
347 
348 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
349 
350 	TNF_PROBE_1_DEBUG(s1394_wait_for_cfgrom_callbacks_enter,
351 	    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_uint, wait_gen, wait_gen);
352 
353 	ret = DDI_SUCCESS;
354 
355 	while (!done) {
356 		mutex_enter(&hal->br_cmplq_mutex);
357 		mutex_enter(&hal->topology_tree_mutex);
358 		while (wait_gen == hal->generation_count &&
359 		    (hal->br_thread_ev_type & BR_THR_GO_AWAY) == 0 &&
360 		    hal->br_cmplq_head == NULL) {
361 			mutex_exit(&hal->topology_tree_mutex);
362 			cv_wait(&hal->br_cmplq_cv, &hal->br_cmplq_mutex);
363 			mutex_enter(&hal->topology_tree_mutex);
364 		}
365 		ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
366 		if (wait_gen != hal->generation_count ||
367 		    (hal->br_thread_ev_type & BR_THR_GO_AWAY) != 0) {
368 
369 #if !defined(NPROBE) && defined(TNF_DEBUG)
370 			int hal_gen = hal->generation_count;
371 #endif
372 
373 			mutex_exit(&hal->topology_tree_mutex);
374 			mutex_exit(&hal->br_cmplq_mutex);
375 			s1394_flush_cmplq(hal);
376 			TNF_PROBE_1_DEBUG(s1394_wait_for_cfgrom_callbacks_exit,
377 			    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_int, hal_gen,
378 			    hal_gen);
379 			return (DDI_FAILURE);
380 		}
381 		mutex_exit(&hal->topology_tree_mutex);
382 
383 		if ((cmd = hal->br_cmplq_head) != NULL) {
384 			s_priv = S1394_GET_CMD_PRIV(cmd);
385 
386 			hal->br_cmplq_head = s_priv->cmd_priv_next;
387 		}
388 		if (cmd == hal->br_cmplq_tail)
389 			hal->br_cmplq_tail = NULL;
390 		mutex_exit(&hal->br_cmplq_mutex);
391 
392 		if (cmd != NULL) {
393 			if (cmd->bus_generation != wait_gen) {
394 				TNF_PROBE_3(
395 				    s1394_wait_for_cfgrom_callbacks,
396 				    S1394_TNF_SL_HOTPLUG_STACK, "",
397 				    tnf_string, msg, "command gen != wait_gen",
398 				    tnf_uint, cmd_gen, cmd->bus_generation,
399 				    tnf_uint, wait_gen, wait_gen);
400 				(void) s1394_free_cmd(hal, &cmd);
401 				continue;
402 			}
403 			cmdret = (*handle_cmd_fn)(hal, cmd);
404 			TNF_PROBE_2_DEBUG(s1394_wait_for_cfgrom_callbacks,
405 			    S1394_TNF_SL_HOTPLUG_STACK, "",
406 			    tnf_opaque, cmd, cmd, tnf_int, cmdret, cmdret);
407 			ASSERT(cmdret != S1394_HCMD_INVALID);
408 			if (cmdret == S1394_HCMD_LOCK_FAILED) {
409 				/* flush completion queue */
410 				ret = DDI_FAILURE;
411 				s1394_flush_cmplq(hal);
412 				break;
413 			} else if (cmdret == S1394_HCMD_NODE_DONE) {
414 				if (--hal->cfgroms_being_read == 0) {
415 					/* All done */
416 					break;
417 				}
418 			} else {
419 				ASSERT(cmdret == S1394_HCMD_NODE_EXPECT_MORE);
420 				done = 0;
421 			}
422 		}
423 	}
424 
425 	TNF_PROBE_0_DEBUG(s1394_wait_for_cfgrom_callbacks_exit,
426 	    S1394_TNF_SL_HOTPLUG_STACK, "");
427 
428 	return (ret);
429 }
430 
431 /*
432  * s1394_flush_cmplq()
433  *    Frees all cmds on the completion queue.
434  */
435 static void
436 s1394_flush_cmplq(s1394_hal_t *hal)
437 {
438 	s1394_cmd_priv_t *s_priv;
439 	cmd1394_cmd_t *cmd, *tcmd;
440 
441 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
442 
443 	TNF_PROBE_0_DEBUG(s1394_flush_cmplq_enter, S1394_TNF_SL_HOTPLUG_STACK,
444 	    "");
445 
446 	cmd = NULL;
447 
448 	do {
449 		mutex_enter(&hal->br_cmplq_mutex);
450 		cmd = hal->br_cmplq_head;
451 		hal->br_cmplq_head = hal->br_cmplq_tail = NULL;
452 		mutex_exit(&hal->br_cmplq_mutex);
453 
454 		while (cmd != NULL) {
455 			s_priv = S1394_GET_CMD_PRIV(cmd);
456 
457 			tcmd = s_priv->cmd_priv_next;
458 			TNF_PROBE_2_DEBUG(s1394_flush_cmplq,
459 			    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_opaque, cmd,
460 			    cmd, tnf_uint, cmd_gen, cmd->bus_generation);
461 			(void) s1394_free_cmd(hal, &cmd);
462 			cmd = tcmd;
463 		}
464 
465 		mutex_enter(&hal->br_cmplq_mutex);
466 		cmd = hal->br_cmplq_head;
467 		mutex_exit(&hal->br_cmplq_mutex);
468 
469 	} while (cmd != NULL);
470 
471 	TNF_PROBE_0_DEBUG(s1394_flush_cmplq_exit, S1394_TNF_SL_HOTPLUG_STACK,
472 	    "");
473 
474 }
475 
476 /*
477  * s1394_br_thread_exit()
478  *    Flushes the completion queue and calls thread_exit() (which effectively
479  *    kills the bus reset thread).
480  */
481 static void
482 s1394_br_thread_exit(s1394_hal_t *hal)
483 {
484 	ASSERT(MUTEX_HELD(&hal->br_thread_mutex));
485 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
486 	TNF_PROBE_0(s1394_br_thread_exit_enter, S1394_TNF_SL_HOTPLUG_STACK, "");
487 	s1394_flush_cmplq(hal);
488 #ifndef	__lock_lint
489 	CALLB_CPR_EXIT(&hal->hal_cprinfo);
490 #endif
491 	hal->br_thread_ev_type &= ~BR_THR_GO_AWAY;
492 	thread_exit();
493 	/*NOTREACHED*/
494 }
495 
496 /*
497  * s1394_target_bus_reset_notifies()
498  *    tells the ndi event framework to invoke any callbacks registered for
499  *    "bus reset event".
500  */
501 static void
502 s1394_target_bus_reset_notifies(s1394_hal_t *hal, t1394_localinfo_t *localinfo)
503 {
504 	ddi_eventcookie_t cookie;
505 
506 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
507 
508 	TNF_PROBE_2_DEBUG(s1394_target_bus_reset_notifies_enter,
509 	    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_uint, bus_gen,
510 	    localinfo->bus_generation, tnf_uint, node_id,
511 	    localinfo->local_nodeID);
512 
513 	if (ndi_event_retrieve_cookie(hal->hal_ndi_event_hdl, NULL,
514 	    DDI_DEVI_BUS_RESET_EVENT, &cookie, NDI_EVENT_NOPASS) ==
515 	    NDI_SUCCESS) {
516 		(void) ndi_event_run_callbacks(hal->hal_ndi_event_hdl, NULL,
517 		    cookie, localinfo);
518 	}
519 	TNF_PROBE_0_DEBUG(s1394_target_bus_reset_notifies_exit,
520 	    S1394_TNF_SL_HOTPLUG_STACK, "");
521 }
522 
523 /*
524  * s1394_alloc_cfgrom()
525  *    Allocates config rom for the node. Sets CFGROM_NEW_ALLOC bit in the
526  *    node cfgrom state. Drops topology_tree_mutex around the calls to
527  *    kmem_zalloc(). If re-locking fails, returns DDI_FAILURE, else returns
528  *    DDI_SUCCESS.
529  */
530 static int
531 s1394_alloc_cfgrom(s1394_hal_t *hal, s1394_node_t *node, s1394_status_t *status)
532 {
533 	uint32_t *cfgrom;
534 
535 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
536 
537 	TNF_PROBE_0_DEBUG(s1394_alloc_cfgrom_enter, S1394_TNF_SL_HOTPLUG_STACK,
538 	    "");
539 
540 	*status = S1394_NOSTATUS;
541 
542 	/*
543 	 * if cfgrom is non-NULL, this has to be generation changed
544 	 * case (where we allocate cfgrom again to reread the cfgrom)
545 	 */
546 	ASSERT(node->cfgrom == NULL || (node->cfgrom != NULL &&
547 	    CFGROM_GEN_CHANGED(node) == B_TRUE));
548 
549 	/*
550 	 * if node matched, either cfgrom has to be NULL or link should be
551 	 * off in the last matched node or config rom generations changed.
552 	 */
553 	ASSERT(NODE_MATCHED(node) == B_FALSE || (NODE_MATCHED(node) == B_TRUE &&
554 	    (node->cfgrom == NULL || LINK_ACTIVE(node->old_node) == B_FALSE) ||
555 	    CFGROM_GEN_CHANGED(node) == B_TRUE));
556 
557 	s1394_unlock_tree(hal);
558 	cfgrom = (uint32_t *)kmem_zalloc(IEEE1394_CONFIG_ROM_SZ, KM_SLEEP);
559 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
560 		kmem_free(cfgrom, IEEE1394_CONFIG_ROM_SZ);
561 		*status |= S1394_LOCK_FAILED;
562 		TNF_PROBE_1(s1394_alloc_cfgrom, S1394_TNF_SL_HOTPLUG_ERROR,
563 		    "", tnf_string, msg, "cannot relock the tree");
564 		TNF_PROBE_0_DEBUG(s1394_alloc_cfgrom_exit,
565 		    S1394_TNF_SL_HOTPLUG_STACK, "");
566 		return (DDI_FAILURE);
567 	}
568 	node->cfgrom = cfgrom;
569 	node->cfgrom_size = IEEE1394_CONFIG_ROM_QUAD_SZ;
570 	SET_CFGROM_NEW_ALLOC(node);
571 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
572 	TNF_PROBE_3(s1394_alloc_cfgrom_exit, S1394_TNF_SL_HOTPLUG_STACK,
573 	    "cfgrom alloc", tnf_uint, hal_gen, hal->generation_count, tnf_uint,
574 	    node_num, node->node_num, tnf_opaque, cfgrom, cfgrom);
575 	return (DDI_SUCCESS);
576 }
577 
578 /*
579  * s1394_free_cfgrom()
580  *    Marks the config rom invalid and frees up the config based on otpions.
581  */
582 void
583 s1394_free_cfgrom(s1394_hal_t *hal, s1394_node_t *node,
584     s1394_free_cfgrom_t options)
585 {
586 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
587 	ASSERT(node->cfgrom != NULL);
588 
589 	TNF_PROBE_0_DEBUG(s1394_free_cfgrom_enter, S1394_TNF_SL_HOTPLUG_STACK,
590 	    "");
591 
592 	if (options == S1394_FREE_CFGROM_BOTH) {
593 		/*
594 		 * free in both old and new trees; will be called with
595 		 * new node.
596 		 */
597 		s1394_node_t *onode = node->old_node;
598 
599 		if (NODE_MATCHED(node) == B_TRUE && onode->cfgrom != NULL)
600 			ASSERT(onode->cfgrom == node->cfgrom);
601 
602 		TNF_PROBE_4(s1394_free_cfgrom_both,
603 		    S1394_TNF_SL_HOTPLUG_STACK, "cfgrom free", tnf_uint,
604 		    hal_gen, hal->generation_count, tnf_int, node_num,
605 		    node->node_num, tnf_opaque, old_cfgrom, onode->cfgrom,
606 		    tnf_opaque, cfgrom, node->cfgrom);
607 
608 		if (onode != NULL && onode->cfgrom != NULL && onode->cfgrom !=
609 		    node->cfgrom)
610 			kmem_free(onode->cfgrom, IEEE1394_CONFIG_ROM_SZ);
611 
612 		kmem_free(node->cfgrom, IEEE1394_CONFIG_ROM_SZ);
613 		onode->cfgrom = NULL;
614 		node->cfgrom = NULL;
615 
616 		CLEAR_CFGROM_STATE(onode);
617 		CLEAR_CFGROM_STATE(node);
618 
619 	} else if (options == S1394_FREE_CFGROM_NEW) {
620 
621 		TNF_PROBE_2(s1394_free_cfgrom_new,
622 		    S1394_TNF_SL_HOTPLUG_STACK, "cfgrom free",
623 		    tnf_int, node_num, node->node_num,
624 		    tnf_opaque, cfgrom, node->cfgrom);
625 
626 		ASSERT(CFGROM_NEW_ALLOC(node) == B_TRUE);
627 		kmem_free(node->cfgrom, IEEE1394_CONFIG_ROM_SZ);
628 		CLEAR_CFGROM_NEW_ALLOC(node);
629 		node->cfgrom = NULL;
630 		CLEAR_CFGROM_STATE(node);
631 
632 	} else if (options == S1394_FREE_CFGROM_OLD) {
633 
634 		/* freeing in old tree */
635 		TNF_PROBE_2_DEBUG(s1394_free_cfgrom_old,
636 		    S1394_TNF_SL_HOTPLUG_STACK, "cfgrom free",
637 		    tnf_int, node_num, node->node_num,
638 		    tnf_opaque, cfgrom, node->cfgrom);
639 		kmem_free(node->cfgrom, IEEE1394_CONFIG_ROM_SZ);
640 		node->cfgrom = NULL;
641 		CLEAR_CFGROM_STATE(node);
642 	}
643 
644 	TNF_PROBE_0_DEBUG(s1394_free_cfgrom_exit, S1394_TNF_SL_HOTPLUG_STACK,
645 	    "");
646 }
647 
648 /*
649  * s1394_copy_cfgrom()
650  *    Copies config rom info from "from" node to "to" node. Clears
651  *    CFGROM_NEW_ALLOC bit in cfgrom state in bothe nodes. (CFGROM_NEW_ALLOC
652  *    acts as a reference count. If set, only the node in the current tree
653  *    has a pointer to it; if clear, both the node in the current tree as
654  *    well as the corresponding node in the old tree point to the same memory).
655  */
656 void
657 s1394_copy_cfgrom(s1394_node_t *to, s1394_node_t *from)
658 {
659 	TNF_PROBE_3_DEBUG(s1394_copy_cfgrom_enter, S1394_TNF_SL_HOTPLUG_STACK,
660 	    "", tnf_int, to_node, to->node_num, tnf_int,
661 	    from_node, from->node_num, tnf_opaque, from_cfgrom, from->cfgrom);
662 
663 	ASSERT(to->cfgrom == NULL);
664 
665 	to->cfgrom = from->cfgrom;
666 	to->cfgrom_state = from->cfgrom_state;
667 	to->cfgrom_valid_size = from->cfgrom_valid_size;
668 	to->cfgrom_size = from->cfgrom_size;
669 	to->node_state = from->node_state;
670 
671 	bcopy(from->dir_stack, to->dir_stack,
672 	    offsetof(s1394_node_t, cfgrom_quad_to_read) -
673 	    offsetof(s1394_node_t, dir_stack));
674 
675 	to->cfgrom_quad_to_read = from->cfgrom_quad_to_read;
676 
677 	CLEAR_CFGROM_NEW_ALLOC(to);
678 	CLEAR_CFGROM_NEW_ALLOC(from);
679 
680 	/*
681 	 * old link off, new link on => handled in s1394_cfgrom_scan_phase1
682 	 * old link on, new link off => handled in s1394_process_old_tree
683 	 */
684 	if (LINK_ACTIVE(from) == B_FALSE) {
685 		/*
686 		 * if last time around, link was off, there wouldn't
687 		 * have been config rom allocated.
688 		 */
689 		ASSERT(from->cfgrom == NULL);
690 		TNF_PROBE_0_DEBUG(s1394_copy_cfgrom_exit,
691 		    S1394_TNF_SL_HOTPLUG_STACK, "");
692 		return;
693 	} else {
694 		s1394_selfid_pkt_t *selfid_pkt = to->selfid_packet;
695 
696 		if (IEEE1394_SELFID_ISLINKON(selfid_pkt))
697 			SET_LINK_ACTIVE(to);
698 	}
699 
700 	TNF_PROBE_0_DEBUG(s1394_copy_cfgrom_exit,
701 	    S1394_TNF_SL_HOTPLUG_STACK, "");
702 }
703 
704 /*
705  * s1394_read_bus_info_blk()
706  *    Attempts to kick off reading IEEE1212_NODE_CAP_QUAD quad or quad 0.
707  *    Increments cfgroms_being_read by 1. Returns DDI_SUCCESS command was
708  *    issued, else sets status to the failure reason and returns DDI_FAILURE.
709  */
710 static int
711 s1394_read_bus_info_blk(s1394_hal_t *hal, s1394_node_t *node,
712     s1394_status_t *status)
713 {
714 	uint32_t quadlet;
715 	cmd1394_cmd_t *cmd;
716 	uchar_t node_num;
717 
718 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
719 	ASSERT(LINK_ACTIVE(node) == B_TRUE);
720 
721 	node_num = node->node_num;
722 
723 	TNF_PROBE_2_DEBUG(s1394_read_bus_info_blk_enter,
724 	    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_uint, hal_gen,
725 	    hal->generation_count, tnf_int, node_num, node_num);
726 
727 	/*
728 	 * drop the topology lock around command allocation. Return failure
729 	 * if either command allocation fails or cannot reacquire the lock
730 	 */
731 	s1394_unlock_tree(hal);
732 	*status = S1394_NOSTATUS;
733 
734 	if (s1394_alloc_cmd(hal, 0, &cmd) != DDI_SUCCESS) {
735 		TNF_PROBE_1(s1394_read_bus_info_blk, S1394_TNF_SL_HOTPLUG_ERROR,
736 		    "", tnf_string, msg, "command allocation failed");
737 		*status |= S1394_CMD_ALLOC_FAILED;
738 	}
739 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
740 		*status |= S1394_LOCK_FAILED;
741 		TNF_PROBE_1(s1394_read_bus_info_blk, S1394_TNF_SL_HOTPLUG_ERROR,
742 		    "", tnf_string, msg, "unable to relock the tree");
743 		/* free the cmd allocated above */
744 		if (((*status) & S1394_CMD_ALLOC_FAILED) != 0)
745 			(void) s1394_free_cmd(hal, (cmd1394_cmd_t **)&cmd);
746 	}
747 	if (((*status) & (S1394_CMD_ALLOC_FAILED | S1394_LOCK_FAILED)) != 0) {
748 		TNF_PROBE_0_DEBUG(s1394_read_bus_info_blk_exit,
749 		    S1394_TNF_SL_HOTPLUG_STACK, "");
750 		return (DDI_FAILURE);
751 	}
752 
753 	/* allocate cfgrom if needed */
754 	if (node->cfgrom == NULL && s1394_alloc_cfgrom(hal, node, status) !=
755 	    DDI_SUCCESS) {
756 		ASSERT(((*status) & S1394_LOCK_FAILED) != 0);
757 		(void) s1394_free_cmd(hal, (cmd1394_cmd_t **)&cmd);
758 		ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
759 		TNF_PROBE_1(s1394_read_bus_info_blk, S1394_TNF_SL_HOTPLUG_ERROR,
760 		    "", tnf_string, msg, "config rom allocation failed");
761 		TNF_PROBE_0_DEBUG(s1394_read_bus_info_blk_exit,
762 		    S1394_TNF_SL_HOTPLUG_STACK, "");
763 		return (DDI_FAILURE);
764 	}
765 
766 	/*
767 	 * if this is a matched node, read quad 2 (node capabilities) to
768 	 * see if the generation count changed.
769 	 */
770 	quadlet = CFGROM_BIB_READ(node) ? IEEE1212_NODE_CAP_QUAD : 0;
771 
772 	/*
773 	 * read bus info block at 100Mbit. This will help us with the cases
774 	 * where LINK is slower than PHY; s1394 uses PHY speed till speed map
775 	 * is updated.
776 	 */
777 	cmd->completion_callback = s1394_cfgrom_read_callback;
778 	cmd->bus_generation = hal->generation_count;
779 	cmd->cmd_options = (CMD1394_CANCEL_ON_BUS_RESET |
780 	    CMD1394_OVERRIDE_ADDR | CMD1394_OVERRIDE_SPEED);
781 	cmd->cmd_speed = IEEE1394_S100;
782 	cmd->cmd_type = CMD1394_ASYNCH_RD_QUAD;
783 
784 	QUAD_TO_CFGROM_ADDR(IEEE1394_LOCAL_BUS, node_num,
785 	    quadlet, cmd->cmd_addr);
786 
787 	TNF_PROBE_3_DEBUG(s1394_read_bus_info_blk,
788 	    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_uint, hal_gen,
789 	    hal->generation_count, tnf_int, node_num, node_num, tnf_uint,
790 	    quadlet, quadlet);
791 
792 	TNF_PROBE_5_DEBUG(s1394_read_bus_info_blk,
793 	    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_int,
794 	    node_num, node_num, tnf_int, parsed, CFGROM_PARSED(node), tnf_int,
795 	    matched, NODE_MATCHED(node), tnf_int, visited,
796 	    NODE_VISITED(node), tnf_int, generation_changed,
797 	    CFGROM_GEN_CHANGED(node));
798 
799 	SETUP_QUAD_READ(node, 1, quadlet, 1);
800 	if (s1394_read_config_quadlet(hal, cmd, status) != DDI_SUCCESS) {
801 		TNF_PROBE_1(s1394_read_bus_info_blk, S1394_TNF_SL_HOTPLUG_ERROR,
802 		    "", tnf_string, msg, "Unable to start read");
803 		/* free the command if it wasn't handed over to the HAL */
804 		if (((*status) & S1394_CMD_INFLIGHT) == 0) {
805 			(void) s1394_free_cmd(hal, (cmd1394_cmd_t **)&cmd);
806 		}
807 		if (((*status) & S1394_LOCK_FAILED) != 0) {
808 			ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
809 		}
810 		TNF_PROBE_0_DEBUG(s1394_read_bus_info_blk_exit,
811 		    S1394_TNF_SL_HOTPLUG_STACK, "");
812 		return (DDI_FAILURE);
813 	}
814 
815 	hal->cfgroms_being_read++;
816 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
817 
818 	TNF_PROBE_1_DEBUG(s1394_read_bus_info_blk_exit,
819 	    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_int, cfgrom_read_cnt,
820 	    hal->cfgroms_being_read);
821 
822 	return (DDI_SUCCESS);
823 }
824 
825 /*
826  * s1394_read_rest_of_cfgrom()
827  *    Attempts to start reading node->cfgrom_quad_to_read quadlet. Increments
828  *    cfgroms_being_read by 1 and returns DDI_SUCCESS if command was issued,
829  *    else sets status to the failure reason and returns DDI_FAILURE.
830  */
831 int
832 s1394_read_rest_of_cfgrom(s1394_hal_t *hal, s1394_node_t *node,
833     s1394_status_t *status)
834 {
835 	cmd1394_cmd_t *cmd;
836 	uchar_t node_num = node->node_num;
837 
838 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
839 	ASSERT(LINK_ACTIVE(node) == B_TRUE);
840 
841 	TNF_PROBE_2_DEBUG(s1394_read_rest_of_cfgrom_enter,
842 	    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_uint, hal_gen,
843 	    hal->generation_count, tnf_int, node_num, node_num);
844 
845 	/*
846 	 * drop the topology lock around command allocation. Return failure
847 	 * if either command allocation fails or cannot reacquire the lock
848 	 */
849 	s1394_unlock_tree(hal);
850 	*status = S1394_NOSTATUS;
851 
852 	if (s1394_alloc_cmd(hal, 0, &cmd) != DDI_SUCCESS) {
853 		*status |= S1394_CMD_ALLOC_FAILED;
854 		TNF_PROBE_1(s1394_read_rest_of_cfgrom,
855 		    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
856 		    "command allocation failed");
857 	}
858 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
859 		*status |= S1394_LOCK_FAILED;
860 		/* free if we allocated a cmd above */
861 		if (((*status) & S1394_CMD_ALLOC_FAILED) == 0)
862 			(void) s1394_free_cmd(hal, (cmd1394_cmd_t **)&cmd);
863 		TNF_PROBE_1(s1394_read_rest_of_cfgrom,
864 		    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
865 		    "unable to relock the tree");
866 	}
867 	if (((*status) & (S1394_CMD_ALLOC_FAILED | S1394_LOCK_FAILED)) != 0) {
868 		TNF_PROBE_0_DEBUG(s1394_read_rest_of_cfgrom_exit,
869 		    S1394_TNF_SL_HOTPLUG_STACK, "");
870 		return (DDI_FAILURE);
871 	}
872 
873 	cmd->completion_callback = s1394_cfgrom_read_callback;
874 	cmd->bus_generation = hal->generation_count;
875 	cmd->cmd_options = (CMD1394_CANCEL_ON_BUS_RESET |
876 	    CMD1394_OVERRIDE_ADDR);
877 	cmd->cmd_type = CMD1394_ASYNCH_RD_QUAD;
878 
879 	TNF_PROBE_2_DEBUG(s1394_read_rest_of_cfgrom, S1394_TNF_SL_HOTPLUG_STACK,
880 	    "", tnf_uint, hal_gen, hal->generation_count, tnf_int, node_num,
881 	    node->node_num);
882 
883 	QUAD_TO_CFGROM_ADDR(IEEE1394_LOCAL_BUS, node_num,
884 	    node->cfgrom_quad_to_read, cmd->cmd_addr);
885 	SETUP_QUAD_READ(node, 1, node->cfgrom_quad_to_read, 1);
886 	if (s1394_read_config_quadlet(hal, cmd, status) != DDI_SUCCESS) {
887 		TNF_PROBE_1(s1394_read_rest_of_cfgrom_exit,
888 		    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
889 		    "unable to start read");
890 		/* free the command if it wasn't handed over to the HAL */
891 		if (((*status) & S1394_CMD_INFLIGHT) == 0) {
892 			(void) s1394_free_cmd(hal, (cmd1394_cmd_t **)&cmd);
893 		}
894 		if (((*status) & S1394_LOCK_FAILED) != 0) {
895 			ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
896 		}
897 		TNF_PROBE_0_DEBUG(s1394_read_rest_of_cfgrom_exit,
898 		    S1394_TNF_SL_HOTPLUG_STACK, "");
899 		return (DDI_FAILURE);
900 	}
901 
902 	hal->cfgroms_being_read++;
903 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
904 
905 	TNF_PROBE_1_DEBUG(s1394_read_rest_of_cfgrom_exit,
906 	    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_int, cfgrom_read_cnt,
907 	    hal->cfgroms_being_read);
908 
909 	return (DDI_SUCCESS);
910 }
911 
912 /*
913  * s1394_cfgrom_scan_phase1()
914  *    Attempts to read bus info blocks for nodes as needed. Returns DDI_FAILURE
915  *    if bus reset generations changed (as indicated by s1394_lock_tree()
916  *    return status) or if any of the callees return failure, else returns
917  *    DDI_SUCCESS.
918  */
919 static int
920 s1394_cfgrom_scan_phase1(s1394_hal_t *hal)
921 {
922 	uint32_t number_of_nodes;
923 	int ret;
924 	int node;
925 	int wait_in_gen;
926 	int wait_for_cbs;
927 	uint_t hal_node_num;
928 	uint_t hal_node_num_old;
929 	s1394_node_t *nnode, *onode;
930 	s1394_selfid_pkt_t *selfid_pkt;
931 	s1394_status_t status;
932 
933 	TNF_PROBE_0_DEBUG(s1394_cfgrom_scan_phase1_enter,
934 	    S1394_TNF_SL_HOTPLUG_STACK, "");
935 
936 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
937 
938 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
939 		TNF_PROBE_0_DEBUG(s1394_cfgrom_scan_phase1_exit,
940 		    S1394_TNF_SL_HOTPLUG_STACK, "");
941 		return (DDI_FAILURE);
942 	}
943 	wait_for_cbs = 0;
944 	number_of_nodes = hal->number_of_nodes;
945 	hal->cfgroms_being_read = 0;
946 	hal_node_num = IEEE1394_NODE_NUM(hal->node_id);
947 	hal_node_num_old = IEEE1394_NODE_NUM(hal->old_node_id);
948 	s1394_unlock_tree(hal);
949 
950 	ret = DDI_SUCCESS;
951 
952 	/* Send requests for all new node config ROM 0 */
953 	for (node = 0; node < number_of_nodes; node++) {
954 
955 		status = S1394_UNKNOWN;
956 
957 		if (s1394_lock_tree(hal) != DDI_SUCCESS) {
958 			status = S1394_LOCK_FAILED;
959 			break;
960 		}
961 
962 		nnode = &hal->topology_tree[node];
963 		onode = nnode->old_node;
964 		/* if node matched, onode should be non NULL */
965 		ASSERT(NODE_MATCHED(nnode) == B_FALSE || (NODE_MATCHED(nnode) ==
966 		    B_TRUE && onode != NULL));
967 
968 		/*
969 		 * Read bus info block if it is a brand new node (MATCHED is 0)
970 		 * or if matched but link was off in previous generations or
971 		 * or if matched but had invalid cfgrom in last generation
972 		 * or if matched but config rom generation > 1 (this is to
973 		 * check if config rom generation changed between bus resets).
974 		 */
975 		if ((node != hal_node_num) &&
976 		    ((NODE_MATCHED(nnode) == B_FALSE) ||
977 		    (NODE_MATCHED(nnode) == B_TRUE && LINK_ACTIVE(onode) ==
978 		    B_FALSE) || (NODE_MATCHED(nnode) == B_TRUE &&
979 		    (onode->cfgrom == NULL || CFGROM_VALID(onode) ==
980 		    B_FALSE)) || (NODE_MATCHED(nnode) == B_TRUE &&
981 		    nnode->cfgrom != NULL && CONFIG_ROM_GEN(nnode->cfgrom) >
982 		    1))) {
983 
984 			SET_NODE_VISITED(nnode);
985 			selfid_pkt = nnode->selfid_packet;
986 			if (IEEE1394_SELFID_ISLINKON(selfid_pkt)) {
987 
988 				SET_LINK_ACTIVE(nnode);
989 
990 				status = S1394_UNKNOWN;
991 
992 				if (s1394_read_bus_info_blk(hal, nnode,
993 				    &status) != DDI_SUCCESS) {
994 					if ((status & S1394_LOCK_FAILED) != 0)
995 						break;
996 				} else {
997 					wait_for_cbs++;
998 					wait_in_gen = hal->br_cfgrom_read_gen;
999 				}
1000 			} else {
1001 				/*
1002 				 * Special case: if link was active last
1003 				 * time around, this should be treated as
1004 				 * node going away.
1005 				 */
1006 				CLEAR_LINK_ACTIVE(nnode);
1007 				if (NODE_MATCHED(nnode) == B_TRUE &&
1008 				    LINK_ACTIVE(onode) == B_TRUE) {
1009 					CLEAR_CFGROM_STATE(nnode);
1010 					TNF_PROBE_3(s1394_cfgrom_scan_phase1,
1011 					    S1394_TNF_SL_HOTPLUG_ERROR,
1012 					    "", tnf_string, msg,
1013 					    "link lost power", tnf_int, node,
1014 					    node, tnf_int, onode,
1015 					    onode->node_num);
1016 				}
1017 			}
1018 		} else {
1019 			if (node == hal_node_num) {
1020 				onode = &hal->old_tree[hal_node_num_old];
1021 				/* Set up the local matched nodes */
1022 				if (onode) {
1023 					nnode->old_node = onode;
1024 					SET_NODE_MATCHED(nnode);
1025 					SET_NODE_MATCHED(onode);
1026 					s1394_copy_cfgrom(nnode, onode);
1027 				}
1028 			}
1029 		}
1030 		s1394_unlock_tree(hal);
1031 	}
1032 
1033 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
1034 
1035 	if ((status & S1394_LOCK_FAILED) != 0) {
1036 		TNF_PROBE_1(s1394_cfrom_scan_phase1_exit,
1037 		    S1394_TNF_SL_HOTPLUG_STACK, "",
1038 		    tnf_string, msg, "Generations changed");
1039 		return (DDI_FAILURE);
1040 	}
1041 
1042 	/*
1043 	 * If we started any reads, wait for completion callbacks
1044 	 */
1045 	if (wait_for_cbs != 0) {
1046 		ret = s1394_wait_for_cfgrom_callbacks(hal, wait_in_gen,
1047 		    s1394_br_thread_handle_cmd_phase1);
1048 	}
1049 
1050 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
1051 
1052 	TNF_PROBE_0_DEBUG(s1394_cfrom_scan_phase1_exit,
1053 	    S1394_TNF_SL_HOTPLUG_STACK, "");
1054 
1055 	return (ret);
1056 }
1057 
1058 /*
1059  * s1394_br_thread_handle_cmd_phase1()
1060  *    Process the cmd completion for phase 1 config rom reads. If we
1061  *    successfully read IEEE1212_NODE_CAP_QUAD quadlet and config rom gen
1062  *    did not change, move targets hanging off the old node to the current
1063  *    node. If config rom generations change, alloc new config rom and start
1064  *    re-reading the new config rom. If all of bus info block is read (as
1065  *    required), mark the node as CFGROM_BIB_READ. If config rom read fails
1066  *    retry if not too many failures. Topology tree mutex is dropped and
1067  *    reacquired in this routine. If reacquiring fails, returns
1068  *    S1394_HCMD_LOCK_FAILED. If the entire bus info block is read, returns
1069  *    S1394_HCMD_NODE_DONE, else returns S1394_HCMD_NODE_EXPECT_MORE (to
1070  *    indicate not done with the node yet).
1071  *
1072  *    If we cannot read any of the quadlets in the bus info block, cfgrom
1073  *    is marked invalid in this generation (a side effect of calling
1074  *    s1394_free_cfgrom()). We free cfgrom in this routine only if the failure
1075  *    is not due to bus generations changing.
1076  */
1077 static hcmd_ret_t
1078 s1394_br_thread_handle_cmd_phase1(s1394_hal_t *hal, cmd1394_cmd_t *cmd)
1079 {
1080 	s1394_target_t *t;
1081 	s1394_node_t *node, *onode;
1082 	uint32_t node_num, quadlet, data;
1083 	int freecmd, done, locked;
1084 	hcmd_ret_t cmdret;
1085 	uchar_t readdelay;
1086 	s1394_status_t status;
1087 
1088 	s1394_get_quad_info(cmd, &node_num, &quadlet, &data);
1089 	ASSERT(quadlet == 0 || quadlet < IEEE1394_BIB_QUAD_SZ);
1090 
1091 	TNF_PROBE_0_DEBUG(s1394_br_thread_handle_cmd_phase1_enter,
1092 	    S1394_TNF_SL_HOTPLUG_STACK, "");
1093 
1094 	cmdret = S1394_HCMD_NODE_EXPECT_MORE;
1095 
1096 	locked = 1;
1097 	freecmd = 1;
1098 
1099 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
1100 		TNF_PROBE_1(s1394_br_thread_handle_cmd_phase1,
1101 		    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string, msg,
1102 		    "unable to lock tree");
1103 		locked = 0;
1104 		goto bail;
1105 	}
1106 
1107 	node = &hal->topology_tree[node_num];
1108 
1109 	if (cmd->cmd_result == CMD1394_CMDSUCCESS) {
1110 
1111 		int reread = 0;
1112 
1113 		done = 0;
1114 
1115 		if (quadlet == IEEE1212_NODE_CAP_QUAD &&
1116 		    CFGROM_BIB_READ(node)) {
1117 
1118 			int cur_gen = ((data & IEEE1394_BIB_GEN_MASK) >>
1119 			    IEEE1394_BIB_GEN_SHIFT);
1120 
1121 			/*
1122 			 * node->old_node can be NULL if this is a new node &
1123 			 * we are doing a rescan
1124 			 */
1125 			onode = node->old_node;
1126 			if (CONFIG_ROM_GEN(node->cfgrom) == cur_gen) {
1127 
1128 				if (CFGROM_PARSED(node) == B_TRUE) {
1129 					rw_enter(&hal->target_list_rwlock,
1130 					    RW_WRITER);
1131 					/* Update the target list, if any */
1132 					if (onode != NULL &&
1133 					    (t = onode->target_list) != NULL) {
1134 						node->target_list = t;
1135 						while (t != NULL) {
1136 							t->on_node = node;
1137 							t = t->target_sibling;
1138 						}
1139 					}
1140 					rw_exit(&hal->target_list_rwlock);
1141 				}
1142 				SET_NODE_MATCHED(node);
1143 				if (onode)
1144 					SET_NODE_MATCHED(onode);
1145 				node->cfgrom_quad_to_read =
1146 				    IEEE1394_BIB_QUAD_SZ;
1147 				done++;
1148 			} else {
1149 
1150 				TNF_PROBE_4(s1394_br_thread_handle_cmd_phase1,
1151 				    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string,
1152 				    msg, "config rom generation changed",
1153 				    tnf_int, node_num, node_num,
1154 				    tnf_int, cur_gen, cur_gen, tnf_int, old_gen,
1155 				    CONFIG_ROM_GEN(node->cfgrom));
1156 
1157 				SET_CFGROM_GEN_CHANGED(node);
1158 				if (onode != NULL)
1159 					SET_CFGROM_GEN_CHANGED(onode);
1160 				/*
1161 				 * Reset BIB_READ flag and start reading entire
1162 				 * config rom.
1163 				 */
1164 				CLEAR_CFGROM_BIB_READ(node);
1165 				reread = 1;
1166 
1167 				/*
1168 				 * if generations changed, allocate cfgrom for
1169 				 * the new generation. s1394_match_GUID() will
1170 				 * free up the cfgrom from the old generation.
1171 				 */
1172 				if (s1394_alloc_cfgrom(hal, node, &status) !=
1173 				    DDI_SUCCESS) {
1174 					ASSERT((status & S1394_LOCK_FAILED) !=
1175 					    0);
1176 					ASSERT(MUTEX_NOT_HELD(&hal->
1177 					    topology_tree_mutex));
1178 					locked = 0;
1179 					/* we failed to relock the tree */
1180 					goto bail;
1181 				}
1182 			}
1183 		}
1184 
1185 		/*
1186 		 * we end up here if we don't have bus_info_blk for this
1187 		 * node or if config rom generation changed.
1188 		 */
1189 
1190 		/*
1191 		 * Pass1 Rio bug workaround. Due to this bug, if we read
1192 		 * past quadlet 5 of the config rom, the PCI bus gets wedged.
1193 		 * Avoid the hang by not reading past quadlet 5.
1194 		 * We identify a remote Rio by the node vendor id part of
1195 		 * quad 3 (which is == SUNW == S1394_SUNW_OUI (0x80020)).
1196 		 */
1197 		if (s1394_enable_rio_pass1_workarounds != 0) {
1198 			if ((quadlet == 3) && ((data >> 8) == S1394_SUNW_OUI)) {
1199 				node->cfgrom_size = IEEE1394_BIB_QUAD_SZ;
1200 				node->cfgrom_valid_size = IEEE1394_BIB_QUAD_SZ;
1201 			}
1202 		}
1203 
1204 		if (!done) {
1205 
1206 			if (reread)
1207 				quadlet = 0;
1208 			else
1209 				node->cfgrom[quadlet++] = data;
1210 
1211 			/* if we don't have the entire bus_info_blk... */
1212 			if (quadlet < IEEE1394_BIB_QUAD_SZ) {
1213 
1214 				CFGROM_GET_READ_DELAY(node, readdelay);
1215 				SETUP_QUAD_READ(node, 1, quadlet, 1);
1216 				s1394_unlock_tree(hal);
1217 				CFGROM_READ_PAUSE(readdelay);
1218 				/* get next quadlet */
1219 				if (s1394_lock_tree(hal) != DDI_SUCCESS) {
1220 					TNF_PROBE_3(
1221 					    s1394_br_thread_handle_cmd_phase1,
1222 					    S1394_TNF_SL_HOTPLUG_STACK, "",
1223 					    tnf_string, msg,
1224 					    "unable to relock tree", tnf_uint,
1225 					    node_num, node_num, tnf_int,
1226 					    quad_to_read, quadlet);
1227 					locked = 0;
1228 				} else if (s1394_read_config_quadlet(hal, cmd,
1229 				    &status) != DDI_SUCCESS) {
1230 					/*
1231 					 * Failed to get going. If command was
1232 					 * successfully handed over to the HAL,
1233 					 * don't free it (it will get freed
1234 					 * later in the callback).
1235 					 */
1236 					TNF_PROBE_3(
1237 					    s1394_br_thread_handle_cmd_phase1,
1238 					    S1394_TNF_SL_HOTPLUG_STACK, "",
1239 					    tnf_string, msg,
1240 					    "unable to read", tnf_uint,
1241 					    node_num, node_num, tnf_int,
1242 					    quad_to_read, quadlet);
1243 					if ((status & S1394_CMD_INFLIGHT) !=
1244 					    0) {
1245 						freecmd = 0;
1246 					}
1247 					if ((status & S1394_LOCK_FAILED) != 0) {
1248 						locked = 0;
1249 					} else {
1250 						if (CFGROM_NEW_ALLOC(node) ==
1251 						    B_TRUE) {
1252 							s1394_free_cfgrom(hal,
1253 							    node,
1254 							S1394_FREE_CFGROM_NEW);
1255 						} else {
1256 							CLEAR_CFGROM_STATE(
1257 							    node);
1258 						}
1259 					}
1260 					done++;
1261 				} else {
1262 					freecmd = 0;
1263 				}
1264 			} else {
1265 				/* got all of bus_info_blk */
1266 				SET_CFGROM_BIB_READ(node);
1267 				if (node->cfgrom_size == IEEE1394_BIB_QUAD_SZ)
1268 				    SET_CFGROM_ALL_READ(node);
1269 				node->cfgrom_quad_to_read = quadlet;
1270 				done++;
1271 				TNF_PROBE_3_DEBUG(
1272 				    s1394_br_thread_handle_cmd_phase1,
1273 				    S1394_TNF_SL_HOTPLUG_STACK,
1274 				    "", tnf_string, msg, "read bus info blk",
1275 				    tnf_int, node_num, node->node_num,
1276 				    tnf_opaque, cfgrom, node->cfgrom);
1277 			}
1278 		}
1279 	} else {
1280 		done = 1;
1281 		node->cfgrom_read_fails++;
1282 		BUMP_CFGROM_READ_DELAY(node);
1283 
1284 		/* retry if not too many failures */
1285 		if (node->cfgrom_read_fails < s1394_cfgrom_read_retry_cnt) {
1286 			CFGROM_GET_READ_DELAY(node, readdelay);
1287 			SETUP_QUAD_READ(node, 0, quadlet, 1);
1288 			s1394_unlock_tree(hal);
1289 			CFGROM_READ_PAUSE(readdelay);
1290 			if (s1394_lock_tree(hal) != DDI_SUCCESS) {
1291 				TNF_PROBE_3(
1292 				    s1394_br_thread_handle_cmd_phase1,
1293 				    S1394_TNF_SL_HOTPLUG_ERROR, "",
1294 				    tnf_string, msg,
1295 				    "unable to relock tree", tnf_uint,
1296 				    node_num, node_num, tnf_int,
1297 				    quad_to_read, quadlet);
1298 				locked = 0;
1299 			} else if (s1394_read_config_quadlet(hal, cmd,
1300 			    &status) != DDI_SUCCESS) {
1301 				/*
1302 				 * Failed to get going. If command was
1303 				 * successfully handed over to the HAL,
1304 				 * don't free it (it will get freed
1305 				 * later in the callback).
1306 				 */
1307 				TNF_PROBE_3(
1308 				    s1394_br_thread_handle_cmd_phase1,
1309 				    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string,
1310 				    msg, "unable to re-read", tnf_uint,
1311 				    node_num, node_num, tnf_int, quad_to_read,
1312 				    quadlet);
1313 				if ((status & S1394_CMD_INFLIGHT) != 0) {
1314 					freecmd = 0;
1315 				}
1316 				if ((status & S1394_LOCK_FAILED) != 0) {
1317 					locked = 0;
1318 				} else {
1319 					if (CFGROM_NEW_ALLOC(node) == B_TRUE) {
1320 						s1394_free_cfgrom(hal, node,
1321 						    S1394_FREE_CFGROM_NEW);
1322 					} else {
1323 						CLEAR_CFGROM_STATE(node);
1324 					}
1325 				}
1326 			} else {
1327 				done = 0;
1328 				freecmd = 0;
1329 			}
1330 		} else {
1331 			TNF_PROBE_4(s1394_br_thread_handle_cmd_phase1,
1332 			    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string, msg,
1333 			    "retries exceeded", tnf_int, node_num, node_num,
1334 			    tnf_int, quadlet, quadlet, tnf_opaque, cfgrom,
1335 			    node->cfgrom);
1336 			if (CFGROM_NEW_ALLOC(node) == B_TRUE) {
1337 				s1394_free_cfgrom(hal, node,
1338 				    S1394_FREE_CFGROM_NEW);
1339 			} else {
1340 				CLEAR_CFGROM_STATE(node);
1341 			}
1342 		}
1343 	}
1344 bail:
1345 	if (freecmd) {
1346 		(void) s1394_free_cmd(hal, &cmd);
1347 	}
1348 
1349 	if (done) {
1350 		cmdret = S1394_HCMD_NODE_DONE;
1351 		TNF_PROBE_2_DEBUG(s1394_br_thread_handle_cmd_phase1,
1352 		    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string, msg,
1353 		    "done with node", tnf_int, node_num, node_num);
1354 	}
1355 
1356 	/* if we are bailing out because locking failed, locked == 0 */
1357 	if (locked == 0)
1358 		cmdret = S1394_HCMD_LOCK_FAILED;
1359 	else
1360 		s1394_unlock_tree(hal);
1361 
1362 	TNF_PROBE_0_DEBUG(s1394_br_thread_handle_cmd_phase1_exit,
1363 	    S1394_TNF_SL_HOTPLUG_STACK, "");
1364 
1365 	return (cmdret);
1366 }
1367 
1368 /*
1369  * s1394_cfgrom_scan_phase2()
1370  *    Handles phase 2 of bus reset processing. Matches GUIDs between old
1371  *    and new topology trees to identify which node moved where. Processes
1372  *    the old topology tree (involves offlining any nodes that got unplugged
1373  *    between the last generation and the current generation). Updates speed
1374  *    map, sets up physical AR request filer and does isoch resource
1375  *    realloc failure notification and bus reset notifications. Then resends
1376  *    any commands that were issued by targets while the reset was being
1377  *    processed. Finally, the current topology tree is processed. This involves
1378  *    reading config rom past the bus info block for new nodes and parsing
1379  *    the config rom, creating a devinfo for each unit directory found in the
1380  *    config rom.
1381  *    Returns DDI_FAILURE if there was bus reset during any of the function
1382  *    calls (as indicated by lock failures) or if any of the routines callees
1383  *    return failure, else returns DDI_SUCCESS.
1384  */
1385 static int
1386 s1394_cfgrom_scan_phase2(s1394_hal_t *hal)
1387 {
1388 	int ret;
1389 	uint_t wait_gen;
1390 	int wait_for_cbs = 0;
1391 	t1394_localinfo_t localinfo;
1392 
1393 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
1394 
1395 	TNF_PROBE_0_DEBUG(s1394_cfgrom_scan_phase2_enter,
1396 	    S1394_TNF_SL_HOTPLUG_STACK, "");
1397 
1398 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
1399 		TNF_PROBE_0_DEBUG(s1394_cfgrom_scan_phase2_exit,
1400 		    S1394_TNF_SL_HOTPLUG_STACK, "");
1401 		return (DDI_FAILURE);
1402 	}
1403 
1404 	if (s1394_match_all_GUIDs(hal) == DDI_SUCCESS) {
1405 		s1394_unlock_tree(hal);
1406 	}
1407 
1408 	if (s1394_process_old_tree(hal) != DDI_SUCCESS) {
1409 		ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
1410 		TNF_PROBE_1(s1394_cfgrom_scan_phase2,
1411 		    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
1412 		    "non-success return from process_old_tree");
1413 		TNF_PROBE_0_DEBUG(s1394_cfgrom_scan_phase2_exit,
1414 		    S1394_TNF_SL_HOTPLUG_STACK, "");
1415 		return (DDI_FAILURE);
1416 	}
1417 
1418 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
1419 		TNF_PROBE_1(s1394_cfgrom_scan_phase2,
1420 		    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
1421 		    "unable to relock the tree");
1422 		TNF_PROBE_0_DEBUG(s1394_cfgrom_scan_phase2_exit,
1423 		    S1394_TNF_SL_HOTPLUG_STACK, "");
1424 		return (DDI_FAILURE);
1425 	}
1426 
1427 	s1394_update_speed_map_link_speeds(hal);
1428 	s1394_unlock_tree(hal);
1429 
1430 	/* Setup physical AR request filters */
1431 	s1394_physical_arreq_setup_all(hal);
1432 
1433 	/* Notify targets of isoch resource realloc failures */
1434 	s1394_isoch_rsrc_realloc_notify(hal);
1435 
1436 	/* Notify targets of the end of bus reset processing */
1437 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
1438 		TNF_PROBE_1(s1394_cfgrom_scan_phase2,
1439 		    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
1440 		    "unable to relock the tree after isoch notify");
1441 		TNF_PROBE_0_DEBUG(s1394_cfgrom_scan_phase2_exit,
1442 		    S1394_TNF_SL_HOTPLUG_STACK, "");
1443 		return (DDI_FAILURE);
1444 	}
1445 
1446 	localinfo.bus_generation = hal->generation_count;
1447 	localinfo.local_nodeID = hal->node_id;
1448 
1449 	s1394_unlock_tree(hal);
1450 	s1394_target_bus_reset_notifies(hal, &localinfo);
1451 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
1452 		TNF_PROBE_1(s1394_cfgrom_scan_phase2,
1453 		    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
1454 		    "unable to relock the tree after reset notify");
1455 		TNF_PROBE_0_DEBUG(s1394_cfgrom_scan_phase2_exit,
1456 		    S1394_TNF_SL_HOTPLUG_STACK, "");
1457 		return (DDI_FAILURE);
1458 	}
1459 
1460 	/* Set HAL state to normal */
1461 	if (hal->disable_requests_bit == 0)
1462 		hal->hal_state = S1394_HAL_NORMAL;
1463 	else
1464 		hal->hal_state = S1394_HAL_DREQ;
1465 
1466 	s1394_unlock_tree(hal);
1467 
1468 	/* Flush the pending Q */
1469 	s1394_resend_pending_cmds(hal);
1470 
1471 	if (s1394_process_topology_tree(hal, &wait_for_cbs, &wait_gen)) {
1472 		TNF_PROBE_1(s1394_cfgrom_scan_phase2,
1473 		    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
1474 		    "non-success return from process_topology_tree");
1475 		TNF_PROBE_0_DEBUG(s1394_cfgrom_scan_phase2_exit,
1476 		    S1394_TNF_SL_HOTPLUG_STACK, "");
1477 		ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
1478 		return (DDI_FAILURE);
1479 	}
1480 
1481 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
1482 		TNF_PROBE_1(s1394_cfgrom_scan_phase2,
1483 		    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
1484 		    "unable to relock after processing topology tree");
1485 		TNF_PROBE_0_DEBUG(s1394_cfgrom_scan_phase2_exit,
1486 		    S1394_TNF_SL_HOTPLUG_STACK, "");
1487 		return (DDI_FAILURE);
1488 	}
1489 
1490 	s1394_print_node_info(hal);
1491 
1492 	s1394_unlock_tree(hal);
1493 
1494 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
1495 
1496 	ret = DDI_SUCCESS;
1497 
1498 	/*
1499 	 * If we started any reads, wait for completion callbacks
1500 	 */
1501 	if (wait_for_cbs != 0) {
1502 		ret = s1394_wait_for_cfgrom_callbacks(hal, wait_gen,
1503 		    s1394_br_thread_handle_cmd_phase2);
1504 
1505 		TNF_PROBE_2_DEBUG(s1394_cfgrom_scan_phase2,
1506 		    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string, msg,
1507 		    "returned from waiting for cfgrom callbacks", tnf_int, ret,
1508 		    ret);
1509 	}
1510 
1511 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
1512 
1513 	TNF_PROBE_0_DEBUG(s1394_cfgrom_scan_phase2_exit,
1514 	    S1394_TNF_SL_HOTPLUG_STACK, "");
1515 
1516 	return (ret);
1517 }
1518 
1519 /*
1520  * s1394_br_thread_handle_cmd_phase2()
1521  *    Process the cmd completion for phase 2 config rom reads. If all the
1522  *    needed quads are read, validates the config rom; if config rom is
1523  *    invalid (crc failures), frees the config rom, else marks the config rom
1524  *    valid and calls s1394_update_devinfo_tree() to parse the config rom.
1525  *    If need to get more quadlets, attempts to kick off the read and returns
1526  *    S1394_HCMD_NODE_EXPECT_MORE if successfully started the read. If a bus
1527  *    reset is seen while in this routine, returns S1394_HCMD_LOCK_FAILED. If
1528  *    done with the node (with or withoug crc errors), returns
1529  *    S1394_HCMD_NODE_DONE, else returns S1394_HCMD_NODE_EXPECT_MORE (to
1530  *    indicate not done with the node yet).
1531  */
1532 static hcmd_ret_t
1533 s1394_br_thread_handle_cmd_phase2(s1394_hal_t *hal, cmd1394_cmd_t *cmd)
1534 {
1535 	s1394_node_t *node;
1536 	uint32_t node_num, quadlet, data;
1537 	int update_devinfo, locked, freecmd, done;
1538 	hcmd_ret_t cmdret;
1539 	uchar_t readdelay;
1540 	s1394_status_t status;
1541 
1542 	TNF_PROBE_0_DEBUG(s1394_br_thread_handle_cmd_phase2_enter,
1543 	    S1394_TNF_SL_HOTPLUG_STACK, "");
1544 
1545 	/*
1546 	 * we end up here if this is a brand new node or if it is a known node
1547 	 * but the config ROM changed (and triggered a re-read).
1548 	 */
1549 	s1394_get_quad_info(cmd, &node_num, &quadlet, &data);
1550 	ASSERT(quadlet == IEEE1394_BIB_QUAD_SZ || quadlet <
1551 	    IEEE1394_CONFIG_ROM_QUAD_SZ);
1552 
1553 	locked = freecmd = done = 1;
1554 	cmdret = S1394_HCMD_NODE_EXPECT_MORE;
1555 
1556 	update_devinfo = 0;
1557 
1558 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
1559 		TNF_PROBE_3(s1394_br_thread_handle_cmd_phase2,
1560 		    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
1561 		    "unable to lock tree", tnf_int, node_num, node_num,
1562 		    tnf_int, quadlet, quadlet);
1563 		locked = 0;
1564 		goto bail;
1565 	}
1566 
1567 	node = &hal->topology_tree[node_num];
1568 
1569 	if (cmd->cmd_result == CMD1394_CMDSUCCESS) {
1570 
1571 		ASSERT(CFGROM_BIB_READ(node) == B_TRUE);
1572 
1573 		node->cfgrom[quadlet] = data;
1574 
1575 		if (s1394_calc_next_quad(hal, node, quadlet, &quadlet) != 0) {
1576 			/*
1577 			 * Done with this node. Mark config rom valid and
1578 			 * update the devinfo tree for this node.
1579 			 */
1580 			TNF_PROBE_4_DEBUG(s1394_br_thread_handle_cmd_phase2,
1581 			    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string, msg,
1582 			    "all read", tnf_int, node_num, node->node_num,
1583 			    tnf_opaque, cfgrom, node->cfgrom, tnf_int, quadlet,
1584 			    quadlet);
1585 
1586 			node->cfgrom_valid_size = quadlet + 1;
1587 			if (s1394_valid_cfgrom(hal, node) == B_TRUE) {
1588 				SET_CFGROM_ALL_READ(node);
1589 				update_devinfo++;
1590 			} else {
1591 				s1394_free_cfgrom(hal, node,
1592 				    S1394_FREE_CFGROM_BOTH);
1593 			}
1594 		} else {
1595 			CFGROM_GET_READ_DELAY(node, readdelay);
1596 			SETUP_QUAD_READ(node, 1, quadlet, 1);
1597 			s1394_unlock_tree(hal);
1598 			CFGROM_READ_PAUSE(readdelay);
1599 			if (s1394_lock_tree(hal) != DDI_SUCCESS) {
1600 				locked = 0;
1601 				TNF_PROBE_3(s1394_br_thread_handle_cmd_phase2,
1602 				    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string,
1603 				    msg, "unable to relock the tree",
1604 				    tnf_int, node_num, node->node_num,
1605 				    tnf_int, quadlet, quadlet);
1606 			} else if (s1394_read_config_quadlet(hal, cmd,
1607 			    &status) != DDI_SUCCESS) {
1608 				/* give up on this guy */
1609 				TNF_PROBE_3(s1394_br_thread_handle_cmd_phase2,
1610 				    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string,
1611 				    msg, "cannot start quadlet read", tnf_int,
1612 				    node_num, node_num, tnf_int, quadlet,
1613 				    quadlet);
1614 
1615 				if ((status & S1394_CMD_INFLIGHT) != 0) {
1616 					freecmd = 0;
1617 				}
1618 				if ((status & S1394_LOCK_FAILED) != 0) {
1619 					locked = 0;
1620 				} else {
1621 					node->cfgrom_valid_size = quadlet;
1622 					if (s1394_valid_cfgrom(hal, node) ==
1623 					    B_TRUE) {
1624 						SET_CFGROM_ALL_READ(node);
1625 						update_devinfo++;
1626 					} else {
1627 						s1394_free_cfgrom(hal, node,
1628 						    S1394_FREE_CFGROM_BOTH);
1629 					}
1630 				}
1631 			} else {
1632 				/* successfully started next read */
1633 				done = 0;
1634 				freecmd = 0;
1635 			}
1636 		}
1637 	} else {
1638 		node->cfgrom_read_fails++;
1639 		BUMP_CFGROM_READ_DELAY(node);
1640 
1641 		/* retry if not too many failures */
1642 		if (node->cfgrom_read_fails < s1394_cfgrom_read_retry_cnt) {
1643 			CFGROM_GET_READ_DELAY(node, readdelay);
1644 			s1394_unlock_tree(hal);
1645 			SETUP_QUAD_READ(node, 0, quadlet, 1);
1646 			CFGROM_READ_PAUSE(readdelay);
1647 			if (s1394_lock_tree(hal) != DDI_SUCCESS) {
1648 				locked = 0;
1649 				TNF_PROBE_3(s1394_br_thread_handle_cmd_phase2,
1650 				    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string,
1651 				    msg, "unable to relock for reread",
1652 				    tnf_int, node_num, node->node_num,
1653 				    tnf_int, quadlet, quadlet);
1654 			} else if (s1394_read_config_quadlet(hal, cmd,
1655 			    &status) != DDI_SUCCESS) {
1656 				if ((status & S1394_CMD_INFLIGHT) != 0) {
1657 					freecmd = 0;
1658 				}
1659 				if ((status & S1394_LOCK_FAILED) != 0) {
1660 					locked = 0;
1661 				} else {
1662 					/* stop further reads */
1663 					TNF_PROBE_4(
1664 					    s1394_br_thread_handle_cmd_phase2,
1665 					    S1394_TNF_SL_HOTPLUG_ERROR, "",
1666 					    tnf_string, msg, "unable to retry",
1667 					    tnf_int, node_num, node->node_num,
1668 					    tnf_int, quadlet, quadlet,
1669 					    tnf_opaque, cfgrom, node->cfgrom);
1670 					node->cfgrom_valid_size = quadlet + 1;
1671 					if (s1394_valid_cfgrom(hal, node) ==
1672 					    B_TRUE) {
1673 						SET_CFGROM_ALL_READ(node);
1674 						update_devinfo++;
1675 					} else {
1676 						s1394_free_cfgrom(hal, node,
1677 						    S1394_FREE_CFGROM_BOTH);
1678 					}
1679 				}
1680 			} else {
1681 				/* successfully started next read */
1682 				done = 0;
1683 				freecmd = 0;
1684 			}
1685 		} else {
1686 
1687 			TNF_PROBE_4(s1394_br_thread_handle_cmd_phase2,
1688 			    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
1689 			    "retries exceeded", tnf_int, node_num, node_num,
1690 			    tnf_int, quadlet, quadlet, tnf_opaque, cfgrom,
1691 			    node->cfgrom);
1692 
1693 			node->cfgrom_valid_size = quadlet + 1;
1694 			if (s1394_valid_cfgrom(hal, node) == B_TRUE) {
1695 				SET_CFGROM_ALL_READ(node);
1696 				update_devinfo++;
1697 			} else {
1698 				s1394_free_cfgrom(hal, node,
1699 				    S1394_FREE_CFGROM_BOTH);
1700 			}
1701 		}
1702 	}
1703 bail:
1704 	if (freecmd) {
1705 		(void) s1394_free_cmd(hal, &cmd);
1706 	}
1707 
1708 	if (done) {
1709 		cmdret = S1394_HCMD_NODE_DONE;
1710 		TNF_PROBE_2_DEBUG(s1394_br_thread_handle_cmd_phase2,
1711 		    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string, msg,
1712 		    "done with a node", tnf_int, node_num, node_num);
1713 	}
1714 
1715 	if (update_devinfo) {
1716 		ASSERT(locked);
1717 		/*
1718 		 * s1394_update_devinfo_tree() drops and reacquires the
1719 		 * topology_tree_mutex. If tree lock fails, it returns
1720 		 * a DDI_FAILURE. Set locked to 0 so in this case so that
1721 		 * we will return S1394_HCMD_LOCK_FAILED below
1722 		 */
1723 		if (s1394_update_devinfo_tree(hal, node) != DDI_SUCCESS) {
1724 			ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
1725 			locked = 0;
1726 			TNF_PROBE_2(s1394_br_thread_handle_cmd_phase2,
1727 			    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
1728 			    "update devinfo returned failure", tnf_int,
1729 			    node_num, node_num);
1730 		}
1731 	}
1732 
1733 	/* if we are bailing out because locking failed, locked == 0 */
1734 	if (locked == 0)
1735 		cmdret = S1394_HCMD_LOCK_FAILED;
1736 	else
1737 		s1394_unlock_tree(hal);
1738 
1739 	TNF_PROBE_1_DEBUG(s1394_br_thread_handle_cmd_phase2_exit,
1740 	    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_int, cmdret, (int)cmdret);
1741 
1742 	return (cmdret);
1743 }
1744 
1745 /*
1746  * s1394_read_config_quadlet()
1747  *    Starts the reads of a config quadlet (deduced cmd_addr).  Returns
1748  *    DDI_SUCCESS if the read was started with no errors, else DDI_FAILURE
1749  *    is returned, with status indicating the reason for the failure(s).
1750  */
1751 static int
1752 s1394_read_config_quadlet(s1394_hal_t *hal, cmd1394_cmd_t *cmd,
1753     s1394_status_t *status)
1754 {
1755 	s1394_node_t *node;
1756 	int ret, err, node_num, quadlet;
1757 
1758 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
1759 	node_num = IEEE1394_ADDR_PHY_ID(cmd->cmd_addr);
1760 	node = &hal->topology_tree[node_num];
1761 	quadlet = node->cfgrom_quad_to_read;
1762 
1763 	TNF_PROBE_2_DEBUG(s1394_read_config_quadlet_enter,
1764 	    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_uint, node_num, node_num,
1765 	    tnf_uint, quadlet, quadlet);
1766 
1767 	/* Calculate the 64-bit address */
1768 	QUAD_TO_CFGROM_ADDR(IEEE1394_LOCAL_BUS, node_num, quadlet,
1769 	    cmd->cmd_addr);
1770 
1771 	*status = S1394_NOSTATUS;
1772 
1773 	ret = s1394_setup_asynch_command(hal, NULL, cmd, S1394_CMD_READ, &err);
1774 
1775 	if (ret != DDI_SUCCESS) {
1776 		*status |= S1394_UNKNOWN;
1777 		ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
1778 		TNF_PROBE_3(s1394_read_config_quadlet,
1779 		    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
1780 		    "failure from setup asynch command", tnf_uint, node_num,
1781 		    node_num, tnf_uint, quadlet, quadlet);
1782 		TNF_PROBE_0_DEBUG(s1394_read_config_quadlet_exit,
1783 		    S1394_TNF_SL_HOTPLUG_STACK, "");
1784 		return (DDI_FAILURE);
1785 	}
1786 
1787 	s1394_unlock_tree(hal);
1788 	ret = DDI_SUCCESS;
1789 	/* Send the command out */
1790 	if (s1394_xfer_asynch_command(hal, cmd, &err) == DDI_SUCCESS) {
1791 		/* Callers can expect a callback now */
1792 		*status |= S1394_CMD_INFLIGHT;
1793 	} else {
1794 
1795 		s1394_cmd_priv_t *s_priv;
1796 
1797 		TNF_PROBE_3(s1394_read_config_quadlet,
1798 		    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
1799 		    "failure from xfer asynch command",
1800 		    tnf_int, quadlet, quadlet, tnf_int, node_num, node_num);
1801 
1802 		/* Remove from queue */
1803 		s1394_remove_q_asynch_cmd(hal, cmd);
1804 		s_priv = S1394_GET_CMD_PRIV(cmd);
1805 
1806 		s_priv->cmd_in_use = B_FALSE;
1807 
1808 		*status |= S1394_XFER_FAILED;
1809 		ret = DDI_FAILURE;
1810 	}
1811 
1812 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
1813 		*status |= S1394_LOCK_FAILED;
1814 		ret = DDI_FAILURE;
1815 		TNF_PROBE_1(s1394_read_config_quadlet,
1816 		    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
1817 		    "unable to relock the tree");
1818 	}
1819 
1820 	TNF_PROBE_0_DEBUG(s1394_read_config_quadlet_exit,
1821 	    S1394_TNF_SL_HOTPLUG_STACK, "");
1822 
1823 	return (ret);
1824 }
1825 
1826 /*
1827  * s1394_cfgrom_read_callback()
1828  *    callback routine for config rom reads. Frees the command if it failed
1829  *    due to bus reset else appends the command to the completion queue
1830  *    and signals the completion queue cv.
1831  */
1832 static void
1833 s1394_cfgrom_read_callback(cmd1394_cmd_t *cmd)
1834 {
1835 	cmd1394_cmd_t *tcmd;
1836 	s1394_cmd_priv_t *s_priv;
1837 	s1394_hal_t *hal;
1838 
1839 #if defined(DEBUG)
1840 	uint32_t node_num, quadlet, data;
1841 #endif
1842 
1843 	TNF_PROBE_0_DEBUG(s1394_cfgrom_read_callback_enter,
1844 	    S1394_TNF_SL_HOTPLUG_STACK, "");
1845 
1846 	/* Get the Services Layer private area */
1847 	s_priv = S1394_GET_CMD_PRIV(cmd);
1848 
1849 	hal = (s1394_hal_t *)s_priv->sent_on_hal;
1850 
1851 #if defined(DEBUG)
1852 
1853 	s1394_get_quad_info(cmd, &node_num, &quadlet, &data);
1854 
1855 	TNF_PROBE_5_DEBUG(s1394_cfgrom_read_callback,
1856 	    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_uint, gen, cmd->bus_generation,
1857 	    tnf_int, quadlet, quadlet,
1858 	    tnf_int, node_num, node_num,
1859 	    tnf_int, data, data, tnf_int, result, cmd->cmd_result);
1860 #endif
1861 
1862 	if (cmd->cmd_result == CMD1394_EBUSRESET) {
1863 		(void) s1394_free_cmd(hal, (cmd1394_cmd_t **)&cmd);
1864 	} else {
1865 		mutex_enter(&hal->br_cmplq_mutex);
1866 
1867 		/* Put the command on completion queue */
1868 		s_priv->cmd_priv_next = NULL;
1869 		if ((tcmd = hal->br_cmplq_tail) != NULL) {
1870 			s_priv = S1394_GET_CMD_PRIV(tcmd);
1871 
1872 			s_priv->cmd_priv_next = cmd;
1873 		}
1874 
1875 		hal->br_cmplq_tail = cmd;
1876 
1877 		if (hal->br_cmplq_head == NULL)
1878 			hal->br_cmplq_head = cmd;
1879 
1880 		cv_signal(&hal->br_cmplq_cv);
1881 		mutex_exit(&hal->br_cmplq_mutex);
1882 	}
1883 
1884 	TNF_PROBE_0_DEBUG(s1394_cfgrom_read_callback_exit,
1885 	    S1394_TNF_SL_HOTPLUG_STACK, "");
1886 }
1887 
1888 /*
1889  * s1394_cfgrom_parse_unit_dir()
1890  *    Parses the unit directory passed in and returns reg[2...5] of reg
1891  *    property (see 1275 binding for reg property defintion). Currently,
1892  *    returns 0 for all the values since none of the existing devices implement
1893  *    this and future devices, per P1212r, need a binding change.
1894  */
1895 /* ARGSUSED */
1896 void
1897 s1394_cfgrom_parse_unit_dir(uint32_t *unit_dir, uint32_t *addr_hi,
1898     uint32_t *addr_lo, uint32_t *size_hi, uint32_t *size_lo)
1899 {
1900 	TNF_PROBE_0_DEBUG(s1394_cfgrom_parse_unit_dir_enter,
1901 	    S1394_TNF_SL_HOTPLUG_STACK, "");
1902 	*addr_hi = *addr_lo = *size_hi = *size_lo = 0;
1903 	TNF_PROBE_0_DEBUG(s1394_cfgrom_parse_unit_dir_exit,
1904 	    S1394_TNF_SL_HOTPLUG_STACK, "");
1905 }
1906 
1907 /*
1908  * s1394_get_quad_info()
1909  *    Helper routine that picks apart the various fields of a 1394 address
1910  */
1911 static void
1912 s1394_get_quad_info(cmd1394_cmd_t *cmd, uint32_t *node_num, uint32_t *quadlet,
1913     uint32_t *data)
1914 {
1915 	uint64_t addr;
1916 
1917 	TNF_PROBE_0_DEBUG(s1394_get_quad_info_enter,
1918 	    S1394_TNF_SL_HOTPLUG_STACK, "");
1919 
1920 	addr = cmd->cmd_addr;
1921 	*node_num = IEEE1394_ADDR_PHY_ID(addr);
1922 	*quadlet = ((addr & IEEE1394_ADDR_OFFSET_MASK) -
1923 	    IEEE1394_CONFIG_ROM_ADDR);
1924 	*quadlet = (*quadlet >> 2);
1925 	*data = T1394_DATA32(cmd->cmd_u.q.quadlet_data);
1926 
1927 	TNF_PROBE_0_DEBUG(s1394_get_quad_info_exit,
1928 	    S1394_TNF_SL_HOTPLUG_STACK, "");
1929 }
1930 
1931 /*
1932  * s1394_match_GUID()
1933  *    attempts to match nnode (which is in the current topology tree) with
1934  *    a node in the old topology tree by comparing GUIDs. If a match is found
1935  *    the old_node field of the current node and cur_node field of the old
1936  *    are set point to each other. Also, this routine makes both the nodes
1937  *    point at the same config rom.  If unable to relock the tree, returns
1938  *    DDI_FAILURE, else returns DDI_SUCCESS.
1939  */
1940 static int
1941 s1394_match_GUID(s1394_hal_t *hal, s1394_node_t *nnode)
1942 {
1943 	int old_node;
1944 	int gen_changed;
1945 	uint32_t old_a, old_b;
1946 	uint32_t new_a, new_b;
1947 	s1394_node_t *onode;
1948 	s1394_target_t *t;
1949 	int	ret = DDI_SUCCESS;
1950 
1951 	TNF_PROBE_0_DEBUG(s1394_match_GUID_enter, S1394_TNF_SL_HOTPLUG_STACK,
1952 	    "");
1953 
1954 	ASSERT(nnode->cfgrom != NULL);
1955 	ASSERT(CFGROM_BIB_READ(nnode));
1956 
1957 	new_a = nnode->node_guid_hi;
1958 	new_b = nnode->node_guid_lo;
1959 
1960 	for (old_node = 0; old_node < hal->old_number_of_nodes; old_node++) {
1961 
1962 		onode = &hal->old_tree[old_node];
1963 		if (onode->cfgrom == NULL || CFGROM_BIB_READ(onode) == B_FALSE)
1964 			continue;
1965 
1966 		old_a = onode->node_guid_hi;
1967 		old_b = onode->node_guid_lo;
1968 
1969 		if ((old_a == new_a) && (old_b == new_b)) {
1970 
1971 			if (NODE_MATCHED(onode) == B_TRUE) {
1972 				TNF_PROBE_4(s1394_match_GUID_duplicate,
1973 				    S1394_TNF_SL_HOTPLUG_ERROR, "",
1974 				    tnf_uint, guid_hi, old_a,
1975 				    tnf_uint, guid_lo, old_b,
1976 				    tnf_uint, old_node_num, old_node,
1977 				    tnf_uint, node_num, nnode->node_num);
1978 				cmn_err(CE_NOTE, "!Duplicate GUIDs: %08x%08x",
1979 				    old_a, old_b);
1980 				/* offline the new node that last matched */
1981 				ret = s1394_offline_node(hal, onode->cur_node);
1982 				/* and make the current new node invalid */
1983 				ASSERT(CFGROM_NEW_ALLOC(nnode) == B_TRUE);
1984 				s1394_free_cfgrom(hal, nnode,
1985 				    S1394_FREE_CFGROM_NEW);
1986 				break;
1987 			}
1988 
1989 			/*
1990 			 * If there is indeed a cfgrom gen change,
1991 			 * CFGROM_GEN_CHANGED() will be set iff we are matching
1992 			 * tree nodes. Otherwise, CONFIG_ROM_GEN(old) !=
1993 			 * CONFIG_ROM_GEN(new).
1994 			 */
1995 			if (CFGROM_GEN_CHANGED(nnode) == B_TRUE ||
1996 			    (CONFIG_ROM_GEN(onode->cfgrom) !=
1997 			    CONFIG_ROM_GEN(nnode->cfgrom))) {
1998 				gen_changed = 1;
1999 				TNF_PROBE_4_DEBUG(s1394_match_GUID_gen_change,
2000 				    S1394_TNF_SL_HOTPLUG_STACK, "",
2001 				    tnf_opaque, old_cfgrom, onode->cfgrom,
2002 				    tnf_int, old_gen,
2003 				    CONFIG_ROM_GEN(onode->cfgrom), tnf_opaque,
2004 				    cfgrom, nnode->cfgrom, tnf_int, new_gen,
2005 				    CONFIG_ROM_GEN(nnode->cfgrom));
2006 			} else {
2007 				gen_changed = 0;
2008 			}
2009 
2010 			onode->cur_node = nnode;
2011 			nnode->old_node = onode;
2012 			nnode->node_state = onode->node_state;
2013 			SET_NODE_VISITED(onode);
2014 			SET_NODE_MATCHED(onode);
2015 			SET_NODE_MATCHED(nnode);
2016 			/*
2017 			 * If generations changed, need to offline any targets
2018 			 * hanging off the old node, prior to freeing up old
2019 			 * cfgrom. If the generations didn't change, we can
2020 			 * free up the new config rom and copy all info from
2021 			 * the old node (this helps in picking up further
2022 			 * reads from where the last generation left off).
2023 			 */
2024 			if (gen_changed == 1) {
2025 				if (s1394_offline_node(hal, onode)) {
2026 					ret = DDI_FAILURE;
2027 					break;
2028 				}
2029 				TNF_PROBE_2(s1394_match_GUID_gen_freecfg,
2030 				    S1394_TNF_SL_HOTPLUG_STACK, "",
2031 				    tnf_opaque, old_cfgrom, onode->cfgrom,
2032 				    tnf_opaque, new_cfgrom, nnode->cfgrom);
2033 				s1394_free_cfgrom(hal, onode,
2034 				    S1394_FREE_CFGROM_OLD);
2035 				CLEAR_CFGROM_PARSED(nnode);
2036 				CLEAR_CFGROM_NEW_ALLOC(nnode);
2037 				CLEAR_CFGROM_NEW_ALLOC(onode);
2038 				onode->cfgrom = nnode->cfgrom;
2039 				/* done */
2040 				break;
2041 			}
2042 
2043 			/*
2044 			 * Free up cfgrom memory in the new_node and
2045 			 * point it at the same config rom as the old one.
2046 			 */
2047 			if (onode->cfgrom != nnode->cfgrom) {
2048 
2049 				TNF_PROBE_5_DEBUG(s1394_match_GUID,
2050 				    S1394_TNF_SL_HOTPLUG_STACK, "",
2051 				    tnf_int, node_num, nnode->node_num,
2052 				    tnf_opaque, cfgrom, nnode->cfgrom,
2053 				    tnf_int, old_node_num, old_node,
2054 				    tnf_opaque, old_cfgrom, onode->cfgrom,
2055 				    tnf_uint, cfgrom_state,
2056 				    nnode->cfgrom_state);
2057 
2058 				ASSERT(CFGROM_NEW_ALLOC(nnode) == B_TRUE);
2059 				s1394_free_cfgrom(hal, nnode,
2060 				    S1394_FREE_CFGROM_NEW);
2061 			}
2062 			nnode->cfgrom = onode->cfgrom;
2063 			nnode->cfgrom_state = onode->cfgrom_state;
2064 			nnode->cfgrom_valid_size = onode->cfgrom_valid_size;
2065 			nnode->cfgrom_size = onode->cfgrom_size;
2066 			nnode->cfgrom_quad_to_read = onode->cfgrom_quad_to_read;
2067 			bcopy(onode->dir_stack, nnode->dir_stack,
2068 			    offsetof(s1394_node_t, cfgrom_quad_to_read) -
2069 			    offsetof(s1394_node_t, dir_stack));
2070 			CLEAR_CFGROM_NEW_ALLOC(nnode);
2071 			CLEAR_CFGROM_NEW_ALLOC(onode);
2072 
2073 			if (CFGROM_PARSED(nnode) == B_TRUE) {
2074 				rw_enter(&hal->target_list_rwlock, RW_WRITER);
2075 				/* Update the target list */
2076 				if ((t = onode->target_list) != NULL) {
2077 					nnode->target_list = t;
2078 					while (t != NULL) {
2079 						t->on_node = nnode;
2080 						t = t->target_sibling;
2081 					}
2082 				}
2083 				rw_exit(&hal->target_list_rwlock);
2084 			}
2085 			break;
2086 		}
2087 	}
2088 
2089 	TNF_PROBE_0_DEBUG(s1394_match_GUID_exit, S1394_TNF_SL_HOTPLUG_STACK,
2090 	    "");
2091 
2092 	return (ret);
2093 }
2094 
2095 /*
2096  * s1394_match_all_GUIDs()
2097  *    attempt to match each node in the current topology tree with the a
2098  *    node in the old topology tree.  If unable to relock the tree, returns
2099  *    DDI_FAILURE, else returns DDI_SUCCESS.
2100  */
2101 static int
2102 s1394_match_all_GUIDs(s1394_hal_t *hal)
2103 {
2104 	int node;
2105 	int ret = DDI_SUCCESS;
2106 	s1394_node_t *nnode;
2107 
2108 	TNF_PROBE_0_DEBUG(s1394_match_all_GUIDs_enter,
2109 	    S1394_TNF_SL_HOTPLUG_STACK, "");
2110 
2111 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
2112 
2113 	for (node = 0; node < hal->number_of_nodes; node++) {
2114 		nnode = &hal->topology_tree[node];
2115 		if (LINK_ACTIVE(nnode) == B_FALSE || CFGROM_BIB_READ(nnode) ==
2116 		    B_FALSE)
2117 			continue;
2118 		if (NODE_MATCHED(nnode)) {
2119 			/*
2120 			 * Skip if node matched. If config rom generations
2121 			 * changed, we want to call s1394_match_GUID() even
2122 			 * if the nodes matched.
2123 			 */
2124 			int gen_changed;
2125 			s1394_node_t *onode = nnode->old_node;
2126 
2127 			gen_changed = (onode && onode->cfgrom &&
2128 			    CONFIG_ROM_GEN(onode->cfgrom) != CONFIG_ROM_GEN(
2129 			    nnode->cfgrom)) ? 1 : 0;
2130 
2131 			if (CFGROM_GEN_CHANGED(nnode) == 0 && gen_changed == 0)
2132 				continue;
2133 		}
2134 
2135 		if (s1394_match_GUID(hal, nnode) == DDI_FAILURE) {
2136 			ret = DDI_FAILURE;
2137 		}
2138 	}
2139 
2140 	TNF_PROBE_0_DEBUG(s1394_match_all_GUIDs_exit,
2141 	    S1394_TNF_SL_HOTPLUG_STACK, "");
2142 
2143 	return (ret);
2144 }
2145 
2146 /*
2147  * s1394_valid_cfgrom()
2148  *    Performs crc check on the config rom. Returns B_TRUE if config rom has
2149  *    good CRC else returns B_FALSE.
2150  */
2151 /* ARGSUSED */
2152 boolean_t
2153 s1394_valid_cfgrom(s1394_hal_t *hal, s1394_node_t *node)
2154 {
2155 	uint32_t crc_len, crc_value, CRC, CRC_old, quad0;
2156 
2157 	TNF_PROBE_0_DEBUG(s1394_valid_cfgrom_enter, S1394_TNF_SL_HOTPLUG_STACK,
2158 	    "");
2159 
2160 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
2161 	ASSERT(node->cfgrom);
2162 
2163 	if (s1394_enable_crc_validation == 0) {
2164 		TNF_PROBE_1_DEBUG(s1394_valid_cfgrom_exit,
2165 		    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string, msg,
2166 		    "validation turned off");
2167 		return (B_TRUE);
2168 	}
2169 
2170 	quad0 = node->cfgrom[0];
2171 	crc_len = (quad0 >> IEEE1394_CFG_ROM_CRC_LEN_SHIFT) &
2172 	    IEEE1394_CFG_ROM_CRC_LEN_MASK;
2173 	crc_value = quad0 & IEEE1394_CFG_ROM_CRC_VALUE_MASK;
2174 
2175 	if (node->cfgrom_valid_size < crc_len + 1) {
2176 		TNF_PROBE_4(s1394_valid_cfgrom_not_enough,
2177 		    S1394_TNF_SL_HOTPLUG_ERROR, "",
2178 		    tnf_uint, node_guid_hi, node->node_guid_hi,
2179 		    tnf_uint, node_guid_lo, node->node_guid_lo,
2180 		    tnf_uint, crc_len, crc_len,
2181 		    tnf_uint, valid_size, node->cfgrom_valid_size);
2182 		TNF_PROBE_0_DEBUG(s1394_valid_cfgrom_exit,
2183 		    S1394_TNF_SL_HOTPLUG_STACK, "");
2184 		return (B_FALSE);
2185 	}
2186 
2187 	CRC = s1394_CRC16(&node->cfgrom[1], crc_len);
2188 
2189 	if (CRC != crc_value) {
2190 		CRC_old = s1394_CRC16_old(&node->cfgrom[1], crc_len);
2191 		if (CRC_old == crc_value) {
2192 			TNF_PROBE_4_DEBUG(s1394_valid_cfgrom_busted_crc,
2193 			    S1394_TNF_SL_HOTPLUG_ERROR, "",
2194 			    tnf_uint, node_guid_hi, node->node_guid_hi,
2195 			    tnf_uint, node_guid_lo, node->node_guid_lo,
2196 			    tnf_uint, node_num, node->node_num,
2197 			    tnf_uint, crc_len, crc_len);
2198 			TNF_PROBE_0_DEBUG(s1394_valid_cfgrom_exit,
2199 			    S1394_TNF_SL_HOTPLUG_STACK, "");
2200 			return (B_TRUE);
2201 		}
2202 
2203 		cmn_err(CE_NOTE,
2204 		    "!Bad CRC in config rom (node's GUID %08x%08x)",
2205 		    node->node_guid_hi, node->node_guid_lo);
2206 
2207 		TNF_PROBE_5(s1394_valid_cfgrom_bad_crc,
2208 		    S1394_TNF_SL_HOTPLUG_ERROR, "",
2209 		    tnf_uint, node_guid_hi, node->node_guid_hi,
2210 		    tnf_uint, node_guid_lo, node->node_guid_lo,
2211 		    tnf_uint, crc_len, crc_len,
2212 		    tnf_uint, crc, crc_value, tnf_uint, crc_computed, CRC);
2213 		TNF_PROBE_0_DEBUG(s1394_valid_cfgrom_exit,
2214 		    S1394_TNF_SL_HOTPLUG_STACK, "");
2215 		return (B_FALSE);
2216 	}
2217 
2218 	TNF_PROBE_3_DEBUG(s1394_valid_cfgrom_exit, S1394_TNF_SL_HOTPLUG_STACK,
2219 	    "", tnf_uint, node_num, node->node_num, tnf_uint, crc_len, crc_len,
2220 	    tnf_uint, crc, crc_value);
2221 
2222 	return (B_TRUE);
2223 }
2224 
2225 /*
2226  * s1394_valid_dir()
2227  *    Performs crc check on a directory.  Returns B_TRUE if dir has good CRC
2228  *    else returns B_FALSE.
2229  */
2230 /*ARGSUSED*/
2231 boolean_t
2232 s1394_valid_dir(s1394_hal_t *hal, s1394_node_t *node,
2233     uint32_t key, uint32_t *dir)
2234 {
2235 	uint32_t dir_len, crc_value, CRC, CRC_old, quad0;
2236 
2237 	TNF_PROBE_0_DEBUG(s1394_valid_dir_enter, S1394_TNF_SL_HOTPLUG_STACK,
2238 	    "");
2239 
2240 	/*
2241 	 * Ideally, we would like to do crc validations for the entire cfgrom
2242 	 * as well as the individual directories. However, we have seen devices
2243 	 * that have valid directories but busted cfgrom crc and devices that
2244 	 * have bad crcs in directories as well as for the entire cfgrom. This
2245 	 * is sad, but unfortunately, real world!
2246 	 */
2247 	if (s1394_enable_crc_validation == 0) {
2248 		TNF_PROBE_1_DEBUG(s1394_valid_dir_exit,
2249 		    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string, msg,
2250 		    "validation turned off");
2251 		return (B_TRUE);
2252 	}
2253 
2254 	quad0 = dir[0];
2255 
2256 	dir_len = IEEE1212_DIR_LEN(quad0);
2257 	crc_value = IEEE1212_DIR_CRC(quad0);
2258 
2259 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
2260 
2261 	CRC = s1394_CRC16(&dir[1], dir_len);
2262 
2263 	if (CRC != crc_value) {
2264 		CRC_old = s1394_CRC16_old(&dir[1], dir_len);
2265 		if (CRC_old == crc_value) {
2266 			TNF_PROBE_5_DEBUG(s1394_valid_dir_crc_old,
2267 			    S1394_TNF_SL_HOTPLUG_STACK, "",
2268 			    tnf_uint, node_guid_hi, node->node_guid_hi,
2269 			    tnf_uint, node_guid_lo, node->node_guid_lo,
2270 			    tnf_uint, node_num, node->node_num,
2271 			    tnf_uint, key, key, tnf_uint, dir_len, dir_len);
2272 			TNF_PROBE_0_DEBUG(s1394_valid_dir_exit,
2273 			    S1394_TNF_SL_HOTPLUG_STACK, "");
2274 			return (B_TRUE);
2275 		}
2276 
2277 		TNF_PROBE_5(s1394_valid_dir_bad_crc,
2278 		    S1394_TNF_SL_HOTPLUG_STACK, "",
2279 		    tnf_uint, node_guid_hi, node->node_guid_hi,
2280 		    tnf_uint, node_guid_lo, node->node_guid_lo,
2281 		    tnf_uint, node_num, node->node_num,
2282 		    tnf_uint, key, key, tnf_uint, dir_len, dir_len);
2283 
2284 		TNF_PROBE_0_DEBUG(s1394_valid_dir_exit,
2285 			    S1394_TNF_SL_HOTPLUG_STACK, "");
2286 		return (B_FALSE);
2287 	}
2288 
2289 	TNF_PROBE_4_DEBUG(s1394_valid_dir,
2290 	    S1394_TNF_SL_HOTPLUG_STACK, "",
2291 	    tnf_uint, node_guid_hi, node->node_guid_hi,
2292 	    tnf_uint, node_guid_lo, node->node_guid_lo,
2293 	    tnf_uint, node_num, node->node_num, tnf_uint, key, key);
2294 
2295 	return (B_TRUE);
2296 }
2297 
2298 /*
2299  * s1394_become_bus_mgr()
2300  *    is a callback from a timeout() setup by the main br_thread.  After
2301  *    a bus reset, depending on the Bus Manager's incumbancy and the state
2302  *    of its abdicate bit, a timer of a certain length is set.  After this
2303  *    time expires, the local host may attempt to become the Bus Manager.
2304  *    This is done by sending a request to the current IRM on the bus.  The
2305  *    IRM holds the BUS_MANAGER_ID register.  Depending on whether or not
2306  *    the local host is already the IRM, we will send a request onto the
2307  *    1394 bus or call into the HAL.
2308  */
2309 static void
2310 s1394_become_bus_mgr(void *arg)
2311 {
2312 	s1394_hal_t	 *hal;
2313 	s1394_cmd_priv_t *s_priv;
2314 	cmd1394_cmd_t	 *cmd;
2315 	uint64_t	 Bus_Mgr_ID_addr;
2316 	uint32_t	 hal_node_num;
2317 	uint32_t	 old_value;
2318 	uint32_t	 generation;
2319 	uint_t		 curr_bus_mgr;
2320 	uint_t		 bm_node;
2321 	uint_t		 IRM_node;
2322 	int		 err;
2323 	int		 ret;
2324 
2325 	TNF_PROBE_0_DEBUG(s1394_become_bus_mgr_enter, S1394_TNF_SL_BR_STACK,
2326 	    "");
2327 
2328 	hal = (s1394_hal_t *)arg;
2329 
2330 	/* Lock the topology tree */
2331 	mutex_enter(&hal->topology_tree_mutex);
2332 
2333 	hal_node_num = IEEE1394_NODE_NUM(hal->node_id);
2334 	generation   = hal->generation_count;
2335 	IRM_node = hal->IRM_node;
2336 
2337 	mutex_enter(&hal->bus_mgr_node_mutex);
2338 	bm_node = hal->bus_mgr_node;
2339 	mutex_exit(&hal->bus_mgr_node_mutex);
2340 
2341 	/* Unlock the topology tree */
2342 	mutex_exit(&hal->topology_tree_mutex);
2343 
2344 	/* Make sure we aren't already the Bus Manager */
2345 	if (bm_node != -1) {
2346 		TNF_PROBE_0_DEBUG(s1394_become_bus_mgr_exit,
2347 		    S1394_TNF_SL_BR_STACK, "");
2348 		return;
2349 	}
2350 
2351 	/* Send compare-swap to BUS_MANAGER_ID */
2352 	/* register on the Isoch Rsrc Mgr */
2353 	if (IRM_node == hal_node_num) {
2354 		/* Local */
2355 		ret = HAL_CALL(hal).csr_cswap32(hal->halinfo.hal_private,
2356 		    generation, (IEEE1394_SCSR_BUSMGR_ID &
2357 		    IEEE1394_CSR_OFFSET_MASK), S1394_INVALID_NODE_NUM,
2358 		    hal_node_num, &old_value);
2359 		if (ret != DDI_SUCCESS) {
2360 			TNF_PROBE_1(s1394_become_bus_mgr_error,
2361 			    S1394_TNF_SL_BR_ERROR, "", tnf_string, msg,
2362 			    "Error in cswap32");
2363 			TNF_PROBE_0_DEBUG(s1394_become_bus_mgr_exit,
2364 			    S1394_TNF_SL_BR_STACK, "");
2365 			return;
2366 		}
2367 		curr_bus_mgr = IEEE1394_NODE_NUM(old_value);
2368 
2369 		mutex_enter(&hal->bus_mgr_node_mutex);
2370 		if ((curr_bus_mgr == S1394_INVALID_NODE_NUM) ||
2371 		    (curr_bus_mgr == hal_node_num)) {
2372 			hal->bus_mgr_node = hal_node_num;
2373 			hal->incumbent_bus_mgr = B_TRUE;
2374 		} else {
2375 			hal->bus_mgr_node = curr_bus_mgr;
2376 			hal->incumbent_bus_mgr = B_FALSE;
2377 		}
2378 		cv_signal(&hal->bus_mgr_node_cv);
2379 		mutex_exit(&hal->bus_mgr_node_mutex);
2380 
2381 	} else {
2382 		/* Remote */
2383 		if (s1394_alloc_cmd(hal, T1394_ALLOC_CMD_NOSLEEP, &cmd) !=
2384 		    DDI_SUCCESS) {
2385 			TNF_PROBE_1(s1394_become_bus_mgr_error,
2386 			    S1394_TNF_SL_BR_ERROR, "", tnf_string, msg,
2387 			    "Error in s1394_alloc_cmd()");
2388 			TNF_PROBE_0_DEBUG(s1394_become_bus_mgr_exit,
2389 			    S1394_TNF_SL_BR_STACK, "");
2390 			return;
2391 		}
2392 
2393 		cmd->cmd_options	   = (CMD1394_CANCEL_ON_BUS_RESET |
2394 		    CMD1394_OVERRIDE_ADDR);
2395 		cmd->cmd_type		   = CMD1394_ASYNCH_LOCK_32;
2396 		cmd->completion_callback   = s1394_become_bus_mgr_callback;
2397 		Bus_Mgr_ID_addr		   = (IEEE1394_ADDR_BUS_ID_MASK |
2398 		    IEEE1394_SCSR_BUSMGR_ID) |
2399 		    (((uint64_t)hal->IRM_node) << IEEE1394_ADDR_PHY_ID_SHIFT);
2400 		cmd->cmd_addr		   = Bus_Mgr_ID_addr;
2401 		cmd->bus_generation	   = generation;
2402 		cmd->cmd_u.l32.arg_value   = T1394_DATA32(
2403 		    S1394_INVALID_NODE_NUM);
2404 		cmd->cmd_u.l32.data_value  = T1394_DATA32(hal_node_num);
2405 		cmd->cmd_u.l32.num_retries = 0;
2406 		cmd->cmd_u.l32.lock_type   = CMD1394_LOCK_COMPARE_SWAP;
2407 
2408 		/* Get the Services Layer private area */
2409 		s_priv = S1394_GET_CMD_PRIV(cmd);
2410 
2411 		/* Lock the topology tree */
2412 		mutex_enter(&hal->topology_tree_mutex);
2413 
2414 		ret = s1394_setup_asynch_command(hal, NULL, cmd,
2415 		    S1394_CMD_LOCK, &err);
2416 
2417 		/* Unlock the topology tree */
2418 		mutex_exit(&hal->topology_tree_mutex);
2419 
2420 		/* Command has now been put onto the queue! */
2421 		if (ret != DDI_SUCCESS) {
2422 			/* Need to free the command */
2423 			(void) s1394_free_cmd(hal, (cmd1394_cmd_t **)&cmd);
2424 			TNF_PROBE_1(s1394_become_bus_mgr_error,
2425 			    S1394_TNF_SL_BR_ERROR, "", tnf_string, msg,
2426 			    "Error in s1394_setup_asynch_command()");
2427 			TNF_PROBE_0_DEBUG(s1394_become_bus_mgr_exit,
2428 			    S1394_TNF_SL_BR_STACK, "");
2429 			return;
2430 		}
2431 
2432 		/* Send the command out */
2433 		ret = s1394_xfer_asynch_command(hal, cmd, &err);
2434 
2435 		if (ret != DDI_SUCCESS) {
2436 			/* Remove cmd outstanding request Q */
2437 			s1394_remove_q_asynch_cmd(hal, cmd);
2438 
2439 			s_priv->cmd_in_use = B_FALSE;
2440 
2441 			mutex_enter(&hal->bus_mgr_node_mutex);
2442 
2443 			/* Don't know who the bus_mgr is */
2444 			hal->bus_mgr_node = S1394_INVALID_NODE_NUM;
2445 			hal->incumbent_bus_mgr = B_FALSE;
2446 
2447 			cv_signal(&hal->bus_mgr_node_cv);
2448 			mutex_exit(&hal->bus_mgr_node_mutex);
2449 
2450 			/* Need to free the command */
2451 			(void) s1394_free_cmd(hal, (cmd1394_cmd_t **)&cmd);
2452 		}
2453 	}
2454 
2455 	TNF_PROBE_0_DEBUG(s1394_become_bus_mgr_exit, S1394_TNF_SL_BR_STACK,
2456 	    "");
2457 }
2458 
2459 /*
2460  * s1394_become_bus_mgr_callback()
2461  *    is the callback used by s1394_become_bus_mgr() when it is necessary
2462  *    to send the Bus Manager request to a remote IRM.  After the completion
2463  *    of the compare-swap request, this routine looks at the "old_value"
2464  *    in the request to determine whether or not it has become the Bus
2465  *    Manager for the current generation.  It sets the bus_mgr_node and
2466  *    incumbent_bus_mgr fields to their appropriate values.
2467  */
2468 static void
2469 s1394_become_bus_mgr_callback(cmd1394_cmd_t *cmd)
2470 {
2471 	s1394_cmd_priv_t *s_priv;
2472 	s1394_hal_t *hal;
2473 	uint32_t hal_node_num;
2474 	uint32_t temp;
2475 	uint_t curr_bus_mgr;
2476 
2477 	TNF_PROBE_0_DEBUG(s1394_become_bus_mgr_callback_enter,
2478 	    S1394_TNF_SL_BR_STACK, "");
2479 
2480 	/* Get the Services Layer private area */
2481 	s_priv = S1394_GET_CMD_PRIV(cmd);
2482 
2483 	hal = (s1394_hal_t *)s_priv->sent_on_hal;
2484 
2485 	/* Lock the topology tree */
2486 	mutex_enter(&hal->topology_tree_mutex);
2487 
2488 	hal_node_num = IEEE1394_NODE_NUM(hal->node_id);
2489 
2490 	/* Was the command successful? */
2491 	if (cmd->cmd_result == CMD1394_CMDSUCCESS) {
2492 		temp = T1394_DATA32(cmd->cmd_u.l32.old_value);
2493 		curr_bus_mgr = IEEE1394_NODE_NUM(temp);
2494 		mutex_enter(&hal->bus_mgr_node_mutex);
2495 		if ((curr_bus_mgr == S1394_INVALID_NODE_NUM) ||
2496 		    (curr_bus_mgr == hal_node_num)) {
2497 
2498 			hal->bus_mgr_node = hal_node_num;
2499 			hal->incumbent_bus_mgr = B_TRUE;
2500 
2501 		} else {
2502 			hal->bus_mgr_node = curr_bus_mgr;
2503 			hal->incumbent_bus_mgr = B_FALSE;
2504 		}
2505 		cv_signal(&hal->bus_mgr_node_cv);
2506 		mutex_exit(&hal->bus_mgr_node_mutex);
2507 
2508 	} else {
2509 		TNF_PROBE_2(s1394_become_bus_mgr_callback_error,
2510 		    S1394_TNF_SL_BR_ERROR, "", tnf_string, msg,
2511 		    "Error while attempting to become bus manager",
2512 		    tnf_uint, status, cmd->cmd_result);
2513 
2514 		mutex_enter(&hal->bus_mgr_node_mutex);
2515 
2516 		/* Don't know who the bus_mgr is */
2517 		hal->bus_mgr_node = S1394_INVALID_NODE_NUM;
2518 		hal->incumbent_bus_mgr = B_FALSE;
2519 
2520 		cv_signal(&hal->bus_mgr_node_cv);
2521 		mutex_exit(&hal->bus_mgr_node_mutex);
2522 	}
2523 
2524 	/* Need to free the command */
2525 	(void) s1394_free_cmd(hal, (cmd1394_cmd_t **)&cmd);
2526 
2527 	/* Unlock the topology tree */
2528 	mutex_exit(&hal->topology_tree_mutex);
2529 
2530 	TNF_PROBE_0_DEBUG(s1394_become_bus_mgr_callback_exit,
2531 	    S1394_TNF_SL_BR_STACK, "");
2532 }
2533 
2534 /*
2535  * s1394_bus_mgr_processing()
2536  *    is called following "phase1" completion of reading Bus_Info_Blocks.
2537  *    Its purpose is to determine whether the local node is capable of
2538  *    becoming the Bus Manager (has the IRMC bit set) and if so to call
2539  *    the s1394_do_bus_mgr_processing() routine.
2540  *    NOTE: we overload DDI_FAILURE return value to mean jump back to
2541  *    the start of bus reset processing.
2542  */
2543 static int
2544 s1394_bus_mgr_processing(s1394_hal_t *hal)
2545 {
2546 	int ret;
2547 	int IRM_node_num;
2548 
2549 	TNF_PROBE_0_DEBUG(s1394_bus_mgr_processing_enter,
2550 	    S1394_TNF_SL_BR_STACK, "");
2551 
2552 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
2553 
2554 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
2555 		return (DDI_FAILURE);
2556 	}
2557 	IRM_node_num = hal->IRM_node;
2558 	s1394_unlock_tree(hal);
2559 
2560 	ret = DDI_SUCCESS;
2561 
2562 	/* If we are IRM capable, then do bus_mgr stuff... */
2563 	if (hal->halinfo.bus_capabilities & IEEE1394_BIB_IRMC_MASK) {
2564 		/* If there is an IRM, then do bus_mgr stuff */
2565 		if (IRM_node_num != -1) {
2566 			if (s1394_do_bus_mgr_processing(hal))
2567 				ret = DDI_FAILURE;
2568 		}
2569 	}
2570 
2571 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
2572 
2573 	TNF_PROBE_0_DEBUG(s1394_bus_mgr_processing_exit,
2574 	    S1394_TNF_SL_BR_STACK, "");
2575 	return (ret);
2576 }
2577 
2578 /*
2579  * s1394_do_bus_mgr_processing()
2580  *    is used to perform those operations expected of the Bus Manager.
2581  *    After being called, s1394_do_bus_mgr_processing() looks at the value
2582  *    in bus_mgr_node and waits if it is -1 (Bus Manager has not been
2583  *    chosen yet).  Then, if there is more than one node on the 1394 bus,
2584  *    and we are either the Bus Manager or (if there is no Bus Manager)
2585  *    the IRM, it optimizes the gap_count and/or sets the cycle master's
2586  *    root holdoff bit (to ensure that the cycle master is/stays root).
2587  *
2588  *    NOTE: we overload DDI_FAILURE return value to mean jump back to
2589  *    the start of bus reset processing.
2590  */
2591 static int
2592 s1394_do_bus_mgr_processing(s1394_hal_t *hal)
2593 {
2594 	int	ret;
2595 	int	IRM_flags, hal_bus_mgr_node;
2596 	int	IRM_node_num;
2597 	uint_t	hal_node_num, number_of_nodes;
2598 	int	new_root, new_gap_cnt;
2599 
2600 	TNF_PROBE_0_DEBUG(s1394_do_bus_mgr_processing_enter,
2601 	    S1394_TNF_SL_BR_STACK, "");
2602 
2603 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
2604 
2605 	/* Wait for Bus Manager to be determined */
2606 	/* or a Bus Reset to happen */
2607 	mutex_enter(&hal->bus_mgr_node_mutex);
2608 	if (hal->bus_mgr_node == -1)
2609 		cv_wait(&hal->bus_mgr_node_cv, &hal->bus_mgr_node_mutex);
2610 
2611 	/* Check if a BUS RESET has come while we've been waiting */
2612 	mutex_enter(&hal->br_thread_mutex);
2613 	if (hal->br_thread_ev_type & (BR_THR_CFGROM_SCAN | BR_THR_GO_AWAY)) {
2614 
2615 		mutex_exit(&hal->br_thread_mutex);
2616 		mutex_exit(&hal->bus_mgr_node_mutex);
2617 
2618 		TNF_PROBE_0_DEBUG(s1394_do_bus_mgr_processing_exit,
2619 		    S1394_TNF_SL_BR_STACK, "");
2620 		return (1);
2621 	}
2622 	mutex_exit(&hal->br_thread_mutex);
2623 
2624 	hal_bus_mgr_node = hal->bus_mgr_node;
2625 	mutex_exit(&hal->bus_mgr_node_mutex);
2626 
2627 	if (s1394_lock_tree(hal) != DDI_SUCCESS) {
2628 		return (1);
2629 	}
2630 	hal_node_num = IEEE1394_NODE_NUM(hal->node_id);
2631 	IRM_node_num = hal->IRM_node;
2632 	number_of_nodes = hal->number_of_nodes;
2633 
2634 	ret = 0;
2635 
2636 	/* If we are the bus_mgr or if there is no bus_mgr */
2637 	/* the IRM and there is > 1 nodes on the bus */
2638 	if ((number_of_nodes > 1) &&
2639 	    ((hal_bus_mgr_node == (int)hal_node_num) ||
2640 		((hal_bus_mgr_node == S1394_INVALID_NODE_NUM) &&
2641 		    (IRM_node_num == (int)hal_node_num)))) {
2642 
2643 		IRM_flags = 0;
2644 
2645 		/* Make sure the root node is cycle master capable */
2646 		if (!s1394_cycle_master_capable(hal)) {
2647 			/* Make the local node root */
2648 			new_root = hal_node_num;
2649 			IRM_flags = IRM_flags | ROOT_HOLDOFF;
2650 
2651 			/* If setting root, then optimize gap_count */
2652 			new_gap_cnt = hal->optimum_gap_count;
2653 			IRM_flags = IRM_flags | GAP_COUNT;
2654 
2655 		} else {
2656 			/* Make sure root's ROOT_HOLDOFF bit is set */
2657 			new_root = (number_of_nodes - 1);
2658 			IRM_flags = IRM_flags | ROOT_HOLDOFF;
2659 		}
2660 		if (hal->gap_count > hal->optimum_gap_count) {
2661 			/* Set the gap_count to optimum */
2662 			new_gap_cnt = hal->optimum_gap_count;
2663 			IRM_flags = IRM_flags | GAP_COUNT;
2664 
2665 		}
2666 
2667 		s1394_unlock_tree(hal);
2668 
2669 		if (IRM_flags) {
2670 			ret = s1394_do_phy_config_pkt(hal, new_root,
2671 			    new_gap_cnt, IRM_flags);
2672 		}
2673 		TNF_PROBE_0_DEBUG(s1394_do_bus_mgr_processing_exit,
2674 		    S1394_TNF_SL_BR_STACK, "");
2675 		return (ret);
2676 	}
2677 
2678 	s1394_unlock_tree(hal);
2679 
2680 	TNF_PROBE_0_DEBUG(s1394_do_bus_mgr_processing_exit,
2681 	    S1394_TNF_SL_BR_STACK, "");
2682 	return (ret);
2683 }
2684 
2685 /*
2686  * s1394_bus_mgr_timers_stop()
2687  *    Cancels bus manager timeouts
2688  */
2689 /*ARGSUSED*/
2690 static void
2691 s1394_bus_mgr_timers_stop(s1394_hal_t *hal, timeout_id_t *bus_mgr_query_tid,
2692     timeout_id_t *bus_mgr_tid)
2693 {
2694 	TNF_PROBE_0_DEBUG(s1394_bus_mgr_timers_stop_enter,
2695 	    S1394_TNF_SL_BR_STACK, "");
2696 
2697 	/* Cancel the Bus Mgr timeouts (if necessary) */
2698 	if (*bus_mgr_tid != 0) {
2699 		(void) untimeout(*bus_mgr_tid);
2700 		*bus_mgr_tid = 0;
2701 	}
2702 	if (*bus_mgr_query_tid != 0) {
2703 		(void) untimeout(*bus_mgr_query_tid);
2704 		*bus_mgr_query_tid = 0;
2705 	}
2706 
2707 	TNF_PROBE_0_DEBUG(s1394_bus_mgr_timers_stop_exit,
2708 	    S1394_TNF_SL_BR_STACK, "");
2709 }
2710 
2711 /*
2712  * s1394_bus_mgr_timers_start()
2713  *    Starts bus manager timeouts if the hal is IRM capable.
2714  */
2715 static void
2716 s1394_bus_mgr_timers_start(s1394_hal_t *hal, timeout_id_t *bus_mgr_query_tid,
2717     timeout_id_t *bus_mgr_tid)
2718 {
2719 	boolean_t incumbant;
2720 	uint_t	  hal_node_num;
2721 	int	  IRM_node_num;
2722 
2723 	TNF_PROBE_0_DEBUG(s1394_bus_mgr_timers_start_enter,
2724 	    S1394_TNF_SL_BR_STACK, "");
2725 
2726 	mutex_enter(&hal->topology_tree_mutex);
2727 
2728 	IRM_node_num = hal->IRM_node;
2729 	hal_node_num = hal->node_id;
2730 
2731 	mutex_enter(&hal->bus_mgr_node_mutex);
2732 	incumbant = hal->incumbent_bus_mgr;
2733 	mutex_exit(&hal->bus_mgr_node_mutex);
2734 
2735 	/* If we are IRM capable, then do bus_mgr stuff... */
2736 	if (hal->halinfo.bus_capabilities & IEEE1394_BIB_IRMC_MASK) {
2737 		/*
2738 		 * If we are the IRM, then wait 625ms
2739 		 * before checking BUS_MANAGER_ID register
2740 		 */
2741 		if (IRM_node_num == IEEE1394_NODE_NUM(hal_node_num)) {
2742 
2743 			TNF_PROBE_0_DEBUG(s1394_bus_mgr_timers_625ms,
2744 			    S1394_TNF_SL_BR_STACK, "");
2745 
2746 			mutex_exit(&hal->topology_tree_mutex);
2747 
2748 			/* Wait 625ms, then check bus manager */
2749 			*bus_mgr_query_tid = timeout(s1394_become_bus_mgr,
2750 			    hal, drv_usectohz(IEEE1394_BM_IRM_TIMEOUT));
2751 
2752 			mutex_enter(&hal->topology_tree_mutex);
2753 		}
2754 
2755 		/* If there is an IRM on the bus */
2756 		if (IRM_node_num != -1) {
2757 			if ((incumbant == B_TRUE) &&
2758 			    (hal->abdicate_bus_mgr_bit == 0)) {
2759 				mutex_exit(&hal->topology_tree_mutex);
2760 
2761 				/* Try to become bus manager */
2762 				s1394_become_bus_mgr(hal);
2763 
2764 				mutex_enter(&hal->topology_tree_mutex);
2765 			} else {
2766 				hal->abdicate_bus_mgr_bit = 0;
2767 
2768 				TNF_PROBE_0_DEBUG(s1394_bus_mgr_timers_125ms,
2769 				    S1394_TNF_SL_BR_STACK, "");
2770 
2771 				mutex_exit(&hal->topology_tree_mutex);
2772 
2773 				/* Wait 125ms, then try to become bus manager */
2774 				*bus_mgr_tid = timeout(s1394_become_bus_mgr,
2775 				    hal, drv_usectohz(
2776 					IEEE1394_BM_INCUMBENT_TIMEOUT));
2777 
2778 				mutex_enter(&hal->topology_tree_mutex);
2779 			}
2780 		} else {
2781 			mutex_enter(&hal->bus_mgr_node_mutex);
2782 			hal->incumbent_bus_mgr = B_FALSE;
2783 			mutex_exit(&hal->bus_mgr_node_mutex);
2784 		}
2785 	}
2786 
2787 	mutex_exit(&hal->topology_tree_mutex);
2788 
2789 	TNF_PROBE_0_DEBUG(s1394_bus_mgr_timers_start_exit,
2790 	    S1394_TNF_SL_BR_STACK, "");
2791 }
2792 
2793 /*
2794  * s1394_get_maxpayload()
2795  *    is used to determine a device's maximum payload size.  That is to
2796  *    say, the largest packet that can be transmitted or received by the
2797  *    the target device given the current topological (speed) constraints
2798  *    and the constraints specified in the local host's and remote device's
2799  *    Config ROM (max_rec).  Caller must hold the topology_tree_mutex and
2800  *    the target_list_rwlock as an RW_READER (at least).
2801  */
2802 /*ARGSUSED*/
2803 void
2804 s1394_get_maxpayload(s1394_target_t *target, uint_t *dev_max_payload,
2805     uint_t *current_max_payload)
2806 {
2807 	s1394_hal_t *hal;
2808 	uint32_t bus_capabilities;
2809 	uint32_t from_node;
2810 	uint32_t to_node;
2811 	uint_t local_max_rec;
2812 	uint_t local_max_blk;
2813 	uint_t max_rec;
2814 	uint_t max_blk;
2815 	uint_t curr_speed;
2816 	uint_t speed_max_blk;
2817 	uint_t temp;
2818 
2819 	TNF_PROBE_0_DEBUG(s1394_get_maxpayload_enter,
2820 	    S1394_TNF_SL_HOTPLUG_STACK, "");
2821 
2822 	/* Find the HAL this target resides on */
2823 	hal = target->on_hal;
2824 
2825 	/* Make sure we're holding the topology_tree_mutex */
2826 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
2827 
2828 	/* Set dev_max_payload to local (HAL's) size */
2829 	bus_capabilities = target->on_hal->halinfo.bus_capabilities;
2830 	local_max_rec = (bus_capabilities & IEEE1394_BIB_MAXREC_MASK) >>
2831 	    IEEE1394_BIB_MAXREC_SHIFT;
2832 	if ((local_max_rec > 0) && (local_max_rec < 14)) {
2833 		local_max_blk = 1 << (local_max_rec + 1);
2834 	} else {
2835 		/* These are either unspecified or reserved */
2836 		local_max_blk = 4;
2837 	}
2838 
2839 	/* Is this target on a node? */
2840 	if ((target->target_state & S1394_TARG_GONE) == 0 &&
2841 	    (target->on_node != NULL)) {
2842 		ASSERT(target->on_node->cfgrom != NULL);
2843 
2844 		bus_capabilities =
2845 		    target->on_node->cfgrom[IEEE1212_NODE_CAP_QUAD];
2846 		max_rec = (bus_capabilities & IEEE1394_BIB_MAXREC_MASK) >>
2847 		    IEEE1394_BIB_MAXREC_SHIFT;
2848 
2849 		if ((max_rec > 0) && (max_rec < 14)) {
2850 			max_blk = 1 << (max_rec + 1);
2851 		} else {
2852 			/* These are either unspecified or reserved */
2853 			max_blk = 4;
2854 		}
2855 		(*dev_max_payload) = max_blk;
2856 
2857 		from_node = IEEE1394_NODE_NUM(target->on_hal->node_id);
2858 		to_node = (target->on_node->node_num);
2859 
2860 		/* Speed is to be filled in from speed map */
2861 		curr_speed = (uint_t)s1394_speed_map_get(target->on_hal,
2862 		    from_node, to_node);
2863 		speed_max_blk = 512 << curr_speed;
2864 		temp = (local_max_blk < max_blk) ? local_max_blk : max_blk;
2865 		(*current_max_payload) = (temp < speed_max_blk) ? temp :
2866 		    speed_max_blk;
2867 	} else {
2868 		/* Set dev_max_payload to local (HAL's) size */
2869 		(*dev_max_payload) = local_max_blk;
2870 		(*current_max_payload) = local_max_blk;
2871 	}
2872 
2873 	TNF_PROBE_0_DEBUG(s1394_get_maxpayload_exit,
2874 	    S1394_TNF_SL_HOTPLUG_STACK, "");
2875 }
2876 
2877 /*
2878  * s1394_cycle_master_capable()
2879  *    is used to determine whether or not the current root node on the
2880  *    1394 bus has its CMC-bit set in it Config ROM.  If not, then it
2881  *    is not capable of being cycle master and a new root node must be
2882  *    selected.
2883  */
2884 static int
2885 s1394_cycle_master_capable(s1394_hal_t *hal)
2886 {
2887 	s1394_node_t	*root;
2888 	int		cycle_master_capable;
2889 	uint_t		hal_node_num;
2890 
2891 	TNF_PROBE_0_DEBUG(s1394_cycle_master_capable_enter,
2892 	    S1394_TNF_SL_HOTPLUG_STACK, "");
2893 
2894 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
2895 
2896 	hal_node_num = IEEE1394_NODE_NUM(hal->node_id);
2897 
2898 	/* Get a pointer to the root node */
2899 	root = s1394_topology_tree_get_root_node(hal);
2900 
2901 	/* Ignore, if we are already root */
2902 	if (root == &hal->topology_tree[hal_node_num]) {
2903 		TNF_PROBE_2_DEBUG(s1394_cmstr_capable_hal,
2904 		    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_int,
2905 		    node_num, hal_node_num, tnf_int, ret, 1);
2906 		return (1);
2907 	}
2908 
2909 	/*
2910 	 * We want to pick a new root if link is off or we don't have
2911 	 * valid config rom
2912 	 */
2913 	if (LINK_ACTIVE(root) == B_FALSE || root->cfgrom == NULL ||
2914 	    CFGROM_BIB_READ(root) == 0) {
2915 
2916 		TNF_PROBE_4_DEBUG(s1394_cmstr_capable_not_hal,
2917 		    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_int,
2918 		    root, root->node_num, tnf_int, link_active,
2919 		    LINK_ACTIVE(root), tnf_opaque, cfgrom, root->cfgrom,
2920 		    tnf_int, bib, CFGROM_BIB_READ(root));
2921 
2922 		return (0);
2923 	}
2924 
2925 	/* Check the Cycle Master bit in the Bus Info Block */
2926 	cycle_master_capable = root->cfgrom[IEEE1212_NODE_CAP_QUAD] &
2927 	    IEEE1394_BIB_CMC_MASK;
2928 
2929 	if (cycle_master_capable) {
2930 		TNF_PROBE_1_DEBUG(s1394_cmstr_capable_root,
2931 		    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_int,
2932 		    root, root->node_num);
2933 		return (1);
2934 	} else {
2935 		TNF_PROBE_1(s1394_cmstr_not_capable_root,
2936 		    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_int,
2937 		    root, root->node_num);
2938 		return (0);
2939 	}
2940 }
2941 
2942 /*
2943  * s1394_do_phy_config_pkt()
2944  *    is called by s1394_do_bus_mgr_processing() to setup and send out
2945  *    a PHY configuration packet onto the 1394 bus.  Depending on the
2946  *    values in IRM_flags, the gap_count and root_holdoff bits on the
2947  *    bus will be affected by this packet.
2948  *
2949  *    NOTE: we overload DDI_FAILURE return value to mean jump back to
2950  *    the start of bus reset processing.
2951  */
2952 static int
2953 s1394_do_phy_config_pkt(s1394_hal_t *hal, int new_root, int new_gap_cnt,
2954     uint32_t IRM_flags)
2955 {
2956 	cmd1394_cmd_t	 *cmd;
2957 	s1394_cmd_priv_t *s_priv;
2958 	h1394_cmd_priv_t *h_priv;
2959 	uint32_t	 pkt_data = 0;
2960 	uint32_t	 gap_cnt = 0;
2961 	uint32_t	 root = 0;
2962 	int		 ret, result;
2963 	uint_t		 flags = 0;
2964 
2965 	TNF_PROBE_0_DEBUG(s1394_do_phy_config_pkt_enter,
2966 	    S1394_TNF_SL_HOTPLUG_STACK, "");
2967 
2968 	/* Gap count needs to be optimized */
2969 	if (IRM_flags & GAP_COUNT) {
2970 
2971 		pkt_data = pkt_data | IEEE1394_PHY_CONFIG_T_BIT_MASK;
2972 		gap_cnt = ((uint32_t)new_gap_cnt) <<
2973 		    IEEE1394_PHY_CONFIG_GAP_CNT_SHIFT;
2974 		gap_cnt = gap_cnt & IEEE1394_PHY_CONFIG_GAP_CNT_MASK;
2975 		pkt_data = pkt_data | gap_cnt;
2976 
2977 		(void) HAL_CALL(hal).set_gap_count(hal->halinfo.hal_private,
2978 		    (uint_t)new_gap_cnt);
2979 	}
2980 
2981 	/* Root node needs to be changed */
2982 	if (IRM_flags & ROOT_HOLDOFF) {
2983 
2984 		pkt_data = pkt_data | IEEE1394_PHY_CONFIG_R_BIT_MASK;
2985 		root = ((uint32_t)new_root) <<
2986 		    IEEE1394_PHY_CONFIG_ROOT_HOLD_SHIFT;
2987 		root = root & IEEE1394_PHY_CONFIG_ROOT_HOLD_MASK;
2988 		pkt_data = pkt_data | root;
2989 
2990 		(void) HAL_CALL(hal).set_root_holdoff_bit(
2991 		    hal->halinfo.hal_private);
2992 	}
2993 
2994 
2995 	if (IRM_flags) {
2996 		if (s1394_alloc_cmd(hal, flags, &cmd) != DDI_SUCCESS) {
2997 			TNF_PROBE_1_DEBUG(s1394_do_phy_config_pkt_error,
2998 			    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string, msg,
2999 			    "Unable to allocate PHY config packet");
3000 			TNF_PROBE_0_DEBUG(s1394_do_phy_config_pkt_exit,
3001 			    S1394_TNF_SL_HOTPLUG_STACK, "");
3002 			return (0);
3003 		}
3004 
3005 		if (s1394_lock_tree(hal) != DDI_SUCCESS) {
3006 			/* lock tree failure indicates a bus gen change */
3007 			(void) s1394_free_cmd(hal, (cmd1394_cmd_t **)&cmd);
3008 			TNF_PROBE_0_DEBUG(s1394_do_phy_config_pkt_exit,
3009 			    S1394_TNF_SL_HOTPLUG_STACK, "");
3010 			return (1);
3011 		}
3012 
3013 		/* Setup the callback routine */
3014 		cmd->completion_callback  = s1394_phy_config_callback;
3015 		cmd->cmd_callback_arg	  = (void *)(uintptr_t)IRM_flags;
3016 		cmd->bus_generation	  = hal->generation_count;
3017 		cmd->cmd_options	  = CMD1394_OVERRIDE_ADDR;
3018 		cmd->cmd_type		  = CMD1394_ASYNCH_WR_QUAD;
3019 		cmd->cmd_u.q.quadlet_data = pkt_data;
3020 
3021 		/* Get the Services Layer private area */
3022 		s_priv = S1394_GET_CMD_PRIV(cmd);
3023 
3024 		/* Get a pointer to the HAL private struct */
3025 		h_priv = (h1394_cmd_priv_t *)&s_priv->hal_cmd_private;
3026 
3027 		s_priv->sent_by_target	= (s1394_target_t *)NULL;
3028 		s_priv->sent_on_hal	= (s1394_hal_t *)hal;
3029 
3030 		h_priv->bus_generation	= cmd->bus_generation;
3031 
3032 		/* Speed must be IEEE1394_S100 on PHY config packets */
3033 		s_priv->hal_cmd_private.speed = IEEE1394_S100;
3034 
3035 		/* Mark command as being used */
3036 		s_priv->cmd_in_use = B_TRUE;
3037 
3038 		s1394_unlock_tree(hal);
3039 
3040 		/* Put command on the HAL's outstanding request Q */
3041 		s1394_insert_q_asynch_cmd(hal, cmd);
3042 
3043 		ret = HAL_CALL(hal).send_phy_configuration_packet(
3044 		    hal->halinfo.hal_private, (cmd1394_cmd_t *)cmd,
3045 		    (h1394_cmd_priv_t *)&s_priv->hal_cmd_private, &result);
3046 
3047 		if (ret != DDI_SUCCESS) {
3048 			TNF_PROBE_2_DEBUG(s1394_do_phy_config_pkt_error,
3049 			    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string, msg,
3050 			    "Unable to send PHY config packet",
3051 			    tnf_int, result, result);
3052 
3053 			(void) s1394_free_cmd(hal, (cmd1394_cmd_t **)&cmd);
3054 
3055 			TNF_PROBE_0_DEBUG(s1394_do_phy_config_pkt_exit,
3056 			    S1394_TNF_SL_HOTPLUG_STACK, "");
3057 			return (0);
3058 
3059 		} else {
3060 			/*
3061 			 * There will be a bus reset only if GAP_COUNT changed
3062 			 */
3063 			if (IRM_flags & GAP_COUNT) {
3064 				return (1);
3065 			}
3066 		}
3067 	}
3068 
3069 	TNF_PROBE_0_DEBUG(s1394_do_phy_config_pkt_exit,
3070 	    S1394_TNF_SL_HOTPLUG_STACK, "");
3071 	return (0);
3072 }
3073 
3074 /*
3075  * s1394_phy_config_callback()
3076  *    is the callback called after the PHY configuration packet has been
3077  *    sent out onto the 1394 bus.  Depending on the values in IRM_flags,
3078  *    (specifically if the gap_count has been changed) this routine may
3079  *    initiate a bus reset.
3080  */
3081 static void
3082 s1394_phy_config_callback(cmd1394_cmd_t *cmd)
3083 {
3084 	s1394_cmd_priv_t *s_priv;
3085 	s1394_hal_t *hal;
3086 	uint32_t IRM_flags;
3087 
3088 	TNF_PROBE_0_DEBUG(s1394_phy_config_callback_enter,
3089 	    S1394_TNF_SL_HOTPLUG_STACK, "");
3090 
3091 	/* Get the Services Layer private area */
3092 	s_priv = S1394_GET_CMD_PRIV(cmd);
3093 
3094 	hal = (s1394_hal_t *)s_priv->sent_on_hal;
3095 
3096 	IRM_flags = (uint32_t)(uintptr_t)cmd->cmd_callback_arg;
3097 
3098 	if (cmd->cmd_result != CMD1394_CMDSUCCESS) {
3099 		TNF_PROBE_2_DEBUG(s1394_do_phy_config_pkt_error,
3100 		    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string, msg,
3101 		    "Error sending PHY config packet",
3102 		    tnf_int, result, cmd->cmd_result);
3103 		(void) s1394_free_cmd(hal, &cmd);
3104 	} else {
3105 		(void) s1394_free_cmd(hal, &cmd);
3106 
3107 		/* Only need a bus reset if we changed GAP_COUNT */
3108 		if (IRM_flags & GAP_COUNT) {
3109 			s1394_initiate_hal_reset(hal, NON_CRITICAL);
3110 		}
3111 	}
3112 
3113 	TNF_PROBE_0_DEBUG(s1394_phy_config_callback_exit,
3114 	    S1394_TNF_SL_HOTPLUG_STACK, "");
3115 }
3116 
3117 /*
3118  * s1394_lock_tree()
3119  *    Attempts to lock the topology tree. Returns DDI_FAILURE if generations
3120  *    changed or if the services layer signals the bus reset thread to go
3121  *    away. Otherwise, returns DDI_SUCCESS.
3122  */
3123 int
3124 s1394_lock_tree(s1394_hal_t *hal)
3125 {
3126 	int	circular;
3127 
3128 	ASSERT(MUTEX_NOT_HELD(&hal->br_thread_mutex));
3129 	ASSERT(MUTEX_NOT_HELD(&hal->topology_tree_mutex));
3130 
3131 	TNF_PROBE_0_DEBUG(s1394_lock_tree_enter, S1394_TNF_SL_HOTPLUG_STACK,
3132 	    "");
3133 
3134 	mutex_enter(&hal->br_thread_mutex);
3135 	ndi_devi_enter(hal->halinfo.dip, &circular);
3136 	mutex_enter(&hal->topology_tree_mutex);
3137 
3138 	if ((hal->br_thread_ev_type & BR_THR_GO_AWAY) != 0) {
3139 		TNF_PROBE_2(s1394_lock_tree_go_away,
3140 		    S1394_TNF_SL_HOTPLUG_STACK, "",
3141 		    tnf_int, hal_generation, hal->generation_count,
3142 		    tnf_int, br_thread_gen, hal->br_cfgrom_read_gen);
3143 		TNF_PROBE_0_DEBUG(s1394_lock_tree_exit,
3144 		    S1394_TNF_SL_HOTPLUG_STACK, "");
3145 		mutex_exit(&hal->br_thread_mutex);
3146 		mutex_exit(&hal->topology_tree_mutex);
3147 		ndi_devi_exit(hal->halinfo.dip, circular);
3148 		return (DDI_FAILURE);
3149 	} else if (hal->br_cfgrom_read_gen != hal->generation_count) {
3150 		TNF_PROBE_2(s1394_lock_tree_gen_changed,
3151 		    S1394_TNF_SL_HOTPLUG_STACK, "",
3152 		    tnf_int, hal_generation, hal->generation_count,
3153 		    tnf_int, br_thread_gen, hal->br_cfgrom_read_gen);
3154 
3155 		TNF_PROBE_0_DEBUG(s1394_lock_tree_exit,
3156 		    S1394_TNF_SL_HOTPLUG_STACK, "");
3157 		mutex_exit(&hal->br_thread_mutex);
3158 		mutex_exit(&hal->topology_tree_mutex);
3159 		ndi_devi_exit(hal->halinfo.dip, circular);
3160 		return (DDI_FAILURE);
3161 	}
3162 
3163 	mutex_exit(&hal->br_thread_mutex);
3164 
3165 	TNF_PROBE_0_DEBUG(s1394_lock_tree_exit, S1394_TNF_SL_HOTPLUG_STACK, "");
3166 
3167 	return (DDI_SUCCESS);
3168 }
3169 
3170 /*
3171  * s1394_unlock_tree()
3172  *    Unlocks the topology tree
3173  */
3174 void
3175 s1394_unlock_tree(s1394_hal_t *hal)
3176 {
3177 	TNF_PROBE_0_DEBUG(s1394_unlock_tree_enter, S1394_TNF_SL_HOTPLUG_STACK,
3178 	    "");
3179 
3180 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
3181 	mutex_exit(&hal->topology_tree_mutex);
3182 	ndi_devi_exit(hal->halinfo.dip, 0);
3183 
3184 	TNF_PROBE_0_DEBUG(s1394_unlock_tree_exit, S1394_TNF_SL_HOTPLUG_STACK,
3185 	    "");
3186 }
3187 
3188 /*
3189  * s1394_calc_next_quad()
3190  *    figures out the next quadlet to read. This maintains a stack of
3191  *    directories in the node. When the first quad of a directory (the
3192  *    first directory would be the root directory) is read, it is pushed on
3193  *    the this stack. When the directory is all read, it scans the directory
3194  *    looking for indirect entries. If any indirect directory entry is found,
3195  *    it is pushed on stack and that directory is read. If we are done dealing
3196  *    with all entries in the current dir, the directory is popped off the
3197  *    stack. If the stack is empty, we are back at the root directory level
3198  *    and essentially read the entire directory hierarchy.
3199  *    Returns 0 is more quads to read, else returns non-zero.
3200  */
3201 static int
3202 s1394_calc_next_quad(s1394_hal_t *hal, s1394_node_t *node, uint32_t quadlet,
3203     uint32_t *nextquadp)
3204 {
3205 	uint32_t data, type, key, value, *ptr;
3206 
3207 	ASSERT(MUTEX_HELD(&hal->topology_tree_mutex));
3208 
3209 	TNF_PROBE_4_DEBUG(s1394_calc_next_quad_enter,
3210 	    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_uint, node_num, node->node_num,
3211 	    tnf_uint, quadlet, quadlet, tnf_int, cfgrom_size, node->cfgrom_size,
3212 	    tnf_uint, hal_gen, hal->generation_count);
3213 
3214 	if (((quadlet + 1) >= node->cfgrom_size) ||
3215 	    (CFGROM_SIZE_IS_CRCSIZE(node) == B_TRUE && (quadlet + 1) >=
3216 		node->cfgrom_valid_size)) {
3217 		TNF_PROBE_0_DEBUG(s1394_calc_next_quad_exit,
3218 		    S1394_TNF_SL_HOTPLUG_STACK, "");
3219 		return (1);
3220 	}
3221 
3222 	if (s1394_turn_off_dir_stack != 0 || CFGROM_DIR_STACK_OFF(node) ==
3223 	    B_TRUE) {
3224 		quadlet++;
3225 		*nextquadp = quadlet;
3226 		TNF_PROBE_3_DEBUG(s1394_calc_next_quad_exit,
3227 		    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string, msg,
3228 		    "dir stack turned off", tnf_uint, quadlet, quadlet,
3229 		    tnf_opaque, cfgrom, node->cfgrom);
3230 		return (0);
3231 	}
3232 
3233 	data = node->cfgrom[quadlet];
3234 
3235 	if (quadlet == IEEE1212_ROOT_DIR_QUAD) {
3236 		node->dir_stack_top = -1;
3237 		node->expected_dir_quad = quadlet;
3238 		node->expected_type = IEEE1212_IMMEDIATE_TYPE;
3239 	}
3240 
3241 	CFGROM_TYPE_KEY_VALUE(data, type, key, value);
3242 
3243 	/*
3244 	 * check to make sure we are looking at a dir. If the config rom
3245 	 * is broken, then revert to normal scanning of the config rom
3246 	 */
3247 	if (node->expected_dir_quad == quadlet) {
3248 		if (type != 0 || key != 0) {
3249 			TNF_PROBE_3_DEBUG(s1394_calc_next_quad,
3250 			    S1394_TNF_SL_HOTPLUG_ERROR, "", tnf_string, msg,
3251 			    "bad directory turning off stack", tnf_uint,
3252 			    quadlet, quadlet, tnf_uint, data, data);
3253 			SET_CFGROM_DIR_STACK_OFF(node);
3254 			quadlet = IEEE1212_ROOT_DIR_QUAD;
3255 		} else {
3256 			node->cur_dir_start = quadlet;
3257 			node->cur_dir_size = IEEE1212_DIR_LEN(data);
3258 			node->expected_dir_quad = 0;
3259 			/* get the next quad */
3260 			quadlet++;
3261 		}
3262 	} else {
3263 		/*
3264 		 * If we read all quads in cur dir and the cur dir is not
3265 		 * a leaf, scan for offsets (if the directory's CRC checks
3266 		 * out OK). If we have a directory or a leaf, we save the
3267 		 * current location on the stack and start reading that
3268 		 * directory. So, we will end up with a depth first read of
3269 		 * the entire config rom. If we are done with the current
3270 		 * directory, pop it off the stack and continue the scanning
3271 		 * as appropriate.
3272 		 */
3273 		if (quadlet == node->cur_dir_start + node->cur_dir_size) {
3274 
3275 			int i, top;
3276 			boolean_t done_with_cur_dir = B_FALSE;
3277 
3278 			if (node->expected_type == IEEE1212_LEAF_TYPE) {
3279 				node->expected_type = IEEE1212_IMMEDIATE_TYPE;
3280 				done_with_cur_dir = B_TRUE;
3281 				TNF_PROBE_2_DEBUG(s1394_calc_next_quad,
3282 				    S1394_TNF_SL_HOTPLUG_STACK, "",
3283 				    tnf_string, msg, "done with a leaf",
3284 				    tnf_uint, quadlet, quadlet);
3285 				goto donewithcurdir;
3286 			}
3287 
3288 			ptr = &node->cfgrom[node->cur_dir_start];
3289 			CFGROM_TYPE_KEY_VALUE(*ptr, type, key, value);
3290 
3291 			/*
3292 			 * If CRC for this directory is invalid, turn off
3293 			 * dir stack and start re-reading from root dir.
3294 			 * This wastes the work done thus far, but CRC
3295 			 * errors in directories should be rather rare.
3296 			 * if s1394_crcsz_is_cfgsz is set, then set
3297 			 * cfgrom_valid_size to the len specfied as crc len
3298 			 * in quadlet 0.
3299 			 */
3300 			if (s1394_valid_dir(hal, node, key, ptr) == B_FALSE) {
3301 				SET_CFGROM_DIR_STACK_OFF(node);
3302 				if (s1394_crcsz_is_cfgsz != 0) {
3303 					SET_CFGROM_SIZE_IS_CRCSIZE(node);
3304 					node->cfgrom_valid_size =
3305 					    ((node->cfgrom[0] >>
3306 					    IEEE1394_CFG_ROM_CRC_LEN_SHIFT) &
3307 					    IEEE1394_CFG_ROM_CRC_LEN_MASK);
3308 					TNF_PROBE_2(s1394_calc_next_quad,
3309 					    S1394_TNF_SL_HOTPLUG_ERROR, "",
3310 					    tnf_string, msg, "crc sz is cfg sz",
3311 					    tnf_uint, size,
3312 					    node->cfgrom_valid_size);
3313 				}
3314 				TNF_PROBE_2_DEBUG(s1394_calc_next_quad_exit,
3315 				    S1394_TNF_SL_HOTPLUG_STACK, "", tnf_string,
3316 				    msg, "crc error", tnf_uint, quadlet,
3317 				    quadlet);
3318 				*nextquadp = IEEE1212_ROOT_DIR_QUAD;
3319 				return (0);
3320 			}
3321 			i = node->cur_dir_start + 1;
3322 		rescan:
3323 			for (done_with_cur_dir = B_FALSE; i <=
3324 			    node->cur_dir_start + node->cur_dir_size; i++) {
3325 				data = node->cfgrom[i];
3326 				CFGROM_TYPE_KEY_VALUE(data, type, key, value);
3327 				/* read leaf type and directory types only */
3328 				if (type == IEEE1212_LEAF_TYPE || type ==
3329 				    IEEE1212_DIRECTORY_TYPE) {
3330 
3331 					/*
3332 					 * push current dir on stack; if the
3333 					 * stack is overflowing, ie, too many
3334 					 * directory level nestings, turn off
3335 					 * dir stack and fall back to serial
3336 					 * scanning, starting at root dir. This
3337 					 * wastes all the work we have done
3338 					 * thus far, but more than 16 levels
3339 					 * of directories is rather odd...
3340 					 */
3341 					top = ++node->dir_stack_top;
3342 					if (top == S1394_DIR_STACK_SIZE) {
3343 
3344 						TNF_PROBE_2_DEBUG(
3345 						    s1394_calc_next_quad_exit,
3346 						    S1394_TNF_SL_HOTPLUG_STACK,
3347 						    "", tnf_string, msg,
3348 						    "dir stack overflow",
3349 						    tnf_uint, quadlet, quadlet);
3350 						SET_CFGROM_DIR_STACK_OFF(node);
3351 						*nextquadp =
3352 						    IEEE1212_ROOT_DIR_QUAD;
3353 						return (0);
3354 					}
3355 
3356 					TNF_PROBE_3_DEBUG(
3357 					    s1394_calc_next_quad,
3358 					    S1394_TNF_SL_HOTPLUG_STACK, "",
3359 					    tnf_string, msg, "push dir stack",
3360 					    tnf_uint, quadlet, quadlet,
3361 					    tnf_int, top, top);
3362 
3363 					node->dir_stack[top].dir_start =
3364 					    node->cur_dir_start;
3365 					node->dir_stack[top].dir_size =
3366 					    node->cur_dir_size;
3367 					node->dir_stack[top].dir_next_quad =
3368 					    i + 1;
3369 					/* and set the next quadlet to read */
3370 					quadlet = i + value;
3371 					node->expected_dir_quad = quadlet;
3372 					node->expected_type = type;
3373 					break;
3374 				}
3375 			}
3376 
3377 		donewithcurdir:
3378 
3379 			if ((i > node->cur_dir_start + node->cur_dir_size) ||
3380 				done_with_cur_dir == B_TRUE) {
3381 
3382 				/*
3383 				 * all done with cur dir; pop it off the stack
3384 				 */
3385 				if (node->dir_stack_top >= 0) {
3386 					TNF_PROBE_3_DEBUG(
3387 					    s1394_calc_next_quad_exit,
3388 					    S1394_TNF_SL_HOTPLUG_STACK, "",
3389 					    tnf_string, msg, "pop dir stack",
3390 					    tnf_uint, quadlet, quadlet,
3391 					    tnf_int, top, node->dir_stack_top);
3392 					top = node->dir_stack_top--;
3393 					node->cur_dir_start =
3394 					    node->dir_stack[top].dir_start;
3395 					node->cur_dir_size =
3396 					    node->dir_stack[top].dir_size;
3397 					i = node->dir_stack[top].dir_next_quad;
3398 					goto rescan;
3399 				} else {
3400 					/*
3401 					 * if empty stack, we are at the top
3402 					 * level; declare done.
3403 					 */
3404 					TNF_PROBE_1_DEBUG(
3405 					    s1394_calc_next_quad_exit,
3406 					    S1394_TNF_SL_HOTPLUG_STACK, "",
3407 					    tnf_string, msg, "all done");
3408 					return (1);
3409 				}
3410 			}
3411 		} else {
3412 			/* get the next quadlet */
3413 			quadlet++;
3414 		}
3415 	}
3416 	*nextquadp = quadlet;
3417 
3418 	TNF_PROBE_1_DEBUG(s1394_calc_next_quad_exit, S1394_TNF_SL_HOTPLUG_STACK,
3419 	    "", tnf_uint, next_quad, quadlet);
3420 
3421 	return (0);
3422 }
3423