fw-card.c 17.9 KB
Newer Older
1 2
/*
 * Copyright (C) 2005-2007  Kristian Hoegsberg <krh@bitplanet.net>
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software Foundation,
 * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 */

19 20
#include <linux/completion.h>
#include <linux/crc-itu-t.h>
21
#include <linux/delay.h>
22
#include <linux/device.h>
23 24 25
#include <linux/errno.h>
#include <linux/kref.h>
#include <linux/module.h>
26
#include <linux/mutex.h>
27

28 29
#include "fw-transaction.h"
#include "fw-topology.h"
30
#include "fw-device.h"
31

32
int fw_compute_block_crc(u32 *block)
33
{
34 35 36 37 38 39 40
	__be32 be32_block[256];
	int i, length;

	length = (*block >> 16) & 0xff;
	for (i = 0; i < length; i++)
		be32_block[i] = cpu_to_be32(block[i + 1]);
	*block |= crc_itu_t(0, (u8 *) be32_block, length * 4);
41

42
	return length;
43 44
}

45
static DEFINE_MUTEX(card_mutex);
46 47 48 49 50
static LIST_HEAD(card_list);

static LIST_HEAD(descriptor_list);
static int descriptor_count;

51 52 53 54 55 56 57 58 59 60 61 62 63 64
#define BIB_CRC(v)		((v) <<  0)
#define BIB_CRC_LENGTH(v)	((v) << 16)
#define BIB_INFO_LENGTH(v)	((v) << 24)

#define BIB_LINK_SPEED(v)	((v) <<  0)
#define BIB_GENERATION(v)	((v) <<  4)
#define BIB_MAX_ROM(v)		((v) <<  8)
#define BIB_MAX_RECEIVE(v)	((v) << 12)
#define BIB_CYC_CLK_ACC(v)	((v) << 16)
#define BIB_PMC			((1) << 27)
#define BIB_BMC			((1) << 28)
#define BIB_ISC			((1) << 29)
#define BIB_CMC			((1) << 30)
#define BIB_IMC			((1) << 31)
65

66
static u32 *generate_config_rom(struct fw_card *card, size_t *config_rom_length)
67 68 69 70 71
{
	struct fw_descriptor *desc;
	static u32 config_rom[256];
	int i, j, length;

72 73
	/*
	 * Initialize contents of config rom buffer.  On the OHCI
74 75 76
	 * controller, block reads to the config rom accesses the host
	 * memory, but quadlet read access the hardware bus info block
	 * registers.  That's just crack, but it means we should make
J
Jay Fenlason 已提交
77
	 * sure the contents of bus info block in host memory matches
78 79
	 * the version stored in the OHCI registers.
	 */
80

81
	memset(config_rom, 0, sizeof(config_rom));
82
	config_rom[0] = BIB_CRC_LENGTH(4) | BIB_INFO_LENGTH(4) | BIB_CRC(0);
83 84 85
	config_rom[1] = 0x31333934;

	config_rom[2] =
86 87 88 89 90
		BIB_LINK_SPEED(card->link_speed) |
		BIB_GENERATION(card->config_rom_generation++ % 14 + 2) |
		BIB_MAX_ROM(2) |
		BIB_MAX_RECEIVE(card->max_receive) |
		BIB_BMC | BIB_ISC | BIB_CMC | BIB_IMC;
91 92 93 94 95 96 97 98 99 100 101
	config_rom[3] = card->guid >> 32;
	config_rom[4] = card->guid;

	/* Generate root directory. */
	i = 5;
	config_rom[i++] = 0;
	config_rom[i++] = 0x0c0083c0; /* node capabilities */
	j = i + descriptor_count;

	/* Generate root directory entries for descriptors. */
	list_for_each_entry (desc, &descriptor_list, link) {
102 103
		if (desc->immediate > 0)
			config_rom[i++] = desc->immediate;
104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121
		config_rom[i] = desc->key | (j - i);
		i++;
		j += desc->length;
	}

	/* Update root directory length. */
	config_rom[5] = (i - 5 - 1) << 16;

	/* End of root directory, now copy in descriptors. */
	list_for_each_entry (desc, &descriptor_list, link) {
		memcpy(&config_rom[i], desc->data, desc->length * 4);
		i += desc->length;
	}

	/* Calculate CRCs for all blocks in the config rom.  This
	 * assumes that CRC length and info length are identical for
	 * the bus info block, which is always the case for this
	 * implementation. */
122 123
	for (i = 0; i < j; i += length + 1)
		length = fw_compute_block_crc(config_rom + i);
124 125 126 127 128 129

	*config_rom_length = j;

	return config_rom;
}

