Linux Audio

Check our new training course

Embedded Linux training

Mar 31-Apr 8, 2025
Register
Loading...
v3.1
   1/* esp_scsi.c: ESP SCSI driver.
   2 *
   3 * Copyright (C) 2007 David S. Miller (davem@davemloft.net)
   4 */
   5
   6#include <linux/kernel.h>
   7#include <linux/types.h>
   8#include <linux/slab.h>
   9#include <linux/delay.h>
  10#include <linux/list.h>
  11#include <linux/completion.h>
  12#include <linux/kallsyms.h>
  13#include <linux/module.h>
  14#include <linux/moduleparam.h>
  15#include <linux/init.h>
  16#include <linux/irqreturn.h>
  17
  18#include <asm/irq.h>
  19#include <asm/io.h>
  20#include <asm/dma.h>
  21
  22#include <scsi/scsi.h>
  23#include <scsi/scsi_host.h>
  24#include <scsi/scsi_cmnd.h>
  25#include <scsi/scsi_device.h>
  26#include <scsi/scsi_tcq.h>
  27#include <scsi/scsi_dbg.h>
  28#include <scsi/scsi_transport_spi.h>
  29
  30#include "esp_scsi.h"
  31
  32#define DRV_MODULE_NAME		"esp"
  33#define PFX DRV_MODULE_NAME	": "
  34#define DRV_VERSION		"2.000"
  35#define DRV_MODULE_RELDATE	"April 19, 2007"
  36
  37/* SCSI bus reset settle time in seconds.  */
  38static int esp_bus_reset_settle = 3;
  39
  40static u32 esp_debug;
  41#define ESP_DEBUG_INTR		0x00000001
  42#define ESP_DEBUG_SCSICMD	0x00000002
  43#define ESP_DEBUG_RESET		0x00000004
  44#define ESP_DEBUG_MSGIN		0x00000008
  45#define ESP_DEBUG_MSGOUT	0x00000010
  46#define ESP_DEBUG_CMDDONE	0x00000020
  47#define ESP_DEBUG_DISCONNECT	0x00000040
  48#define ESP_DEBUG_DATASTART	0x00000080
  49#define ESP_DEBUG_DATADONE	0x00000100
  50#define ESP_DEBUG_RECONNECT	0x00000200
  51#define ESP_DEBUG_AUTOSENSE	0x00000400
 
 
  52
  53#define esp_log_intr(f, a...) \
  54do {	if (esp_debug & ESP_DEBUG_INTR) \
  55		printk(f, ## a); \
  56} while (0)
  57
  58#define esp_log_reset(f, a...) \
  59do {	if (esp_debug & ESP_DEBUG_RESET) \
  60		printk(f, ## a); \
  61} while (0)
  62
  63#define esp_log_msgin(f, a...) \
  64do {	if (esp_debug & ESP_DEBUG_MSGIN) \
  65		printk(f, ## a); \
  66} while (0)
  67
  68#define esp_log_msgout(f, a...) \
  69do {	if (esp_debug & ESP_DEBUG_MSGOUT) \
  70		printk(f, ## a); \
  71} while (0)
  72
  73#define esp_log_cmddone(f, a...) \
  74do {	if (esp_debug & ESP_DEBUG_CMDDONE) \
  75		printk(f, ## a); \
  76} while (0)
  77
  78#define esp_log_disconnect(f, a...) \
  79do {	if (esp_debug & ESP_DEBUG_DISCONNECT) \
  80		printk(f, ## a); \
  81} while (0)
  82
  83#define esp_log_datastart(f, a...) \
  84do {	if (esp_debug & ESP_DEBUG_DATASTART) \
  85		printk(f, ## a); \
  86} while (0)
  87
  88#define esp_log_datadone(f, a...) \
  89do {	if (esp_debug & ESP_DEBUG_DATADONE) \
  90		printk(f, ## a); \
  91} while (0)
  92
  93#define esp_log_reconnect(f, a...) \
  94do {	if (esp_debug & ESP_DEBUG_RECONNECT) \
  95		printk(f, ## a); \
  96} while (0)
  97
  98#define esp_log_autosense(f, a...) \
  99do {	if (esp_debug & ESP_DEBUG_AUTOSENSE) \
 100		printk(f, ## a); \
 
 
 
 
 
 
 
 
 
 
 101} while (0)
 102
 103#define esp_read8(REG)		esp->ops->esp_read8(esp, REG)
 104#define esp_write8(VAL,REG)	esp->ops->esp_write8(esp, VAL, REG)
 105
 106static void esp_log_fill_regs(struct esp *esp,
 107			      struct esp_event_ent *p)
 108{
 109	p->sreg = esp->sreg;
 110	p->seqreg = esp->seqreg;
 111	p->sreg2 = esp->sreg2;
 112	p->ireg = esp->ireg;
 113	p->select_state = esp->select_state;
 114	p->event = esp->event;
 115}
 116
 117void scsi_esp_cmd(struct esp *esp, u8 val)
 118{
 119	struct esp_event_ent *p;
 120	int idx = esp->esp_event_cur;
 121
 122	p = &esp->esp_event_log[idx];
 123	p->type = ESP_EVENT_TYPE_CMD;
 124	p->val = val;
 125	esp_log_fill_regs(esp, p);
 126
 127	esp->esp_event_cur = (idx + 1) & (ESP_EVENT_LOG_SZ - 1);
 128
 
 129	esp_write8(val, ESP_CMD);
 130}
 131EXPORT_SYMBOL(scsi_esp_cmd);
 132
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 133static void esp_event(struct esp *esp, u8 val)
 134{
 135	struct esp_event_ent *p;
 136	int idx = esp->esp_event_cur;
 137
 138	p = &esp->esp_event_log[idx];
 139	p->type = ESP_EVENT_TYPE_EVENT;
 140	p->val = val;
 141	esp_log_fill_regs(esp, p);
 142
 143	esp->esp_event_cur = (idx + 1) & (ESP_EVENT_LOG_SZ - 1);
 144
 145	esp->event = val;
 146}
 147
 148static void esp_dump_cmd_log(struct esp *esp)
 149{
 150	int idx = esp->esp_event_cur;
 151	int stop = idx;
 152
 153	printk(KERN_INFO PFX "esp%d: Dumping command log\n",
 154	       esp->host->unique_id);
 155	do {
 156		struct esp_event_ent *p = &esp->esp_event_log[idx];
 157
 158		printk(KERN_INFO PFX "esp%d: ent[%d] %s ",
 159		       esp->host->unique_id, idx,
 160		       p->type == ESP_EVENT_TYPE_CMD ? "CMD" : "EVENT");
 161
 162		printk("val[%02x] sreg[%02x] seqreg[%02x] "
 163		       "sreg2[%02x] ireg[%02x] ss[%02x] event[%02x]\n",
 164		       p->val, p->sreg, p->seqreg,
 165		       p->sreg2, p->ireg, p->select_state, p->event);
 166
 167		idx = (idx + 1) & (ESP_EVENT_LOG_SZ - 1);
 168	} while (idx != stop);
 169}
 170
 171static void esp_flush_fifo(struct esp *esp)
 172{
 173	scsi_esp_cmd(esp, ESP_CMD_FLUSH);
 174	if (esp->rev == ESP236) {
 175		int lim = 1000;
 176
 177		while (esp_read8(ESP_FFLAGS) & ESP_FF_FBYTES) {
 178			if (--lim == 0) {
 179				printk(KERN_ALERT PFX "esp%d: ESP_FF_BYTES "
 180				       "will not clear!\n",
 181				       esp->host->unique_id);
 182				break;
 183			}
 184			udelay(1);
 185		}
 186	}
 187}
 188
 189static void hme_read_fifo(struct esp *esp)
 190{
 191	int fcnt = esp_read8(ESP_FFLAGS) & ESP_FF_FBYTES;
 192	int idx = 0;
 193
 194	while (fcnt--) {
 195		esp->fifo[idx++] = esp_read8(ESP_FDATA);
 196		esp->fifo[idx++] = esp_read8(ESP_FDATA);
 197	}
 198	if (esp->sreg2 & ESP_STAT2_F1BYTE) {
 199		esp_write8(0, ESP_FDATA);
 200		esp->fifo[idx++] = esp_read8(ESP_FDATA);
 201		scsi_esp_cmd(esp, ESP_CMD_FLUSH);
 202	}
 203	esp->fifo_cnt = idx;
 204}
 205
 206static void esp_set_all_config3(struct esp *esp, u8 val)
 207{
 208	int i;
 209
 210	for (i = 0; i < ESP_MAX_TARGET; i++)
 211		esp->target[i].esp_config3 = val;
 212}
 213
 214/* Reset the ESP chip, _not_ the SCSI bus. */
 215static void esp_reset_esp(struct esp *esp)
 216{
 217	u8 family_code, version;
 218
 219	/* Now reset the ESP chip */
 220	scsi_esp_cmd(esp, ESP_CMD_RC);
 221	scsi_esp_cmd(esp, ESP_CMD_NULL | ESP_CMD_DMA);
 222	if (esp->rev == FAST)
 223		esp_write8(ESP_CONFIG2_FENAB, ESP_CFG2);
 224	scsi_esp_cmd(esp, ESP_CMD_NULL | ESP_CMD_DMA);
 225
 226	/* This is the only point at which it is reliable to read
 227	 * the ID-code for a fast ESP chip variants.
 228	 */
 229	esp->max_period = ((35 * esp->ccycle) / 1000);
 230	if (esp->rev == FAST) {
 231		version = esp_read8(ESP_UID);
 232		family_code = (version & 0xf8) >> 3;
 233		if (family_code == 0x02)
 234			esp->rev = FAS236;
 235		else if (family_code == 0x0a)
 236			esp->rev = FASHME; /* Version is usually '5'. */
 237		else
 238			esp->rev = FAS100A;
 239		esp->min_period = ((4 * esp->ccycle) / 1000);
 240	} else {
 241		esp->min_period = ((5 * esp->ccycle) / 1000);
 242	}
 
 
 
 
 
 
 
 
 
 
 
 
 
 243	esp->max_period = (esp->max_period + 3)>>2;
 244	esp->min_period = (esp->min_period + 3)>>2;
 245
 246	esp_write8(esp->config1, ESP_CFG1);
 247	switch (esp->rev) {
 248	case ESP100:
 249		/* nothing to do */
 250		break;
 251
 252	case ESP100A:
 253		esp_write8(esp->config2, ESP_CFG2);
 254		break;
 255
 256	case ESP236:
 257		/* Slow 236 */
 258		esp_write8(esp->config2, ESP_CFG2);
 259		esp->prev_cfg3 = esp->target[0].esp_config3;
 260		esp_write8(esp->prev_cfg3, ESP_CFG3);
 261		break;
 262
 263	case FASHME:
 264		esp->config2 |= (ESP_CONFIG2_HME32 | ESP_CONFIG2_HMEFENAB);
 265		/* fallthrough... */
 266
 267	case FAS236:
 268		/* Fast 236 or HME */
 
 269		esp_write8(esp->config2, ESP_CFG2);
 270		if (esp->rev == FASHME) {
 271			u8 cfg3 = esp->target[0].esp_config3;
 272
 273			cfg3 |= ESP_CONFIG3_FCLOCK | ESP_CONFIG3_OBPUSH;
 274			if (esp->scsi_id >= 8)
 275				cfg3 |= ESP_CONFIG3_IDBIT3;
 276			esp_set_all_config3(esp, cfg3);
 277		} else {
 278			u32 cfg3 = esp->target[0].esp_config3;
 279
 280			cfg3 |= ESP_CONFIG3_FCLK;
 281			esp_set_all_config3(esp, cfg3);
 282		}
 283		esp->prev_cfg3 = esp->target[0].esp_config3;
 284		esp_write8(esp->prev_cfg3, ESP_CFG3);
 285		if (esp->rev == FASHME) {
 286			esp->radelay = 80;
 287		} else {
 288			if (esp->flags & ESP_FLAG_DIFFERENTIAL)
 289				esp->radelay = 0;
 290			else
 291				esp->radelay = 96;
 292		}
 293		break;
 294
 295	case FAS100A:
 296		/* Fast 100a */
 297		esp_write8(esp->config2, ESP_CFG2);
 298		esp_set_all_config3(esp,
 299				    (esp->target[0].esp_config3 |
 300				     ESP_CONFIG3_FCLOCK));
 301		esp->prev_cfg3 = esp->target[0].esp_config3;
 302		esp_write8(esp->prev_cfg3, ESP_CFG3);
 303		esp->radelay = 32;
 304		break;
 305
 306	default:
 307		break;
 308	}
 309
 310	/* Reload the configuration registers */
 311	esp_write8(esp->cfact, ESP_CFACT);
 312
 313	esp->prev_stp = 0;
 314	esp_write8(esp->prev_stp, ESP_STP);
 315
 316	esp->prev_soff = 0;
 317	esp_write8(esp->prev_soff, ESP_SOFF);
 318
 319	esp_write8(esp->neg_defp, ESP_TIMEO);
 320
 321	/* Eat any bitrot in the chip */
 322	esp_read8(ESP_INTRPT);
 323	udelay(100);
 324}
 325
 326static void esp_map_dma(struct esp *esp, struct scsi_cmnd *cmd)
 327{
 328	struct esp_cmd_priv *spriv = ESP_CMD_PRIV(cmd);
 329	struct scatterlist *sg = scsi_sglist(cmd);
 330	int dir = cmd->sc_data_direction;
 331	int total, i;
 332
 333	if (dir == DMA_NONE)
 334		return;
 335
 336	spriv->u.num_sg = esp->ops->map_sg(esp, sg, scsi_sg_count(cmd), dir);
 337	spriv->cur_residue = sg_dma_len(sg);
 338	spriv->cur_sg = sg;
 339
 340	total = 0;
 341	for (i = 0; i < spriv->u.num_sg; i++)
 342		total += sg_dma_len(&sg[i]);
 343	spriv->tot_residue = total;
 344}
 345
 346static dma_addr_t esp_cur_dma_addr(struct esp_cmd_entry *ent,
 347				   struct scsi_cmnd *cmd)
 348{
 349	struct esp_cmd_priv *p = ESP_CMD_PRIV(cmd);
 350
 351	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 352		return ent->sense_dma +
 353			(ent->sense_ptr - cmd->sense_buffer);
 354	}
 355
 356	return sg_dma_address(p->cur_sg) +
 357		(sg_dma_len(p->cur_sg) -
 358		 p->cur_residue);
 359}
 360
 361static unsigned int esp_cur_dma_len(struct esp_cmd_entry *ent,
 362				    struct scsi_cmnd *cmd)
 363{
 364	struct esp_cmd_priv *p = ESP_CMD_PRIV(cmd);
 365
 366	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 367		return SCSI_SENSE_BUFFERSIZE -
 368			(ent->sense_ptr - cmd->sense_buffer);
 369	}
 370	return p->cur_residue;
 371}
 372
 373static void esp_advance_dma(struct esp *esp, struct esp_cmd_entry *ent,
 374			    struct scsi_cmnd *cmd, unsigned int len)
 375{
 376	struct esp_cmd_priv *p = ESP_CMD_PRIV(cmd);
 377
 378	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 379		ent->sense_ptr += len;
 380		return;
 381	}
 382
 383	p->cur_residue -= len;
 384	p->tot_residue -= len;
 385	if (p->cur_residue < 0 || p->tot_residue < 0) {
 386		printk(KERN_ERR PFX "esp%d: Data transfer overflow.\n",
 387		       esp->host->unique_id);
 388		printk(KERN_ERR PFX "esp%d: cur_residue[%d] tot_residue[%d] "
 389		       "len[%u]\n",
 390		       esp->host->unique_id,
 391		       p->cur_residue, p->tot_residue, len);
 392		p->cur_residue = 0;
 393		p->tot_residue = 0;
 394	}
 395	if (!p->cur_residue && p->tot_residue) {
 396		p->cur_sg++;
 397		p->cur_residue = sg_dma_len(p->cur_sg);
 398	}
 399}
 400
 401static void esp_unmap_dma(struct esp *esp, struct scsi_cmnd *cmd)
 402{
 403	struct esp_cmd_priv *spriv = ESP_CMD_PRIV(cmd);
 404	int dir = cmd->sc_data_direction;
 405
 406	if (dir == DMA_NONE)
 407		return;
 408
 409	esp->ops->unmap_sg(esp, scsi_sglist(cmd), spriv->u.num_sg, dir);
 410}
 411
 412static void esp_save_pointers(struct esp *esp, struct esp_cmd_entry *ent)
 413{
 414	struct scsi_cmnd *cmd = ent->cmd;
 415	struct esp_cmd_priv *spriv = ESP_CMD_PRIV(cmd);
 416
 417	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 418		ent->saved_sense_ptr = ent->sense_ptr;
 419		return;
 420	}
 421	ent->saved_cur_residue = spriv->cur_residue;
 422	ent->saved_cur_sg = spriv->cur_sg;
 423	ent->saved_tot_residue = spriv->tot_residue;
 424}
 425
 426static void esp_restore_pointers(struct esp *esp, struct esp_cmd_entry *ent)
 427{
 428	struct scsi_cmnd *cmd = ent->cmd;
 429	struct esp_cmd_priv *spriv = ESP_CMD_PRIV(cmd);
 430
 431	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 432		ent->sense_ptr = ent->saved_sense_ptr;
 433		return;
 434	}
 435	spriv->cur_residue = ent->saved_cur_residue;
 436	spriv->cur_sg = ent->saved_cur_sg;
 437	spriv->tot_residue = ent->saved_tot_residue;
 438}
 439
 440static void esp_check_command_len(struct esp *esp, struct scsi_cmnd *cmd)
 441{
 442	if (cmd->cmd_len == 6 ||
 443	    cmd->cmd_len == 10 ||
 444	    cmd->cmd_len == 12) {
 445		esp->flags &= ~ESP_FLAG_DOING_SLOWCMD;
 446	} else {
 447		esp->flags |= ESP_FLAG_DOING_SLOWCMD;
 448	}
 449}
 450
 451static void esp_write_tgt_config3(struct esp *esp, int tgt)
 452{
 453	if (esp->rev > ESP100A) {
 454		u8 val = esp->target[tgt].esp_config3;
 455
 456		if (val != esp->prev_cfg3) {
 457			esp->prev_cfg3 = val;
 458			esp_write8(val, ESP_CFG3);
 459		}
 460	}
 461}
 462
 463static void esp_write_tgt_sync(struct esp *esp, int tgt)
 464{
 465	u8 off = esp->target[tgt].esp_offset;
 466	u8 per = esp->target[tgt].esp_period;
 467
 468	if (off != esp->prev_soff) {
 469		esp->prev_soff = off;
 470		esp_write8(off, ESP_SOFF);
 471	}
 472	if (per != esp->prev_stp) {
 473		esp->prev_stp = per;
 474		esp_write8(per, ESP_STP);
 475	}
 476}
 477
 478static u32 esp_dma_length_limit(struct esp *esp, u32 dma_addr, u32 dma_len)
 479{
 480	if (esp->rev == FASHME) {
 481		/* Arbitrary segment boundaries, 24-bit counts.  */
 482		if (dma_len > (1U << 24))
 483			dma_len = (1U << 24);
 484	} else {
 485		u32 base, end;
 486
 487		/* ESP chip limits other variants by 16-bits of transfer
 488		 * count.  Actually on FAS100A and FAS236 we could get
 489		 * 24-bits of transfer count by enabling ESP_CONFIG2_FENAB
 490		 * in the ESP_CFG2 register but that causes other unwanted
 491		 * changes so we don't use it currently.
 492		 */
 493		if (dma_len > (1U << 16))
 494			dma_len = (1U << 16);
 495
 496		/* All of the DMA variants hooked up to these chips
 497		 * cannot handle crossing a 24-bit address boundary.
 498		 */
 499		base = dma_addr & ((1U << 24) - 1U);
 500		end = base + dma_len;
 501		if (end > (1U << 24))
 502			end = (1U <<24);
 503		dma_len = end - base;
 504	}
 505	return dma_len;
 506}
 507
 508static int esp_need_to_nego_wide(struct esp_target_data *tp)
 509{
 510	struct scsi_target *target = tp->starget;
 511
 512	return spi_width(target) != tp->nego_goal_width;
 513}
 514
 515static int esp_need_to_nego_sync(struct esp_target_data *tp)
 516{
 517	struct scsi_target *target = tp->starget;
 518
 519	/* When offset is zero, period is "don't care".  */
 520	if (!spi_offset(target) && !tp->nego_goal_offset)
 521		return 0;
 522
 523	if (spi_offset(target) == tp->nego_goal_offset &&
 524	    spi_period(target) == tp->nego_goal_period)
 525		return 0;
 526
 527	return 1;
 528}
 529
 530static int esp_alloc_lun_tag(struct esp_cmd_entry *ent,
 531			     struct esp_lun_data *lp)
 532{
 533	if (!ent->tag[0]) {
 534		/* Non-tagged, slot already taken?  */
 535		if (lp->non_tagged_cmd)
 536			return -EBUSY;
 537
 538		if (lp->hold) {
 539			/* We are being held by active tagged
 540			 * commands.
 541			 */
 542			if (lp->num_tagged)
 543				return -EBUSY;
 544
 545			/* Tagged commands completed, we can unplug
 546			 * the queue and run this untagged command.
 547			 */
 548			lp->hold = 0;
 549		} else if (lp->num_tagged) {
 550			/* Plug the queue until num_tagged decreases
 551			 * to zero in esp_free_lun_tag.
 552			 */
 553			lp->hold = 1;
 554			return -EBUSY;
 555		}
 556
 557		lp->non_tagged_cmd = ent;
 558		return 0;
 559	} else {
 560		/* Tagged command, see if blocked by a
 561		 * non-tagged one.
 562		 */
 563		if (lp->non_tagged_cmd || lp->hold)
 564			return -EBUSY;
 565	}
 566
 567	BUG_ON(lp->tagged_cmds[ent->tag[1]]);
 568
 569	lp->tagged_cmds[ent->tag[1]] = ent;
 570	lp->num_tagged++;
 571
 572	return 0;
 573}
 574
 575static void esp_free_lun_tag(struct esp_cmd_entry *ent,
 576			     struct esp_lun_data *lp)
 577{
 578	if (ent->tag[0]) {
 579		BUG_ON(lp->tagged_cmds[ent->tag[1]] != ent);
 580		lp->tagged_cmds[ent->tag[1]] = NULL;
 581		lp->num_tagged--;
 582	} else {
 583		BUG_ON(lp->non_tagged_cmd != ent);
 584		lp->non_tagged_cmd = NULL;
 585	}
 586}
 587
 588/* When a contingent allegiance conditon is created, we force feed a
 589 * REQUEST_SENSE command to the device to fetch the sense data.  I
 590 * tried many other schemes, relying on the scsi error handling layer
 591 * to send out the REQUEST_SENSE automatically, but this was difficult
 592 * to get right especially in the presence of applications like smartd
 593 * which use SG_IO to send out their own REQUEST_SENSE commands.
 594 */
 595static void esp_autosense(struct esp *esp, struct esp_cmd_entry *ent)
 596{
 597	struct scsi_cmnd *cmd = ent->cmd;
 598	struct scsi_device *dev = cmd->device;
 599	int tgt, lun;
 600	u8 *p, val;
 601
 602	tgt = dev->id;
 603	lun = dev->lun;
 604
 605
 606	if (!ent->sense_ptr) {
 607		esp_log_autosense("esp%d: Doing auto-sense for "
 608				  "tgt[%d] lun[%d]\n",
 609				  esp->host->unique_id, tgt, lun);
 610
 611		ent->sense_ptr = cmd->sense_buffer;
 612		ent->sense_dma = esp->ops->map_single(esp,
 613						      ent->sense_ptr,
 614						      SCSI_SENSE_BUFFERSIZE,
 615						      DMA_FROM_DEVICE);
 616	}
 617	ent->saved_sense_ptr = ent->sense_ptr;
 618
 619	esp->active_cmd = ent;
 620
 621	p = esp->command_block;
 622	esp->msg_out_len = 0;
 623
 624	*p++ = IDENTIFY(0, lun);
 625	*p++ = REQUEST_SENSE;
 626	*p++ = ((dev->scsi_level <= SCSI_2) ?
 627		(lun << 5) : 0);
 628	*p++ = 0;
 629	*p++ = 0;
 630	*p++ = SCSI_SENSE_BUFFERSIZE;
 631	*p++ = 0;
 632
 633	esp->select_state = ESP_SELECT_BASIC;
 634
 635	val = tgt;
 636	if (esp->rev == FASHME)
 637		val |= ESP_BUSID_RESELID | ESP_BUSID_CTR32BIT;
 638	esp_write8(val, ESP_BUSID);
 639
 640	esp_write_tgt_sync(esp, tgt);
 641	esp_write_tgt_config3(esp, tgt);
 642
 643	val = (p - esp->command_block);
 644
 645	if (esp->rev == FASHME)
 646		scsi_esp_cmd(esp, ESP_CMD_FLUSH);
 647	esp->ops->send_dma_cmd(esp, esp->command_block_dma,
 648			       val, 16, 0, ESP_CMD_DMA | ESP_CMD_SELA);
 649}
 650
 651static struct esp_cmd_entry *find_and_prep_issuable_command(struct esp *esp)
 652{
 653	struct esp_cmd_entry *ent;
 654
 655	list_for_each_entry(ent, &esp->queued_cmds, list) {
 656		struct scsi_cmnd *cmd = ent->cmd;
 657		struct scsi_device *dev = cmd->device;
 658		struct esp_lun_data *lp = dev->hostdata;
 659
 660		if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 661			ent->tag[0] = 0;
 662			ent->tag[1] = 0;
 663			return ent;
 664		}
 665
 666		if (!scsi_populate_tag_msg(cmd, &ent->tag[0])) {
 667			ent->tag[0] = 0;
 668			ent->tag[1] = 0;
 669		}
 
 
 670
 671		if (esp_alloc_lun_tag(ent, lp) < 0)
 672			continue;
 673
 674		return ent;
 675	}
 676
 677	return NULL;
 678}
 679
 680static void esp_maybe_execute_command(struct esp *esp)
 681{
 682	struct esp_target_data *tp;
 683	struct esp_lun_data *lp;
 684	struct scsi_device *dev;
 685	struct scsi_cmnd *cmd;
 686	struct esp_cmd_entry *ent;
 687	int tgt, lun, i;
 688	u32 val, start_cmd;
 689	u8 *p;
 690
 691	if (esp->active_cmd ||
 692	    (esp->flags & ESP_FLAG_RESETTING))
 693		return;
 694
 695	ent = find_and_prep_issuable_command(esp);
 696	if (!ent)
 697		return;
 698
 699	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 700		esp_autosense(esp, ent);
 701		return;
 702	}
 703
 704	cmd = ent->cmd;
 705	dev = cmd->device;
 706	tgt = dev->id;
 707	lun = dev->lun;
 708	tp = &esp->target[tgt];
 709	lp = dev->hostdata;
 710
 711	list_move(&ent->list, &esp->active_cmds);
 712
 713	esp->active_cmd = ent;
 714
 715	esp_map_dma(esp, cmd);
 716	esp_save_pointers(esp, ent);
 717
 718	esp_check_command_len(esp, cmd);
 719
 720	p = esp->command_block;
 721
 722	esp->msg_out_len = 0;
 723	if (tp->flags & ESP_TGT_CHECK_NEGO) {
 724		/* Need to negotiate.  If the target is broken
 725		 * go for synchronous transfers and non-wide.
 726		 */
 727		if (tp->flags & ESP_TGT_BROKEN) {
 728			tp->flags &= ~ESP_TGT_DISCONNECT;
 729			tp->nego_goal_period = 0;
 730			tp->nego_goal_offset = 0;
 731			tp->nego_goal_width = 0;
 732			tp->nego_goal_tags = 0;
 733		}
 734
 735		/* If the settings are not changing, skip this.  */
 736		if (spi_width(tp->starget) == tp->nego_goal_width &&
 737		    spi_period(tp->starget) == tp->nego_goal_period &&
 738		    spi_offset(tp->starget) == tp->nego_goal_offset) {
 739			tp->flags &= ~ESP_TGT_CHECK_NEGO;
 740			goto build_identify;
 741		}
 742
 743		if (esp->rev == FASHME && esp_need_to_nego_wide(tp)) {
 744			esp->msg_out_len =
 745				spi_populate_width_msg(&esp->msg_out[0],
 746						       (tp->nego_goal_width ?
 747							1 : 0));
 748			tp->flags |= ESP_TGT_NEGO_WIDE;
 749		} else if (esp_need_to_nego_sync(tp)) {
 750			esp->msg_out_len =
 751				spi_populate_sync_msg(&esp->msg_out[0],
 752						      tp->nego_goal_period,
 753						      tp->nego_goal_offset);
 754			tp->flags |= ESP_TGT_NEGO_SYNC;
 755		} else {
 756			tp->flags &= ~ESP_TGT_CHECK_NEGO;
 757		}
 758
 759		/* Process it like a slow command.  */
 760		if (tp->flags & (ESP_TGT_NEGO_WIDE | ESP_TGT_NEGO_SYNC))
 761			esp->flags |= ESP_FLAG_DOING_SLOWCMD;
 762	}
 763
 764build_identify:
 765	/* If we don't have a lun-data struct yet, we're probing
 766	 * so do not disconnect.  Also, do not disconnect unless
 767	 * we have a tag on this command.
 768	 */
 769	if (lp && (tp->flags & ESP_TGT_DISCONNECT) && ent->tag[0])
 770		*p++ = IDENTIFY(1, lun);
 771	else
 772		*p++ = IDENTIFY(0, lun);
 773
 774	if (ent->tag[0] && esp->rev == ESP100) {
 775		/* ESP100 lacks select w/atn3 command, use select
 776		 * and stop instead.
 777		 */
 778		esp->flags |= ESP_FLAG_DOING_SLOWCMD;
 779	}
 780
 781	if (!(esp->flags & ESP_FLAG_DOING_SLOWCMD)) {
 782		start_cmd = ESP_CMD_DMA | ESP_CMD_SELA;
 783		if (ent->tag[0]) {
 784			*p++ = ent->tag[0];
 785			*p++ = ent->tag[1];
 786
 787			start_cmd = ESP_CMD_DMA | ESP_CMD_SA3;
 788		}
 789
 790		for (i = 0; i < cmd->cmd_len; i++)
 791			*p++ = cmd->cmnd[i];
 792
 793		esp->select_state = ESP_SELECT_BASIC;
 794	} else {
 795		esp->cmd_bytes_left = cmd->cmd_len;
 796		esp->cmd_bytes_ptr = &cmd->cmnd[0];
 797
 798		if (ent->tag[0]) {
 799			for (i = esp->msg_out_len - 1;
 800			     i >= 0; i--)
 801				esp->msg_out[i + 2] = esp->msg_out[i];
 802			esp->msg_out[0] = ent->tag[0];
 803			esp->msg_out[1] = ent->tag[1];
 804			esp->msg_out_len += 2;
 805		}
 806
 807		start_cmd = ESP_CMD_DMA | ESP_CMD_SELAS;
 808		esp->select_state = ESP_SELECT_MSGOUT;
 809	}
 810	val = tgt;
 811	if (esp->rev == FASHME)
 812		val |= ESP_BUSID_RESELID | ESP_BUSID_CTR32BIT;
 813	esp_write8(val, ESP_BUSID);
 814
 815	esp_write_tgt_sync(esp, tgt);
 816	esp_write_tgt_config3(esp, tgt);
 817
 818	val = (p - esp->command_block);
 819
 820	if (esp_debug & ESP_DEBUG_SCSICMD) {
 821		printk("ESP: tgt[%d] lun[%d] scsi_cmd [ ", tgt, lun);
 822		for (i = 0; i < cmd->cmd_len; i++)
 823			printk("%02x ", cmd->cmnd[i]);
 824		printk("]\n");
 825	}
 826
 827	if (esp->rev == FASHME)
 828		scsi_esp_cmd(esp, ESP_CMD_FLUSH);
 829	esp->ops->send_dma_cmd(esp, esp->command_block_dma,
 830			       val, 16, 0, start_cmd);
 831}
 832
 833static struct esp_cmd_entry *esp_get_ent(struct esp *esp)
 834{
 835	struct list_head *head = &esp->esp_cmd_pool;
 836	struct esp_cmd_entry *ret;
 837
 838	if (list_empty(head)) {
 839		ret = kzalloc(sizeof(struct esp_cmd_entry), GFP_ATOMIC);
 840	} else {
 841		ret = list_entry(head->next, struct esp_cmd_entry, list);
 842		list_del(&ret->list);
 843		memset(ret, 0, sizeof(*ret));
 844	}
 845	return ret;
 846}
 847
 848static void esp_put_ent(struct esp *esp, struct esp_cmd_entry *ent)
 849{
 850	list_add(&ent->list, &esp->esp_cmd_pool);
 851}
 852
 853static void esp_cmd_is_done(struct esp *esp, struct esp_cmd_entry *ent,
 854			    struct scsi_cmnd *cmd, unsigned int result)
 855{
 856	struct scsi_device *dev = cmd->device;
 857	int tgt = dev->id;
 858	int lun = dev->lun;
 859
 860	esp->active_cmd = NULL;
 861	esp_unmap_dma(esp, cmd);
 862	esp_free_lun_tag(ent, dev->hostdata);
 863	cmd->result = result;
 864
 865	if (ent->eh_done) {
 866		complete(ent->eh_done);
 867		ent->eh_done = NULL;
 868	}
 869
 870	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 871		esp->ops->unmap_single(esp, ent->sense_dma,
 872				       SCSI_SENSE_BUFFERSIZE, DMA_FROM_DEVICE);
 873		ent->sense_ptr = NULL;
 874
 875		/* Restore the message/status bytes to what we actually
 876		 * saw originally.  Also, report that we are providing
 877		 * the sense data.
 878		 */
 879		cmd->result = ((DRIVER_SENSE << 24) |
 880			       (DID_OK << 16) |
 881			       (COMMAND_COMPLETE << 8) |
 882			       (SAM_STAT_CHECK_CONDITION << 0));
 883
 884		ent->flags &= ~ESP_CMD_FLAG_AUTOSENSE;
 885		if (esp_debug & ESP_DEBUG_AUTOSENSE) {
 886			int i;
 887
 888			printk("esp%d: tgt[%d] lun[%d] AUTO SENSE[ ",
 889			       esp->host->unique_id, tgt, lun);
 890			for (i = 0; i < 18; i++)
 891				printk("%02x ", cmd->sense_buffer[i]);
 892			printk("]\n");
 893		}
 894	}
 895
 896	cmd->scsi_done(cmd);
 897
 898	list_del(&ent->list);
 899	esp_put_ent(esp, ent);
 900
 901	esp_maybe_execute_command(esp);
 902}
 903
 904static unsigned int compose_result(unsigned int status, unsigned int message,
 905				   unsigned int driver_code)
 906{
 907	return (status | (message << 8) | (driver_code << 16));
 908}
 909
 910static void esp_event_queue_full(struct esp *esp, struct esp_cmd_entry *ent)
 911{
 912	struct scsi_device *dev = ent->cmd->device;
 913	struct esp_lun_data *lp = dev->hostdata;
 914
 915	scsi_track_queue_full(dev, lp->num_tagged - 1);
 916}
 917
 918static int esp_queuecommand_lck(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *))
 919{
 920	struct scsi_device *dev = cmd->device;
 921	struct esp *esp = shost_priv(dev->host);
 922	struct esp_cmd_priv *spriv;
 923	struct esp_cmd_entry *ent;
 924
 925	ent = esp_get_ent(esp);
 926	if (!ent)
 927		return SCSI_MLQUEUE_HOST_BUSY;
 928
 929	ent->cmd = cmd;
 930
 931	cmd->scsi_done = done;
 932
 933	spriv = ESP_CMD_PRIV(cmd);
 934	spriv->u.dma_addr = ~(dma_addr_t)0x0;
 935
 936	list_add_tail(&ent->list, &esp->queued_cmds);
 937
 938	esp_maybe_execute_command(esp);
 939
 940	return 0;
 941}
 942
 943static DEF_SCSI_QCMD(esp_queuecommand)
 944
 945static int esp_check_gross_error(struct esp *esp)
 946{
 947	if (esp->sreg & ESP_STAT_SPAM) {
 948		/* Gross Error, could be one of:
 949		 * - top of fifo overwritten
 950		 * - top of command register overwritten
 951		 * - DMA programmed with wrong direction
 952		 * - improper phase change
 953		 */
 954		printk(KERN_ERR PFX "esp%d: Gross error sreg[%02x]\n",
 955		       esp->host->unique_id, esp->sreg);
 956		/* XXX Reset the chip. XXX */
 957		return 1;
 958	}
 959	return 0;
 960}
 961
 962static int esp_check_spur_intr(struct esp *esp)
 963{
 964	switch (esp->rev) {
 965	case ESP100:
 966	case ESP100A:
 967		/* The interrupt pending bit of the status register cannot
 968		 * be trusted on these revisions.
 969		 */
 970		esp->sreg &= ~ESP_STAT_INTR;
 971		break;
 972
 973	default:
 974		if (!(esp->sreg & ESP_STAT_INTR)) {
 975			esp->ireg = esp_read8(ESP_INTRPT);
 976			if (esp->ireg & ESP_INTR_SR)
 977				return 1;
 978
 979			/* If the DMA is indicating interrupt pending and the
 980			 * ESP is not, the only possibility is a DMA error.
 981			 */
 982			if (!esp->ops->dma_error(esp)) {
 983				printk(KERN_ERR PFX "esp%d: Spurious irq, "
 984				       "sreg=%02x.\n",
 985				       esp->host->unique_id, esp->sreg);
 986				return -1;
 987			}
 988
 989			printk(KERN_ERR PFX "esp%d: DMA error\n",
 990			       esp->host->unique_id);
 991
 992			/* XXX Reset the chip. XXX */
 993			return -1;
 994		}
 995		break;
 996	}
 997
 998	return 0;
 999}
1000
1001static void esp_schedule_reset(struct esp *esp)
1002{
1003	esp_log_reset("ESP: esp_schedule_reset() from %p\n",
1004		      __builtin_return_address(0));
1005	esp->flags |= ESP_FLAG_RESETTING;
1006	esp_event(esp, ESP_EVENT_RESET);
1007}
1008
1009/* In order to avoid having to add a special half-reconnected state
1010 * into the driver we just sit here and poll through the rest of
1011 * the reselection process to get the tag message bytes.
1012 */
1013static struct esp_cmd_entry *esp_reconnect_with_tag(struct esp *esp,
1014						    struct esp_lun_data *lp)
1015{
1016	struct esp_cmd_entry *ent;
1017	int i;
1018
1019	if (!lp->num_tagged) {
1020		printk(KERN_ERR PFX "esp%d: Reconnect w/num_tagged==0\n",
1021		       esp->host->unique_id);
1022		return NULL;
1023	}
1024
1025	esp_log_reconnect("ESP: reconnect tag, ");
1026
1027	for (i = 0; i < ESP_QUICKIRQ_LIMIT; i++) {
1028		if (esp->ops->irq_pending(esp))
1029			break;
1030	}
1031	if (i == ESP_QUICKIRQ_LIMIT) {
1032		printk(KERN_ERR PFX "esp%d: Reconnect IRQ1 timeout\n",
1033		       esp->host->unique_id);
1034		return NULL;
1035	}
1036
1037	esp->sreg = esp_read8(ESP_STATUS);
1038	esp->ireg = esp_read8(ESP_INTRPT);
1039
1040	esp_log_reconnect("IRQ(%d:%x:%x), ",
1041			  i, esp->ireg, esp->sreg);
1042
1043	if (esp->ireg & ESP_INTR_DC) {
1044		printk(KERN_ERR PFX "esp%d: Reconnect, got disconnect.\n",
1045		       esp->host->unique_id);
1046		return NULL;
1047	}
1048
1049	if ((esp->sreg & ESP_STAT_PMASK) != ESP_MIP) {
1050		printk(KERN_ERR PFX "esp%d: Reconnect, not MIP sreg[%02x].\n",
1051		       esp->host->unique_id, esp->sreg);
1052		return NULL;
1053	}
1054
1055	/* DMA in the tag bytes... */
1056	esp->command_block[0] = 0xff;
1057	esp->command_block[1] = 0xff;
1058	esp->ops->send_dma_cmd(esp, esp->command_block_dma,
1059			       2, 2, 1, ESP_CMD_DMA | ESP_CMD_TI);
1060
1061	/* ACK the message.  */
1062	scsi_esp_cmd(esp, ESP_CMD_MOK);
1063
1064	for (i = 0; i < ESP_RESELECT_TAG_LIMIT; i++) {
1065		if (esp->ops->irq_pending(esp)) {
1066			esp->sreg = esp_read8(ESP_STATUS);
1067			esp->ireg = esp_read8(ESP_INTRPT);
1068			if (esp->ireg & ESP_INTR_FDONE)
1069				break;
1070		}
1071		udelay(1);
1072	}
1073	if (i == ESP_RESELECT_TAG_LIMIT) {
1074		printk(KERN_ERR PFX "esp%d: Reconnect IRQ2 timeout\n",
1075		       esp->host->unique_id);
1076		return NULL;
1077	}
1078	esp->ops->dma_drain(esp);
1079	esp->ops->dma_invalidate(esp);
1080
1081	esp_log_reconnect("IRQ2(%d:%x:%x) tag[%x:%x]\n",
1082			  i, esp->ireg, esp->sreg,
1083			  esp->command_block[0],
1084			  esp->command_block[1]);
1085
1086	if (esp->command_block[0] < SIMPLE_QUEUE_TAG ||
1087	    esp->command_block[0] > ORDERED_QUEUE_TAG) {
1088		printk(KERN_ERR PFX "esp%d: Reconnect, bad tag "
1089		       "type %02x.\n",
1090		       esp->host->unique_id, esp->command_block[0]);
1091		return NULL;
1092	}
1093
1094	ent = lp->tagged_cmds[esp->command_block[1]];
1095	if (!ent) {
1096		printk(KERN_ERR PFX "esp%d: Reconnect, no entry for "
1097		       "tag %02x.\n",
1098		       esp->host->unique_id, esp->command_block[1]);
1099		return NULL;
1100	}
1101
1102	return ent;
1103}
1104
1105static int esp_reconnect(struct esp *esp)
1106{
1107	struct esp_cmd_entry *ent;
1108	struct esp_target_data *tp;
1109	struct esp_lun_data *lp;
1110	struct scsi_device *dev;
1111	int target, lun;
1112
1113	BUG_ON(esp->active_cmd);
1114	if (esp->rev == FASHME) {
1115		/* FASHME puts the target and lun numbers directly
1116		 * into the fifo.
1117		 */
1118		target = esp->fifo[0];
1119		lun = esp->fifo[1] & 0x7;
1120	} else {
1121		u8 bits = esp_read8(ESP_FDATA);
1122
1123		/* Older chips put the lun directly into the fifo, but
1124		 * the target is given as a sample of the arbitration
1125		 * lines on the bus at reselection time.  So we should
1126		 * see the ID of the ESP and the one reconnecting target
1127		 * set in the bitmap.
1128		 */
1129		if (!(bits & esp->scsi_id_mask))
1130			goto do_reset;
1131		bits &= ~esp->scsi_id_mask;
1132		if (!bits || (bits & (bits - 1)))
1133			goto do_reset;
1134
1135		target = ffs(bits) - 1;
1136		lun = (esp_read8(ESP_FDATA) & 0x7);
1137
1138		scsi_esp_cmd(esp, ESP_CMD_FLUSH);
1139		if (esp->rev == ESP100) {
1140			u8 ireg = esp_read8(ESP_INTRPT);
1141			/* This chip has a bug during reselection that can
1142			 * cause a spurious illegal-command interrupt, which
1143			 * we simply ACK here.  Another possibility is a bus
1144			 * reset so we must check for that.
1145			 */
1146			if (ireg & ESP_INTR_SR)
1147				goto do_reset;
1148		}
1149		scsi_esp_cmd(esp, ESP_CMD_NULL);
1150	}
1151
1152	esp_write_tgt_sync(esp, target);
1153	esp_write_tgt_config3(esp, target);
1154
1155	scsi_esp_cmd(esp, ESP_CMD_MOK);
1156
1157	if (esp->rev == FASHME)
1158		esp_write8(target | ESP_BUSID_RESELID | ESP_BUSID_CTR32BIT,
1159			   ESP_BUSID);
1160
1161	tp = &esp->target[target];
1162	dev = __scsi_device_lookup_by_target(tp->starget, lun);
1163	if (!dev) {
1164		printk(KERN_ERR PFX "esp%d: Reconnect, no lp "
1165		       "tgt[%u] lun[%u]\n",
1166		       esp->host->unique_id, target, lun);
1167		goto do_reset;
1168	}
1169	lp = dev->hostdata;
1170
1171	ent = lp->non_tagged_cmd;
1172	if (!ent) {
1173		ent = esp_reconnect_with_tag(esp, lp);
1174		if (!ent)
1175			goto do_reset;
1176	}
1177
1178	esp->active_cmd = ent;
1179
1180	if (ent->flags & ESP_CMD_FLAG_ABORT) {
1181		esp->msg_out[0] = ABORT_TASK_SET;
1182		esp->msg_out_len = 1;
1183		scsi_esp_cmd(esp, ESP_CMD_SATN);
1184	}
1185
1186	esp_event(esp, ESP_EVENT_CHECK_PHASE);
1187	esp_restore_pointers(esp, ent);
1188	esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
1189	return 1;
1190
1191do_reset:
1192	esp_schedule_reset(esp);
1193	return 0;
1194}
1195
1196static int esp_finish_select(struct esp *esp)
1197{
1198	struct esp_cmd_entry *ent;
1199	struct scsi_cmnd *cmd;
1200	u8 orig_select_state;
1201
1202	orig_select_state = esp->select_state;
1203
1204	/* No longer selecting.  */
1205	esp->select_state = ESP_SELECT_NONE;
1206
1207	esp->seqreg = esp_read8(ESP_SSTEP) & ESP_STEP_VBITS;
1208	ent = esp->active_cmd;
1209	cmd = ent->cmd;
1210
1211	if (esp->ops->dma_error(esp)) {
1212		/* If we see a DMA error during or as a result of selection,
1213		 * all bets are off.
1214		 */
1215		esp_schedule_reset(esp);
1216		esp_cmd_is_done(esp, ent, cmd, (DID_ERROR << 16));
1217		return 0;
1218	}
1219
1220	esp->ops->dma_invalidate(esp);
1221
1222	if (esp->ireg == (ESP_INTR_RSEL | ESP_INTR_FDONE)) {
1223		struct esp_target_data *tp = &esp->target[cmd->device->id];
1224
1225		/* Carefully back out of the selection attempt.  Release
1226		 * resources (such as DMA mapping & TAG) and reset state (such
1227		 * as message out and command delivery variables).
1228		 */
1229		if (!(ent->flags & ESP_CMD_FLAG_AUTOSENSE)) {
1230			esp_unmap_dma(esp, cmd);
1231			esp_free_lun_tag(ent, cmd->device->hostdata);
1232			tp->flags &= ~(ESP_TGT_NEGO_SYNC | ESP_TGT_NEGO_WIDE);
1233			esp->flags &= ~ESP_FLAG_DOING_SLOWCMD;
1234			esp->cmd_bytes_ptr = NULL;
1235			esp->cmd_bytes_left = 0;
1236		} else {
1237			esp->ops->unmap_single(esp, ent->sense_dma,
1238					       SCSI_SENSE_BUFFERSIZE,
1239					       DMA_FROM_DEVICE);
1240			ent->sense_ptr = NULL;
1241		}
1242
1243		/* Now that the state is unwound properly, put back onto
1244		 * the issue queue.  This command is no longer active.
1245		 */
1246		list_move(&ent->list, &esp->queued_cmds);
1247		esp->active_cmd = NULL;
1248
1249		/* Return value ignored by caller, it directly invokes
1250		 * esp_reconnect().
1251		 */
1252		return 0;
1253	}
1254
1255	if (esp->ireg == ESP_INTR_DC) {
1256		struct scsi_device *dev = cmd->device;
1257
1258		/* Disconnect.  Make sure we re-negotiate sync and
1259		 * wide parameters if this target starts responding
1260		 * again in the future.
1261		 */
1262		esp->target[dev->id].flags |= ESP_TGT_CHECK_NEGO;
1263
1264		scsi_esp_cmd(esp, ESP_CMD_ESEL);
1265		esp_cmd_is_done(esp, ent, cmd, (DID_BAD_TARGET << 16));
1266		return 1;
1267	}
1268
1269	if (esp->ireg == (ESP_INTR_FDONE | ESP_INTR_BSERV)) {
1270		/* Selection successful.  On pre-FAST chips we have
1271		 * to do a NOP and possibly clean out the FIFO.
1272		 */
1273		if (esp->rev <= ESP236) {
1274			int fcnt = esp_read8(ESP_FFLAGS) & ESP_FF_FBYTES;
1275
1276			scsi_esp_cmd(esp, ESP_CMD_NULL);
1277
1278			if (!fcnt &&
1279			    (!esp->prev_soff ||
1280			     ((esp->sreg & ESP_STAT_PMASK) != ESP_DIP)))
1281				esp_flush_fifo(esp);
1282		}
1283
1284		/* If we are doing a slow command, negotiation, etc.
1285		 * we'll do the right thing as we transition to the
1286		 * next phase.
1287		 */
1288		esp_event(esp, ESP_EVENT_CHECK_PHASE);
1289		return 0;
1290	}
1291
1292	printk("ESP: Unexpected selection completion ireg[%x].\n",
1293	       esp->ireg);
1294	esp_schedule_reset(esp);
1295	return 0;
1296}
1297
1298static int esp_data_bytes_sent(struct esp *esp, struct esp_cmd_entry *ent,
1299			       struct scsi_cmnd *cmd)
1300{
1301	int fifo_cnt, ecount, bytes_sent, flush_fifo;
1302
1303	fifo_cnt = esp_read8(ESP_FFLAGS) & ESP_FF_FBYTES;
1304	if (esp->prev_cfg3 & ESP_CONFIG3_EWIDE)
1305		fifo_cnt <<= 1;
1306
1307	ecount = 0;
1308	if (!(esp->sreg & ESP_STAT_TCNT)) {
1309		ecount = ((unsigned int)esp_read8(ESP_TCLOW) |
1310			  (((unsigned int)esp_read8(ESP_TCMED)) << 8));
1311		if (esp->rev == FASHME)
1312			ecount |= ((unsigned int)esp_read8(FAS_RLO)) << 16;
 
 
1313	}
1314
1315	bytes_sent = esp->data_dma_len;
1316	bytes_sent -= ecount;
1317
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1318	if (!(ent->flags & ESP_CMD_FLAG_WRITE))
1319		bytes_sent -= fifo_cnt;
1320
1321	flush_fifo = 0;
1322	if (!esp->prev_soff) {
1323		/* Synchronous data transfer, always flush fifo. */
1324		flush_fifo = 1;
1325	} else {
1326		if (esp->rev == ESP100) {
1327			u32 fflags, phase;
1328
1329			/* ESP100 has a chip bug where in the synchronous data
1330			 * phase it can mistake a final long REQ pulse from the
1331			 * target as an extra data byte.  Fun.
1332			 *
1333			 * To detect this case we resample the status register
1334			 * and fifo flags.  If we're still in a data phase and
1335			 * we see spurious chunks in the fifo, we return error
1336			 * to the caller which should reset and set things up
1337			 * such that we only try future transfers to this
1338			 * target in synchronous mode.
1339			 */
1340			esp->sreg = esp_read8(ESP_STATUS);
1341			phase = esp->sreg & ESP_STAT_PMASK;
1342			fflags = esp_read8(ESP_FFLAGS);
1343
1344			if ((phase == ESP_DOP &&
1345			     (fflags & ESP_FF_ONOTZERO)) ||
1346			    (phase == ESP_DIP &&
1347			     (fflags & ESP_FF_FBYTES)))
1348				return -1;
1349		}
1350		if (!(ent->flags & ESP_CMD_FLAG_WRITE))
1351			flush_fifo = 1;
1352	}
1353
1354	if (flush_fifo)
1355		esp_flush_fifo(esp);
1356
1357	return bytes_sent;
1358}
1359
1360static void esp_setsync(struct esp *esp, struct esp_target_data *tp,
1361			u8 scsi_period, u8 scsi_offset,
1362			u8 esp_stp, u8 esp_soff)
1363{
1364	spi_period(tp->starget) = scsi_period;
1365	spi_offset(tp->starget) = scsi_offset;
1366	spi_width(tp->starget) = (tp->flags & ESP_TGT_WIDE) ? 1 : 0;
1367
1368	if (esp_soff) {
1369		esp_stp &= 0x1f;
1370		esp_soff |= esp->radelay;
1371		if (esp->rev >= FAS236) {
1372			u8 bit = ESP_CONFIG3_FSCSI;
1373			if (esp->rev >= FAS100A)
1374				bit = ESP_CONFIG3_FAST;
1375
1376			if (scsi_period < 50) {
1377				if (esp->rev == FASHME)
1378					esp_soff &= ~esp->radelay;
1379				tp->esp_config3 |= bit;
1380			} else {
1381				tp->esp_config3 &= ~bit;
1382			}
1383			esp->prev_cfg3 = tp->esp_config3;
1384			esp_write8(esp->prev_cfg3, ESP_CFG3);
1385		}
1386	}
1387
1388	tp->esp_period = esp->prev_stp = esp_stp;
1389	tp->esp_offset = esp->prev_soff = esp_soff;
1390
1391	esp_write8(esp_soff, ESP_SOFF);
1392	esp_write8(esp_stp, ESP_STP);
1393
1394	tp->flags &= ~(ESP_TGT_NEGO_SYNC | ESP_TGT_CHECK_NEGO);
1395
1396	spi_display_xfer_agreement(tp->starget);
1397}
1398
1399static void esp_msgin_reject(struct esp *esp)
1400{
1401	struct esp_cmd_entry *ent = esp->active_cmd;
1402	struct scsi_cmnd *cmd = ent->cmd;
1403	struct esp_target_data *tp;
1404	int tgt;
1405
1406	tgt = cmd->device->id;
1407	tp = &esp->target[tgt];
1408
1409	if (tp->flags & ESP_TGT_NEGO_WIDE) {
1410		tp->flags &= ~(ESP_TGT_NEGO_WIDE | ESP_TGT_WIDE);
1411
1412		if (!esp_need_to_nego_sync(tp)) {
1413			tp->flags &= ~ESP_TGT_CHECK_NEGO;
1414			scsi_esp_cmd(esp, ESP_CMD_RATN);
1415		} else {
1416			esp->msg_out_len =
1417				spi_populate_sync_msg(&esp->msg_out[0],
1418						      tp->nego_goal_period,
1419						      tp->nego_goal_offset);
1420			tp->flags |= ESP_TGT_NEGO_SYNC;
1421			scsi_esp_cmd(esp, ESP_CMD_SATN);
1422		}
1423		return;
1424	}
1425
1426	if (tp->flags & ESP_TGT_NEGO_SYNC) {
1427		tp->flags &= ~(ESP_TGT_NEGO_SYNC | ESP_TGT_CHECK_NEGO);
1428		tp->esp_period = 0;
1429		tp->esp_offset = 0;
1430		esp_setsync(esp, tp, 0, 0, 0, 0);
1431		scsi_esp_cmd(esp, ESP_CMD_RATN);
1432		return;
1433	}
1434
1435	esp->msg_out[0] = ABORT_TASK_SET;
1436	esp->msg_out_len = 1;
1437	scsi_esp_cmd(esp, ESP_CMD_SATN);
1438}
1439
1440static void esp_msgin_sdtr(struct esp *esp, struct esp_target_data *tp)
1441{
1442	u8 period = esp->msg_in[3];
1443	u8 offset = esp->msg_in[4];
1444	u8 stp;
1445
1446	if (!(tp->flags & ESP_TGT_NEGO_SYNC))
1447		goto do_reject;
1448
1449	if (offset > 15)
1450		goto do_reject;
1451
1452	if (offset) {
1453		int one_clock;
1454
1455		if (period > esp->max_period) {
1456			period = offset = 0;
1457			goto do_sdtr;
1458		}
1459		if (period < esp->min_period)
1460			goto do_reject;
1461
1462		one_clock = esp->ccycle / 1000;
1463		stp = DIV_ROUND_UP(period << 2, one_clock);
1464		if (stp && esp->rev >= FAS236) {
1465			if (stp >= 50)
1466				stp--;
1467		}
1468	} else {
1469		stp = 0;
1470	}
1471
1472	esp_setsync(esp, tp, period, offset, stp, offset);
1473	return;
1474
1475do_reject:
1476	esp->msg_out[0] = MESSAGE_REJECT;
1477	esp->msg_out_len = 1;
1478	scsi_esp_cmd(esp, ESP_CMD_SATN);
1479	return;
1480
1481do_sdtr:
1482	tp->nego_goal_period = period;
1483	tp->nego_goal_offset = offset;
1484	esp->msg_out_len =
1485		spi_populate_sync_msg(&esp->msg_out[0],
1486				      tp->nego_goal_period,
1487				      tp->nego_goal_offset);
1488	scsi_esp_cmd(esp, ESP_CMD_SATN);
1489}
1490
1491static void esp_msgin_wdtr(struct esp *esp, struct esp_target_data *tp)
1492{
1493	int size = 8 << esp->msg_in[3];
1494	u8 cfg3;
1495
1496	if (esp->rev != FASHME)
1497		goto do_reject;
1498
1499	if (size != 8 && size != 16)
1500		goto do_reject;
1501
1502	if (!(tp->flags & ESP_TGT_NEGO_WIDE))
1503		goto do_reject;
1504
1505	cfg3 = tp->esp_config3;
1506	if (size == 16) {
1507		tp->flags |= ESP_TGT_WIDE;
1508		cfg3 |= ESP_CONFIG3_EWIDE;
1509	} else {
1510		tp->flags &= ~ESP_TGT_WIDE;
1511		cfg3 &= ~ESP_CONFIG3_EWIDE;
1512	}
1513	tp->esp_config3 = cfg3;
1514	esp->prev_cfg3 = cfg3;
1515	esp_write8(cfg3, ESP_CFG3);
1516
1517	tp->flags &= ~ESP_TGT_NEGO_WIDE;
1518
1519	spi_period(tp->starget) = 0;
1520	spi_offset(tp->starget) = 0;
1521	if (!esp_need_to_nego_sync(tp)) {
1522		tp->flags &= ~ESP_TGT_CHECK_NEGO;
1523		scsi_esp_cmd(esp, ESP_CMD_RATN);
1524	} else {
1525		esp->msg_out_len =
1526			spi_populate_sync_msg(&esp->msg_out[0],
1527					      tp->nego_goal_period,
1528					      tp->nego_goal_offset);
1529		tp->flags |= ESP_TGT_NEGO_SYNC;
1530		scsi_esp_cmd(esp, ESP_CMD_SATN);
1531	}
1532	return;
1533
1534do_reject:
1535	esp->msg_out[0] = MESSAGE_REJECT;
1536	esp->msg_out_len = 1;
1537	scsi_esp_cmd(esp, ESP_CMD_SATN);
1538}
1539
1540static void esp_msgin_extended(struct esp *esp)
1541{
1542	struct esp_cmd_entry *ent = esp->active_cmd;
1543	struct scsi_cmnd *cmd = ent->cmd;
1544	struct esp_target_data *tp;
1545	int tgt = cmd->device->id;
1546
1547	tp = &esp->target[tgt];
1548	if (esp->msg_in[2] == EXTENDED_SDTR) {
1549		esp_msgin_sdtr(esp, tp);
1550		return;
1551	}
1552	if (esp->msg_in[2] == EXTENDED_WDTR) {
1553		esp_msgin_wdtr(esp, tp);
1554		return;
1555	}
1556
1557	printk("ESP: Unexpected extended msg type %x\n",
1558	       esp->msg_in[2]);
1559
1560	esp->msg_out[0] = ABORT_TASK_SET;
1561	esp->msg_out_len = 1;
1562	scsi_esp_cmd(esp, ESP_CMD_SATN);
1563}
1564
1565/* Analyze msgin bytes received from target so far.  Return non-zero
1566 * if there are more bytes needed to complete the message.
1567 */
1568static int esp_msgin_process(struct esp *esp)
1569{
1570	u8 msg0 = esp->msg_in[0];
1571	int len = esp->msg_in_len;
1572
1573	if (msg0 & 0x80) {
1574		/* Identify */
1575		printk("ESP: Unexpected msgin identify\n");
 
1576		return 0;
1577	}
1578
1579	switch (msg0) {
1580	case EXTENDED_MESSAGE:
1581		if (len == 1)
1582			return 1;
1583		if (len < esp->msg_in[1] + 2)
1584			return 1;
1585		esp_msgin_extended(esp);
1586		return 0;
1587
1588	case IGNORE_WIDE_RESIDUE: {
1589		struct esp_cmd_entry *ent;
1590		struct esp_cmd_priv *spriv;
1591		if (len == 1)
1592			return 1;
1593
1594		if (esp->msg_in[1] != 1)
1595			goto do_reject;
1596
1597		ent = esp->active_cmd;
1598		spriv = ESP_CMD_PRIV(ent->cmd);
1599
1600		if (spriv->cur_residue == sg_dma_len(spriv->cur_sg)) {
1601			spriv->cur_sg--;
1602			spriv->cur_residue = 1;
1603		} else
1604			spriv->cur_residue++;
1605		spriv->tot_residue++;
1606		return 0;
1607	}
1608	case NOP:
1609		return 0;
1610	case RESTORE_POINTERS:
1611		esp_restore_pointers(esp, esp->active_cmd);
1612		return 0;
1613	case SAVE_POINTERS:
1614		esp_save_pointers(esp, esp->active_cmd);
1615		return 0;
1616
1617	case COMMAND_COMPLETE:
1618	case DISCONNECT: {
1619		struct esp_cmd_entry *ent = esp->active_cmd;
1620
1621		ent->message = msg0;
1622		esp_event(esp, ESP_EVENT_FREE_BUS);
1623		esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
1624		return 0;
1625	}
1626	case MESSAGE_REJECT:
1627		esp_msgin_reject(esp);
1628		return 0;
1629
1630	default:
1631	do_reject:
1632		esp->msg_out[0] = MESSAGE_REJECT;
1633		esp->msg_out_len = 1;
1634		scsi_esp_cmd(esp, ESP_CMD_SATN);
1635		return 0;
1636	}
1637}
1638
1639static int esp_process_event(struct esp *esp)
1640{
1641	int write;
1642
1643again:
1644	write = 0;
 
 
1645	switch (esp->event) {
1646	case ESP_EVENT_CHECK_PHASE:
1647		switch (esp->sreg & ESP_STAT_PMASK) {
1648		case ESP_DOP:
1649			esp_event(esp, ESP_EVENT_DATA_OUT);
1650			break;
1651		case ESP_DIP:
1652			esp_event(esp, ESP_EVENT_DATA_IN);
1653			break;
1654		case ESP_STATP:
1655			esp_flush_fifo(esp);
1656			scsi_esp_cmd(esp, ESP_CMD_ICCSEQ);
1657			esp_event(esp, ESP_EVENT_STATUS);
1658			esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
1659			return 1;
1660
1661		case ESP_MOP:
1662			esp_event(esp, ESP_EVENT_MSGOUT);
1663			break;
1664
1665		case ESP_MIP:
1666			esp_event(esp, ESP_EVENT_MSGIN);
1667			break;
1668
1669		case ESP_CMDP:
1670			esp_event(esp, ESP_EVENT_CMD_START);
1671			break;
1672
1673		default:
1674			printk("ESP: Unexpected phase, sreg=%02x\n",
1675			       esp->sreg);
 
1676			esp_schedule_reset(esp);
1677			return 0;
1678		}
1679		goto again;
1680		break;
1681
1682	case ESP_EVENT_DATA_IN:
1683		write = 1;
1684		/* fallthru */
1685
1686	case ESP_EVENT_DATA_OUT: {
1687		struct esp_cmd_entry *ent = esp->active_cmd;
1688		struct scsi_cmnd *cmd = ent->cmd;
1689		dma_addr_t dma_addr = esp_cur_dma_addr(ent, cmd);
1690		unsigned int dma_len = esp_cur_dma_len(ent, cmd);
1691
1692		if (esp->rev == ESP100)
1693			scsi_esp_cmd(esp, ESP_CMD_NULL);
1694
1695		if (write)
1696			ent->flags |= ESP_CMD_FLAG_WRITE;
1697		else
1698			ent->flags &= ~ESP_CMD_FLAG_WRITE;
1699
1700		if (esp->ops->dma_length_limit)
1701			dma_len = esp->ops->dma_length_limit(esp, dma_addr,
1702							     dma_len);
1703		else
1704			dma_len = esp_dma_length_limit(esp, dma_addr, dma_len);
1705
1706		esp->data_dma_len = dma_len;
1707
1708		if (!dma_len) {
1709			printk(KERN_ERR PFX "esp%d: DMA length is zero!\n",
1710			       esp->host->unique_id);
1711			printk(KERN_ERR PFX "esp%d: cur adr[%08llx] len[%08x]\n",
1712			       esp->host->unique_id,
1713			       (unsigned long long)esp_cur_dma_addr(ent, cmd),
1714			       esp_cur_dma_len(ent, cmd));
1715			esp_schedule_reset(esp);
1716			return 0;
1717		}
1718
1719		esp_log_datastart("ESP: start data addr[%08llx] len[%u] "
1720				  "write(%d)\n",
1721				  (unsigned long long)dma_addr, dma_len, write);
1722
1723		esp->ops->send_dma_cmd(esp, dma_addr, dma_len, dma_len,
1724				       write, ESP_CMD_DMA | ESP_CMD_TI);
1725		esp_event(esp, ESP_EVENT_DATA_DONE);
1726		break;
1727	}
1728	case ESP_EVENT_DATA_DONE: {
1729		struct esp_cmd_entry *ent = esp->active_cmd;
1730		struct scsi_cmnd *cmd = ent->cmd;
1731		int bytes_sent;
1732
1733		if (esp->ops->dma_error(esp)) {
1734			printk("ESP: data done, DMA error, resetting\n");
 
1735			esp_schedule_reset(esp);
1736			return 0;
1737		}
1738
1739		if (ent->flags & ESP_CMD_FLAG_WRITE) {
1740			/* XXX parity errors, etc. XXX */
1741
1742			esp->ops->dma_drain(esp);
1743		}
1744		esp->ops->dma_invalidate(esp);
1745
1746		if (esp->ireg != ESP_INTR_BSERV) {
1747			/* We should always see exactly a bus-service
1748			 * interrupt at the end of a successful transfer.
1749			 */
1750			printk("ESP: data done, not BSERV, resetting\n");
 
1751			esp_schedule_reset(esp);
1752			return 0;
1753		}
1754
1755		bytes_sent = esp_data_bytes_sent(esp, ent, cmd);
1756
1757		esp_log_datadone("ESP: data done flgs[%x] sent[%d]\n",
1758				 ent->flags, bytes_sent);
1759
1760		if (bytes_sent < 0) {
1761			/* XXX force sync mode for this target XXX */
1762			esp_schedule_reset(esp);
1763			return 0;
1764		}
1765
1766		esp_advance_dma(esp, ent, cmd, bytes_sent);
1767		esp_event(esp, ESP_EVENT_CHECK_PHASE);
1768		goto again;
1769	}
1770
1771	case ESP_EVENT_STATUS: {
1772		struct esp_cmd_entry *ent = esp->active_cmd;
1773
1774		if (esp->ireg & ESP_INTR_FDONE) {
1775			ent->status = esp_read8(ESP_FDATA);
1776			ent->message = esp_read8(ESP_FDATA);
1777			scsi_esp_cmd(esp, ESP_CMD_MOK);
1778		} else if (esp->ireg == ESP_INTR_BSERV) {
1779			ent->status = esp_read8(ESP_FDATA);
1780			ent->message = 0xff;
1781			esp_event(esp, ESP_EVENT_MSGIN);
1782			return 0;
1783		}
1784
1785		if (ent->message != COMMAND_COMPLETE) {
1786			printk("ESP: Unexpected message %x in status\n",
1787			       ent->message);
 
1788			esp_schedule_reset(esp);
1789			return 0;
1790		}
1791
1792		esp_event(esp, ESP_EVENT_FREE_BUS);
1793		esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
1794		break;
1795	}
1796	case ESP_EVENT_FREE_BUS: {
1797		struct esp_cmd_entry *ent = esp->active_cmd;
1798		struct scsi_cmnd *cmd = ent->cmd;
1799
1800		if (ent->message == COMMAND_COMPLETE ||
1801		    ent->message == DISCONNECT)
1802			scsi_esp_cmd(esp, ESP_CMD_ESEL);
1803
1804		if (ent->message == COMMAND_COMPLETE) {
1805			esp_log_cmddone("ESP: Command done status[%x] "
1806					"message[%x]\n",
1807					ent->status, ent->message);
1808			if (ent->status == SAM_STAT_TASK_SET_FULL)
1809				esp_event_queue_full(esp, ent);
1810
1811			if (ent->status == SAM_STAT_CHECK_CONDITION &&
1812			    !(ent->flags & ESP_CMD_FLAG_AUTOSENSE)) {
1813				ent->flags |= ESP_CMD_FLAG_AUTOSENSE;
1814				esp_autosense(esp, ent);
1815			} else {
1816				esp_cmd_is_done(esp, ent, cmd,
1817						compose_result(ent->status,
1818							       ent->message,
1819							       DID_OK));
1820			}
1821		} else if (ent->message == DISCONNECT) {
1822			esp_log_disconnect("ESP: Disconnecting tgt[%d] "
1823					   "tag[%x:%x]\n",
1824					   cmd->device->id,
1825					   ent->tag[0], ent->tag[1]);
1826
1827			esp->active_cmd = NULL;
1828			esp_maybe_execute_command(esp);
1829		} else {
1830			printk("ESP: Unexpected message %x in freebus\n",
1831			       ent->message);
 
1832			esp_schedule_reset(esp);
1833			return 0;
1834		}
1835		if (esp->active_cmd)
1836			esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
1837		break;
1838	}
1839	case ESP_EVENT_MSGOUT: {
1840		scsi_esp_cmd(esp, ESP_CMD_FLUSH);
1841
1842		if (esp_debug & ESP_DEBUG_MSGOUT) {
1843			int i;
1844			printk("ESP: Sending message [ ");
1845			for (i = 0; i < esp->msg_out_len; i++)
1846				printk("%02x ", esp->msg_out[i]);
1847			printk("]\n");
1848		}
1849
1850		if (esp->rev == FASHME) {
1851			int i;
1852
1853			/* Always use the fifo.  */
1854			for (i = 0; i < esp->msg_out_len; i++) {
1855				esp_write8(esp->msg_out[i], ESP_FDATA);
1856				esp_write8(0, ESP_FDATA);
1857			}
1858			scsi_esp_cmd(esp, ESP_CMD_TI);
1859		} else {
1860			if (esp->msg_out_len == 1) {
1861				esp_write8(esp->msg_out[0], ESP_FDATA);
1862				scsi_esp_cmd(esp, ESP_CMD_TI);
 
 
 
 
1863			} else {
1864				/* Use DMA. */
1865				memcpy(esp->command_block,
1866				       esp->msg_out,
1867				       esp->msg_out_len);
1868
1869				esp->ops->send_dma_cmd(esp,
1870						       esp->command_block_dma,
1871						       esp->msg_out_len,
1872						       esp->msg_out_len,
1873						       0,
1874						       ESP_CMD_DMA|ESP_CMD_TI);
1875			}
1876		}
1877		esp_event(esp, ESP_EVENT_MSGOUT_DONE);
1878		break;
1879	}
1880	case ESP_EVENT_MSGOUT_DONE:
1881		if (esp->rev == FASHME) {
1882			scsi_esp_cmd(esp, ESP_CMD_FLUSH);
1883		} else {
1884			if (esp->msg_out_len > 1)
1885				esp->ops->dma_invalidate(esp);
1886		}
1887
1888		if (!(esp->ireg & ESP_INTR_DC)) {
1889			if (esp->rev != FASHME)
1890				scsi_esp_cmd(esp, ESP_CMD_NULL);
1891		}
1892		esp_event(esp, ESP_EVENT_CHECK_PHASE);
1893		goto again;
1894	case ESP_EVENT_MSGIN:
1895		if (esp->ireg & ESP_INTR_BSERV) {
1896			if (esp->rev == FASHME) {
1897				if (!(esp_read8(ESP_STATUS2) &
1898				      ESP_STAT2_FEMPTY))
1899					scsi_esp_cmd(esp, ESP_CMD_FLUSH);
1900			} else {
1901				scsi_esp_cmd(esp, ESP_CMD_FLUSH);
1902				if (esp->rev == ESP100)
1903					scsi_esp_cmd(esp, ESP_CMD_NULL);
1904			}
1905			scsi_esp_cmd(esp, ESP_CMD_TI);
1906			esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
1907			return 1;
1908		}
1909		if (esp->ireg & ESP_INTR_FDONE) {
1910			u8 val;
1911
1912			if (esp->rev == FASHME)
1913				val = esp->fifo[0];
1914			else
1915				val = esp_read8(ESP_FDATA);
1916			esp->msg_in[esp->msg_in_len++] = val;
1917
1918			esp_log_msgin("ESP: Got msgin byte %x\n", val);
1919
1920			if (!esp_msgin_process(esp))
1921				esp->msg_in_len = 0;
1922
1923			if (esp->rev == FASHME)
1924				scsi_esp_cmd(esp, ESP_CMD_FLUSH);
1925
1926			scsi_esp_cmd(esp, ESP_CMD_MOK);
1927
1928			if (esp->event != ESP_EVENT_FREE_BUS)
1929				esp_event(esp, ESP_EVENT_CHECK_PHASE);
1930		} else {
1931			printk("ESP: MSGIN neither BSERV not FDON, resetting");
 
1932			esp_schedule_reset(esp);
1933			return 0;
1934		}
1935		break;
1936	case ESP_EVENT_CMD_START:
1937		memcpy(esp->command_block, esp->cmd_bytes_ptr,
1938		       esp->cmd_bytes_left);
1939		if (esp->rev == FASHME)
1940			scsi_esp_cmd(esp, ESP_CMD_FLUSH);
1941		esp->ops->send_dma_cmd(esp, esp->command_block_dma,
1942				       esp->cmd_bytes_left, 16, 0,
1943				       ESP_CMD_DMA | ESP_CMD_TI);
1944		esp_event(esp, ESP_EVENT_CMD_DONE);
1945		esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
1946		break;
1947	case ESP_EVENT_CMD_DONE:
1948		esp->ops->dma_invalidate(esp);
1949		if (esp->ireg & ESP_INTR_BSERV) {
1950			esp_event(esp, ESP_EVENT_CHECK_PHASE);
1951			goto again;
1952		}
1953		esp_schedule_reset(esp);
1954		return 0;
1955		break;
1956
1957	case ESP_EVENT_RESET:
1958		scsi_esp_cmd(esp, ESP_CMD_RS);
1959		break;
1960
1961	default:
1962		printk("ESP: Unexpected event %x, resetting\n",
1963		       esp->event);
1964		esp_schedule_reset(esp);
1965		return 0;
1966		break;
1967	}
1968	return 1;
1969}
1970
1971static void esp_reset_cleanup_one(struct esp *esp, struct esp_cmd_entry *ent)
1972{
1973	struct scsi_cmnd *cmd = ent->cmd;
1974
1975	esp_unmap_dma(esp, cmd);
1976	esp_free_lun_tag(ent, cmd->device->hostdata);
1977	cmd->result = DID_RESET << 16;
1978
1979	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
1980		esp->ops->unmap_single(esp, ent->sense_dma,
1981				       SCSI_SENSE_BUFFERSIZE, DMA_FROM_DEVICE);
1982		ent->sense_ptr = NULL;
1983	}
1984
1985	cmd->scsi_done(cmd);
1986	list_del(&ent->list);
1987	esp_put_ent(esp, ent);
1988}
1989
1990static void esp_clear_hold(struct scsi_device *dev, void *data)
1991{
1992	struct esp_lun_data *lp = dev->hostdata;
1993
1994	BUG_ON(lp->num_tagged);
1995	lp->hold = 0;
1996}
1997
1998static void esp_reset_cleanup(struct esp *esp)
1999{
2000	struct esp_cmd_entry *ent, *tmp;
2001	int i;
2002
2003	list_for_each_entry_safe(ent, tmp, &esp->queued_cmds, list) {
2004		struct scsi_cmnd *cmd = ent->cmd;
2005
2006		list_del(&ent->list);
2007		cmd->result = DID_RESET << 16;
2008		cmd->scsi_done(cmd);
2009		esp_put_ent(esp, ent);
2010	}
2011
2012	list_for_each_entry_safe(ent, tmp, &esp->active_cmds, list) {
2013		if (ent == esp->active_cmd)
2014			esp->active_cmd = NULL;
2015		esp_reset_cleanup_one(esp, ent);
2016	}
2017
2018	BUG_ON(esp->active_cmd != NULL);
2019
2020	/* Force renegotiation of sync/wide transfers.  */
2021	for (i = 0; i < ESP_MAX_TARGET; i++) {
2022		struct esp_target_data *tp = &esp->target[i];
2023
2024		tp->esp_period = 0;
2025		tp->esp_offset = 0;
2026		tp->esp_config3 &= ~(ESP_CONFIG3_EWIDE |
2027				     ESP_CONFIG3_FSCSI |
2028				     ESP_CONFIG3_FAST);
2029		tp->flags &= ~ESP_TGT_WIDE;
2030		tp->flags |= ESP_TGT_CHECK_NEGO;
2031
2032		if (tp->starget)
2033			__starget_for_each_device(tp->starget, NULL,
2034						  esp_clear_hold);
2035	}
2036	esp->flags &= ~ESP_FLAG_RESETTING;
2037}
2038
2039/* Runs under host->lock */
2040static void __esp_interrupt(struct esp *esp)
2041{
2042	int finish_reset, intr_done;
2043	u8 phase;
2044
 
 
 
2045	esp->sreg = esp_read8(ESP_STATUS);
 
 
2046
2047	if (esp->flags & ESP_FLAG_RESETTING) {
2048		finish_reset = 1;
2049	} else {
2050		if (esp_check_gross_error(esp))
2051			return;
2052
2053		finish_reset = esp_check_spur_intr(esp);
2054		if (finish_reset < 0)
2055			return;
2056	}
2057
2058	esp->ireg = esp_read8(ESP_INTRPT);
2059
2060	if (esp->ireg & ESP_INTR_SR)
2061		finish_reset = 1;
2062
2063	if (finish_reset) {
2064		esp_reset_cleanup(esp);
2065		if (esp->eh_reset) {
2066			complete(esp->eh_reset);
2067			esp->eh_reset = NULL;
2068		}
2069		return;
2070	}
2071
2072	phase = (esp->sreg & ESP_STAT_PMASK);
2073	if (esp->rev == FASHME) {
2074		if (((phase != ESP_DIP && phase != ESP_DOP) &&
2075		     esp->select_state == ESP_SELECT_NONE &&
2076		     esp->event != ESP_EVENT_STATUS &&
2077		     esp->event != ESP_EVENT_DATA_DONE) ||
2078		    (esp->ireg & ESP_INTR_RSEL)) {
2079			esp->sreg2 = esp_read8(ESP_STATUS2);
2080			if (!(esp->sreg2 & ESP_STAT2_FEMPTY) ||
2081			    (esp->sreg2 & ESP_STAT2_F1BYTE))
2082				hme_read_fifo(esp);
2083		}
2084	}
2085
2086	esp_log_intr("ESP: intr sreg[%02x] seqreg[%02x] "
2087		     "sreg2[%02x] ireg[%02x]\n",
2088		     esp->sreg, esp->seqreg, esp->sreg2, esp->ireg);
2089
2090	intr_done = 0;
2091
2092	if (esp->ireg & (ESP_INTR_S | ESP_INTR_SATN | ESP_INTR_IC)) {
2093		printk("ESP: unexpected IREG %02x\n", esp->ireg);
 
2094		if (esp->ireg & ESP_INTR_IC)
2095			esp_dump_cmd_log(esp);
2096
2097		esp_schedule_reset(esp);
2098	} else {
2099		if (!(esp->ireg & ESP_INTR_RSEL)) {
2100			/* Some combination of FDONE, BSERV, DC.  */
2101			if (esp->select_state != ESP_SELECT_NONE)
2102				intr_done = esp_finish_select(esp);
2103		} else if (esp->ireg & ESP_INTR_RSEL) {
2104			if (esp->active_cmd)
2105				(void) esp_finish_select(esp);
2106			intr_done = esp_reconnect(esp);
2107		}
2108	}
2109	while (!intr_done)
2110		intr_done = esp_process_event(esp);
2111}
2112
2113irqreturn_t scsi_esp_intr(int irq, void *dev_id)
2114{
2115	struct esp *esp = dev_id;
2116	unsigned long flags;
2117	irqreturn_t ret;
2118
2119	spin_lock_irqsave(esp->host->host_lock, flags);
2120	ret = IRQ_NONE;
2121	if (esp->ops->irq_pending(esp)) {
2122		ret = IRQ_HANDLED;
2123		for (;;) {
2124			int i;
2125
2126			__esp_interrupt(esp);
2127			if (!(esp->flags & ESP_FLAG_QUICKIRQ_CHECK))
2128				break;
2129			esp->flags &= ~ESP_FLAG_QUICKIRQ_CHECK;
2130
2131			for (i = 0; i < ESP_QUICKIRQ_LIMIT; i++) {
2132				if (esp->ops->irq_pending(esp))
2133					break;
2134			}
2135			if (i == ESP_QUICKIRQ_LIMIT)
2136				break;
2137		}
2138	}
2139	spin_unlock_irqrestore(esp->host->host_lock, flags);
2140
2141	return ret;
2142}
2143EXPORT_SYMBOL(scsi_esp_intr);
2144
2145static void esp_get_revision(struct esp *esp)
2146{
2147	u8 val;
2148
2149	esp->config1 = (ESP_CONFIG1_PENABLE | (esp->scsi_id & 7));
2150	esp->config2 = (ESP_CONFIG2_SCSI2ENAB | ESP_CONFIG2_REGPARITY);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2151	esp_write8(esp->config2, ESP_CFG2);
 
 
2152
2153	val = esp_read8(ESP_CFG2);
2154	val &= ~ESP_CONFIG2_MAGIC;
2155	if (val != (ESP_CONFIG2_SCSI2ENAB | ESP_CONFIG2_REGPARITY)) {
2156		/* If what we write to cfg2 does not come back, cfg2 is not
2157		 * implemented, therefore this must be a plain esp100.
2158		 */
2159		esp->rev = ESP100;
2160	} else {
2161		esp->config2 = 0;
2162		esp_set_all_config3(esp, 5);
2163		esp->prev_cfg3 = 5;
2164		esp_write8(esp->config2, ESP_CFG2);
2165		esp_write8(0, ESP_CFG3);
2166		esp_write8(esp->prev_cfg3, ESP_CFG3);
2167
2168		val = esp_read8(ESP_CFG3);
2169		if (val != 5) {
2170			/* The cfg2 register is implemented, however
2171			 * cfg3 is not, must be esp100a.
2172			 */
2173			esp->rev = ESP100A;
2174		} else {
2175			esp_set_all_config3(esp, 0);
2176			esp->prev_cfg3 = 0;
2177			esp_write8(esp->prev_cfg3, ESP_CFG3);
2178
2179			/* All of cfg{1,2,3} implemented, must be one of
2180			 * the fas variants, figure out which one.
2181			 */
2182			if (esp->cfact == 0 || esp->cfact > ESP_CCF_F5) {
2183				esp->rev = FAST;
2184				esp->sync_defp = SYNC_DEFP_FAST;
2185			} else {
2186				esp->rev = ESP236;
2187			}
2188			esp->config2 = 0;
2189			esp_write8(esp->config2, ESP_CFG2);
2190		}
2191	}
2192}
2193
2194static void esp_init_swstate(struct esp *esp)
2195{
2196	int i;
2197
2198	INIT_LIST_HEAD(&esp->queued_cmds);
2199	INIT_LIST_HEAD(&esp->active_cmds);
2200	INIT_LIST_HEAD(&esp->esp_cmd_pool);
2201
2202	/* Start with a clear state, domain validation (via ->slave_configure,
2203	 * spi_dv_device()) will attempt to enable SYNC, WIDE, and tagged
2204	 * commands.
2205	 */
2206	for (i = 0 ; i < ESP_MAX_TARGET; i++) {
2207		esp->target[i].flags = 0;
2208		esp->target[i].nego_goal_period = 0;
2209		esp->target[i].nego_goal_offset = 0;
2210		esp->target[i].nego_goal_width = 0;
2211		esp->target[i].nego_goal_tags = 0;
2212	}
2213}
2214
2215/* This places the ESP into a known state at boot time. */
2216static void esp_bootup_reset(struct esp *esp)
2217{
2218	u8 val;
2219
2220	/* Reset the DMA */
2221	esp->ops->reset_dma(esp);
2222
2223	/* Reset the ESP */
2224	esp_reset_esp(esp);
2225
2226	/* Reset the SCSI bus, but tell ESP not to generate an irq */
2227	val = esp_read8(ESP_CFG1);
2228	val |= ESP_CONFIG1_SRRDISAB;
2229	esp_write8(val, ESP_CFG1);
2230
2231	scsi_esp_cmd(esp, ESP_CMD_RS);
2232	udelay(400);
2233
2234	esp_write8(esp->config1, ESP_CFG1);
2235
2236	/* Eat any bitrot in the chip and we are done... */
2237	esp_read8(ESP_INTRPT);
2238}
2239
2240static void esp_set_clock_params(struct esp *esp)
2241{
2242	int fhz;
2243	u8 ccf;
2244
2245	/* This is getting messy but it has to be done correctly or else
2246	 * you get weird behavior all over the place.  We are trying to
2247	 * basically figure out three pieces of information.
2248	 *
2249	 * a) Clock Conversion Factor
2250	 *
2251	 *    This is a representation of the input crystal clock frequency
2252	 *    going into the ESP on this machine.  Any operation whose timing
2253	 *    is longer than 400ns depends on this value being correct.  For
2254	 *    example, you'll get blips for arbitration/selection during high
2255	 *    load or with multiple targets if this is not set correctly.
2256	 *
2257	 * b) Selection Time-Out
2258	 *
2259	 *    The ESP isn't very bright and will arbitrate for the bus and try
2260	 *    to select a target forever if you let it.  This value tells the
2261	 *    ESP when it has taken too long to negotiate and that it should
2262	 *    interrupt the CPU so we can see what happened.  The value is
2263	 *    computed as follows (from NCR/Symbios chip docs).
2264	 *
2265	 *          (Time Out Period) *  (Input Clock)
2266	 *    STO = ----------------------------------
2267	 *          (8192) * (Clock Conversion Factor)
2268	 *
2269	 *    We use a time out period of 250ms (ESP_BUS_TIMEOUT).
2270	 *
2271	 * c) Imperical constants for synchronous offset and transfer period
2272         *    register values
2273	 *
2274	 *    This entails the smallest and largest sync period we could ever
2275	 *    handle on this ESP.
2276	 */
2277	fhz = esp->cfreq;
2278
2279	ccf = ((fhz / 1000000) + 4) / 5;
2280	if (ccf == 1)
2281		ccf = 2;
2282
2283	/* If we can't find anything reasonable, just assume 20MHZ.
2284	 * This is the clock frequency of the older sun4c's where I've
2285	 * been unable to find the clock-frequency PROM property.  All
2286	 * other machines provide useful values it seems.
2287	 */
2288	if (fhz <= 5000000 || ccf < 1 || ccf > 8) {
2289		fhz = 20000000;
2290		ccf = 4;
2291	}
2292
2293	esp->cfact = (ccf == 8 ? 0 : ccf);
2294	esp->cfreq = fhz;
2295	esp->ccycle = ESP_HZ_TO_CYCLE(fhz);
2296	esp->ctick = ESP_TICK(ccf, esp->ccycle);
2297	esp->neg_defp = ESP_NEG_DEFP(fhz, ccf);
2298	esp->sync_defp = SYNC_DEFP_SLOW;
2299}
2300
2301static const char *esp_chip_names[] = {
2302	"ESP100",
2303	"ESP100A",
2304	"ESP236",
2305	"FAS236",
2306	"FAS100A",
2307	"FAST",
2308	"FASHME",
 
2309};
2310
2311static struct scsi_transport_template *esp_transport_template;
2312
2313int scsi_esp_register(struct esp *esp, struct device *dev)
2314{
2315	static int instance;
2316	int err;
2317
 
 
2318	esp->host->transportt = esp_transport_template;
2319	esp->host->max_lun = ESP_MAX_LUN;
2320	esp->host->cmd_per_lun = 2;
2321	esp->host->unique_id = instance;
2322
2323	esp_set_clock_params(esp);
2324
2325	esp_get_revision(esp);
2326
2327	esp_init_swstate(esp);
2328
2329	esp_bootup_reset(esp);
2330
2331	printk(KERN_INFO PFX "esp%u, regs[%1p:%1p] irq[%u]\n",
2332	       esp->host->unique_id, esp->regs, esp->dma_regs,
2333	       esp->host->irq);
2334	printk(KERN_INFO PFX "esp%u is a %s, %u MHz (ccf=%u), SCSI ID %u\n",
2335	       esp->host->unique_id, esp_chip_names[esp->rev],
2336	       esp->cfreq / 1000000, esp->cfact, esp->scsi_id);
 
2337
2338	/* Let the SCSI bus reset settle. */
2339	ssleep(esp_bus_reset_settle);
2340
2341	err = scsi_add_host(esp->host, dev);
2342	if (err)
2343		return err;
2344
2345	instance++;
2346
2347	scsi_scan_host(esp->host);
2348
2349	return 0;
2350}
2351EXPORT_SYMBOL(scsi_esp_register);
2352
2353void scsi_esp_unregister(struct esp *esp)
2354{
2355	scsi_remove_host(esp->host);
2356}
2357EXPORT_SYMBOL(scsi_esp_unregister);
2358
2359static int esp_target_alloc(struct scsi_target *starget)
2360{
2361	struct esp *esp = shost_priv(dev_to_shost(&starget->dev));
2362	struct esp_target_data *tp = &esp->target[starget->id];
2363
2364	tp->starget = starget;
2365
2366	return 0;
2367}
2368
2369static void esp_target_destroy(struct scsi_target *starget)
2370{
2371	struct esp *esp = shost_priv(dev_to_shost(&starget->dev));
2372	struct esp_target_data *tp = &esp->target[starget->id];
2373
2374	tp->starget = NULL;
2375}
2376
2377static int esp_slave_alloc(struct scsi_device *dev)
2378{
2379	struct esp *esp = shost_priv(dev->host);
2380	struct esp_target_data *tp = &esp->target[dev->id];
2381	struct esp_lun_data *lp;
2382
2383	lp = kzalloc(sizeof(*lp), GFP_KERNEL);
2384	if (!lp)
2385		return -ENOMEM;
2386	dev->hostdata = lp;
2387
2388	spi_min_period(tp->starget) = esp->min_period;
2389	spi_max_offset(tp->starget) = 15;
2390
2391	if (esp->flags & ESP_FLAG_WIDE_CAPABLE)
2392		spi_max_width(tp->starget) = 1;
2393	else
2394		spi_max_width(tp->starget) = 0;
2395
2396	return 0;
2397}
2398
2399static int esp_slave_configure(struct scsi_device *dev)
2400{
2401	struct esp *esp = shost_priv(dev->host);
2402	struct esp_target_data *tp = &esp->target[dev->id];
2403	int goal_tags, queue_depth;
2404
2405	goal_tags = 0;
2406
2407	if (dev->tagged_supported) {
2408		/* XXX make this configurable somehow XXX */
2409		goal_tags = ESP_DEFAULT_TAGS;
2410
2411		if (goal_tags > ESP_MAX_TAG)
2412			goal_tags = ESP_MAX_TAG;
2413	}
2414
2415	queue_depth = goal_tags;
2416	if (queue_depth < dev->host->cmd_per_lun)
2417		queue_depth = dev->host->cmd_per_lun;
2418
2419	if (goal_tags) {
2420		scsi_set_tag_type(dev, MSG_ORDERED_TAG);
2421		scsi_activate_tcq(dev, queue_depth);
2422	} else {
2423		scsi_deactivate_tcq(dev, queue_depth);
2424	}
2425	tp->flags |= ESP_TGT_DISCONNECT;
2426
2427	if (!spi_initial_dv(dev->sdev_target))
2428		spi_dv_device(dev);
2429
2430	return 0;
2431}
2432
2433static void esp_slave_destroy(struct scsi_device *dev)
2434{
2435	struct esp_lun_data *lp = dev->hostdata;
2436
2437	kfree(lp);
2438	dev->hostdata = NULL;
2439}
2440
2441static int esp_eh_abort_handler(struct scsi_cmnd *cmd)
2442{
2443	struct esp *esp = shost_priv(cmd->device->host);
2444	struct esp_cmd_entry *ent, *tmp;
2445	struct completion eh_done;
2446	unsigned long flags;
2447
2448	/* XXX This helps a lot with debugging but might be a bit
2449	 * XXX much for the final driver.
2450	 */
2451	spin_lock_irqsave(esp->host->host_lock, flags);
2452	printk(KERN_ERR PFX "esp%d: Aborting command [%p:%02x]\n",
2453	       esp->host->unique_id, cmd, cmd->cmnd[0]);
2454	ent = esp->active_cmd;
2455	if (ent)
2456		printk(KERN_ERR PFX "esp%d: Current command [%p:%02x]\n",
2457		       esp->host->unique_id, ent->cmd, ent->cmd->cmnd[0]);
 
2458	list_for_each_entry(ent, &esp->queued_cmds, list) {
2459		printk(KERN_ERR PFX "esp%d: Queued command [%p:%02x]\n",
2460		       esp->host->unique_id, ent->cmd, ent->cmd->cmnd[0]);
2461	}
2462	list_for_each_entry(ent, &esp->active_cmds, list) {
2463		printk(KERN_ERR PFX "esp%d: Active command [%p:%02x]\n",
2464		       esp->host->unique_id, ent->cmd, ent->cmd->cmnd[0]);
2465	}
2466	esp_dump_cmd_log(esp);
2467	spin_unlock_irqrestore(esp->host->host_lock, flags);
2468
2469	spin_lock_irqsave(esp->host->host_lock, flags);
2470
2471	ent = NULL;
2472	list_for_each_entry(tmp, &esp->queued_cmds, list) {
2473		if (tmp->cmd == cmd) {
2474			ent = tmp;
2475			break;
2476		}
2477	}
2478
2479	if (ent) {
2480		/* Easiest case, we didn't even issue the command
2481		 * yet so it is trivial to abort.
2482		 */
2483		list_del(&ent->list);
2484
2485		cmd->result = DID_ABORT << 16;
2486		cmd->scsi_done(cmd);
2487
2488		esp_put_ent(esp, ent);
2489
2490		goto out_success;
2491	}
2492
2493	init_completion(&eh_done);
2494
2495	ent = esp->active_cmd;
2496	if (ent && ent->cmd == cmd) {
2497		/* Command is the currently active command on
2498		 * the bus.  If we already have an output message
2499		 * pending, no dice.
2500		 */
2501		if (esp->msg_out_len)
2502			goto out_failure;
2503
2504		/* Send out an abort, encouraging the target to
2505		 * go to MSGOUT phase by asserting ATN.
2506		 */
2507		esp->msg_out[0] = ABORT_TASK_SET;
2508		esp->msg_out_len = 1;
2509		ent->eh_done = &eh_done;
2510
2511		scsi_esp_cmd(esp, ESP_CMD_SATN);
2512	} else {
2513		/* The command is disconnected.  This is not easy to
2514		 * abort.  For now we fail and let the scsi error
2515		 * handling layer go try a scsi bus reset or host
2516		 * reset.
2517		 *
2518		 * What we could do is put together a scsi command
2519		 * solely for the purpose of sending an abort message
2520		 * to the target.  Coming up with all the code to
2521		 * cook up scsi commands, special case them everywhere,
2522		 * etc. is for questionable gain and it would be better
2523		 * if the generic scsi error handling layer could do at
2524		 * least some of that for us.
2525		 *
2526		 * Anyways this is an area for potential future improvement
2527		 * in this driver.
2528		 */
2529		goto out_failure;
2530	}
2531
2532	spin_unlock_irqrestore(esp->host->host_lock, flags);
2533
2534	if (!wait_for_completion_timeout(&eh_done, 5 * HZ)) {
2535		spin_lock_irqsave(esp->host->host_lock, flags);
2536		ent->eh_done = NULL;
2537		spin_unlock_irqrestore(esp->host->host_lock, flags);
2538
2539		return FAILED;
2540	}
2541
2542	return SUCCESS;
2543
2544out_success:
2545	spin_unlock_irqrestore(esp->host->host_lock, flags);
2546	return SUCCESS;
2547
2548out_failure:
2549	/* XXX This might be a good location to set ESP_TGT_BROKEN
2550	 * XXX since we know which target/lun in particular is
2551	 * XXX causing trouble.
2552	 */
2553	spin_unlock_irqrestore(esp->host->host_lock, flags);
2554	return FAILED;
2555}
2556
2557static int esp_eh_bus_reset_handler(struct scsi_cmnd *cmd)
2558{
2559	struct esp *esp = shost_priv(cmd->device->host);
2560	struct completion eh_reset;
2561	unsigned long flags;
2562
2563	init_completion(&eh_reset);
2564
2565	spin_lock_irqsave(esp->host->host_lock, flags);
2566
2567	esp->eh_reset = &eh_reset;
2568
2569	/* XXX This is too simple... We should add lots of
2570	 * XXX checks here so that if we find that the chip is
2571	 * XXX very wedged we return failure immediately so
2572	 * XXX that we can perform a full chip reset.
2573	 */
2574	esp->flags |= ESP_FLAG_RESETTING;
2575	scsi_esp_cmd(esp, ESP_CMD_RS);
2576
2577	spin_unlock_irqrestore(esp->host->host_lock, flags);
2578
2579	ssleep(esp_bus_reset_settle);
2580
2581	if (!wait_for_completion_timeout(&eh_reset, 5 * HZ)) {
2582		spin_lock_irqsave(esp->host->host_lock, flags);
2583		esp->eh_reset = NULL;
2584		spin_unlock_irqrestore(esp->host->host_lock, flags);
2585
2586		return FAILED;
2587	}
2588
2589	return SUCCESS;
2590}
2591
2592/* All bets are off, reset the entire device.  */
2593static int esp_eh_host_reset_handler(struct scsi_cmnd *cmd)
2594{
2595	struct esp *esp = shost_priv(cmd->device->host);
2596	unsigned long flags;
2597
2598	spin_lock_irqsave(esp->host->host_lock, flags);
2599	esp_bootup_reset(esp);
2600	esp_reset_cleanup(esp);
2601	spin_unlock_irqrestore(esp->host->host_lock, flags);
2602
2603	ssleep(esp_bus_reset_settle);
2604
2605	return SUCCESS;
2606}
2607
2608static const char *esp_info(struct Scsi_Host *host)
2609{
2610	return "esp";
2611}
2612
2613struct scsi_host_template scsi_esp_template = {
2614	.module			= THIS_MODULE,
2615	.name			= "esp",
2616	.info			= esp_info,
2617	.queuecommand		= esp_queuecommand,
2618	.target_alloc		= esp_target_alloc,
2619	.target_destroy		= esp_target_destroy,
2620	.slave_alloc		= esp_slave_alloc,
2621	.slave_configure	= esp_slave_configure,
2622	.slave_destroy		= esp_slave_destroy,
2623	.eh_abort_handler	= esp_eh_abort_handler,
2624	.eh_bus_reset_handler	= esp_eh_bus_reset_handler,
2625	.eh_host_reset_handler	= esp_eh_host_reset_handler,
2626	.can_queue		= 7,
2627	.this_id		= 7,
2628	.sg_tablesize		= SG_ALL,
2629	.use_clustering		= ENABLE_CLUSTERING,
2630	.max_sectors		= 0xffff,
2631	.skip_settle_delay	= 1,
2632};
2633EXPORT_SYMBOL(scsi_esp_template);
2634
2635static void esp_get_signalling(struct Scsi_Host *host)
2636{
2637	struct esp *esp = shost_priv(host);
2638	enum spi_signal_type type;
2639
2640	if (esp->flags & ESP_FLAG_DIFFERENTIAL)
2641		type = SPI_SIGNAL_HVD;
2642	else
2643		type = SPI_SIGNAL_SE;
2644
2645	spi_signalling(host) = type;
2646}
2647
2648static void esp_set_offset(struct scsi_target *target, int offset)
2649{
2650	struct Scsi_Host *host = dev_to_shost(target->dev.parent);
2651	struct esp *esp = shost_priv(host);
2652	struct esp_target_data *tp = &esp->target[target->id];
2653
2654	if (esp->flags & ESP_FLAG_DISABLE_SYNC)
2655		tp->nego_goal_offset = 0;
2656	else
2657		tp->nego_goal_offset = offset;
2658	tp->flags |= ESP_TGT_CHECK_NEGO;
2659}
2660
2661static void esp_set_period(struct scsi_target *target, int period)
2662{
2663	struct Scsi_Host *host = dev_to_shost(target->dev.parent);
2664	struct esp *esp = shost_priv(host);
2665	struct esp_target_data *tp = &esp->target[target->id];
2666
2667	tp->nego_goal_period = period;
2668	tp->flags |= ESP_TGT_CHECK_NEGO;
2669}
2670
2671static void esp_set_width(struct scsi_target *target, int width)
2672{
2673	struct Scsi_Host *host = dev_to_shost(target->dev.parent);
2674	struct esp *esp = shost_priv(host);
2675	struct esp_target_data *tp = &esp->target[target->id];
2676
2677	tp->nego_goal_width = (width ? 1 : 0);
2678	tp->flags |= ESP_TGT_CHECK_NEGO;
2679}
2680
2681static struct spi_function_template esp_transport_ops = {
2682	.set_offset		= esp_set_offset,
2683	.show_offset		= 1,
2684	.set_period		= esp_set_period,
2685	.show_period		= 1,
2686	.set_width		= esp_set_width,
2687	.show_width		= 1,
2688	.get_signalling		= esp_get_signalling,
2689};
2690
2691static int __init esp_init(void)
2692{
2693	BUILD_BUG_ON(sizeof(struct scsi_pointer) <
2694		     sizeof(struct esp_cmd_priv));
2695
2696	esp_transport_template = spi_attach_transport(&esp_transport_ops);
2697	if (!esp_transport_template)
2698		return -ENODEV;
2699
2700	return 0;
2701}
2702
2703static void __exit esp_exit(void)
2704{
2705	spi_release_transport(esp_transport_template);
2706}
2707
2708MODULE_DESCRIPTION("ESP SCSI driver core");
2709MODULE_AUTHOR("David S. Miller (davem@davemloft.net)");
2710MODULE_LICENSE("GPL");
2711MODULE_VERSION(DRV_VERSION);
2712
2713module_param(esp_bus_reset_settle, int, 0);
2714MODULE_PARM_DESC(esp_bus_reset_settle,
2715		 "ESP scsi bus reset delay in seconds");
2716
2717module_param(esp_debug, int, 0);
2718MODULE_PARM_DESC(esp_debug,
2719"ESP bitmapped debugging message enable value:\n"
2720"	0x00000001	Log interrupt events\n"
2721"	0x00000002	Log scsi commands\n"
2722"	0x00000004	Log resets\n"
2723"	0x00000008	Log message in events\n"
2724"	0x00000010	Log message out events\n"
2725"	0x00000020	Log command completion\n"
2726"	0x00000040	Log disconnects\n"
2727"	0x00000080	Log data start\n"
2728"	0x00000100	Log data done\n"
2729"	0x00000200	Log reconnects\n"
2730"	0x00000400	Log auto-sense data\n"
2731);
2732
2733module_init(esp_init);
2734module_exit(esp_exit);
v4.6
   1/* esp_scsi.c: ESP SCSI driver.
   2 *
   3 * Copyright (C) 2007 David S. Miller (davem@davemloft.net)
   4 */
   5
   6#include <linux/kernel.h>
   7#include <linux/types.h>
   8#include <linux/slab.h>
   9#include <linux/delay.h>
  10#include <linux/list.h>
  11#include <linux/completion.h>
  12#include <linux/kallsyms.h>
  13#include <linux/module.h>
  14#include <linux/moduleparam.h>
  15#include <linux/init.h>
  16#include <linux/irqreturn.h>
  17
  18#include <asm/irq.h>
  19#include <asm/io.h>
  20#include <asm/dma.h>
  21
  22#include <scsi/scsi.h>
  23#include <scsi/scsi_host.h>
  24#include <scsi/scsi_cmnd.h>
  25#include <scsi/scsi_device.h>
  26#include <scsi/scsi_tcq.h>
  27#include <scsi/scsi_dbg.h>
  28#include <scsi/scsi_transport_spi.h>
  29
  30#include "esp_scsi.h"
  31
  32#define DRV_MODULE_NAME		"esp"
  33#define PFX DRV_MODULE_NAME	": "
  34#define DRV_VERSION		"2.000"
  35#define DRV_MODULE_RELDATE	"April 19, 2007"
  36
  37/* SCSI bus reset settle time in seconds.  */
  38static int esp_bus_reset_settle = 3;
  39
  40static u32 esp_debug;
  41#define ESP_DEBUG_INTR		0x00000001
  42#define ESP_DEBUG_SCSICMD	0x00000002
  43#define ESP_DEBUG_RESET		0x00000004
  44#define ESP_DEBUG_MSGIN		0x00000008
  45#define ESP_DEBUG_MSGOUT	0x00000010
  46#define ESP_DEBUG_CMDDONE	0x00000020
  47#define ESP_DEBUG_DISCONNECT	0x00000040
  48#define ESP_DEBUG_DATASTART	0x00000080
  49#define ESP_DEBUG_DATADONE	0x00000100
  50#define ESP_DEBUG_RECONNECT	0x00000200
  51#define ESP_DEBUG_AUTOSENSE	0x00000400
  52#define ESP_DEBUG_EVENT		0x00000800
  53#define ESP_DEBUG_COMMAND	0x00001000
  54
  55#define esp_log_intr(f, a...) \
  56do {	if (esp_debug & ESP_DEBUG_INTR) \
  57		shost_printk(KERN_DEBUG, esp->host, f, ## a);	\
  58} while (0)
  59
  60#define esp_log_reset(f, a...) \
  61do {	if (esp_debug & ESP_DEBUG_RESET) \
  62		shost_printk(KERN_DEBUG, esp->host, f, ## a);	\
  63} while (0)
  64
  65#define esp_log_msgin(f, a...) \
  66do {	if (esp_debug & ESP_DEBUG_MSGIN) \
  67		shost_printk(KERN_DEBUG, esp->host, f, ## a);	\
  68} while (0)
  69
  70#define esp_log_msgout(f, a...) \
  71do {	if (esp_debug & ESP_DEBUG_MSGOUT) \
  72		shost_printk(KERN_DEBUG, esp->host, f, ## a);	\
  73} while (0)
  74
  75#define esp_log_cmddone(f, a...) \
  76do {	if (esp_debug & ESP_DEBUG_CMDDONE) \
  77		shost_printk(KERN_DEBUG, esp->host, f, ## a);	\
  78} while (0)
  79
  80#define esp_log_disconnect(f, a...) \
  81do {	if (esp_debug & ESP_DEBUG_DISCONNECT) \
  82		shost_printk(KERN_DEBUG, esp->host, f, ## a);	\
  83} while (0)
  84
  85#define esp_log_datastart(f, a...) \
  86do {	if (esp_debug & ESP_DEBUG_DATASTART) \
  87		shost_printk(KERN_DEBUG, esp->host, f, ## a);	\
  88} while (0)
  89
  90#define esp_log_datadone(f, a...) \
  91do {	if (esp_debug & ESP_DEBUG_DATADONE) \
  92		shost_printk(KERN_DEBUG, esp->host, f, ## a);	\
  93} while (0)
  94
  95#define esp_log_reconnect(f, a...) \
  96do {	if (esp_debug & ESP_DEBUG_RECONNECT) \
  97		shost_printk(KERN_DEBUG, esp->host, f, ## a);	\
  98} while (0)
  99
 100#define esp_log_autosense(f, a...) \
 101do {	if (esp_debug & ESP_DEBUG_AUTOSENSE) \
 102		shost_printk(KERN_DEBUG, esp->host, f, ## a);	\
 103} while (0)
 104
 105#define esp_log_event(f, a...) \
 106do {   if (esp_debug & ESP_DEBUG_EVENT)	\
 107		shost_printk(KERN_DEBUG, esp->host, f, ## a);	\
 108} while (0)
 109
 110#define esp_log_command(f, a...) \
 111do {   if (esp_debug & ESP_DEBUG_COMMAND)	\
 112		shost_printk(KERN_DEBUG, esp->host, f, ## a);	\
 113} while (0)
 114
 115#define esp_read8(REG)		esp->ops->esp_read8(esp, REG)
 116#define esp_write8(VAL,REG)	esp->ops->esp_write8(esp, VAL, REG)
 117
 118static void esp_log_fill_regs(struct esp *esp,
 119			      struct esp_event_ent *p)
 120{
 121	p->sreg = esp->sreg;
 122	p->seqreg = esp->seqreg;
 123	p->sreg2 = esp->sreg2;
 124	p->ireg = esp->ireg;
 125	p->select_state = esp->select_state;
 126	p->event = esp->event;
 127}
 128
 129void scsi_esp_cmd(struct esp *esp, u8 val)
 130{
 131	struct esp_event_ent *p;
 132	int idx = esp->esp_event_cur;
 133
 134	p = &esp->esp_event_log[idx];
 135	p->type = ESP_EVENT_TYPE_CMD;
 136	p->val = val;
 137	esp_log_fill_regs(esp, p);
 138
 139	esp->esp_event_cur = (idx + 1) & (ESP_EVENT_LOG_SZ - 1);
 140
 141	esp_log_command("cmd[%02x]\n", val);
 142	esp_write8(val, ESP_CMD);
 143}
 144EXPORT_SYMBOL(scsi_esp_cmd);
 145
 146static void esp_send_dma_cmd(struct esp *esp, int len, int max_len, int cmd)
 147{
 148	if (esp->flags & ESP_FLAG_USE_FIFO) {
 149		int i;
 150
 151		scsi_esp_cmd(esp, ESP_CMD_FLUSH);
 152		for (i = 0; i < len; i++)
 153			esp_write8(esp->command_block[i], ESP_FDATA);
 154		scsi_esp_cmd(esp, cmd);
 155	} else {
 156		if (esp->rev == FASHME)
 157			scsi_esp_cmd(esp, ESP_CMD_FLUSH);
 158		cmd |= ESP_CMD_DMA;
 159		esp->ops->send_dma_cmd(esp, esp->command_block_dma,
 160				       len, max_len, 0, cmd);
 161	}
 162}
 163
 164static void esp_event(struct esp *esp, u8 val)
 165{
 166	struct esp_event_ent *p;
 167	int idx = esp->esp_event_cur;
 168
 169	p = &esp->esp_event_log[idx];
 170	p->type = ESP_EVENT_TYPE_EVENT;
 171	p->val = val;
 172	esp_log_fill_regs(esp, p);
 173
 174	esp->esp_event_cur = (idx + 1) & (ESP_EVENT_LOG_SZ - 1);
 175
 176	esp->event = val;
 177}
 178
 179static void esp_dump_cmd_log(struct esp *esp)
 180{
 181	int idx = esp->esp_event_cur;
 182	int stop = idx;
 183
 184	shost_printk(KERN_INFO, esp->host, "Dumping command log\n");
 
 185	do {
 186		struct esp_event_ent *p = &esp->esp_event_log[idx];
 187
 188		shost_printk(KERN_INFO, esp->host,
 189			     "ent[%d] %s val[%02x] sreg[%02x] seqreg[%02x] "
 190			     "sreg2[%02x] ireg[%02x] ss[%02x] event[%02x]\n",
 191			     idx,
 192			     p->type == ESP_EVENT_TYPE_CMD ? "CMD" : "EVENT",
 193			     p->val, p->sreg, p->seqreg,
 194			     p->sreg2, p->ireg, p->select_state, p->event);
 
 195
 196		idx = (idx + 1) & (ESP_EVENT_LOG_SZ - 1);
 197	} while (idx != stop);
 198}
 199
 200static void esp_flush_fifo(struct esp *esp)
 201{
 202	scsi_esp_cmd(esp, ESP_CMD_FLUSH);
 203	if (esp->rev == ESP236) {
 204		int lim = 1000;
 205
 206		while (esp_read8(ESP_FFLAGS) & ESP_FF_FBYTES) {
 207			if (--lim == 0) {
 208				shost_printk(KERN_ALERT, esp->host,
 209					     "ESP_FF_BYTES will not clear!\n");
 
 210				break;
 211			}
 212			udelay(1);
 213		}
 214	}
 215}
 216
 217static void hme_read_fifo(struct esp *esp)
 218{
 219	int fcnt = esp_read8(ESP_FFLAGS) & ESP_FF_FBYTES;
 220	int idx = 0;
 221
 222	while (fcnt--) {
 223		esp->fifo[idx++] = esp_read8(ESP_FDATA);
 224		esp->fifo[idx++] = esp_read8(ESP_FDATA);
 225	}
 226	if (esp->sreg2 & ESP_STAT2_F1BYTE) {
 227		esp_write8(0, ESP_FDATA);
 228		esp->fifo[idx++] = esp_read8(ESP_FDATA);
 229		scsi_esp_cmd(esp, ESP_CMD_FLUSH);
 230	}
 231	esp->fifo_cnt = idx;
 232}
 233
 234static void esp_set_all_config3(struct esp *esp, u8 val)
 235{
 236	int i;
 237
 238	for (i = 0; i < ESP_MAX_TARGET; i++)
 239		esp->target[i].esp_config3 = val;
 240}
 241
 242/* Reset the ESP chip, _not_ the SCSI bus. */
 243static void esp_reset_esp(struct esp *esp)
 244{
 245	u8 family_code, version;
 246
 247	/* Now reset the ESP chip */
 248	scsi_esp_cmd(esp, ESP_CMD_RC);
 249	scsi_esp_cmd(esp, ESP_CMD_NULL | ESP_CMD_DMA);
 250	if (esp->rev == FAST)
 251		esp_write8(ESP_CONFIG2_FENAB, ESP_CFG2);
 252	scsi_esp_cmd(esp, ESP_CMD_NULL | ESP_CMD_DMA);
 253
 254	/* This is the only point at which it is reliable to read
 255	 * the ID-code for a fast ESP chip variants.
 256	 */
 257	esp->max_period = ((35 * esp->ccycle) / 1000);
 258	if (esp->rev == FAST) {
 259		version = esp_read8(ESP_UID);
 260		family_code = (version & 0xf8) >> 3;
 261		if (family_code == 0x02)
 262			esp->rev = FAS236;
 263		else if (family_code == 0x0a)
 264			esp->rev = FASHME; /* Version is usually '5'. */
 265		else
 266			esp->rev = FAS100A;
 267		esp->min_period = ((4 * esp->ccycle) / 1000);
 268	} else {
 269		esp->min_period = ((5 * esp->ccycle) / 1000);
 270	}
 271	if (esp->rev == FAS236) {
 272		/*
 273		 * The AM53c974 chip returns the same ID as FAS236;
 274		 * try to configure glitch eater.
 275		 */
 276		u8 config4 = ESP_CONFIG4_GE1;
 277		esp_write8(config4, ESP_CFG4);
 278		config4 = esp_read8(ESP_CFG4);
 279		if (config4 & ESP_CONFIG4_GE1) {
 280			esp->rev = PCSCSI;
 281			esp_write8(esp->config4, ESP_CFG4);
 282		}
 283	}
 284	esp->max_period = (esp->max_period + 3)>>2;
 285	esp->min_period = (esp->min_period + 3)>>2;
 286
 287	esp_write8(esp->config1, ESP_CFG1);
 288	switch (esp->rev) {
 289	case ESP100:
 290		/* nothing to do */
 291		break;
 292
 293	case ESP100A:
 294		esp_write8(esp->config2, ESP_CFG2);
 295		break;
 296
 297	case ESP236:
 298		/* Slow 236 */
 299		esp_write8(esp->config2, ESP_CFG2);
 300		esp->prev_cfg3 = esp->target[0].esp_config3;
 301		esp_write8(esp->prev_cfg3, ESP_CFG3);
 302		break;
 303
 304	case FASHME:
 305		esp->config2 |= (ESP_CONFIG2_HME32 | ESP_CONFIG2_HMEFENAB);
 306		/* fallthrough... */
 307
 308	case FAS236:
 309	case PCSCSI:
 310		/* Fast 236, AM53c974 or HME */
 311		esp_write8(esp->config2, ESP_CFG2);
 312		if (esp->rev == FASHME) {
 313			u8 cfg3 = esp->target[0].esp_config3;
 314
 315			cfg3 |= ESP_CONFIG3_FCLOCK | ESP_CONFIG3_OBPUSH;
 316			if (esp->scsi_id >= 8)
 317				cfg3 |= ESP_CONFIG3_IDBIT3;
 318			esp_set_all_config3(esp, cfg3);
 319		} else {
 320			u32 cfg3 = esp->target[0].esp_config3;
 321
 322			cfg3 |= ESP_CONFIG3_FCLK;
 323			esp_set_all_config3(esp, cfg3);
 324		}
 325		esp->prev_cfg3 = esp->target[0].esp_config3;
 326		esp_write8(esp->prev_cfg3, ESP_CFG3);
 327		if (esp->rev == FASHME) {
 328			esp->radelay = 80;
 329		} else {
 330			if (esp->flags & ESP_FLAG_DIFFERENTIAL)
 331				esp->radelay = 0;
 332			else
 333				esp->radelay = 96;
 334		}
 335		break;
 336
 337	case FAS100A:
 338		/* Fast 100a */
 339		esp_write8(esp->config2, ESP_CFG2);
 340		esp_set_all_config3(esp,
 341				    (esp->target[0].esp_config3 |
 342				     ESP_CONFIG3_FCLOCK));
 343		esp->prev_cfg3 = esp->target[0].esp_config3;
 344		esp_write8(esp->prev_cfg3, ESP_CFG3);
 345		esp->radelay = 32;
 346		break;
 347
 348	default:
 349		break;
 350	}
 351
 352	/* Reload the configuration registers */
 353	esp_write8(esp->cfact, ESP_CFACT);
 354
 355	esp->prev_stp = 0;
 356	esp_write8(esp->prev_stp, ESP_STP);
 357
 358	esp->prev_soff = 0;
 359	esp_write8(esp->prev_soff, ESP_SOFF);
 360
 361	esp_write8(esp->neg_defp, ESP_TIMEO);
 362
 363	/* Eat any bitrot in the chip */
 364	esp_read8(ESP_INTRPT);
 365	udelay(100);
 366}
 367
 368static void esp_map_dma(struct esp *esp, struct scsi_cmnd *cmd)
 369{
 370	struct esp_cmd_priv *spriv = ESP_CMD_PRIV(cmd);
 371	struct scatterlist *sg = scsi_sglist(cmd);
 372	int dir = cmd->sc_data_direction;
 373	int total, i;
 374
 375	if (dir == DMA_NONE)
 376		return;
 377
 378	spriv->u.num_sg = esp->ops->map_sg(esp, sg, scsi_sg_count(cmd), dir);
 379	spriv->cur_residue = sg_dma_len(sg);
 380	spriv->cur_sg = sg;
 381
 382	total = 0;
 383	for (i = 0; i < spriv->u.num_sg; i++)
 384		total += sg_dma_len(&sg[i]);
 385	spriv->tot_residue = total;
 386}
 387
 388static dma_addr_t esp_cur_dma_addr(struct esp_cmd_entry *ent,
 389				   struct scsi_cmnd *cmd)
 390{
 391	struct esp_cmd_priv *p = ESP_CMD_PRIV(cmd);
 392
 393	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 394		return ent->sense_dma +
 395			(ent->sense_ptr - cmd->sense_buffer);
 396	}
 397
 398	return sg_dma_address(p->cur_sg) +
 399		(sg_dma_len(p->cur_sg) -
 400		 p->cur_residue);
 401}
 402
 403static unsigned int esp_cur_dma_len(struct esp_cmd_entry *ent,
 404				    struct scsi_cmnd *cmd)
 405{
 406	struct esp_cmd_priv *p = ESP_CMD_PRIV(cmd);
 407
 408	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 409		return SCSI_SENSE_BUFFERSIZE -
 410			(ent->sense_ptr - cmd->sense_buffer);
 411	}
 412	return p->cur_residue;
 413}
 414
 415static void esp_advance_dma(struct esp *esp, struct esp_cmd_entry *ent,
 416			    struct scsi_cmnd *cmd, unsigned int len)
 417{
 418	struct esp_cmd_priv *p = ESP_CMD_PRIV(cmd);
 419
 420	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 421		ent->sense_ptr += len;
 422		return;
 423	}
 424
 425	p->cur_residue -= len;
 426	p->tot_residue -= len;
 427	if (p->cur_residue < 0 || p->tot_residue < 0) {
 428		shost_printk(KERN_ERR, esp->host,
 429			     "Data transfer overflow.\n");
 430		shost_printk(KERN_ERR, esp->host,
 431			     "cur_residue[%d] tot_residue[%d] len[%u]\n",
 432			     p->cur_residue, p->tot_residue, len);
 
 433		p->cur_residue = 0;
 434		p->tot_residue = 0;
 435	}
 436	if (!p->cur_residue && p->tot_residue) {
 437		p->cur_sg++;
 438		p->cur_residue = sg_dma_len(p->cur_sg);
 439	}
 440}
 441
 442static void esp_unmap_dma(struct esp *esp, struct scsi_cmnd *cmd)
 443{
 444	struct esp_cmd_priv *spriv = ESP_CMD_PRIV(cmd);
 445	int dir = cmd->sc_data_direction;
 446
 447	if (dir == DMA_NONE)
 448		return;
 449
 450	esp->ops->unmap_sg(esp, scsi_sglist(cmd), spriv->u.num_sg, dir);
 451}
 452
 453static void esp_save_pointers(struct esp *esp, struct esp_cmd_entry *ent)
 454{
 455	struct scsi_cmnd *cmd = ent->cmd;
 456	struct esp_cmd_priv *spriv = ESP_CMD_PRIV(cmd);
 457
 458	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 459		ent->saved_sense_ptr = ent->sense_ptr;
 460		return;
 461	}
 462	ent->saved_cur_residue = spriv->cur_residue;
 463	ent->saved_cur_sg = spriv->cur_sg;
 464	ent->saved_tot_residue = spriv->tot_residue;
 465}
 466
 467static void esp_restore_pointers(struct esp *esp, struct esp_cmd_entry *ent)
 468{
 469	struct scsi_cmnd *cmd = ent->cmd;
 470	struct esp_cmd_priv *spriv = ESP_CMD_PRIV(cmd);
 471
 472	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 473		ent->sense_ptr = ent->saved_sense_ptr;
 474		return;
 475	}
 476	spriv->cur_residue = ent->saved_cur_residue;
 477	spriv->cur_sg = ent->saved_cur_sg;
 478	spriv->tot_residue = ent->saved_tot_residue;
 479}
 480
 481static void esp_check_command_len(struct esp *esp, struct scsi_cmnd *cmd)
 482{
 483	if (cmd->cmd_len == 6 ||
 484	    cmd->cmd_len == 10 ||
 485	    cmd->cmd_len == 12) {
 486		esp->flags &= ~ESP_FLAG_DOING_SLOWCMD;
 487	} else {
 488		esp->flags |= ESP_FLAG_DOING_SLOWCMD;
 489	}
 490}
 491
 492static void esp_write_tgt_config3(struct esp *esp, int tgt)
 493{
 494	if (esp->rev > ESP100A) {
 495		u8 val = esp->target[tgt].esp_config3;
 496
 497		if (val != esp->prev_cfg3) {
 498			esp->prev_cfg3 = val;
 499			esp_write8(val, ESP_CFG3);
 500		}
 501	}
 502}
 503
 504static void esp_write_tgt_sync(struct esp *esp, int tgt)
 505{
 506	u8 off = esp->target[tgt].esp_offset;
 507	u8 per = esp->target[tgt].esp_period;
 508
 509	if (off != esp->prev_soff) {
 510		esp->prev_soff = off;
 511		esp_write8(off, ESP_SOFF);
 512	}
 513	if (per != esp->prev_stp) {
 514		esp->prev_stp = per;
 515		esp_write8(per, ESP_STP);
 516	}
 517}
 518
 519static u32 esp_dma_length_limit(struct esp *esp, u32 dma_addr, u32 dma_len)
 520{
 521	if (esp->rev == FASHME) {
 522		/* Arbitrary segment boundaries, 24-bit counts.  */
 523		if (dma_len > (1U << 24))
 524			dma_len = (1U << 24);
 525	} else {
 526		u32 base, end;
 527
 528		/* ESP chip limits other variants by 16-bits of transfer
 529		 * count.  Actually on FAS100A and FAS236 we could get
 530		 * 24-bits of transfer count by enabling ESP_CONFIG2_FENAB
 531		 * in the ESP_CFG2 register but that causes other unwanted
 532		 * changes so we don't use it currently.
 533		 */
 534		if (dma_len > (1U << 16))
 535			dma_len = (1U << 16);
 536
 537		/* All of the DMA variants hooked up to these chips
 538		 * cannot handle crossing a 24-bit address boundary.
 539		 */
 540		base = dma_addr & ((1U << 24) - 1U);
 541		end = base + dma_len;
 542		if (end > (1U << 24))
 543			end = (1U <<24);
 544		dma_len = end - base;
 545	}
 546	return dma_len;
 547}
 548
 549static int esp_need_to_nego_wide(struct esp_target_data *tp)
 550{
 551	struct scsi_target *target = tp->starget;
 552
 553	return spi_width(target) != tp->nego_goal_width;
 554}
 555
 556static int esp_need_to_nego_sync(struct esp_target_data *tp)
 557{
 558	struct scsi_target *target = tp->starget;
 559
 560	/* When offset is zero, period is "don't care".  */
 561	if (!spi_offset(target) && !tp->nego_goal_offset)
 562		return 0;
 563
 564	if (spi_offset(target) == tp->nego_goal_offset &&
 565	    spi_period(target) == tp->nego_goal_period)
 566		return 0;
 567
 568	return 1;
 569}
 570
 571static int esp_alloc_lun_tag(struct esp_cmd_entry *ent,
 572			     struct esp_lun_data *lp)
 573{
 574	if (!ent->orig_tag[0]) {
 575		/* Non-tagged, slot already taken?  */
 576		if (lp->non_tagged_cmd)
 577			return -EBUSY;
 578
 579		if (lp->hold) {
 580			/* We are being held by active tagged
 581			 * commands.
 582			 */
 583			if (lp->num_tagged)
 584				return -EBUSY;
 585
 586			/* Tagged commands completed, we can unplug
 587			 * the queue and run this untagged command.
 588			 */
 589			lp->hold = 0;
 590		} else if (lp->num_tagged) {
 591			/* Plug the queue until num_tagged decreases
 592			 * to zero in esp_free_lun_tag.
 593			 */
 594			lp->hold = 1;
 595			return -EBUSY;
 596		}
 597
 598		lp->non_tagged_cmd = ent;
 599		return 0;
 600	} else {
 601		/* Tagged command, see if blocked by a
 602		 * non-tagged one.
 603		 */
 604		if (lp->non_tagged_cmd || lp->hold)
 605			return -EBUSY;
 606	}
 607
 608	BUG_ON(lp->tagged_cmds[ent->orig_tag[1]]);
 609
 610	lp->tagged_cmds[ent->orig_tag[1]] = ent;
 611	lp->num_tagged++;
 612
 613	return 0;
 614}
 615
 616static void esp_free_lun_tag(struct esp_cmd_entry *ent,
 617			     struct esp_lun_data *lp)
 618{
 619	if (ent->orig_tag[0]) {
 620		BUG_ON(lp->tagged_cmds[ent->orig_tag[1]] != ent);
 621		lp->tagged_cmds[ent->orig_tag[1]] = NULL;
 622		lp->num_tagged--;
 623	} else {
 624		BUG_ON(lp->non_tagged_cmd != ent);
 625		lp->non_tagged_cmd = NULL;
 626	}
 627}
 628
 629/* When a contingent allegiance conditon is created, we force feed a
 630 * REQUEST_SENSE command to the device to fetch the sense data.  I
 631 * tried many other schemes, relying on the scsi error handling layer
 632 * to send out the REQUEST_SENSE automatically, but this was difficult
 633 * to get right especially in the presence of applications like smartd
 634 * which use SG_IO to send out their own REQUEST_SENSE commands.
 635 */
 636static void esp_autosense(struct esp *esp, struct esp_cmd_entry *ent)
 637{
 638	struct scsi_cmnd *cmd = ent->cmd;
 639	struct scsi_device *dev = cmd->device;
 640	int tgt, lun;
 641	u8 *p, val;
 642
 643	tgt = dev->id;
 644	lun = dev->lun;
 645
 646
 647	if (!ent->sense_ptr) {
 648		esp_log_autosense("Doing auto-sense for tgt[%d] lun[%d]\n",
 649				  tgt, lun);
 
 650
 651		ent->sense_ptr = cmd->sense_buffer;
 652		ent->sense_dma = esp->ops->map_single(esp,
 653						      ent->sense_ptr,
 654						      SCSI_SENSE_BUFFERSIZE,
 655						      DMA_FROM_DEVICE);
 656	}
 657	ent->saved_sense_ptr = ent->sense_ptr;
 658
 659	esp->active_cmd = ent;
 660
 661	p = esp->command_block;
 662	esp->msg_out_len = 0;
 663
 664	*p++ = IDENTIFY(0, lun);
 665	*p++ = REQUEST_SENSE;
 666	*p++ = ((dev->scsi_level <= SCSI_2) ?
 667		(lun << 5) : 0);
 668	*p++ = 0;
 669	*p++ = 0;
 670	*p++ = SCSI_SENSE_BUFFERSIZE;
 671	*p++ = 0;
 672
 673	esp->select_state = ESP_SELECT_BASIC;
 674
 675	val = tgt;
 676	if (esp->rev == FASHME)
 677		val |= ESP_BUSID_RESELID | ESP_BUSID_CTR32BIT;
 678	esp_write8(val, ESP_BUSID);
 679
 680	esp_write_tgt_sync(esp, tgt);
 681	esp_write_tgt_config3(esp, tgt);
 682
 683	val = (p - esp->command_block);
 684
 685	esp_send_dma_cmd(esp, val, 16, ESP_CMD_SELA);
 
 
 
 686}
 687
 688static struct esp_cmd_entry *find_and_prep_issuable_command(struct esp *esp)
 689{
 690	struct esp_cmd_entry *ent;
 691
 692	list_for_each_entry(ent, &esp->queued_cmds, list) {
 693		struct scsi_cmnd *cmd = ent->cmd;
 694		struct scsi_device *dev = cmd->device;
 695		struct esp_lun_data *lp = dev->hostdata;
 696
 697		if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 698			ent->tag[0] = 0;
 699			ent->tag[1] = 0;
 700			return ent;
 701		}
 702
 703		if (!spi_populate_tag_msg(&ent->tag[0], cmd)) {
 704			ent->tag[0] = 0;
 705			ent->tag[1] = 0;
 706		}
 707		ent->orig_tag[0] = ent->tag[0];
 708		ent->orig_tag[1] = ent->tag[1];
 709
 710		if (esp_alloc_lun_tag(ent, lp) < 0)
 711			continue;
 712
 713		return ent;
 714	}
 715
 716	return NULL;
 717}
 718
 719static void esp_maybe_execute_command(struct esp *esp)
 720{
 721	struct esp_target_data *tp;
 722	struct esp_lun_data *lp;
 723	struct scsi_device *dev;
 724	struct scsi_cmnd *cmd;
 725	struct esp_cmd_entry *ent;
 726	int tgt, lun, i;
 727	u32 val, start_cmd;
 728	u8 *p;
 729
 730	if (esp->active_cmd ||
 731	    (esp->flags & ESP_FLAG_RESETTING))
 732		return;
 733
 734	ent = find_and_prep_issuable_command(esp);
 735	if (!ent)
 736		return;
 737
 738	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 739		esp_autosense(esp, ent);
 740		return;
 741	}
 742
 743	cmd = ent->cmd;
 744	dev = cmd->device;
 745	tgt = dev->id;
 746	lun = dev->lun;
 747	tp = &esp->target[tgt];
 748	lp = dev->hostdata;
 749
 750	list_move(&ent->list, &esp->active_cmds);
 751
 752	esp->active_cmd = ent;
 753
 754	esp_map_dma(esp, cmd);
 755	esp_save_pointers(esp, ent);
 756
 757	esp_check_command_len(esp, cmd);
 758
 759	p = esp->command_block;
 760
 761	esp->msg_out_len = 0;
 762	if (tp->flags & ESP_TGT_CHECK_NEGO) {
 763		/* Need to negotiate.  If the target is broken
 764		 * go for synchronous transfers and non-wide.
 765		 */
 766		if (tp->flags & ESP_TGT_BROKEN) {
 767			tp->flags &= ~ESP_TGT_DISCONNECT;
 768			tp->nego_goal_period = 0;
 769			tp->nego_goal_offset = 0;
 770			tp->nego_goal_width = 0;
 771			tp->nego_goal_tags = 0;
 772		}
 773
 774		/* If the settings are not changing, skip this.  */
 775		if (spi_width(tp->starget) == tp->nego_goal_width &&
 776		    spi_period(tp->starget) == tp->nego_goal_period &&
 777		    spi_offset(tp->starget) == tp->nego_goal_offset) {
 778			tp->flags &= ~ESP_TGT_CHECK_NEGO;
 779			goto build_identify;
 780		}
 781
 782		if (esp->rev == FASHME && esp_need_to_nego_wide(tp)) {
 783			esp->msg_out_len =
 784				spi_populate_width_msg(&esp->msg_out[0],
 785						       (tp->nego_goal_width ?
 786							1 : 0));
 787			tp->flags |= ESP_TGT_NEGO_WIDE;
 788		} else if (esp_need_to_nego_sync(tp)) {
 789			esp->msg_out_len =
 790				spi_populate_sync_msg(&esp->msg_out[0],
 791						      tp->nego_goal_period,
 792						      tp->nego_goal_offset);
 793			tp->flags |= ESP_TGT_NEGO_SYNC;
 794		} else {
 795			tp->flags &= ~ESP_TGT_CHECK_NEGO;
 796		}
 797
 798		/* Process it like a slow command.  */
 799		if (tp->flags & (ESP_TGT_NEGO_WIDE | ESP_TGT_NEGO_SYNC))
 800			esp->flags |= ESP_FLAG_DOING_SLOWCMD;
 801	}
 802
 803build_identify:
 804	/* If we don't have a lun-data struct yet, we're probing
 805	 * so do not disconnect.  Also, do not disconnect unless
 806	 * we have a tag on this command.
 807	 */
 808	if (lp && (tp->flags & ESP_TGT_DISCONNECT) && ent->tag[0])
 809		*p++ = IDENTIFY(1, lun);
 810	else
 811		*p++ = IDENTIFY(0, lun);
 812
 813	if (ent->tag[0] && esp->rev == ESP100) {
 814		/* ESP100 lacks select w/atn3 command, use select
 815		 * and stop instead.
 816		 */
 817		esp->flags |= ESP_FLAG_DOING_SLOWCMD;
 818	}
 819
 820	if (!(esp->flags & ESP_FLAG_DOING_SLOWCMD)) {
 821		start_cmd = ESP_CMD_SELA;
 822		if (ent->tag[0]) {
 823			*p++ = ent->tag[0];
 824			*p++ = ent->tag[1];
 825
 826			start_cmd = ESP_CMD_SA3;
 827		}
 828
 829		for (i = 0; i < cmd->cmd_len; i++)
 830			*p++ = cmd->cmnd[i];
 831
 832		esp->select_state = ESP_SELECT_BASIC;
 833	} else {
 834		esp->cmd_bytes_left = cmd->cmd_len;
 835		esp->cmd_bytes_ptr = &cmd->cmnd[0];
 836
 837		if (ent->tag[0]) {
 838			for (i = esp->msg_out_len - 1;
 839			     i >= 0; i--)
 840				esp->msg_out[i + 2] = esp->msg_out[i];
 841			esp->msg_out[0] = ent->tag[0];
 842			esp->msg_out[1] = ent->tag[1];
 843			esp->msg_out_len += 2;
 844		}
 845
 846		start_cmd = ESP_CMD_SELAS;
 847		esp->select_state = ESP_SELECT_MSGOUT;
 848	}
 849	val = tgt;
 850	if (esp->rev == FASHME)
 851		val |= ESP_BUSID_RESELID | ESP_BUSID_CTR32BIT;
 852	esp_write8(val, ESP_BUSID);
 853
 854	esp_write_tgt_sync(esp, tgt);
 855	esp_write_tgt_config3(esp, tgt);
 856
 857	val = (p - esp->command_block);
 858
 859	if (esp_debug & ESP_DEBUG_SCSICMD) {
 860		printk("ESP: tgt[%d] lun[%d] scsi_cmd [ ", tgt, lun);
 861		for (i = 0; i < cmd->cmd_len; i++)
 862			printk("%02x ", cmd->cmnd[i]);
 863		printk("]\n");
 864	}
 865
 866	esp_send_dma_cmd(esp, val, 16, start_cmd);
 
 
 
 867}
 868
 869static struct esp_cmd_entry *esp_get_ent(struct esp *esp)
 870{
 871	struct list_head *head = &esp->esp_cmd_pool;
 872	struct esp_cmd_entry *ret;
 873
 874	if (list_empty(head)) {
 875		ret = kzalloc(sizeof(struct esp_cmd_entry), GFP_ATOMIC);
 876	} else {
 877		ret = list_entry(head->next, struct esp_cmd_entry, list);
 878		list_del(&ret->list);
 879		memset(ret, 0, sizeof(*ret));
 880	}
 881	return ret;
 882}
 883
 884static void esp_put_ent(struct esp *esp, struct esp_cmd_entry *ent)
 885{
 886	list_add(&ent->list, &esp->esp_cmd_pool);
 887}
 888
 889static void esp_cmd_is_done(struct esp *esp, struct esp_cmd_entry *ent,
 890			    struct scsi_cmnd *cmd, unsigned int result)
 891{
 892	struct scsi_device *dev = cmd->device;
 893	int tgt = dev->id;
 894	int lun = dev->lun;
 895
 896	esp->active_cmd = NULL;
 897	esp_unmap_dma(esp, cmd);
 898	esp_free_lun_tag(ent, dev->hostdata);
 899	cmd->result = result;
 900
 901	if (ent->eh_done) {
 902		complete(ent->eh_done);
 903		ent->eh_done = NULL;
 904	}
 905
 906	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
 907		esp->ops->unmap_single(esp, ent->sense_dma,
 908				       SCSI_SENSE_BUFFERSIZE, DMA_FROM_DEVICE);
 909		ent->sense_ptr = NULL;
 910
 911		/* Restore the message/status bytes to what we actually
 912		 * saw originally.  Also, report that we are providing
 913		 * the sense data.
 914		 */
 915		cmd->result = ((DRIVER_SENSE << 24) |
 916			       (DID_OK << 16) |
 917			       (COMMAND_COMPLETE << 8) |
 918			       (SAM_STAT_CHECK_CONDITION << 0));
 919
 920		ent->flags &= ~ESP_CMD_FLAG_AUTOSENSE;
 921		if (esp_debug & ESP_DEBUG_AUTOSENSE) {
 922			int i;
 923
 924			printk("esp%d: tgt[%d] lun[%d] AUTO SENSE[ ",
 925			       esp->host->unique_id, tgt, lun);
 926			for (i = 0; i < 18; i++)
 927				printk("%02x ", cmd->sense_buffer[i]);
 928			printk("]\n");
 929		}
 930	}
 931
 932	cmd->scsi_done(cmd);
 933
 934	list_del(&ent->list);
 935	esp_put_ent(esp, ent);
 936
 937	esp_maybe_execute_command(esp);
 938}
 939
 940static unsigned int compose_result(unsigned int status, unsigned int message,
 941				   unsigned int driver_code)
 942{
 943	return (status | (message << 8) | (driver_code << 16));
 944}
 945
 946static void esp_event_queue_full(struct esp *esp, struct esp_cmd_entry *ent)
 947{
 948	struct scsi_device *dev = ent->cmd->device;
 949	struct esp_lun_data *lp = dev->hostdata;
 950
 951	scsi_track_queue_full(dev, lp->num_tagged - 1);
 952}
 953
 954static int esp_queuecommand_lck(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *))
 955{
 956	struct scsi_device *dev = cmd->device;
 957	struct esp *esp = shost_priv(dev->host);
 958	struct esp_cmd_priv *spriv;
 959	struct esp_cmd_entry *ent;
 960
 961	ent = esp_get_ent(esp);
 962	if (!ent)
 963		return SCSI_MLQUEUE_HOST_BUSY;
 964
 965	ent->cmd = cmd;
 966
 967	cmd->scsi_done = done;
 968
 969	spriv = ESP_CMD_PRIV(cmd);
 970	spriv->u.dma_addr = ~(dma_addr_t)0x0;
 971
 972	list_add_tail(&ent->list, &esp->queued_cmds);
 973
 974	esp_maybe_execute_command(esp);
 975
 976	return 0;
 977}
 978
 979static DEF_SCSI_QCMD(esp_queuecommand)
 980
 981static int esp_check_gross_error(struct esp *esp)
 982{
 983	if (esp->sreg & ESP_STAT_SPAM) {
 984		/* Gross Error, could be one of:
 985		 * - top of fifo overwritten
 986		 * - top of command register overwritten
 987		 * - DMA programmed with wrong direction
 988		 * - improper phase change
 989		 */
 990		shost_printk(KERN_ERR, esp->host,
 991			     "Gross error sreg[%02x]\n", esp->sreg);
 992		/* XXX Reset the chip. XXX */
 993		return 1;
 994	}
 995	return 0;
 996}
 997
 998static int esp_check_spur_intr(struct esp *esp)
 999{
1000	switch (esp->rev) {
1001	case ESP100:
1002	case ESP100A:
1003		/* The interrupt pending bit of the status register cannot
1004		 * be trusted on these revisions.
1005		 */
1006		esp->sreg &= ~ESP_STAT_INTR;
1007		break;
1008
1009	default:
1010		if (!(esp->sreg & ESP_STAT_INTR)) {
 
1011			if (esp->ireg & ESP_INTR_SR)
1012				return 1;
1013
1014			/* If the DMA is indicating interrupt pending and the
1015			 * ESP is not, the only possibility is a DMA error.
1016			 */
1017			if (!esp->ops->dma_error(esp)) {
1018				shost_printk(KERN_ERR, esp->host,
1019					     "Spurious irq, sreg=%02x.\n",
1020					     esp->sreg);
1021				return -1;
1022			}
1023
1024			shost_printk(KERN_ERR, esp->host, "DMA error\n");
 
1025
1026			/* XXX Reset the chip. XXX */
1027			return -1;
1028		}
1029		break;
1030	}
1031
1032	return 0;
1033}
1034
1035static void esp_schedule_reset(struct esp *esp)
1036{
1037	esp_log_reset("esp_schedule_reset() from %pf\n",
1038		      __builtin_return_address(0));
1039	esp->flags |= ESP_FLAG_RESETTING;
1040	esp_event(esp, ESP_EVENT_RESET);
1041}
1042
1043/* In order to avoid having to add a special half-reconnected state
1044 * into the driver we just sit here and poll through the rest of
1045 * the reselection process to get the tag message bytes.
1046 */
1047static struct esp_cmd_entry *esp_reconnect_with_tag(struct esp *esp,
1048						    struct esp_lun_data *lp)
1049{
1050	struct esp_cmd_entry *ent;
1051	int i;
1052
1053	if (!lp->num_tagged) {
1054		shost_printk(KERN_ERR, esp->host,
1055			     "Reconnect w/num_tagged==0\n");
1056		return NULL;
1057	}
1058
1059	esp_log_reconnect("reconnect tag, ");
1060
1061	for (i = 0; i < ESP_QUICKIRQ_LIMIT; i++) {
1062		if (esp->ops->irq_pending(esp))
1063			break;
1064	}
1065	if (i == ESP_QUICKIRQ_LIMIT) {
1066		shost_printk(KERN_ERR, esp->host,
1067			     "Reconnect IRQ1 timeout\n");
1068		return NULL;
1069	}
1070
1071	esp->sreg = esp_read8(ESP_STATUS);
1072	esp->ireg = esp_read8(ESP_INTRPT);
1073
1074	esp_log_reconnect("IRQ(%d:%x:%x), ",
1075			  i, esp->ireg, esp->sreg);
1076
1077	if (esp->ireg & ESP_INTR_DC) {
1078		shost_printk(KERN_ERR, esp->host,
1079			     "Reconnect, got disconnect.\n");
1080		return NULL;
1081	}
1082
1083	if ((esp->sreg & ESP_STAT_PMASK) != ESP_MIP) {
1084		shost_printk(KERN_ERR, esp->host,
1085			     "Reconnect, not MIP sreg[%02x].\n", esp->sreg);
1086		return NULL;
1087	}
1088
1089	/* DMA in the tag bytes... */
1090	esp->command_block[0] = 0xff;
1091	esp->command_block[1] = 0xff;
1092	esp->ops->send_dma_cmd(esp, esp->command_block_dma,
1093			       2, 2, 1, ESP_CMD_DMA | ESP_CMD_TI);
1094
1095	/* ACK the message.  */
1096	scsi_esp_cmd(esp, ESP_CMD_MOK);
1097
1098	for (i = 0; i < ESP_RESELECT_TAG_LIMIT; i++) {
1099		if (esp->ops->irq_pending(esp)) {
1100			esp->sreg = esp_read8(ESP_STATUS);
1101			esp->ireg = esp_read8(ESP_INTRPT);
1102			if (esp->ireg & ESP_INTR_FDONE)
1103				break;
1104		}
1105		udelay(1);
1106	}
1107	if (i == ESP_RESELECT_TAG_LIMIT) {
1108		shost_printk(KERN_ERR, esp->host, "Reconnect IRQ2 timeout\n");
 
1109		return NULL;
1110	}
1111	esp->ops->dma_drain(esp);
1112	esp->ops->dma_invalidate(esp);
1113
1114	esp_log_reconnect("IRQ2(%d:%x:%x) tag[%x:%x]\n",
1115			  i, esp->ireg, esp->sreg,
1116			  esp->command_block[0],
1117			  esp->command_block[1]);
1118
1119	if (esp->command_block[0] < SIMPLE_QUEUE_TAG ||
1120	    esp->command_block[0] > ORDERED_QUEUE_TAG) {
1121		shost_printk(KERN_ERR, esp->host,
1122			     "Reconnect, bad tag type %02x.\n",
1123			     esp->command_block[0]);
1124		return NULL;
1125	}
1126
1127	ent = lp->tagged_cmds[esp->command_block[1]];
1128	if (!ent) {
1129		shost_printk(KERN_ERR, esp->host,
1130			     "Reconnect, no entry for tag %02x.\n",
1131			     esp->command_block[1]);
1132		return NULL;
1133	}
1134
1135	return ent;
1136}
1137
1138static int esp_reconnect(struct esp *esp)
1139{
1140	struct esp_cmd_entry *ent;
1141	struct esp_target_data *tp;
1142	struct esp_lun_data *lp;
1143	struct scsi_device *dev;
1144	int target, lun;
1145
1146	BUG_ON(esp->active_cmd);
1147	if (esp->rev == FASHME) {
1148		/* FASHME puts the target and lun numbers directly
1149		 * into the fifo.
1150		 */
1151		target = esp->fifo[0];
1152		lun = esp->fifo[1] & 0x7;
1153	} else {
1154		u8 bits = esp_read8(ESP_FDATA);
1155
1156		/* Older chips put the lun directly into the fifo, but
1157		 * the target is given as a sample of the arbitration
1158		 * lines on the bus at reselection time.  So we should
1159		 * see the ID of the ESP and the one reconnecting target
1160		 * set in the bitmap.
1161		 */
1162		if (!(bits & esp->scsi_id_mask))
1163			goto do_reset;
1164		bits &= ~esp->scsi_id_mask;
1165		if (!bits || (bits & (bits - 1)))
1166			goto do_reset;
1167
1168		target = ffs(bits) - 1;
1169		lun = (esp_read8(ESP_FDATA) & 0x7);
1170
1171		scsi_esp_cmd(esp, ESP_CMD_FLUSH);
1172		if (esp->rev == ESP100) {
1173			u8 ireg = esp_read8(ESP_INTRPT);
1174			/* This chip has a bug during reselection that can
1175			 * cause a spurious illegal-command interrupt, which
1176			 * we simply ACK here.  Another possibility is a bus
1177			 * reset so we must check for that.
1178			 */
1179			if (ireg & ESP_INTR_SR)
1180				goto do_reset;
1181		}
1182		scsi_esp_cmd(esp, ESP_CMD_NULL);
1183	}
1184
1185	esp_write_tgt_sync(esp, target);
1186	esp_write_tgt_config3(esp, target);
1187
1188	scsi_esp_cmd(esp, ESP_CMD_MOK);
1189
1190	if (esp->rev == FASHME)
1191		esp_write8(target | ESP_BUSID_RESELID | ESP_BUSID_CTR32BIT,
1192			   ESP_BUSID);
1193
1194	tp = &esp->target[target];
1195	dev = __scsi_device_lookup_by_target(tp->starget, lun);
1196	if (!dev) {
1197		shost_printk(KERN_ERR, esp->host,
1198			     "Reconnect, no lp tgt[%u] lun[%u]\n",
1199			     target, lun);
1200		goto do_reset;
1201	}
1202	lp = dev->hostdata;
1203
1204	ent = lp->non_tagged_cmd;
1205	if (!ent) {
1206		ent = esp_reconnect_with_tag(esp, lp);
1207		if (!ent)
1208			goto do_reset;
1209	}
1210
1211	esp->active_cmd = ent;
1212
1213	if (ent->flags & ESP_CMD_FLAG_ABORT) {
1214		esp->msg_out[0] = ABORT_TASK_SET;
1215		esp->msg_out_len = 1;
1216		scsi_esp_cmd(esp, ESP_CMD_SATN);
1217	}
1218
1219	esp_event(esp, ESP_EVENT_CHECK_PHASE);
1220	esp_restore_pointers(esp, ent);
1221	esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
1222	return 1;
1223
1224do_reset:
1225	esp_schedule_reset(esp);
1226	return 0;
1227}
1228
1229static int esp_finish_select(struct esp *esp)
1230{
1231	struct esp_cmd_entry *ent;
1232	struct scsi_cmnd *cmd;
1233	u8 orig_select_state;
1234
1235	orig_select_state = esp->select_state;
1236
1237	/* No longer selecting.  */
1238	esp->select_state = ESP_SELECT_NONE;
1239
1240	esp->seqreg = esp_read8(ESP_SSTEP) & ESP_STEP_VBITS;
1241	ent = esp->active_cmd;
1242	cmd = ent->cmd;
1243
1244	if (esp->ops->dma_error(esp)) {
1245		/* If we see a DMA error during or as a result of selection,
1246		 * all bets are off.
1247		 */
1248		esp_schedule_reset(esp);
1249		esp_cmd_is_done(esp, ent, cmd, (DID_ERROR << 16));
1250		return 0;
1251	}
1252
1253	esp->ops->dma_invalidate(esp);
1254
1255	if (esp->ireg == (ESP_INTR_RSEL | ESP_INTR_FDONE)) {
1256		struct esp_target_data *tp = &esp->target[cmd->device->id];
1257
1258		/* Carefully back out of the selection attempt.  Release
1259		 * resources (such as DMA mapping & TAG) and reset state (such
1260		 * as message out and command delivery variables).
1261		 */
1262		if (!(ent->flags & ESP_CMD_FLAG_AUTOSENSE)) {
1263			esp_unmap_dma(esp, cmd);
1264			esp_free_lun_tag(ent, cmd->device->hostdata);
1265			tp->flags &= ~(ESP_TGT_NEGO_SYNC | ESP_TGT_NEGO_WIDE);
1266			esp->flags &= ~ESP_FLAG_DOING_SLOWCMD;
1267			esp->cmd_bytes_ptr = NULL;
1268			esp->cmd_bytes_left = 0;
1269		} else {
1270			esp->ops->unmap_single(esp, ent->sense_dma,
1271					       SCSI_SENSE_BUFFERSIZE,
1272					       DMA_FROM_DEVICE);
1273			ent->sense_ptr = NULL;
1274		}
1275
1276		/* Now that the state is unwound properly, put back onto
1277		 * the issue queue.  This command is no longer active.
1278		 */
1279		list_move(&ent->list, &esp->queued_cmds);
1280		esp->active_cmd = NULL;
1281
1282		/* Return value ignored by caller, it directly invokes
1283		 * esp_reconnect().
1284		 */
1285		return 0;
1286	}
1287
1288	if (esp->ireg == ESP_INTR_DC) {
1289		struct scsi_device *dev = cmd->device;
1290
1291		/* Disconnect.  Make sure we re-negotiate sync and
1292		 * wide parameters if this target starts responding
1293		 * again in the future.
1294		 */
1295		esp->target[dev->id].flags |= ESP_TGT_CHECK_NEGO;
1296
1297		scsi_esp_cmd(esp, ESP_CMD_ESEL);
1298		esp_cmd_is_done(esp, ent, cmd, (DID_BAD_TARGET << 16));
1299		return 1;
1300	}
1301
1302	if (esp->ireg == (ESP_INTR_FDONE | ESP_INTR_BSERV)) {
1303		/* Selection successful.  On pre-FAST chips we have
1304		 * to do a NOP and possibly clean out the FIFO.
1305		 */
1306		if (esp->rev <= ESP236) {
1307			int fcnt = esp_read8(ESP_FFLAGS) & ESP_FF_FBYTES;
1308
1309			scsi_esp_cmd(esp, ESP_CMD_NULL);
1310
1311			if (!fcnt &&
1312			    (!esp->prev_soff ||
1313			     ((esp->sreg & ESP_STAT_PMASK) != ESP_DIP)))
1314				esp_flush_fifo(esp);
1315		}
1316
1317		/* If we are doing a slow command, negotiation, etc.
1318		 * we'll do the right thing as we transition to the
1319		 * next phase.
1320		 */
1321		esp_event(esp, ESP_EVENT_CHECK_PHASE);
1322		return 0;
1323	}
1324
1325	shost_printk(KERN_INFO, esp->host,
1326		     "Unexpected selection completion ireg[%x]\n", esp->ireg);
1327	esp_schedule_reset(esp);
1328	return 0;
1329}
1330
1331static int esp_data_bytes_sent(struct esp *esp, struct esp_cmd_entry *ent,
1332			       struct scsi_cmnd *cmd)
1333{
1334	int fifo_cnt, ecount, bytes_sent, flush_fifo;
1335
1336	fifo_cnt = esp_read8(ESP_FFLAGS) & ESP_FF_FBYTES;
1337	if (esp->prev_cfg3 & ESP_CONFIG3_EWIDE)
1338		fifo_cnt <<= 1;
1339
1340	ecount = 0;
1341	if (!(esp->sreg & ESP_STAT_TCNT)) {
1342		ecount = ((unsigned int)esp_read8(ESP_TCLOW) |
1343			  (((unsigned int)esp_read8(ESP_TCMED)) << 8));
1344		if (esp->rev == FASHME)
1345			ecount |= ((unsigned int)esp_read8(FAS_RLO)) << 16;
1346		if (esp->rev == PCSCSI && (esp->config2 & ESP_CONFIG2_FENAB))
1347			ecount |= ((unsigned int)esp_read8(ESP_TCHI)) << 16;
1348	}
1349
1350	bytes_sent = esp->data_dma_len;
1351	bytes_sent -= ecount;
1352
1353	/*
1354	 * The am53c974 has a DMA 'pecularity'. The doc states:
1355	 * In some odd byte conditions, one residual byte will
1356	 * be left in the SCSI FIFO, and the FIFO Flags will
1357	 * never count to '0 '. When this happens, the residual
1358	 * byte should be retrieved via PIO following completion
1359	 * of the BLAST operation.
1360	 */
1361	if (fifo_cnt == 1 && ent->flags & ESP_CMD_FLAG_RESIDUAL) {
1362		size_t count = 1;
1363		size_t offset = bytes_sent;
1364		u8 bval = esp_read8(ESP_FDATA);
1365
1366		if (ent->flags & ESP_CMD_FLAG_AUTOSENSE)
1367			ent->sense_ptr[bytes_sent] = bval;
1368		else {
1369			struct esp_cmd_priv *p = ESP_CMD_PRIV(cmd);
1370			u8 *ptr;
1371
1372			ptr = scsi_kmap_atomic_sg(p->cur_sg, p->u.num_sg,
1373						  &offset, &count);
1374			if (likely(ptr)) {
1375				*(ptr + offset) = bval;
1376				scsi_kunmap_atomic_sg(ptr);
1377			}
1378		}
1379		bytes_sent += fifo_cnt;
1380		ent->flags &= ~ESP_CMD_FLAG_RESIDUAL;
1381	}
1382	if (!(ent->flags & ESP_CMD_FLAG_WRITE))
1383		bytes_sent -= fifo_cnt;
1384
1385	flush_fifo = 0;
1386	if (!esp->prev_soff) {
1387		/* Synchronous data transfer, always flush fifo. */
1388		flush_fifo = 1;
1389	} else {
1390		if (esp->rev == ESP100) {
1391			u32 fflags, phase;
1392
1393			/* ESP100 has a chip bug where in the synchronous data
1394			 * phase it can mistake a final long REQ pulse from the
1395			 * target as an extra data byte.  Fun.
1396			 *
1397			 * To detect this case we resample the status register
1398			 * and fifo flags.  If we're still in a data phase and
1399			 * we see spurious chunks in the fifo, we return error
1400			 * to the caller which should reset and set things up
1401			 * such that we only try future transfers to this
1402			 * target in synchronous mode.
1403			 */
1404			esp->sreg = esp_read8(ESP_STATUS);
1405			phase = esp->sreg & ESP_STAT_PMASK;
1406			fflags = esp_read8(ESP_FFLAGS);
1407
1408			if ((phase == ESP_DOP &&
1409			     (fflags & ESP_FF_ONOTZERO)) ||
1410			    (phase == ESP_DIP &&
1411			     (fflags & ESP_FF_FBYTES)))
1412				return -1;
1413		}
1414		if (!(ent->flags & ESP_CMD_FLAG_WRITE))
1415			flush_fifo = 1;
1416	}
1417
1418	if (flush_fifo)
1419		esp_flush_fifo(esp);
1420
1421	return bytes_sent;
1422}
1423
1424static void esp_setsync(struct esp *esp, struct esp_target_data *tp,
1425			u8 scsi_period, u8 scsi_offset,
1426			u8 esp_stp, u8 esp_soff)
1427{
1428	spi_period(tp->starget) = scsi_period;
1429	spi_offset(tp->starget) = scsi_offset;
1430	spi_width(tp->starget) = (tp->flags & ESP_TGT_WIDE) ? 1 : 0;
1431
1432	if (esp_soff) {
1433		esp_stp &= 0x1f;
1434		esp_soff |= esp->radelay;
1435		if (esp->rev >= FAS236) {
1436			u8 bit = ESP_CONFIG3_FSCSI;
1437			if (esp->rev >= FAS100A)
1438				bit = ESP_CONFIG3_FAST;
1439
1440			if (scsi_period < 50) {
1441				if (esp->rev == FASHME)
1442					esp_soff &= ~esp->radelay;
1443				tp->esp_config3 |= bit;
1444			} else {
1445				tp->esp_config3 &= ~bit;
1446			}
1447			esp->prev_cfg3 = tp->esp_config3;
1448			esp_write8(esp->prev_cfg3, ESP_CFG3);
1449		}
1450	}
1451
1452	tp->esp_period = esp->prev_stp = esp_stp;
1453	tp->esp_offset = esp->prev_soff = esp_soff;
1454
1455	esp_write8(esp_soff, ESP_SOFF);
1456	esp_write8(esp_stp, ESP_STP);
1457
1458	tp->flags &= ~(ESP_TGT_NEGO_SYNC | ESP_TGT_CHECK_NEGO);
1459
1460	spi_display_xfer_agreement(tp->starget);
1461}
1462
1463static void esp_msgin_reject(struct esp *esp)
1464{
1465	struct esp_cmd_entry *ent = esp->active_cmd;
1466	struct scsi_cmnd *cmd = ent->cmd;
1467	struct esp_target_data *tp;
1468	int tgt;
1469
1470	tgt = cmd->device->id;
1471	tp = &esp->target[tgt];
1472
1473	if (tp->flags & ESP_TGT_NEGO_WIDE) {
1474		tp->flags &= ~(ESP_TGT_NEGO_WIDE | ESP_TGT_WIDE);
1475
1476		if (!esp_need_to_nego_sync(tp)) {
1477			tp->flags &= ~ESP_TGT_CHECK_NEGO;
1478			scsi_esp_cmd(esp, ESP_CMD_RATN);
1479		} else {
1480			esp->msg_out_len =
1481				spi_populate_sync_msg(&esp->msg_out[0],
1482						      tp->nego_goal_period,
1483						      tp->nego_goal_offset);
1484			tp->flags |= ESP_TGT_NEGO_SYNC;
1485			scsi_esp_cmd(esp, ESP_CMD_SATN);
1486		}
1487		return;
1488	}
1489
1490	if (tp->flags & ESP_TGT_NEGO_SYNC) {
1491		tp->flags &= ~(ESP_TGT_NEGO_SYNC | ESP_TGT_CHECK_NEGO);
1492		tp->esp_period = 0;
1493		tp->esp_offset = 0;
1494		esp_setsync(esp, tp, 0, 0, 0, 0);
1495		scsi_esp_cmd(esp, ESP_CMD_RATN);
1496		return;
1497	}
1498
1499	esp->msg_out[0] = ABORT_TASK_SET;
1500	esp->msg_out_len = 1;
1501	scsi_esp_cmd(esp, ESP_CMD_SATN);
1502}
1503
1504static void esp_msgin_sdtr(struct esp *esp, struct esp_target_data *tp)
1505{
1506	u8 period = esp->msg_in[3];
1507	u8 offset = esp->msg_in[4];
1508	u8 stp;
1509
1510	if (!(tp->flags & ESP_TGT_NEGO_SYNC))
1511		goto do_reject;
1512
1513	if (offset > 15)
1514		goto do_reject;
1515
1516	if (offset) {
1517		int one_clock;
1518
1519		if (period > esp->max_period) {
1520			period = offset = 0;
1521			goto do_sdtr;
1522		}
1523		if (period < esp->min_period)
1524			goto do_reject;
1525
1526		one_clock = esp->ccycle / 1000;
1527		stp = DIV_ROUND_UP(period << 2, one_clock);
1528		if (stp && esp->rev >= FAS236) {
1529			if (stp >= 50)
1530				stp--;
1531		}
1532	} else {
1533		stp = 0;
1534	}
1535
1536	esp_setsync(esp, tp, period, offset, stp, offset);
1537	return;
1538
1539do_reject:
1540	esp->msg_out[0] = MESSAGE_REJECT;
1541	esp->msg_out_len = 1;
1542	scsi_esp_cmd(esp, ESP_CMD_SATN);
1543	return;
1544
1545do_sdtr:
1546	tp->nego_goal_period = period;
1547	tp->nego_goal_offset = offset;
1548	esp->msg_out_len =
1549		spi_populate_sync_msg(&esp->msg_out[0],
1550				      tp->nego_goal_period,
1551				      tp->nego_goal_offset);
1552	scsi_esp_cmd(esp, ESP_CMD_SATN);
1553}
1554
1555static void esp_msgin_wdtr(struct esp *esp, struct esp_target_data *tp)
1556{
1557	int size = 8 << esp->msg_in[3];
1558	u8 cfg3;
1559
1560	if (esp->rev != FASHME)
1561		goto do_reject;
1562
1563	if (size != 8 && size != 16)
1564		goto do_reject;
1565
1566	if (!(tp->flags & ESP_TGT_NEGO_WIDE))
1567		goto do_reject;
1568
1569	cfg3 = tp->esp_config3;
1570	if (size == 16) {
1571		tp->flags |= ESP_TGT_WIDE;
1572		cfg3 |= ESP_CONFIG3_EWIDE;
1573	} else {
1574		tp->flags &= ~ESP_TGT_WIDE;
1575		cfg3 &= ~ESP_CONFIG3_EWIDE;
1576	}
1577	tp->esp_config3 = cfg3;
1578	esp->prev_cfg3 = cfg3;
1579	esp_write8(cfg3, ESP_CFG3);
1580
1581	tp->flags &= ~ESP_TGT_NEGO_WIDE;
1582
1583	spi_period(tp->starget) = 0;
1584	spi_offset(tp->starget) = 0;
1585	if (!esp_need_to_nego_sync(tp)) {
1586		tp->flags &= ~ESP_TGT_CHECK_NEGO;
1587		scsi_esp_cmd(esp, ESP_CMD_RATN);
1588	} else {
1589		esp->msg_out_len =
1590			spi_populate_sync_msg(&esp->msg_out[0],
1591					      tp->nego_goal_period,
1592					      tp->nego_goal_offset);
1593		tp->flags |= ESP_TGT_NEGO_SYNC;
1594		scsi_esp_cmd(esp, ESP_CMD_SATN);
1595	}
1596	return;
1597
1598do_reject:
1599	esp->msg_out[0] = MESSAGE_REJECT;
1600	esp->msg_out_len = 1;
1601	scsi_esp_cmd(esp, ESP_CMD_SATN);
1602}
1603
1604static void esp_msgin_extended(struct esp *esp)
1605{
1606	struct esp_cmd_entry *ent = esp->active_cmd;
1607	struct scsi_cmnd *cmd = ent->cmd;
1608	struct esp_target_data *tp;
1609	int tgt = cmd->device->id;
1610
1611	tp = &esp->target[tgt];
1612	if (esp->msg_in[2] == EXTENDED_SDTR) {
1613		esp_msgin_sdtr(esp, tp);
1614		return;
1615	}
1616	if (esp->msg_in[2] == EXTENDED_WDTR) {
1617		esp_msgin_wdtr(esp, tp);
1618		return;
1619	}
1620
1621	shost_printk(KERN_INFO, esp->host,
1622		     "Unexpected extended msg type %x\n", esp->msg_in[2]);
1623
1624	esp->msg_out[0] = ABORT_TASK_SET;
1625	esp->msg_out_len = 1;
1626	scsi_esp_cmd(esp, ESP_CMD_SATN);
1627}
1628
1629/* Analyze msgin bytes received from target so far.  Return non-zero
1630 * if there are more bytes needed to complete the message.
1631 */
1632static int esp_msgin_process(struct esp *esp)
1633{
1634	u8 msg0 = esp->msg_in[0];
1635	int len = esp->msg_in_len;
1636
1637	if (msg0 & 0x80) {
1638		/* Identify */
1639		shost_printk(KERN_INFO, esp->host,
1640			     "Unexpected msgin identify\n");
1641		return 0;
1642	}
1643
1644	switch (msg0) {
1645	case EXTENDED_MESSAGE:
1646		if (len == 1)
1647			return 1;
1648		if (len < esp->msg_in[1] + 2)
1649			return 1;
1650		esp_msgin_extended(esp);
1651		return 0;
1652
1653	case IGNORE_WIDE_RESIDUE: {
1654		struct esp_cmd_entry *ent;
1655		struct esp_cmd_priv *spriv;
1656		if (len == 1)
1657			return 1;
1658
1659		if (esp->msg_in[1] != 1)
1660			goto do_reject;
1661
1662		ent = esp->active_cmd;
1663		spriv = ESP_CMD_PRIV(ent->cmd);
1664
1665		if (spriv->cur_residue == sg_dma_len(spriv->cur_sg)) {
1666			spriv->cur_sg--;
1667			spriv->cur_residue = 1;
1668		} else
1669			spriv->cur_residue++;
1670		spriv->tot_residue++;
1671		return 0;
1672	}
1673	case NOP:
1674		return 0;
1675	case RESTORE_POINTERS:
1676		esp_restore_pointers(esp, esp->active_cmd);
1677		return 0;
1678	case SAVE_POINTERS:
1679		esp_save_pointers(esp, esp->active_cmd);
1680		return 0;
1681
1682	case COMMAND_COMPLETE:
1683	case DISCONNECT: {
1684		struct esp_cmd_entry *ent = esp->active_cmd;
1685
1686		ent->message = msg0;
1687		esp_event(esp, ESP_EVENT_FREE_BUS);
1688		esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
1689		return 0;
1690	}
1691	case MESSAGE_REJECT:
1692		esp_msgin_reject(esp);
1693		return 0;
1694
1695	default:
1696	do_reject:
1697		esp->msg_out[0] = MESSAGE_REJECT;
1698		esp->msg_out_len = 1;
1699		scsi_esp_cmd(esp, ESP_CMD_SATN);
1700		return 0;
1701	}
1702}
1703
1704static int esp_process_event(struct esp *esp)
1705{
1706	int write, i;
1707
1708again:
1709	write = 0;
1710	esp_log_event("process event %d phase %x\n",
1711		      esp->event, esp->sreg & ESP_STAT_PMASK);
1712	switch (esp->event) {
1713	case ESP_EVENT_CHECK_PHASE:
1714		switch (esp->sreg & ESP_STAT_PMASK) {
1715		case ESP_DOP:
1716			esp_event(esp, ESP_EVENT_DATA_OUT);
1717			break;
1718		case ESP_DIP:
1719			esp_event(esp, ESP_EVENT_DATA_IN);
1720			break;
1721		case ESP_STATP:
1722			esp_flush_fifo(esp);
1723			scsi_esp_cmd(esp, ESP_CMD_ICCSEQ);
1724			esp_event(esp, ESP_EVENT_STATUS);
1725			esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
1726			return 1;
1727
1728		case ESP_MOP:
1729			esp_event(esp, ESP_EVENT_MSGOUT);
1730			break;
1731
1732		case ESP_MIP:
1733			esp_event(esp, ESP_EVENT_MSGIN);
1734			break;
1735
1736		case ESP_CMDP:
1737			esp_event(esp, ESP_EVENT_CMD_START);
1738			break;
1739
1740		default:
1741			shost_printk(KERN_INFO, esp->host,
1742				     "Unexpected phase, sreg=%02x\n",
1743				     esp->sreg);
1744			esp_schedule_reset(esp);
1745			return 0;
1746		}
1747		goto again;
1748		break;
1749
1750	case ESP_EVENT_DATA_IN:
1751		write = 1;
1752		/* fallthru */
1753
1754	case ESP_EVENT_DATA_OUT: {
1755		struct esp_cmd_entry *ent = esp->active_cmd;
1756		struct scsi_cmnd *cmd = ent->cmd;
1757		dma_addr_t dma_addr = esp_cur_dma_addr(ent, cmd);
1758		unsigned int dma_len = esp_cur_dma_len(ent, cmd);
1759
1760		if (esp->rev == ESP100)
1761			scsi_esp_cmd(esp, ESP_CMD_NULL);
1762
1763		if (write)
1764			ent->flags |= ESP_CMD_FLAG_WRITE;
1765		else
1766			ent->flags &= ~ESP_CMD_FLAG_WRITE;
1767
1768		if (esp->ops->dma_length_limit)
1769			dma_len = esp->ops->dma_length_limit(esp, dma_addr,
1770							     dma_len);
1771		else
1772			dma_len = esp_dma_length_limit(esp, dma_addr, dma_len);
1773
1774		esp->data_dma_len = dma_len;
1775
1776		if (!dma_len) {
1777			shost_printk(KERN_ERR, esp->host,
1778				     "DMA length is zero!\n");
1779			shost_printk(KERN_ERR, esp->host,
1780				     "cur adr[%08llx] len[%08x]\n",
1781				     (unsigned long long)esp_cur_dma_addr(ent, cmd),
1782				     esp_cur_dma_len(ent, cmd));
1783			esp_schedule_reset(esp);
1784			return 0;
1785		}
1786
1787		esp_log_datastart("start data addr[%08llx] len[%u] write(%d)\n",
 
1788				  (unsigned long long)dma_addr, dma_len, write);
1789
1790		esp->ops->send_dma_cmd(esp, dma_addr, dma_len, dma_len,
1791				       write, ESP_CMD_DMA | ESP_CMD_TI);
1792		esp_event(esp, ESP_EVENT_DATA_DONE);
1793		break;
1794	}
1795	case ESP_EVENT_DATA_DONE: {
1796		struct esp_cmd_entry *ent = esp->active_cmd;
1797		struct scsi_cmnd *cmd = ent->cmd;
1798		int bytes_sent;
1799
1800		if (esp->ops->dma_error(esp)) {
1801			shost_printk(KERN_INFO, esp->host,
1802				     "data done, DMA error, resetting\n");
1803			esp_schedule_reset(esp);
1804			return 0;
1805		}
1806
1807		if (ent->flags & ESP_CMD_FLAG_WRITE) {
1808			/* XXX parity errors, etc. XXX */
1809
1810			esp->ops->dma_drain(esp);
1811		}
1812		esp->ops->dma_invalidate(esp);
1813
1814		if (esp->ireg != ESP_INTR_BSERV) {
1815			/* We should always see exactly a bus-service
1816			 * interrupt at the end of a successful transfer.
1817			 */
1818			shost_printk(KERN_INFO, esp->host,
1819				     "data done, not BSERV, resetting\n");
1820			esp_schedule_reset(esp);
1821			return 0;
1822		}
1823
1824		bytes_sent = esp_data_bytes_sent(esp, ent, cmd);
1825
1826		esp_log_datadone("data done flgs[%x] sent[%d]\n",
1827				 ent->flags, bytes_sent);
1828
1829		if (bytes_sent < 0) {
1830			/* XXX force sync mode for this target XXX */
1831			esp_schedule_reset(esp);
1832			return 0;
1833		}
1834
1835		esp_advance_dma(esp, ent, cmd, bytes_sent);
1836		esp_event(esp, ESP_EVENT_CHECK_PHASE);
1837		goto again;
1838	}
1839
1840	case ESP_EVENT_STATUS: {
1841		struct esp_cmd_entry *ent = esp->active_cmd;
1842
1843		if (esp->ireg & ESP_INTR_FDONE) {
1844			ent->status = esp_read8(ESP_FDATA);
1845			ent->message = esp_read8(ESP_FDATA);
1846			scsi_esp_cmd(esp, ESP_CMD_MOK);
1847		} else if (esp->ireg == ESP_INTR_BSERV) {
1848			ent->status = esp_read8(ESP_FDATA);
1849			ent->message = 0xff;
1850			esp_event(esp, ESP_EVENT_MSGIN);
1851			return 0;
1852		}
1853
1854		if (ent->message != COMMAND_COMPLETE) {
1855			shost_printk(KERN_INFO, esp->host,
1856				     "Unexpected message %x in status\n",
1857				     ent->message);
1858			esp_schedule_reset(esp);
1859			return 0;
1860		}
1861
1862		esp_event(esp, ESP_EVENT_FREE_BUS);
1863		esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
1864		break;
1865	}
1866	case ESP_EVENT_FREE_BUS: {
1867		struct esp_cmd_entry *ent = esp->active_cmd;
1868		struct scsi_cmnd *cmd = ent->cmd;
1869
1870		if (ent->message == COMMAND_COMPLETE ||
1871		    ent->message == DISCONNECT)
1872			scsi_esp_cmd(esp, ESP_CMD_ESEL);
1873
1874		if (ent->message == COMMAND_COMPLETE) {
1875			esp_log_cmddone("Command done status[%x] message[%x]\n",
 
1876					ent->status, ent->message);
1877			if (ent->status == SAM_STAT_TASK_SET_FULL)
1878				esp_event_queue_full(esp, ent);
1879
1880			if (ent->status == SAM_STAT_CHECK_CONDITION &&
1881			    !(ent->flags & ESP_CMD_FLAG_AUTOSENSE)) {
1882				ent->flags |= ESP_CMD_FLAG_AUTOSENSE;
1883				esp_autosense(esp, ent);
1884			} else {
1885				esp_cmd_is_done(esp, ent, cmd,
1886						compose_result(ent->status,
1887							       ent->message,
1888							       DID_OK));
1889			}
1890		} else if (ent->message == DISCONNECT) {
1891			esp_log_disconnect("Disconnecting tgt[%d] tag[%x:%x]\n",
 
1892					   cmd->device->id,
1893					   ent->tag[0], ent->tag[1]);
1894
1895			esp->active_cmd = NULL;
1896			esp_maybe_execute_command(esp);
1897		} else {
1898			shost_printk(KERN_INFO, esp->host,
1899				     "Unexpected message %x in freebus\n",
1900				     ent->message);
1901			esp_schedule_reset(esp);
1902			return 0;
1903		}
1904		if (esp->active_cmd)
1905			esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
1906		break;
1907	}
1908	case ESP_EVENT_MSGOUT: {
1909		scsi_esp_cmd(esp, ESP_CMD_FLUSH);
1910
1911		if (esp_debug & ESP_DEBUG_MSGOUT) {
1912			int i;
1913			printk("ESP: Sending message [ ");
1914			for (i = 0; i < esp->msg_out_len; i++)
1915				printk("%02x ", esp->msg_out[i]);
1916			printk("]\n");
1917		}
1918
1919		if (esp->rev == FASHME) {
1920			int i;
1921
1922			/* Always use the fifo.  */
1923			for (i = 0; i < esp->msg_out_len; i++) {
1924				esp_write8(esp->msg_out[i], ESP_FDATA);
1925				esp_write8(0, ESP_FDATA);
1926			}
1927			scsi_esp_cmd(esp, ESP_CMD_TI);
1928		} else {
1929			if (esp->msg_out_len == 1) {
1930				esp_write8(esp->msg_out[0], ESP_FDATA);
1931				scsi_esp_cmd(esp, ESP_CMD_TI);
1932			} else if (esp->flags & ESP_FLAG_USE_FIFO) {
1933				for (i = 0; i < esp->msg_out_len; i++)
1934					esp_write8(esp->msg_out[i], ESP_FDATA);
1935				scsi_esp_cmd(esp, ESP_CMD_TI);
1936			} else {
1937				/* Use DMA. */
1938				memcpy(esp->command_block,
1939				       esp->msg_out,
1940				       esp->msg_out_len);
1941
1942				esp->ops->send_dma_cmd(esp,
1943						       esp->command_block_dma,
1944						       esp->msg_out_len,
1945						       esp->msg_out_len,
1946						       0,
1947						       ESP_CMD_DMA|ESP_CMD_TI);
1948			}
1949		}
1950		esp_event(esp, ESP_EVENT_MSGOUT_DONE);
1951		break;
1952	}
1953	case ESP_EVENT_MSGOUT_DONE:
1954		if (esp->rev == FASHME) {
1955			scsi_esp_cmd(esp, ESP_CMD_FLUSH);
1956		} else {
1957			if (esp->msg_out_len > 1)
1958				esp->ops->dma_invalidate(esp);
1959		}
1960
1961		if (!(esp->ireg & ESP_INTR_DC)) {
1962			if (esp->rev != FASHME)
1963				scsi_esp_cmd(esp, ESP_CMD_NULL);
1964		}
1965		esp_event(esp, ESP_EVENT_CHECK_PHASE);
1966		goto again;
1967	case ESP_EVENT_MSGIN:
1968		if (esp->ireg & ESP_INTR_BSERV) {
1969			if (esp->rev == FASHME) {
1970				if (!(esp_read8(ESP_STATUS2) &
1971				      ESP_STAT2_FEMPTY))
1972					scsi_esp_cmd(esp, ESP_CMD_FLUSH);
1973			} else {
1974				scsi_esp_cmd(esp, ESP_CMD_FLUSH);
1975				if (esp->rev == ESP100)
1976					scsi_esp_cmd(esp, ESP_CMD_NULL);
1977			}
1978			scsi_esp_cmd(esp, ESP_CMD_TI);
1979			esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
1980			return 1;
1981		}
1982		if (esp->ireg & ESP_INTR_FDONE) {
1983			u8 val;
1984
1985			if (esp->rev == FASHME)
1986				val = esp->fifo[0];
1987			else
1988				val = esp_read8(ESP_FDATA);
1989			esp->msg_in[esp->msg_in_len++] = val;
1990
1991			esp_log_msgin("Got msgin byte %x\n", val);
1992
1993			if (!esp_msgin_process(esp))
1994				esp->msg_in_len = 0;
1995
1996			if (esp->rev == FASHME)
1997				scsi_esp_cmd(esp, ESP_CMD_FLUSH);
1998
1999			scsi_esp_cmd(esp, ESP_CMD_MOK);
2000
2001			if (esp->event != ESP_EVENT_FREE_BUS)
2002				esp_event(esp, ESP_EVENT_CHECK_PHASE);
2003		} else {
2004			shost_printk(KERN_INFO, esp->host,
2005				     "MSGIN neither BSERV not FDON, resetting");
2006			esp_schedule_reset(esp);
2007			return 0;
2008		}
2009		break;
2010	case ESP_EVENT_CMD_START:
2011		memcpy(esp->command_block, esp->cmd_bytes_ptr,
2012		       esp->cmd_bytes_left);
2013		esp_send_dma_cmd(esp, esp->cmd_bytes_left, 16, ESP_CMD_TI);
 
 
 
 
2014		esp_event(esp, ESP_EVENT_CMD_DONE);
2015		esp->flags |= ESP_FLAG_QUICKIRQ_CHECK;
2016		break;
2017	case ESP_EVENT_CMD_DONE:
2018		esp->ops->dma_invalidate(esp);
2019		if (esp->ireg & ESP_INTR_BSERV) {
2020			esp_event(esp, ESP_EVENT_CHECK_PHASE);
2021			goto again;
2022		}
2023		esp_schedule_reset(esp);
2024		return 0;
2025		break;
2026
2027	case ESP_EVENT_RESET:
2028		scsi_esp_cmd(esp, ESP_CMD_RS);
2029		break;
2030
2031	default:
2032		shost_printk(KERN_INFO, esp->host,
2033			     "Unexpected event %x, resetting\n", esp->event);
2034		esp_schedule_reset(esp);
2035		return 0;
2036		break;
2037	}
2038	return 1;
2039}
2040
2041static void esp_reset_cleanup_one(struct esp *esp, struct esp_cmd_entry *ent)
2042{
2043	struct scsi_cmnd *cmd = ent->cmd;
2044
2045	esp_unmap_dma(esp, cmd);
2046	esp_free_lun_tag(ent, cmd->device->hostdata);
2047	cmd->result = DID_RESET << 16;
2048
2049	if (ent->flags & ESP_CMD_FLAG_AUTOSENSE) {
2050		esp->ops->unmap_single(esp, ent->sense_dma,
2051				       SCSI_SENSE_BUFFERSIZE, DMA_FROM_DEVICE);
2052		ent->sense_ptr = NULL;
2053	}
2054
2055	cmd->scsi_done(cmd);
2056	list_del(&ent->list);
2057	esp_put_ent(esp, ent);
2058}
2059
2060static void esp_clear_hold(struct scsi_device *dev, void *data)
2061{
2062	struct esp_lun_data *lp = dev->hostdata;
2063
2064	BUG_ON(lp->num_tagged);
2065	lp->hold = 0;
2066}
2067
2068static void esp_reset_cleanup(struct esp *esp)
2069{
2070	struct esp_cmd_entry *ent, *tmp;
2071	int i;
2072
2073	list_for_each_entry_safe(ent, tmp, &esp->queued_cmds, list) {
2074		struct scsi_cmnd *cmd = ent->cmd;
2075
2076		list_del(&ent->list);
2077		cmd->result = DID_RESET << 16;
2078		cmd->scsi_done(cmd);
2079		esp_put_ent(esp, ent);
2080	}
2081
2082	list_for_each_entry_safe(ent, tmp, &esp->active_cmds, list) {
2083		if (ent == esp->active_cmd)
2084			esp->active_cmd = NULL;
2085		esp_reset_cleanup_one(esp, ent);
2086	}
2087
2088	BUG_ON(esp->active_cmd != NULL);
2089
2090	/* Force renegotiation of sync/wide transfers.  */
2091	for (i = 0; i < ESP_MAX_TARGET; i++) {
2092		struct esp_target_data *tp = &esp->target[i];
2093
2094		tp->esp_period = 0;
2095		tp->esp_offset = 0;
2096		tp->esp_config3 &= ~(ESP_CONFIG3_EWIDE |
2097				     ESP_CONFIG3_FSCSI |
2098				     ESP_CONFIG3_FAST);
2099		tp->flags &= ~ESP_TGT_WIDE;
2100		tp->flags |= ESP_TGT_CHECK_NEGO;
2101
2102		if (tp->starget)
2103			__starget_for_each_device(tp->starget, NULL,
2104						  esp_clear_hold);
2105	}
2106	esp->flags &= ~ESP_FLAG_RESETTING;
2107}
2108
2109/* Runs under host->lock */
2110static void __esp_interrupt(struct esp *esp)
2111{
2112	int finish_reset, intr_done;
2113	u8 phase;
2114
2115       /*
2116	* Once INTRPT is read STATUS and SSTEP are cleared.
2117	*/
2118	esp->sreg = esp_read8(ESP_STATUS);
2119	esp->seqreg = esp_read8(ESP_SSTEP);
2120	esp->ireg = esp_read8(ESP_INTRPT);
2121
2122	if (esp->flags & ESP_FLAG_RESETTING) {
2123		finish_reset = 1;
2124	} else {
2125		if (esp_check_gross_error(esp))
2126			return;
2127
2128		finish_reset = esp_check_spur_intr(esp);
2129		if (finish_reset < 0)
2130			return;
2131	}
2132
 
 
2133	if (esp->ireg & ESP_INTR_SR)
2134		finish_reset = 1;
2135
2136	if (finish_reset) {
2137		esp_reset_cleanup(esp);
2138		if (esp->eh_reset) {
2139			complete(esp->eh_reset);
2140			esp->eh_reset = NULL;
2141		}
2142		return;
2143	}
2144
2145	phase = (esp->sreg & ESP_STAT_PMASK);
2146	if (esp->rev == FASHME) {
2147		if (((phase != ESP_DIP && phase != ESP_DOP) &&
2148		     esp->select_state == ESP_SELECT_NONE &&
2149		     esp->event != ESP_EVENT_STATUS &&
2150		     esp->event != ESP_EVENT_DATA_DONE) ||
2151		    (esp->ireg & ESP_INTR_RSEL)) {
2152			esp->sreg2 = esp_read8(ESP_STATUS2);
2153			if (!(esp->sreg2 & ESP_STAT2_FEMPTY) ||
2154			    (esp->sreg2 & ESP_STAT2_F1BYTE))
2155				hme_read_fifo(esp);
2156		}
2157	}
2158
2159	esp_log_intr("intr sreg[%02x] seqreg[%02x] "
2160		     "sreg2[%02x] ireg[%02x]\n",
2161		     esp->sreg, esp->seqreg, esp->sreg2, esp->ireg);
2162
2163	intr_done = 0;
2164
2165	if (esp->ireg & (ESP_INTR_S | ESP_INTR_SATN | ESP_INTR_IC)) {
2166		shost_printk(KERN_INFO, esp->host,
2167			     "unexpected IREG %02x\n", esp->ireg);
2168		if (esp->ireg & ESP_INTR_IC)
2169			esp_dump_cmd_log(esp);
2170
2171		esp_schedule_reset(esp);
2172	} else {
2173		if (!(esp->ireg & ESP_INTR_RSEL)) {
2174			/* Some combination of FDONE, BSERV, DC.  */
2175			if (esp->select_state != ESP_SELECT_NONE)
2176				intr_done = esp_finish_select(esp);
2177		} else if (esp->ireg & ESP_INTR_RSEL) {
2178			if (esp->active_cmd)
2179				(void) esp_finish_select(esp);
2180			intr_done = esp_reconnect(esp);
2181		}
2182	}
2183	while (!intr_done)
2184		intr_done = esp_process_event(esp);
2185}
2186
2187irqreturn_t scsi_esp_intr(int irq, void *dev_id)
2188{
2189	struct esp *esp = dev_id;
2190	unsigned long flags;
2191	irqreturn_t ret;
2192
2193	spin_lock_irqsave(esp->host->host_lock, flags);
2194	ret = IRQ_NONE;
2195	if (esp->ops->irq_pending(esp)) {
2196		ret = IRQ_HANDLED;
2197		for (;;) {
2198			int i;
2199
2200			__esp_interrupt(esp);
2201			if (!(esp->flags & ESP_FLAG_QUICKIRQ_CHECK))
2202				break;
2203			esp->flags &= ~ESP_FLAG_QUICKIRQ_CHECK;
2204
2205			for (i = 0; i < ESP_QUICKIRQ_LIMIT; i++) {
2206				if (esp->ops->irq_pending(esp))
2207					break;
2208			}
2209			if (i == ESP_QUICKIRQ_LIMIT)
2210				break;
2211		}
2212	}
2213	spin_unlock_irqrestore(esp->host->host_lock, flags);
2214
2215	return ret;
2216}
2217EXPORT_SYMBOL(scsi_esp_intr);
2218
2219static void esp_get_revision(struct esp *esp)
2220{
2221	u8 val;
2222
2223	esp->config1 = (ESP_CONFIG1_PENABLE | (esp->scsi_id & 7));
2224	if (esp->config2 == 0) {
2225		esp->config2 = (ESP_CONFIG2_SCSI2ENAB | ESP_CONFIG2_REGPARITY);
2226		esp_write8(esp->config2, ESP_CFG2);
2227
2228		val = esp_read8(ESP_CFG2);
2229		val &= ~ESP_CONFIG2_MAGIC;
2230
2231		esp->config2 = 0;
2232		if (val != (ESP_CONFIG2_SCSI2ENAB | ESP_CONFIG2_REGPARITY)) {
2233			/*
2234			 * If what we write to cfg2 does not come back,
2235			 * cfg2 is not implemented.
2236			 * Therefore this must be a plain esp100.
2237			 */
2238			esp->rev = ESP100;
2239			return;
2240		}
2241	}
2242
2243	esp_set_all_config3(esp, 5);
2244	esp->prev_cfg3 = 5;
2245	esp_write8(esp->config2, ESP_CFG2);
2246	esp_write8(0, ESP_CFG3);
2247	esp_write8(esp->prev_cfg3, ESP_CFG3);
2248
2249	val = esp_read8(ESP_CFG3);
2250	if (val != 5) {
2251		/* The cfg2 register is implemented, however
2252		 * cfg3 is not, must be esp100a.
 
2253		 */
2254		esp->rev = ESP100A;
2255	} else {
2256		esp_set_all_config3(esp, 0);
2257		esp->prev_cfg3 = 0;
 
 
 
2258		esp_write8(esp->prev_cfg3, ESP_CFG3);
2259
2260		/* All of cfg{1,2,3} implemented, must be one of
2261		 * the fas variants, figure out which one.
2262		 */
2263		if (esp->cfact == 0 || esp->cfact > ESP_CCF_F5) {
2264			esp->rev = FAST;
2265			esp->sync_defp = SYNC_DEFP_FAST;
2266		} else {
2267			esp->rev = ESP236;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2268		}
2269	}
2270}
2271
2272static void esp_init_swstate(struct esp *esp)
2273{
2274	int i;
2275
2276	INIT_LIST_HEAD(&esp->queued_cmds);
2277	INIT_LIST_HEAD(&esp->active_cmds);
2278	INIT_LIST_HEAD(&esp->esp_cmd_pool);
2279
2280	/* Start with a clear state, domain validation (via ->slave_configure,
2281	 * spi_dv_device()) will attempt to enable SYNC, WIDE, and tagged
2282	 * commands.
2283	 */
2284	for (i = 0 ; i < ESP_MAX_TARGET; i++) {
2285		esp->target[i].flags = 0;
2286		esp->target[i].nego_goal_period = 0;
2287		esp->target[i].nego_goal_offset = 0;
2288		esp->target[i].nego_goal_width = 0;
2289		esp->target[i].nego_goal_tags = 0;
2290	}
2291}
2292
2293/* This places the ESP into a known state at boot time. */
2294static void esp_bootup_reset(struct esp *esp)
2295{
2296	u8 val;
2297
2298	/* Reset the DMA */
2299	esp->ops->reset_dma(esp);
2300
2301	/* Reset the ESP */
2302	esp_reset_esp(esp);
2303
2304	/* Reset the SCSI bus, but tell ESP not to generate an irq */
2305	val = esp_read8(ESP_CFG1);
2306	val |= ESP_CONFIG1_SRRDISAB;
2307	esp_write8(val, ESP_CFG1);
2308
2309	scsi_esp_cmd(esp, ESP_CMD_RS);
2310	udelay(400);
2311
2312	esp_write8(esp->config1, ESP_CFG1);
2313
2314	/* Eat any bitrot in the chip and we are done... */
2315	esp_read8(ESP_INTRPT);
2316}
2317
2318static void esp_set_clock_params(struct esp *esp)
2319{
2320	int fhz;
2321	u8 ccf;
2322
2323	/* This is getting messy but it has to be done correctly or else
2324	 * you get weird behavior all over the place.  We are trying to
2325	 * basically figure out three pieces of information.
2326	 *
2327	 * a) Clock Conversion Factor
2328	 *
2329	 *    This is a representation of the input crystal clock frequency
2330	 *    going into the ESP on this machine.  Any operation whose timing
2331	 *    is longer than 400ns depends on this value being correct.  For
2332	 *    example, you'll get blips for arbitration/selection during high
2333	 *    load or with multiple targets if this is not set correctly.
2334	 *
2335	 * b) Selection Time-Out
2336	 *
2337	 *    The ESP isn't very bright and will arbitrate for the bus and try
2338	 *    to select a target forever if you let it.  This value tells the
2339	 *    ESP when it has taken too long to negotiate and that it should
2340	 *    interrupt the CPU so we can see what happened.  The value is
2341	 *    computed as follows (from NCR/Symbios chip docs).
2342	 *
2343	 *          (Time Out Period) *  (Input Clock)
2344	 *    STO = ----------------------------------
2345	 *          (8192) * (Clock Conversion Factor)
2346	 *
2347	 *    We use a time out period of 250ms (ESP_BUS_TIMEOUT).
2348	 *
2349	 * c) Imperical constants for synchronous offset and transfer period
2350         *    register values
2351	 *
2352	 *    This entails the smallest and largest sync period we could ever
2353	 *    handle on this ESP.
2354	 */
2355	fhz = esp->cfreq;
2356
2357	ccf = ((fhz / 1000000) + 4) / 5;
2358	if (ccf == 1)
2359		ccf = 2;
2360
2361	/* If we can't find anything reasonable, just assume 20MHZ.
2362	 * This is the clock frequency of the older sun4c's where I've
2363	 * been unable to find the clock-frequency PROM property.  All
2364	 * other machines provide useful values it seems.
2365	 */
2366	if (fhz <= 5000000 || ccf < 1 || ccf > 8) {
2367		fhz = 20000000;
2368		ccf = 4;
2369	}
2370
2371	esp->cfact = (ccf == 8 ? 0 : ccf);
2372	esp->cfreq = fhz;
2373	esp->ccycle = ESP_HZ_TO_CYCLE(fhz);
2374	esp->ctick = ESP_TICK(ccf, esp->ccycle);
2375	esp->neg_defp = ESP_NEG_DEFP(fhz, ccf);
2376	esp->sync_defp = SYNC_DEFP_SLOW;
2377}
2378
2379static const char *esp_chip_names[] = {
2380	"ESP100",
2381	"ESP100A",
2382	"ESP236",
2383	"FAS236",
2384	"FAS100A",
2385	"FAST",
2386	"FASHME",
2387	"AM53C974",
2388};
2389
2390static struct scsi_transport_template *esp_transport_template;
2391
2392int scsi_esp_register(struct esp *esp, struct device *dev)
2393{
2394	static int instance;
2395	int err;
2396
2397	if (!esp->num_tags)
2398		esp->num_tags = ESP_DEFAULT_TAGS;
2399	esp->host->transportt = esp_transport_template;
2400	esp->host->max_lun = ESP_MAX_LUN;
2401	esp->host->cmd_per_lun = 2;
2402	esp->host->unique_id = instance;
2403
2404	esp_set_clock_params(esp);
2405
2406	esp_get_revision(esp);
2407
2408	esp_init_swstate(esp);
2409
2410	esp_bootup_reset(esp);
2411
2412	dev_printk(KERN_INFO, dev, "esp%u: regs[%1p:%1p] irq[%u]\n",
2413		   esp->host->unique_id, esp->regs, esp->dma_regs,
2414		   esp->host->irq);
2415	dev_printk(KERN_INFO, dev,
2416		   "esp%u: is a %s, %u MHz (ccf=%u), SCSI ID %u\n",
2417		   esp->host->unique_id, esp_chip_names[esp->rev],
2418		   esp->cfreq / 1000000, esp->cfact, esp->scsi_id);
2419
2420	/* Let the SCSI bus reset settle. */
2421	ssleep(esp_bus_reset_settle);
2422
2423	err = scsi_add_host(esp->host, dev);
2424	if (err)
2425		return err;
2426
2427	instance++;
2428
2429	scsi_scan_host(esp->host);
2430
2431	return 0;
2432}
2433EXPORT_SYMBOL(scsi_esp_register);
2434
2435void scsi_esp_unregister(struct esp *esp)
2436{
2437	scsi_remove_host(esp->host);
2438}
2439EXPORT_SYMBOL(scsi_esp_unregister);
2440
2441static int esp_target_alloc(struct scsi_target *starget)
2442{
2443	struct esp *esp = shost_priv(dev_to_shost(&starget->dev));
2444	struct esp_target_data *tp = &esp->target[starget->id];
2445
2446	tp->starget = starget;
2447
2448	return 0;
2449}
2450
2451static void esp_target_destroy(struct scsi_target *starget)
2452{
2453	struct esp *esp = shost_priv(dev_to_shost(&starget->dev));
2454	struct esp_target_data *tp = &esp->target[starget->id];
2455
2456	tp->starget = NULL;
2457}
2458
2459static int esp_slave_alloc(struct scsi_device *dev)
2460{
2461	struct esp *esp = shost_priv(dev->host);
2462	struct esp_target_data *tp = &esp->target[dev->id];
2463	struct esp_lun_data *lp;
2464
2465	lp = kzalloc(sizeof(*lp), GFP_KERNEL);
2466	if (!lp)
2467		return -ENOMEM;
2468	dev->hostdata = lp;
2469
2470	spi_min_period(tp->starget) = esp->min_period;
2471	spi_max_offset(tp->starget) = 15;
2472
2473	if (esp->flags & ESP_FLAG_WIDE_CAPABLE)
2474		spi_max_width(tp->starget) = 1;
2475	else
2476		spi_max_width(tp->starget) = 0;
2477
2478	return 0;
2479}
2480
2481static int esp_slave_configure(struct scsi_device *dev)
2482{
2483	struct esp *esp = shost_priv(dev->host);
2484	struct esp_target_data *tp = &esp->target[dev->id];
 
 
 
2485
2486	if (dev->tagged_supported)
2487		scsi_change_queue_depth(dev, esp->num_tags);
 
 
 
 
 
2488
 
 
 
 
 
 
 
 
 
 
2489	tp->flags |= ESP_TGT_DISCONNECT;
2490
2491	if (!spi_initial_dv(dev->sdev_target))
2492		spi_dv_device(dev);
2493
2494	return 0;
2495}
2496
2497static void esp_slave_destroy(struct scsi_device *dev)
2498{
2499	struct esp_lun_data *lp = dev->hostdata;
2500
2501	kfree(lp);
2502	dev->hostdata = NULL;
2503}
2504
2505static int esp_eh_abort_handler(struct scsi_cmnd *cmd)
2506{
2507	struct esp *esp = shost_priv(cmd->device->host);
2508	struct esp_cmd_entry *ent, *tmp;
2509	struct completion eh_done;
2510	unsigned long flags;
2511
2512	/* XXX This helps a lot with debugging but might be a bit
2513	 * XXX much for the final driver.
2514	 */
2515	spin_lock_irqsave(esp->host->host_lock, flags);
2516	shost_printk(KERN_ERR, esp->host, "Aborting command [%p:%02x]\n",
2517		     cmd, cmd->cmnd[0]);
2518	ent = esp->active_cmd;
2519	if (ent)
2520		shost_printk(KERN_ERR, esp->host,
2521			     "Current command [%p:%02x]\n",
2522			     ent->cmd, ent->cmd->cmnd[0]);
2523	list_for_each_entry(ent, &esp->queued_cmds, list) {
2524		shost_printk(KERN_ERR, esp->host, "Queued command [%p:%02x]\n",
2525			     ent->cmd, ent->cmd->cmnd[0]);
2526	}
2527	list_for_each_entry(ent, &esp->active_cmds, list) {
2528		shost_printk(KERN_ERR, esp->host, " Active command [%p:%02x]\n",
2529			     ent->cmd, ent->cmd->cmnd[0]);
2530	}
2531	esp_dump_cmd_log(esp);
2532	spin_unlock_irqrestore(esp->host->host_lock, flags);
2533
2534	spin_lock_irqsave(esp->host->host_lock, flags);
2535
2536	ent = NULL;
2537	list_for_each_entry(tmp, &esp->queued_cmds, list) {
2538		if (tmp->cmd == cmd) {
2539			ent = tmp;
2540			break;
2541		}
2542	}
2543
2544	if (ent) {
2545		/* Easiest case, we didn't even issue the command
2546		 * yet so it is trivial to abort.
2547		 */
2548		list_del(&ent->list);
2549
2550		cmd->result = DID_ABORT << 16;
2551		cmd->scsi_done(cmd);
2552
2553		esp_put_ent(esp, ent);
2554
2555		goto out_success;
2556	}
2557
2558	init_completion(&eh_done);
2559
2560	ent = esp->active_cmd;
2561	if (ent && ent->cmd == cmd) {
2562		/* Command is the currently active command on
2563		 * the bus.  If we already have an output message
2564		 * pending, no dice.
2565		 */
2566		if (esp->msg_out_len)
2567			goto out_failure;
2568
2569		/* Send out an abort, encouraging the target to
2570		 * go to MSGOUT phase by asserting ATN.
2571		 */
2572		esp->msg_out[0] = ABORT_TASK_SET;
2573		esp->msg_out_len = 1;
2574		ent->eh_done = &eh_done;
2575
2576		scsi_esp_cmd(esp, ESP_CMD_SATN);
2577	} else {
2578		/* The command is disconnected.  This is not easy to
2579		 * abort.  For now we fail and let the scsi error
2580		 * handling layer go try a scsi bus reset or host
2581		 * reset.
2582		 *
2583		 * What we could do is put together a scsi command
2584		 * solely for the purpose of sending an abort message
2585		 * to the target.  Coming up with all the code to
2586		 * cook up scsi commands, special case them everywhere,
2587		 * etc. is for questionable gain and it would be better
2588		 * if the generic scsi error handling layer could do at
2589		 * least some of that for us.
2590		 *
2591		 * Anyways this is an area for potential future improvement
2592		 * in this driver.
2593		 */
2594		goto out_failure;
2595	}
2596
2597	spin_unlock_irqrestore(esp->host->host_lock, flags);
2598
2599	if (!wait_for_completion_timeout(&eh_done, 5 * HZ)) {
2600		spin_lock_irqsave(esp->host->host_lock, flags);
2601		ent->eh_done = NULL;
2602		spin_unlock_irqrestore(esp->host->host_lock, flags);
2603
2604		return FAILED;
2605	}
2606
2607	return SUCCESS;
2608
2609out_success:
2610	spin_unlock_irqrestore(esp->host->host_lock, flags);
2611	return SUCCESS;
2612
2613out_failure:
2614	/* XXX This might be a good location to set ESP_TGT_BROKEN
2615	 * XXX since we know which target/lun in particular is
2616	 * XXX causing trouble.
2617	 */
2618	spin_unlock_irqrestore(esp->host->host_lock, flags);
2619	return FAILED;
2620}
2621
2622static int esp_eh_bus_reset_handler(struct scsi_cmnd *cmd)
2623{
2624	struct esp *esp = shost_priv(cmd->device->host);
2625	struct completion eh_reset;
2626	unsigned long flags;
2627
2628	init_completion(&eh_reset);
2629
2630	spin_lock_irqsave(esp->host->host_lock, flags);
2631
2632	esp->eh_reset = &eh_reset;
2633
2634	/* XXX This is too simple... We should add lots of
2635	 * XXX checks here so that if we find that the chip is
2636	 * XXX very wedged we return failure immediately so
2637	 * XXX that we can perform a full chip reset.
2638	 */
2639	esp->flags |= ESP_FLAG_RESETTING;
2640	scsi_esp_cmd(esp, ESP_CMD_RS);
2641
2642	spin_unlock_irqrestore(esp->host->host_lock, flags);
2643
2644	ssleep(esp_bus_reset_settle);
2645
2646	if (!wait_for_completion_timeout(&eh_reset, 5 * HZ)) {
2647		spin_lock_irqsave(esp->host->host_lock, flags);
2648		esp->eh_reset = NULL;
2649		spin_unlock_irqrestore(esp->host->host_lock, flags);
2650
2651		return FAILED;
2652	}
2653
2654	return SUCCESS;
2655}
2656
2657/* All bets are off, reset the entire device.  */
2658static int esp_eh_host_reset_handler(struct scsi_cmnd *cmd)
2659{
2660	struct esp *esp = shost_priv(cmd->device->host);
2661	unsigned long flags;
2662
2663	spin_lock_irqsave(esp->host->host_lock, flags);
2664	esp_bootup_reset(esp);
2665	esp_reset_cleanup(esp);
2666	spin_unlock_irqrestore(esp->host->host_lock, flags);
2667
2668	ssleep(esp_bus_reset_settle);
2669
2670	return SUCCESS;
2671}
2672
2673static const char *esp_info(struct Scsi_Host *host)
2674{
2675	return "esp";
2676}
2677
2678struct scsi_host_template scsi_esp_template = {
2679	.module			= THIS_MODULE,
2680	.name			= "esp",
2681	.info			= esp_info,
2682	.queuecommand		= esp_queuecommand,
2683	.target_alloc		= esp_target_alloc,
2684	.target_destroy		= esp_target_destroy,
2685	.slave_alloc		= esp_slave_alloc,
2686	.slave_configure	= esp_slave_configure,
2687	.slave_destroy		= esp_slave_destroy,
2688	.eh_abort_handler	= esp_eh_abort_handler,
2689	.eh_bus_reset_handler	= esp_eh_bus_reset_handler,
2690	.eh_host_reset_handler	= esp_eh_host_reset_handler,
2691	.can_queue		= 7,
2692	.this_id		= 7,
2693	.sg_tablesize		= SG_ALL,
2694	.use_clustering		= ENABLE_CLUSTERING,
2695	.max_sectors		= 0xffff,
2696	.skip_settle_delay	= 1,
2697};
2698EXPORT_SYMBOL(scsi_esp_template);
2699
2700static void esp_get_signalling(struct Scsi_Host *host)
2701{
2702	struct esp *esp = shost_priv(host);
2703	enum spi_signal_type type;
2704
2705	if (esp->flags & ESP_FLAG_DIFFERENTIAL)
2706		type = SPI_SIGNAL_HVD;
2707	else
2708		type = SPI_SIGNAL_SE;
2709
2710	spi_signalling(host) = type;
2711}
2712
2713static void esp_set_offset(struct scsi_target *target, int offset)
2714{
2715	struct Scsi_Host *host = dev_to_shost(target->dev.parent);
2716	struct esp *esp = shost_priv(host);
2717	struct esp_target_data *tp = &esp->target[target->id];
2718
2719	if (esp->flags & ESP_FLAG_DISABLE_SYNC)
2720		tp->nego_goal_offset = 0;
2721	else
2722		tp->nego_goal_offset = offset;
2723	tp->flags |= ESP_TGT_CHECK_NEGO;
2724}
2725
2726static void esp_set_period(struct scsi_target *target, int period)
2727{
2728	struct Scsi_Host *host = dev_to_shost(target->dev.parent);
2729	struct esp *esp = shost_priv(host);
2730	struct esp_target_data *tp = &esp->target[target->id];
2731
2732	tp->nego_goal_period = period;
2733	tp->flags |= ESP_TGT_CHECK_NEGO;
2734}
2735
2736static void esp_set_width(struct scsi_target *target, int width)
2737{
2738	struct Scsi_Host *host = dev_to_shost(target->dev.parent);
2739	struct esp *esp = shost_priv(host);
2740	struct esp_target_data *tp = &esp->target[target->id];
2741
2742	tp->nego_goal_width = (width ? 1 : 0);
2743	tp->flags |= ESP_TGT_CHECK_NEGO;
2744}
2745
2746static struct spi_function_template esp_transport_ops = {
2747	.set_offset		= esp_set_offset,
2748	.show_offset		= 1,
2749	.set_period		= esp_set_period,
2750	.show_period		= 1,
2751	.set_width		= esp_set_width,
2752	.show_width		= 1,
2753	.get_signalling		= esp_get_signalling,
2754};
2755
2756static int __init esp_init(void)
2757{
2758	BUILD_BUG_ON(sizeof(struct scsi_pointer) <
2759		     sizeof(struct esp_cmd_priv));
2760
2761	esp_transport_template = spi_attach_transport(&esp_transport_ops);
2762	if (!esp_transport_template)
2763		return -ENODEV;
2764
2765	return 0;
2766}
2767
2768static void __exit esp_exit(void)
2769{
2770	spi_release_transport(esp_transport_template);
2771}
2772
2773MODULE_DESCRIPTION("ESP SCSI driver core");
2774MODULE_AUTHOR("David S. Miller (davem@davemloft.net)");
2775MODULE_LICENSE("GPL");
2776MODULE_VERSION(DRV_VERSION);
2777
2778module_param(esp_bus_reset_settle, int, 0);
2779MODULE_PARM_DESC(esp_bus_reset_settle,
2780		 "ESP scsi bus reset delay in seconds");
2781
2782module_param(esp_debug, int, 0);
2783MODULE_PARM_DESC(esp_debug,
2784"ESP bitmapped debugging message enable value:\n"
2785"	0x00000001	Log interrupt events\n"
2786"	0x00000002	Log scsi commands\n"
2787"	0x00000004	Log resets\n"
2788"	0x00000008	Log message in events\n"
2789"	0x00000010	Log message out events\n"
2790"	0x00000020	Log command completion\n"
2791"	0x00000040	Log disconnects\n"
2792"	0x00000080	Log data start\n"
2793"	0x00000100	Log data done\n"
2794"	0x00000200	Log reconnects\n"
2795"	0x00000400	Log auto-sense data\n"
2796);
2797
2798module_init(esp_init);
2799module_exit(esp_exit);