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 372
	irm_device = irm_node->data;
	local_device = local_node->data;
373 374 375

	grace = time_after(jiffies, card->reset_jiffies + DIV_ROUND_UP(HZ, 8));

376
	if (is_next_generation(generation, card->bm_generation) ||
377
	    (card->bm_generation != generation && grace)) {
378 379
		/*
		 * This first step is to figure out who is IRM and
380 381 382 383 384 385 386
		 * 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
387 388
		 * next generation.
		 */
389

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

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

		spin_unlock_irqrestore(&card->lock, flags);

J
Jay Fenlason 已提交
403 404 405 406
		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));
407

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

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

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

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

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

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

484
 pick_me:
485 486 487 488 489
	/*
	 * 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 &&
490 491
	    root_node->max_hops < ARRAY_SIZE(gap_count_table))
		gap_count = gap_count_table[root_node->max_hops];
492 493 494
	else
		gap_count = 63;

495
	/*
496 497
	 * 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
498 499
	 * have either a new root or a new gap count setting, let's do it.
	 */
500

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

	spin_unlock_irqrestore(&card->lock, flags);

507 508
	if (do_reset) {
		fw_notify("phy config: card %d, new root=%x, gap_count=%d\n",
509 510
			  card->index, new_root_id, gap_count);
		fw_send_phy_config(card, new_root_id, generation, gap_count);
511
		fw_core_initiate_bus_reset(card, 1);
512 513 514 515 516 517 518
	} 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);
519
	}
520

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

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

	fw_flush_transactions(card);
}

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

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

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

	card->local_node = NULL;

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

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

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

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

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

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


591 592
/*
 * The next few functions implements a dummy driver that use once a
593 594 595
 * 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
596 597
 * dummy driver just fails all IO.
 */
598

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

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

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

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

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

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

637 638
static int dummy_enable_phys_dma(struct fw_card *card,
				 int node_id, int generation)
639 640 641 642 643 644 645 646
{
	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,
647
	.send_request    = dummy_send_request,
648
	.cancel_packet   = dummy_cancel_packet,
649
	.send_response   = dummy_send_response,
650
	.enable_phys_dma = dummy_enable_phys_dma,
651 652
};

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

	complete(&card->done);
}

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

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

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

	fw_destroy_nodes(card);
674 675 676 677

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

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

684
int fw_core_initiate_bus_reset(struct fw_card *card, int short_reset)
685
{
686 687 688 689
	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);
690 691
}
EXPORT_SYMBOL(fw_core_initiate_bus_reset);