130
static void update_config_roms(void)
131 132 133 134 135 136 137 138 139 140 141
{
	struct fw_card *card;
	u32 *config_rom;
	size_t length;

	list_for_each_entry (card, &card_list, link) {
		config_rom = generate_config_rom(card, &length);
		card->driver->set_config_rom(card, config_rom, length);
	}
}

142
int fw_core_add_descriptor(struct fw_descriptor *desc)
143 144 145
{
	size_t i;

146 147
	/*
	 * Check descriptor is valid; the length of all blocks in the
148
	 * descriptor has to add up to exactly the length of the
149 150
	 * block.
	 */
151 152 153 154 155
	i = 0;
	while (i < desc->length)
		i += (desc->data[i] >> 16) + 1;

	if (i != desc->length)
156
		return -EINVAL;
157

158
	mutex_lock(&card_mutex);
159

160
	list_add_tail(&desc->link, &descriptor_list);
161
	descriptor_count++;
162 163
	if (desc->immediate > 0)
		descriptor_count++;
164 165
	update_config_roms();

166
	mutex_unlock(&card_mutex);
167 168 169 170

	return 0;
}

171
void fw_core_remove_descriptor(struct fw_descriptor *desc)
172
{
173
	mutex_lock(&card_mutex);
174 175 176

	list_del(&desc->link);
	descriptor_count--;
177 178
	if (desc->immediate > 0)
		descriptor_count--;
179 180
	update_config_roms();

181
	mutex_unlock(&card_mutex);
182 183
}

184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324
/* ------------------------------------------------------------------ */
/* Code to handle 1394a broadcast channel */

#define THIRTY_TWO_CHANNELS (0xFFFFFFFFU)
#define IRM_RETRIES 2

/*
 * The abi is set by device_for_each_child(), even though we have no use
 * for data, nor do we have a meaningful return value.
 */
int fw_irm_set_broadcast_channel_register(struct device *dev, void *data)
{
	struct fw_device *d;
	int rcode;
	int node_id;
	int max_speed;
	int retries;
	int generation;
	__be32 regval;
	struct fw_card *card;

	d = fw_device(dev);
	/* FIXME: do we need locking here? */
	generation = d->generation;
	smp_rmb(); /* Ensure generation is at least as old as node_id */
	node_id = d->node_id;
	max_speed = d->max_speed;
	retries = IRM_RETRIES;
	card = d->card;
tryagain_r:
	rcode = fw_run_transaction(card, TCODE_READ_QUADLET_REQUEST,
				   node_id, generation, max_speed,
				   CSR_REGISTER_BASE + CSR_BROADCAST_CHANNEL,
				   &regval, 4);
	switch (rcode) {
	case RCODE_BUSY:
		if (retries--)
			goto tryagain_r;
		fw_notify("node %x read broadcast channel busy\n",
			  node_id);
		return 0;

	default:
		fw_notify("node %x read broadcast channel failed %x\n",
			  node_id, rcode);
		return 0;

	case RCODE_COMPLETE:
		/*
		 * Paranoid reporting of nonstandard broadcast channel
		 * contents goes here
		 */
		if (regval != cpu_to_be32(BROADCAST_CHANNEL_INITIAL))
			return 0;
		break;
	}
	retries = IRM_RETRIES;
	regval = cpu_to_be32(BROADCAST_CHANNEL_INITIAL |
			     BROADCAST_CHANNEL_VALID);
tryagain_w:
	rcode = fw_run_transaction(card,
			TCODE_WRITE_QUADLET_REQUEST, node_id,
			generation, max_speed,
			CSR_REGISTER_BASE + CSR_BROADCAST_CHANNEL,
			&regval, 4);
	switch (rcode) {
	case RCODE_BUSY:
		if (retries--)
			goto tryagain_w;
		fw_notify("node %x write broadcast channel busy\n",
			  node_id);
		return 0;

	default:
		fw_notify("node %x write broadcast channel failed %x\n",
			  node_id, rcode);
		return 0;

	case RCODE_COMPLETE:
		return 0;
	}
	return 0;
}

static void
irm_allocate_broadcast(struct fw_device *irm_dev, struct device *locald)
{
	u32 generation;
	u32 node_id;
	u32 max_speed;
	u32 retries;
	__be32 old_data;
	__be32 lock_data[2];
	int rcode;

	/*
	 * The device we are updating is the IRM, so we must do
	 * some extra work.
	 */
	retries = IRM_RETRIES;
	generation = irm_dev->generation;
	/* FIXME: do we need locking here? */
	smp_rmb();
	node_id = irm_dev->node_id;
	max_speed = irm_dev->max_speed;

	lock_data[0] = cpu_to_be32(THIRTY_TWO_CHANNELS);
	lock_data[1] = cpu_to_be32(THIRTY_TWO_CHANNELS & ~1);
tryagain:
	old_data = lock_data[0];
	rcode = fw_run_transaction(irm_dev->card, TCODE_LOCK_COMPARE_SWAP,
				   node_id, generation, max_speed,
				   CSR_REGISTER_BASE+CSR_CHANNELS_AVAILABLE_HI,
				   &lock_data[0], 8);
	switch (rcode) {
	case RCODE_BUSY:
		if (retries--)
			goto tryagain;
		/* fallthrough */
	default:
		fw_error("node %x: allocate broadcast channel failed (%x)\n",
			 node_id, rcode);
		return;

	case RCODE_COMPLETE:
		if (lock_data[0] == old_data)
			break;
		if (retries--) {
			lock_data[1] = cpu_to_be32(be32_to_cpu(lock_data[0])&~1);
			goto tryagain;
		}
		fw_error("node %x: allocate broadcast channel failed: too many"
			 " retries\n", node_id);
		return;
	}
	irm_dev->card->is_irm = true;
	device_for_each_child(locald, NULL, fw_irm_set_broadcast_channel_register);
}
/* ------------------------------------------------------------------ */


325 326 327 328
static const char gap_count_table[] = {
	63, 5, 7, 8, 10, 13, 16, 18, 21, 24, 26, 29, 32, 35, 37, 40
};

329
void fw_schedule_bm_work(struct fw_card *card, unsigned long delay)
330 331 332 333 334 335 336 337 338
{
	int scheduled;

	fw_card_get(card);
	scheduled = schedule_delayed_work(&card->work, delay);
	if (!scheduled)
		fw_card_put(card);
}

339
static void fw_card_bm_work(struct work_struct *work)
340
{
341
	struct fw_card *card = container_of(work, struct fw_card, work.work);
342 343
	struct fw_device *root_device, *irm_device, *local_device;
	struct fw_node *root_node, *local_node, *irm_node;
344
	unsigned long flags;
J
Jay Fenlason 已提交
345
	int root_id, new_root_id, irm_id, gap_count, generation, grace, rcode;
346
	bool do_reset = false;
347 348
	bool root_device_is_running;
	bool root_device_is_cmc;
J
Jay Fenlason 已提交
349
	__be32 lock_data[2];
350 351

	spin_lock_irqsave(&card->lock, flags);
352
	card->is_irm = false;
353 354
	local_node = card->local_node;
	root_node  = card->root_node;
355
	irm_node = card->irm_node;
356 357 358

	if (local_node == NULL) {
		spin_unlock_irqrestore(&card->lock, flags);
359
		goto out_put_card;
360 361 362
	}
	fw_node_get(local_node);
	fw_node_get(root_node);
363
	fw_node_get(irm_node);
364 365

	generation = card->generation;
366
	root_device = root_node->data;
367 368 369
	root_device_is_running = root_device &&
			atomic_read(&root_device->state) == FW_DEVICE_RUNNING;
	root_device_is_cmc = root_device && root_device->cmc;
370
	root_id = root_node->node_id;
371
	grace = time_after(jiffies, card->reset_jiffies + DIV_ROUND_UP(HZ, 10));
372 373
	irm_device = irm_node->data;
	local_device = local_node->data;
374
	if (is_next_generation(generation, card->bm_generation) ||
375
	    (card->bm_generation != generation && grace)) {
376 377
		/*
		 * This first step is to figure out who is IRM and
378 379 380 381 382 383 384
		 * then try to become bus manager.  If the IRM is not
		 * well defined (e.g. does not have an active link
		 * layer or does not responds to our lock request, we
		 * will have to do a little vigilante bus management.
		 * In that case, we do a goto into the gap count logic
		 * so that when we do the reset, we still optimize the
		 * gap count.  That could well save a reset in the
385 386
		 * next generation.
		 */
387

388 389
		irm_id = irm_node->node_id;
		if (!irm_node->link_on) {
390
			new_root_id = local_node->node_id;
391 392 393 394 395
			fw_notify("IRM has link off, making local node (%02x) root.\n",
				  new_root_id);
			goto pick_me;
		}

J
Jay Fenlason 已提交
396 397
		lock_data[0] = cpu_to_be32(0x3f);
		lock_data[1] = cpu_to_be32(local_node->node_id);
398 399 400

		spin_unlock_irqrestore(&card->lock, flags);

J
Jay Fenlason 已提交
401 402 403 404
		rcode = fw_run_transaction(card, TCODE_LOCK_COMPARE_SWAP,
				irm_id, generation, SCODE_100,
				CSR_REGISTER_BASE + CSR_BUS_MANAGER_ID,
				lock_data, sizeof(lock_data));
405

J
Jay Fenlason 已提交
406 407
		if (rcode == RCODE_GENERATION)
			/* Another bus reset, BM work has been rescheduled. */
408
			goto out;
409

J
Jay Fenlason 已提交
410
		if (rcode == RCODE_COMPLETE &&
411
		    lock_data[0] != cpu_to_be32(0x3f)) {
412
			/* Somebody else is BM, let them do the work. */
413 414 415 416 417
			if (irm_id == local_node->node_id) {
				/* But we are IRM, so do irm-y things */
				irm_allocate_broadcast(irm_device,
						       card->device);
			}
418
			goto out;
419
		}
420 421

		spin_lock_irqsave(&card->lock, flags);
J
Jay Fenlason 已提交
422 423

		if (rcode != RCODE_COMPLETE) {
424 425
			/*
			 * The lock request failed, maybe the IRM
426 427
			 * isn't really IRM capable after all. Let's
			 * do a bus reset and pick the local node as
428 429
			 * root, and thus, IRM.
			 */
430
			new_root_id = local_node->node_id;
431 432 433 434 435
			fw_notify("BM lock failed, making local node (%02x) root.\n",
				  new_root_id);
			goto pick_me;
		}
	} else if (card->bm_generation != generation) {
436 437
		/*
		 * OK, we weren't BM in the last generation, and it's
438
		 * less than 100ms since last bus reset. Reschedule
439 440
		 * this task 100ms from now.
		 */
441
		spin_unlock_irqrestore(&card->lock, flags);
442
		fw_schedule_bm_work(card, DIV_ROUND_UP(HZ, 10));
443
		goto out;
444 445
	}

446 447
	/*
	 * We're bus manager for this generation, so next step is to
448
	 * make sure we have an active cycle master and do gap count
449 450
	 * optimization.
	 */
451
	card->bm_generation = generation;
452

453
	if (root_device == NULL) {
454 455 456 457
		/*
		 * Either link_on is false, or we failed to read the
		 * config rom.  In either case, pick another root.
		 */
458
		new_root_id = local_node->node_id;
459
	} else if (!root_device_is_running) {
460 461 462 463
		/*
		 * If we haven't probed this device yet, bail out now
		 * and let's try again once that's done.
		 */
464
		spin_unlock_irqrestore(&card->lock, flags);
465
		goto out;
466
	} else if (root_device_is_cmc) {
467 468
		/*
		 * FIXME: I suppose we should set the cmstr bit in the
469 470
		 * STATE_CLEAR register of this node, as described in
		 * 1394-1995, 8.4.2.6.  Also, send out a force root
471 472
		 * packet for this node.
		 */
473
		new_root_id = root_id;
474
	} else {
475 476
		/*
		 * Current root has an active link layer and we
477
		 * successfully read the config rom, but it's not
478 479
		 * cycle master capable.
		 */
480
		new_root_id = local_node->node_id;
481 482
	}

483
 pick_me:
484 485 486 487 488
	/*
	 * Pick a gap count from 1394a table E-1.  The table doesn't cover
	 * the typically much larger 1394b beta repeater delays though.
	 */
	if (!card->beta_repeaters_present &&
489 490
	    root_node->max_hops < ARRAY_SIZE(gap_count_table))
		gap_count = gap_count_table[root_node->max_hops];
491 492 493
	else
		gap_count = 63;

494
	/*
495 496
	 * Finally, figure out if we should do a reset or not.  If we have
	 * done less than 5 resets with the same physical topology and we
497 498
	 * have either a new root or a new gap count setting, let's do it.
	 */
499

500 501
	if (card->bm_retries++ < 5 &&
	    (card->gap_count != gap_count || new_root_id != root_id))
502
		do_reset = true;
503 504 505

	spin_unlock_irqrestore(&card->lock, flags);

506 507
	if (do_reset) {
		fw_notify("phy config: card %d, new root=%x, gap_count=%d\n",
508 509
			  card->index, new_root_id, gap_count);
		fw_send_phy_config(card, new_root_id, generation, gap_count);
510
		fw_core_initiate_bus_reset(card, 1);
511 512 513 514 515 516 517
	} else if (irm_node->node_id == local_node->node_id) {
		/*
		 * We are IRM, so do irm-y things.
		 * There's no reason to do this if we're doing a reset. . .
		 * We'll be back.
		 */
		irm_allocate_broadcast(irm_device, card->device);
518
	}
519

520 521 522
 out:
	fw_node_put(root_node);
	fw_node_put(local_node);
523
	fw_node_put(irm_node);
524 525
 out_put_card:
	fw_card_put(card);
526 527
}

528
static void flush_timer_callback(unsigned long data)
529 530 531 532 533 534
{
	struct fw_card *card = (struct fw_card *)data;

	fw_flush_transactions(card);
}

535 536 537
void fw_card_initialize(struct fw_card *card,
			const struct fw_card_driver *driver,
			struct device *device)
538
{
539
	static atomic_t index = ATOMIC_INIT(-1);
540

541
	card->index = atomic_inc_return(&index);
542
	card->driver = driver;
543
	card->device = device;
544 545
	card->current_tlabel = 0;
	card->tlabel_mask = 0;
546
	card->color = 0;
547
	card->broadcast_channel = BROADCAST_CHANNEL_INITIAL;
548

549 550
	kref_init(&card->kref);
	init_completion(&card->done);
551
	INIT_LIST_HEAD(&card->transaction_list);
552 553 554 555 556 557
	spin_lock_init(&card->lock);
	setup_timer(&card->flush_timer,
		    flush_timer_callback, (unsigned long)card);

	card->local_node = NULL;

558
	INIT_DELAYED_WORK(&card->work, fw_card_bm_work);
559 560 561
}
EXPORT_SYMBOL(fw_card_initialize);

562 563
int fw_card_add(struct fw_card *card,
		u32 max_receive, u32 link_speed, u64 guid)
564 565 566
{
	u32 *config_rom;
	size_t length;
567
	int ret;
568 569 570 571 572

	card->max_receive = max_receive;
	card->link_speed = link_speed;
	card->guid = guid;

573
	mutex_lock(&card_mutex);
574
	config_rom = generate_config_rom(card, &length);
575
	list_add_tail(&card->link, &card_list);
576
	mutex_unlock(&card_mutex);
577

578 579
	ret = card->driver->enable(card, config_rom, length);
	if (ret < 0) {
580 581 582 583
		mutex_lock(&card_mutex);
		list_del(&card->link);
		mutex_unlock(&card_mutex);
	}
584 585

	return ret;
586 587 588 589
}
EXPORT_SYMBOL(fw_card_add);


590 591
/*
 * The next few functions implements a dummy driver that use once a
592 593 594
 * card driver shuts down an fw_card.  This allows the driver to
 * cleanly unload, as all IO to the card will be handled by the dummy
 * driver instead of calling into the (possibly) unloaded module.  The
595 596
 * dummy driver just fails all IO.
 */
597

598
static int dummy_enable(struct fw_card *card, u32 *config_rom, size_t length)
599 600 601 602 603
{
	BUG();
	return -1;
}

604 605
static int dummy_update_phy_reg(struct fw_card *card, int address,
				int clear_bits, int set_bits)
606 607 608 609
{
	return -ENODEV;
}

610 611
static int dummy_set_config_rom(struct fw_card *card,
				u32 *config_rom, size_t length)
612
{
613 614 615 616
	/*
	 * We take the card out of card_list before setting the dummy
	 * driver, so this should never get called.
	 */
617 618 619 620
	BUG();
	return -1;
}

621
static void dummy_send_request(struct fw_card *card, struct fw_packet *packet)
622
{
623
	packet->callback(packet, card, -ENODEV);
624 625
}

626
static void dummy_send_response(struct fw_card *card, struct fw_packet *packet)
627
{
628
	packet->callback(packet, card, -ENODEV);
629 630
}

631
static int dummy_cancel_packet(struct fw_card *card, struct fw_packet *packet)
632 633 634 635
{
	return -ENOENT;
}

636 637
static int dummy_enable_phys_dma(struct fw_card *card,
				 int node_id, int generation)
638 639 640 641 642 643 644 645
{
	return -ENODEV;
}

static struct fw_card_driver dummy_driver = {
	.enable          = dummy_enable,
	.update_phy_reg  = dummy_update_phy_reg,
	.set_config_rom  = dummy_set_config_rom,
646
	.send_request    = dummy_send_request,
647
	.cancel_packet   = dummy_cancel_packet,
648
	.send_response   = dummy_send_response,
649
	.enable_phys_dma = dummy_enable_phys_dma,
650 651
};

652
void fw_card_release(struct kref *kref)
653 654 655 656 657 658
{
	struct fw_card *card = container_of(kref, struct fw_card, kref);

	complete(&card->done);
}

659
void fw_core_remove_card(struct fw_card *card)
660
{
661 662
	card->driver->update_phy_reg(card, 4,
				     PHY_LINK_ACTIVE | PHY_CONTENDER, 0);
663 664
	fw_core_initiate_bus_reset(card, 1);

665
	mutex_lock(&card_mutex);
666
	list_del_init(&card->link);
667
	mutex_unlock(&card_mutex);
668 669 670 671 672

	/* Set up the dummy driver. */
	card->driver = &dummy_driver;

	fw_destroy_nodes(card);
673 674 675 676

	/* Wait for all users, especially device workqueue jobs, to finish. */
	fw_card_put(card);
	wait_for_completion(&card->done);
677

678
	WARN_ON(!list_empty(&card->transaction_list));
679
	del_timer_sync(&card->flush_timer);
680 681 682
}
EXPORT_SYMBOL(fw_core_remove_card);

683
int fw_core_initiate_bus_reset(struct fw_card *card, int short_reset)
684
{
685 686 687 688
	int reg = short_reset ? 5 : 1;
	int bit = short_reset ? PHY_BUS_SHORT_RESET : PHY_BUS_RESET;

	return card->driver->update_phy_reg(card, reg, 0, bit);
689 690
}
EXPORT_SYMBOL(fw_core_initiate_bus_reset);