1 /* 2 * QEMU LSI53C895A SCSI Host Bus Adapter emulation 3 * 4 * Copyright (c) 2006 CodeSourcery. 5 * Written by Paul Brook 6 * 7 * This code is licensed under the LGPL. 8 */ 9 10 /* Note: 11 * LSI53C810 emulation is incorrect, in the sense that it supports 12 * features added in later evolutions. This should not be a problem, 13 * as well-behaved operating systems will not try to use them. 14 */ 15 16 #include "qemu/osdep.h" 17 18 #include "hw/hw.h" 19 #include "hw/irq.h" 20 #include "hw/pci/pci.h" 21 #include "hw/scsi/scsi.h" 22 #include "sysemu/dma.h" 23 #include "qemu/log.h" 24 #include "qemu/module.h" 25 #include "trace.h" 26 27 static const char *names[] = { 28 "SCNTL0", "SCNTL1", "SCNTL2", "SCNTL3", "SCID", "SXFER", "SDID", "GPREG", 29 "SFBR", "SOCL", "SSID", "SBCL", "DSTAT", "SSTAT0", "SSTAT1", "SSTAT2", 30 "DSA0", "DSA1", "DSA2", "DSA3", "ISTAT", "0x15", "0x16", "0x17", 31 "CTEST0", "CTEST1", "CTEST2", "CTEST3", "TEMP0", "TEMP1", "TEMP2", "TEMP3", 32 "DFIFO", "CTEST4", "CTEST5", "CTEST6", "DBC0", "DBC1", "DBC2", "DCMD", 33 "DNAD0", "DNAD1", "DNAD2", "DNAD3", "DSP0", "DSP1", "DSP2", "DSP3", 34 "DSPS0", "DSPS1", "DSPS2", "DSPS3", "SCRATCHA0", "SCRATCHA1", "SCRATCHA2", "SCRATCHA3", 35 "DMODE", "DIEN", "SBR", "DCNTL", "ADDER0", "ADDER1", "ADDER2", "ADDER3", 36 "SIEN0", "SIEN1", "SIST0", "SIST1", "SLPAR", "0x45", "MACNTL", "GPCNTL", 37 "STIME0", "STIME1", "RESPID", "0x4b", "STEST0", "STEST1", "STEST2", "STEST3", 38 "SIDL", "0x51", "0x52", "0x53", "SODL", "0x55", "0x56", "0x57", 39 "SBDL", "0x59", "0x5a", "0x5b", "SCRATCHB0", "SCRATCHB1", "SCRATCHB2", "SCRATCHB3", 40 }; 41 42 #define LSI_MAX_DEVS 7 43 44 #define LSI_SCNTL0_TRG 0x01 45 #define LSI_SCNTL0_AAP 0x02 46 #define LSI_SCNTL0_EPC 0x08 47 #define LSI_SCNTL0_WATN 0x10 48 #define LSI_SCNTL0_START 0x20 49 50 #define LSI_SCNTL1_SST 0x01 51 #define LSI_SCNTL1_IARB 0x02 52 #define LSI_SCNTL1_AESP 0x04 53 #define LSI_SCNTL1_RST 0x08 54 #define LSI_SCNTL1_CON 0x10 55 #define LSI_SCNTL1_DHP 0x20 56 #define LSI_SCNTL1_ADB 0x40 57 #define LSI_SCNTL1_EXC 0x80 58 59 #define LSI_SCNTL2_WSR 0x01 60 #define LSI_SCNTL2_VUE0 0x02 61 #define LSI_SCNTL2_VUE1 0x04 62 #define LSI_SCNTL2_WSS 0x08 63 #define LSI_SCNTL2_SLPHBEN 0x10 64 #define LSI_SCNTL2_SLPMD 0x20 65 #define LSI_SCNTL2_CHM 0x40 66 #define LSI_SCNTL2_SDU 0x80 67 68 #define LSI_ISTAT0_DIP 0x01 69 #define LSI_ISTAT0_SIP 0x02 70 #define LSI_ISTAT0_INTF 0x04 71 #define LSI_ISTAT0_CON 0x08 72 #define LSI_ISTAT0_SEM 0x10 73 #define LSI_ISTAT0_SIGP 0x20 74 #define LSI_ISTAT0_SRST 0x40 75 #define LSI_ISTAT0_ABRT 0x80 76 77 #define LSI_ISTAT1_SI 0x01 78 #define LSI_ISTAT1_SRUN 0x02 79 #define LSI_ISTAT1_FLSH 0x04 80 81 #define LSI_SSTAT0_SDP0 0x01 82 #define LSI_SSTAT0_RST 0x02 83 #define LSI_SSTAT0_WOA 0x04 84 #define LSI_SSTAT0_LOA 0x08 85 #define LSI_SSTAT0_AIP 0x10 86 #define LSI_SSTAT0_OLF 0x20 87 #define LSI_SSTAT0_ORF 0x40 88 #define LSI_SSTAT0_ILF 0x80 89 90 #define LSI_SIST0_PAR 0x01 91 #define LSI_SIST0_RST 0x02 92 #define LSI_SIST0_UDC 0x04 93 #define LSI_SIST0_SGE 0x08 94 #define LSI_SIST0_RSL 0x10 95 #define LSI_SIST0_SEL 0x20 96 #define LSI_SIST0_CMP 0x40 97 #define LSI_SIST0_MA 0x80 98 99 #define LSI_SIST1_HTH 0x01 100 #define LSI_SIST1_GEN 0x02 101 #define LSI_SIST1_STO 0x04 102 #define LSI_SIST1_SBMC 0x10 103 104 #define LSI_SOCL_IO 0x01 105 #define LSI_SOCL_CD 0x02 106 #define LSI_SOCL_MSG 0x04 107 #define LSI_SOCL_ATN 0x08 108 #define LSI_SOCL_SEL 0x10 109 #define LSI_SOCL_BSY 0x20 110 #define LSI_SOCL_ACK 0x40 111 #define LSI_SOCL_REQ 0x80 112 113 #define LSI_DSTAT_IID 0x01 114 #define LSI_DSTAT_SIR 0x04 115 #define LSI_DSTAT_SSI 0x08 116 #define LSI_DSTAT_ABRT 0x10 117 #define LSI_DSTAT_BF 0x20 118 #define LSI_DSTAT_MDPE 0x40 119 #define LSI_DSTAT_DFE 0x80 120 121 #define LSI_DCNTL_COM 0x01 122 #define LSI_DCNTL_IRQD 0x02 123 #define LSI_DCNTL_STD 0x04 124 #define LSI_DCNTL_IRQM 0x08 125 #define LSI_DCNTL_SSM 0x10 126 #define LSI_DCNTL_PFEN 0x20 127 #define LSI_DCNTL_PFF 0x40 128 #define LSI_DCNTL_CLSE 0x80 129 130 #define LSI_DMODE_MAN 0x01 131 #define LSI_DMODE_BOF 0x02 132 #define LSI_DMODE_ERMP 0x04 133 #define LSI_DMODE_ERL 0x08 134 #define LSI_DMODE_DIOM 0x10 135 #define LSI_DMODE_SIOM 0x20 136 137 #define LSI_CTEST2_DACK 0x01 138 #define LSI_CTEST2_DREQ 0x02 139 #define LSI_CTEST2_TEOP 0x04 140 #define LSI_CTEST2_PCICIE 0x08 141 #define LSI_CTEST2_CM 0x10 142 #define LSI_CTEST2_CIO 0x20 143 #define LSI_CTEST2_SIGP 0x40 144 #define LSI_CTEST2_DDIR 0x80 145 146 #define LSI_CTEST5_BL2 0x04 147 #define LSI_CTEST5_DDIR 0x08 148 #define LSI_CTEST5_MASR 0x10 149 #define LSI_CTEST5_DFSN 0x20 150 #define LSI_CTEST5_BBCK 0x40 151 #define LSI_CTEST5_ADCK 0x80 152 153 #define LSI_CCNTL0_DILS 0x01 154 #define LSI_CCNTL0_DISFC 0x10 155 #define LSI_CCNTL0_ENNDJ 0x20 156 #define LSI_CCNTL0_PMJCTL 0x40 157 #define LSI_CCNTL0_ENPMJ 0x80 158 159 #define LSI_CCNTL1_EN64DBMV 0x01 160 #define LSI_CCNTL1_EN64TIBMV 0x02 161 #define LSI_CCNTL1_64TIMOD 0x04 162 #define LSI_CCNTL1_DDAC 0x08 163 #define LSI_CCNTL1_ZMOD 0x80 164 165 #define LSI_SBCL_ATN 0x08 166 #define LSI_SBCL_BSY 0x20 167 #define LSI_SBCL_ACK 0x40 168 #define LSI_SBCL_REQ 0x80 169 170 /* Enable Response to Reselection */ 171 #define LSI_SCID_RRE 0x60 172 173 #define LSI_CCNTL1_40BIT (LSI_CCNTL1_EN64TIBMV|LSI_CCNTL1_64TIMOD) 174 175 #define PHASE_DO 0 176 #define PHASE_DI 1 177 #define PHASE_CMD 2 178 #define PHASE_ST 3 179 #define PHASE_MO 6 180 #define PHASE_MI 7 181 #define PHASE_MASK 7 182 183 /* Maximum length of MSG IN data. */ 184 #define LSI_MAX_MSGIN_LEN 8 185 186 /* Flag set if this is a tagged command. */ 187 #define LSI_TAG_VALID (1 << 16) 188 189 typedef struct lsi_request { 190 SCSIRequest *req; 191 uint32_t tag; 192 uint32_t dma_len; 193 uint8_t *dma_buf; 194 uint32_t pending; 195 int out; 196 QTAILQ_ENTRY(lsi_request) next; 197 } lsi_request; 198 199 enum { 200 LSI_NOWAIT, /* SCRIPTS are running or stopped */ 201 LSI_WAIT_RESELECT, /* Wait Reselect instruction has been issued */ 202 LSI_DMA_SCRIPTS, /* processing DMA from lsi_execute_script */ 203 LSI_DMA_IN_PROGRESS, /* DMA operation is in progress */ 204 }; 205 206 enum { 207 LSI_MSG_ACTION_COMMAND = 0, 208 LSI_MSG_ACTION_DISCONNECT = 1, 209 LSI_MSG_ACTION_DOUT = 2, 210 LSI_MSG_ACTION_DIN = 3, 211 }; 212 213 typedef struct { 214 /*< private >*/ 215 PCIDevice parent_obj; 216 /*< public >*/ 217 218 qemu_irq ext_irq; 219 MemoryRegion mmio_io; 220 MemoryRegion ram_io; 221 MemoryRegion io_io; 222 AddressSpace pci_io_as; 223 224 int carry; /* ??? Should this be an a visible register somewhere? */ 225 int status; 226 int msg_action; 227 int msg_len; 228 uint8_t msg[LSI_MAX_MSGIN_LEN]; 229 int waiting; 230 SCSIBus bus; 231 int current_lun; 232 /* The tag is a combination of the device ID and the SCSI tag. */ 233 uint32_t select_tag; 234 int command_complete; 235 QTAILQ_HEAD(, lsi_request) queue; 236 lsi_request *current; 237 238 uint32_t dsa; 239 uint32_t temp; 240 uint32_t dnad; 241 uint32_t dbc; 242 uint8_t istat0; 243 uint8_t istat1; 244 uint8_t dcmd; 245 uint8_t dstat; 246 uint8_t dien; 247 uint8_t sist0; 248 uint8_t sist1; 249 uint8_t sien0; 250 uint8_t sien1; 251 uint8_t mbox0; 252 uint8_t mbox1; 253 uint8_t dfifo; 254 uint8_t ctest2; 255 uint8_t ctest3; 256 uint8_t ctest4; 257 uint8_t ctest5; 258 uint8_t ccntl0; 259 uint8_t ccntl1; 260 uint32_t dsp; 261 uint32_t dsps; 262 uint8_t dmode; 263 uint8_t dcntl; 264 uint8_t scntl0; 265 uint8_t scntl1; 266 uint8_t scntl2; 267 uint8_t scntl3; 268 uint8_t sstat0; 269 uint8_t sstat1; 270 uint8_t scid; 271 uint8_t sxfer; 272 uint8_t socl; 273 uint8_t sdid; 274 uint8_t ssid; 275 uint8_t sfbr; 276 uint8_t sbcl; 277 uint8_t stest1; 278 uint8_t stest2; 279 uint8_t stest3; 280 uint8_t sidl; 281 uint8_t stime0; 282 uint8_t respid0; 283 uint8_t respid1; 284 uint32_t mmrs; 285 uint32_t mmws; 286 uint32_t sfs; 287 uint32_t drs; 288 uint32_t sbms; 289 uint32_t dbms; 290 uint32_t dnad64; 291 uint32_t pmjad1; 292 uint32_t pmjad2; 293 uint32_t rbc; 294 uint32_t ua; 295 uint32_t ia; 296 uint32_t sbc; 297 uint32_t csbc; 298 uint32_t scratch[18]; /* SCRATCHA-SCRATCHR */ 299 uint8_t sbr; 300 uint32_t adder; 301 302 uint8_t script_ram[2048 * sizeof(uint32_t)]; 303 } LSIState; 304 305 #define TYPE_LSI53C810 "lsi53c810" 306 #define TYPE_LSI53C895A "lsi53c895a" 307 308 #define LSI53C895A(obj) \ 309 OBJECT_CHECK(LSIState, (obj), TYPE_LSI53C895A) 310 311 static const char *scsi_phases[] = { 312 "DOUT", 313 "DIN", 314 "CMD", 315 "STATUS", 316 "RSVOUT", 317 "RSVIN", 318 "MSGOUT", 319 "MSGIN" 320 }; 321 322 static const char *scsi_phase_name(int phase) 323 { 324 return scsi_phases[phase & PHASE_MASK]; 325 } 326 327 static inline int lsi_irq_on_rsl(LSIState *s) 328 { 329 return (s->sien0 & LSI_SIST0_RSL) && (s->scid & LSI_SCID_RRE); 330 } 331 332 static lsi_request *get_pending_req(LSIState *s) 333 { 334 lsi_request *p; 335 336 QTAILQ_FOREACH(p, &s->queue, next) { 337 if (p->pending) { 338 return p; 339 } 340 } 341 return NULL; 342 } 343 344 static void lsi_soft_reset(LSIState *s) 345 { 346 trace_lsi_reset(); 347 s->carry = 0; 348 349 s->msg_action = LSI_MSG_ACTION_COMMAND; 350 s->msg_len = 0; 351 s->waiting = LSI_NOWAIT; 352 s->dsa = 0; 353 s->dnad = 0; 354 s->dbc = 0; 355 s->temp = 0; 356 memset(s->scratch, 0, sizeof(s->scratch)); 357 s->istat0 = 0; 358 s->istat1 = 0; 359 s->dcmd = 0x40; 360 s->dstat = 0; 361 s->dien = 0; 362 s->sist0 = 0; 363 s->sist1 = 0; 364 s->sien0 = 0; 365 s->sien1 = 0; 366 s->mbox0 = 0; 367 s->mbox1 = 0; 368 s->dfifo = 0; 369 s->ctest2 = LSI_CTEST2_DACK; 370 s->ctest3 = 0; 371 s->ctest4 = 0; 372 s->ctest5 = 0; 373 s->ccntl0 = 0; 374 s->ccntl1 = 0; 375 s->dsp = 0; 376 s->dsps = 0; 377 s->dmode = 0; 378 s->dcntl = 0; 379 s->scntl0 = 0xc0; 380 s->scntl1 = 0; 381 s->scntl2 = 0; 382 s->scntl3 = 0; 383 s->sstat0 = 0; 384 s->sstat1 = 0; 385 s->scid = 7; 386 s->sxfer = 0; 387 s->socl = 0; 388 s->sdid = 0; 389 s->ssid = 0; 390 s->sbcl = 0; 391 s->stest1 = 0; 392 s->stest2 = 0; 393 s->stest3 = 0; 394 s->sidl = 0; 395 s->stime0 = 0; 396 s->respid0 = 0x80; 397 s->respid1 = 0; 398 s->mmrs = 0; 399 s->mmws = 0; 400 s->sfs = 0; 401 s->drs = 0; 402 s->sbms = 0; 403 s->dbms = 0; 404 s->dnad64 = 0; 405 s->pmjad1 = 0; 406 s->pmjad2 = 0; 407 s->rbc = 0; 408 s->ua = 0; 409 s->ia = 0; 410 s->sbc = 0; 411 s->csbc = 0; 412 s->sbr = 0; 413 assert(QTAILQ_EMPTY(&s->queue)); 414 assert(!s->current); 415 } 416 417 static int lsi_dma_40bit(LSIState *s) 418 { 419 if ((s->ccntl1 & LSI_CCNTL1_40BIT) == LSI_CCNTL1_40BIT) 420 return 1; 421 return 0; 422 } 423 424 static int lsi_dma_ti64bit(LSIState *s) 425 { 426 if ((s->ccntl1 & LSI_CCNTL1_EN64TIBMV) == LSI_CCNTL1_EN64TIBMV) 427 return 1; 428 return 0; 429 } 430 431 static int lsi_dma_64bit(LSIState *s) 432 { 433 if ((s->ccntl1 & LSI_CCNTL1_EN64DBMV) == LSI_CCNTL1_EN64DBMV) 434 return 1; 435 return 0; 436 } 437 438 static uint8_t lsi_reg_readb(LSIState *s, int offset); 439 static void lsi_reg_writeb(LSIState *s, int offset, uint8_t val); 440 static void lsi_execute_script(LSIState *s); 441 static void lsi_reselect(LSIState *s, lsi_request *p); 442 443 static inline void lsi_mem_read(LSIState *s, dma_addr_t addr, 444 void *buf, dma_addr_t len) 445 { 446 if (s->dmode & LSI_DMODE_SIOM) { 447 address_space_read(&s->pci_io_as, addr, MEMTXATTRS_UNSPECIFIED, 448 buf, len); 449 } else { 450 pci_dma_read(PCI_DEVICE(s), addr, buf, len); 451 } 452 } 453 454 static inline void lsi_mem_write(LSIState *s, dma_addr_t addr, 455 const void *buf, dma_addr_t len) 456 { 457 if (s->dmode & LSI_DMODE_DIOM) { 458 address_space_write(&s->pci_io_as, addr, MEMTXATTRS_UNSPECIFIED, 459 buf, len); 460 } else { 461 pci_dma_write(PCI_DEVICE(s), addr, buf, len); 462 } 463 } 464 465 static inline uint32_t read_dword(LSIState *s, uint32_t addr) 466 { 467 uint32_t buf; 468 469 pci_dma_read(PCI_DEVICE(s), addr, &buf, 4); 470 return cpu_to_le32(buf); 471 } 472 473 static void lsi_stop_script(LSIState *s) 474 { 475 s->istat1 &= ~LSI_ISTAT1_SRUN; 476 } 477 478 static void lsi_set_irq(LSIState *s, int level) 479 { 480 PCIDevice *d = PCI_DEVICE(s); 481 482 if (s->ext_irq) { 483 qemu_set_irq(s->ext_irq, level); 484 } else { 485 pci_set_irq(d, level); 486 } 487 } 488 489 static void lsi_update_irq(LSIState *s) 490 { 491 int level; 492 static int last_level; 493 494 /* It's unclear whether the DIP/SIP bits should be cleared when the 495 Interrupt Status Registers are cleared or when istat0 is read. 496 We currently do the formwer, which seems to work. */ 497 level = 0; 498 if (s->dstat) { 499 if (s->dstat & s->dien) 500 level = 1; 501 s->istat0 |= LSI_ISTAT0_DIP; 502 } else { 503 s->istat0 &= ~LSI_ISTAT0_DIP; 504 } 505 506 if (s->sist0 || s->sist1) { 507 if ((s->sist0 & s->sien0) || (s->sist1 & s->sien1)) 508 level = 1; 509 s->istat0 |= LSI_ISTAT0_SIP; 510 } else { 511 s->istat0 &= ~LSI_ISTAT0_SIP; 512 } 513 if (s->istat0 & LSI_ISTAT0_INTF) 514 level = 1; 515 516 if (level != last_level) { 517 trace_lsi_update_irq(level, s->dstat, s->sist1, s->sist0); 518 last_level = level; 519 } 520 lsi_set_irq(s, level); 521 522 if (!s->current && !level && lsi_irq_on_rsl(s) && !(s->scntl1 & LSI_SCNTL1_CON)) { 523 lsi_request *p; 524 525 trace_lsi_update_irq_disconnected(); 526 p = get_pending_req(s); 527 if (p) { 528 lsi_reselect(s, p); 529 } 530 } 531 } 532 533 /* Stop SCRIPTS execution and raise a SCSI interrupt. */ 534 static void lsi_script_scsi_interrupt(LSIState *s, int stat0, int stat1) 535 { 536 uint32_t mask0; 537 uint32_t mask1; 538 539 trace_lsi_script_scsi_interrupt(stat1, stat0, s->sist1, s->sist0); 540 s->sist0 |= stat0; 541 s->sist1 |= stat1; 542 /* Stop processor on fatal or unmasked interrupt. As a special hack 543 we don't stop processing when raising STO. Instead continue 544 execution and stop at the next insn that accesses the SCSI bus. */ 545 mask0 = s->sien0 | ~(LSI_SIST0_CMP | LSI_SIST0_SEL | LSI_SIST0_RSL); 546 mask1 = s->sien1 | ~(LSI_SIST1_GEN | LSI_SIST1_HTH); 547 mask1 &= ~LSI_SIST1_STO; 548 if (s->sist0 & mask0 || s->sist1 & mask1) { 549 lsi_stop_script(s); 550 } 551 lsi_update_irq(s); 552 } 553 554 /* Stop SCRIPTS execution and raise a DMA interrupt. */ 555 static void lsi_script_dma_interrupt(LSIState *s, int stat) 556 { 557 trace_lsi_script_dma_interrupt(stat, s->dstat); 558 s->dstat |= stat; 559 lsi_update_irq(s); 560 lsi_stop_script(s); 561 } 562 563 static inline void lsi_set_phase(LSIState *s, int phase) 564 { 565 s->sbcl &= ~PHASE_MASK; 566 s->sbcl |= phase | LSI_SBCL_REQ; 567 s->sstat1 = (s->sstat1 & ~PHASE_MASK) | phase; 568 } 569 570 static void lsi_bad_phase(LSIState *s, int out, int new_phase) 571 { 572 /* Trigger a phase mismatch. */ 573 if (s->ccntl0 & LSI_CCNTL0_ENPMJ) { 574 if ((s->ccntl0 & LSI_CCNTL0_PMJCTL)) { 575 s->dsp = out ? s->pmjad1 : s->pmjad2; 576 } else { 577 s->dsp = (s->scntl2 & LSI_SCNTL2_WSR ? s->pmjad2 : s->pmjad1); 578 } 579 trace_lsi_bad_phase_jump(s->dsp); 580 } else { 581 trace_lsi_bad_phase_interrupt(); 582 lsi_script_scsi_interrupt(s, LSI_SIST0_MA, 0); 583 lsi_stop_script(s); 584 } 585 lsi_set_phase(s, new_phase); 586 } 587 588 589 /* Resume SCRIPTS execution after a DMA operation. */ 590 static void lsi_resume_script(LSIState *s) 591 { 592 if (s->waiting != 2) { 593 s->waiting = LSI_NOWAIT; 594 lsi_execute_script(s); 595 } else { 596 s->waiting = LSI_NOWAIT; 597 } 598 } 599 600 static void lsi_disconnect(LSIState *s) 601 { 602 s->scntl1 &= ~LSI_SCNTL1_CON; 603 s->sstat1 &= ~PHASE_MASK; 604 s->sbcl = 0; 605 } 606 607 static void lsi_bad_selection(LSIState *s, uint32_t id) 608 { 609 trace_lsi_bad_selection(id); 610 lsi_script_scsi_interrupt(s, 0, LSI_SIST1_STO); 611 lsi_disconnect(s); 612 } 613 614 /* Initiate a SCSI layer data transfer. */ 615 static void lsi_do_dma(LSIState *s, int out) 616 { 617 uint32_t count; 618 dma_addr_t addr; 619 SCSIDevice *dev; 620 621 assert(s->current); 622 if (!s->current->dma_len) { 623 /* Wait until data is available. */ 624 trace_lsi_do_dma_unavailable(); 625 return; 626 } 627 628 dev = s->current->req->dev; 629 assert(dev); 630 631 count = s->dbc; 632 if (count > s->current->dma_len) 633 count = s->current->dma_len; 634 635 addr = s->dnad; 636 /* both 40 and Table Indirect 64-bit DMAs store upper bits in dnad64 */ 637 if (lsi_dma_40bit(s) || lsi_dma_ti64bit(s)) 638 addr |= ((uint64_t)s->dnad64 << 32); 639 else if (s->dbms) 640 addr |= ((uint64_t)s->dbms << 32); 641 else if (s->sbms) 642 addr |= ((uint64_t)s->sbms << 32); 643 644 trace_lsi_do_dma(addr, count); 645 s->csbc += count; 646 s->dnad += count; 647 s->dbc -= count; 648 if (s->current->dma_buf == NULL) { 649 s->current->dma_buf = scsi_req_get_buf(s->current->req); 650 } 651 /* ??? Set SFBR to first data byte. */ 652 if (out) { 653 lsi_mem_read(s, addr, s->current->dma_buf, count); 654 } else { 655 lsi_mem_write(s, addr, s->current->dma_buf, count); 656 } 657 s->current->dma_len -= count; 658 if (s->current->dma_len == 0) { 659 s->current->dma_buf = NULL; 660 scsi_req_continue(s->current->req); 661 } else { 662 s->current->dma_buf += count; 663 lsi_resume_script(s); 664 } 665 } 666 667 668 /* Add a command to the queue. */ 669 static void lsi_queue_command(LSIState *s) 670 { 671 lsi_request *p = s->current; 672 673 trace_lsi_queue_command(p->tag); 674 assert(s->current != NULL); 675 assert(s->current->dma_len == 0); 676 QTAILQ_INSERT_TAIL(&s->queue, s->current, next); 677 s->current = NULL; 678 679 p->pending = 0; 680 p->out = (s->sstat1 & PHASE_MASK) == PHASE_DO; 681 } 682 683 /* Queue a byte for a MSG IN phase. */ 684 static void lsi_add_msg_byte(LSIState *s, uint8_t data) 685 { 686 if (s->msg_len >= LSI_MAX_MSGIN_LEN) { 687 trace_lsi_add_msg_byte_error(); 688 } else { 689 trace_lsi_add_msg_byte(data); 690 s->msg[s->msg_len++] = data; 691 } 692 } 693 694 /* Perform reselection to continue a command. */ 695 static void lsi_reselect(LSIState *s, lsi_request *p) 696 { 697 int id; 698 699 assert(s->current == NULL); 700 QTAILQ_REMOVE(&s->queue, p, next); 701 s->current = p; 702 703 id = (p->tag >> 8) & 0xf; 704 s->ssid = id | 0x80; 705 /* LSI53C700 Family Compatibility, see LSI53C895A 4-73 */ 706 if (!(s->dcntl & LSI_DCNTL_COM)) { 707 s->sfbr = 1 << (id & 0x7); 708 } 709 trace_lsi_reselect(id); 710 s->scntl1 |= LSI_SCNTL1_CON; 711 lsi_set_phase(s, PHASE_MI); 712 s->msg_action = p->out ? LSI_MSG_ACTION_DOUT : LSI_MSG_ACTION_DIN; 713 s->current->dma_len = p->pending; 714 lsi_add_msg_byte(s, 0x80); 715 if (s->current->tag & LSI_TAG_VALID) { 716 lsi_add_msg_byte(s, 0x20); 717 lsi_add_msg_byte(s, p->tag & 0xff); 718 } 719 720 if (lsi_irq_on_rsl(s)) { 721 lsi_script_scsi_interrupt(s, LSI_SIST0_RSL, 0); 722 } 723 } 724 725 static lsi_request *lsi_find_by_tag(LSIState *s, uint32_t tag) 726 { 727 lsi_request *p; 728 729 QTAILQ_FOREACH(p, &s->queue, next) { 730 if (p->tag == tag) { 731 return p; 732 } 733 } 734 735 return NULL; 736 } 737 738 static void lsi_request_free(LSIState *s, lsi_request *p) 739 { 740 if (p == s->current) { 741 s->current = NULL; 742 } else { 743 QTAILQ_REMOVE(&s->queue, p, next); 744 } 745 g_free(p); 746 } 747 748 static void lsi_request_cancelled(SCSIRequest *req) 749 { 750 LSIState *s = LSI53C895A(req->bus->qbus.parent); 751 lsi_request *p = req->hba_private; 752 753 req->hba_private = NULL; 754 lsi_request_free(s, p); 755 scsi_req_unref(req); 756 } 757 758 /* Record that data is available for a queued command. Returns zero if 759 the device was reselected, nonzero if the IO is deferred. */ 760 static int lsi_queue_req(LSIState *s, SCSIRequest *req, uint32_t len) 761 { 762 lsi_request *p = req->hba_private; 763 764 if (p->pending) { 765 trace_lsi_queue_req_error(p); 766 } 767 p->pending = len; 768 /* Reselect if waiting for it, or if reselection triggers an IRQ 769 and the bus is free. 770 Since no interrupt stacking is implemented in the emulation, it 771 is also required that there are no pending interrupts waiting 772 for service from the device driver. */ 773 if (s->waiting == LSI_WAIT_RESELECT || 774 (lsi_irq_on_rsl(s) && !(s->scntl1 & LSI_SCNTL1_CON) && 775 !(s->istat0 & (LSI_ISTAT0_SIP | LSI_ISTAT0_DIP)))) { 776 /* Reselect device. */ 777 lsi_reselect(s, p); 778 return 0; 779 } else { 780 trace_lsi_queue_req(p->tag); 781 p->pending = len; 782 return 1; 783 } 784 } 785 786 /* Callback to indicate that the SCSI layer has completed a command. */ 787 static void lsi_command_complete(SCSIRequest *req, uint32_t status, size_t resid) 788 { 789 LSIState *s = LSI53C895A(req->bus->qbus.parent); 790 int out; 791 792 out = (s->sstat1 & PHASE_MASK) == PHASE_DO; 793 trace_lsi_command_complete(status); 794 s->status = status; 795 s->command_complete = 2; 796 if (s->waiting && s->dbc != 0) { 797 /* Raise phase mismatch for short transfers. */ 798 lsi_bad_phase(s, out, PHASE_ST); 799 } else { 800 lsi_set_phase(s, PHASE_ST); 801 } 802 803 if (req->hba_private == s->current) { 804 req->hba_private = NULL; 805 lsi_request_free(s, s->current); 806 scsi_req_unref(req); 807 } 808 lsi_resume_script(s); 809 } 810 811 /* Callback to indicate that the SCSI layer has completed a transfer. */ 812 static void lsi_transfer_data(SCSIRequest *req, uint32_t len) 813 { 814 LSIState *s = LSI53C895A(req->bus->qbus.parent); 815 int out; 816 817 assert(req->hba_private); 818 if (s->waiting == LSI_WAIT_RESELECT || req->hba_private != s->current || 819 (lsi_irq_on_rsl(s) && !(s->scntl1 & LSI_SCNTL1_CON))) { 820 if (lsi_queue_req(s, req, len)) { 821 return; 822 } 823 } 824 825 out = (s->sstat1 & PHASE_MASK) == PHASE_DO; 826 827 /* host adapter (re)connected */ 828 trace_lsi_transfer_data(req->tag, len); 829 s->current->dma_len = len; 830 s->command_complete = 1; 831 if (s->waiting) { 832 if (s->waiting == LSI_WAIT_RESELECT || s->dbc == 0) { 833 lsi_resume_script(s); 834 } else { 835 lsi_do_dma(s, out); 836 } 837 } 838 } 839 840 static void lsi_do_command(LSIState *s) 841 { 842 SCSIDevice *dev; 843 uint8_t buf[16]; 844 uint32_t id; 845 int n; 846 847 trace_lsi_do_command(s->dbc); 848 if (s->dbc > 16) 849 s->dbc = 16; 850 pci_dma_read(PCI_DEVICE(s), s->dnad, buf, s->dbc); 851 s->sfbr = buf[0]; 852 s->command_complete = 0; 853 854 id = (s->select_tag >> 8) & 0xf; 855 dev = scsi_device_find(&s->bus, 0, id, s->current_lun); 856 if (!dev) { 857 lsi_bad_selection(s, id); 858 return; 859 } 860 861 assert(s->current == NULL); 862 s->current = g_new0(lsi_request, 1); 863 s->current->tag = s->select_tag; 864 s->current->req = scsi_req_new(dev, s->current->tag, s->current_lun, buf, 865 s->current); 866 867 n = scsi_req_enqueue(s->current->req); 868 if (n) { 869 if (n > 0) { 870 lsi_set_phase(s, PHASE_DI); 871 } else if (n < 0) { 872 lsi_set_phase(s, PHASE_DO); 873 } 874 scsi_req_continue(s->current->req); 875 } 876 if (!s->command_complete) { 877 if (n) { 878 /* Command did not complete immediately so disconnect. */ 879 lsi_add_msg_byte(s, 2); /* SAVE DATA POINTER */ 880 lsi_add_msg_byte(s, 4); /* DISCONNECT */ 881 /* wait data */ 882 lsi_set_phase(s, PHASE_MI); 883 s->msg_action = LSI_MSG_ACTION_DISCONNECT; 884 lsi_queue_command(s); 885 } else { 886 /* wait command complete */ 887 lsi_set_phase(s, PHASE_DI); 888 } 889 } 890 } 891 892 static void lsi_do_status(LSIState *s) 893 { 894 uint8_t status; 895 trace_lsi_do_status(s->dbc, s->status); 896 if (s->dbc != 1) { 897 trace_lsi_do_status_error(); 898 } 899 s->dbc = 1; 900 status = s->status; 901 s->sfbr = status; 902 pci_dma_write(PCI_DEVICE(s), s->dnad, &status, 1); 903 lsi_set_phase(s, PHASE_MI); 904 s->msg_action = LSI_MSG_ACTION_DISCONNECT; 905 lsi_add_msg_byte(s, 0); /* COMMAND COMPLETE */ 906 } 907 908 static void lsi_do_msgin(LSIState *s) 909 { 910 uint8_t len; 911 trace_lsi_do_msgin(s->dbc, s->msg_len); 912 s->sfbr = s->msg[0]; 913 len = s->msg_len; 914 assert(len > 0 && len <= LSI_MAX_MSGIN_LEN); 915 if (len > s->dbc) 916 len = s->dbc; 917 pci_dma_write(PCI_DEVICE(s), s->dnad, s->msg, len); 918 /* Linux drivers rely on the last byte being in the SIDL. */ 919 s->sidl = s->msg[len - 1]; 920 s->msg_len -= len; 921 if (s->msg_len) { 922 memmove(s->msg, s->msg + len, s->msg_len); 923 } else { 924 /* ??? Check if ATN (not yet implemented) is asserted and maybe 925 switch to PHASE_MO. */ 926 switch (s->msg_action) { 927 case LSI_MSG_ACTION_COMMAND: 928 lsi_set_phase(s, PHASE_CMD); 929 break; 930 case LSI_MSG_ACTION_DISCONNECT: 931 lsi_disconnect(s); 932 break; 933 case LSI_MSG_ACTION_DOUT: 934 lsi_set_phase(s, PHASE_DO); 935 break; 936 case LSI_MSG_ACTION_DIN: 937 lsi_set_phase(s, PHASE_DI); 938 break; 939 default: 940 abort(); 941 } 942 } 943 } 944 945 /* Read the next byte during a MSGOUT phase. */ 946 static uint8_t lsi_get_msgbyte(LSIState *s) 947 { 948 uint8_t data; 949 pci_dma_read(PCI_DEVICE(s), s->dnad, &data, 1); 950 s->dnad++; 951 s->dbc--; 952 return data; 953 } 954 955 /* Skip the next n bytes during a MSGOUT phase. */ 956 static void lsi_skip_msgbytes(LSIState *s, unsigned int n) 957 { 958 s->dnad += n; 959 s->dbc -= n; 960 } 961 962 static void lsi_do_msgout(LSIState *s) 963 { 964 uint8_t msg; 965 int len; 966 uint32_t current_tag; 967 lsi_request *current_req, *p, *p_next; 968 969 if (s->current) { 970 current_tag = s->current->tag; 971 current_req = s->current; 972 } else { 973 current_tag = s->select_tag; 974 current_req = lsi_find_by_tag(s, current_tag); 975 } 976 977 trace_lsi_do_msgout(s->dbc); 978 while (s->dbc) { 979 msg = lsi_get_msgbyte(s); 980 s->sfbr = msg; 981 982 switch (msg) { 983 case 0x04: 984 trace_lsi_do_msgout_disconnect(); 985 lsi_disconnect(s); 986 break; 987 case 0x08: 988 trace_lsi_do_msgout_noop(); 989 lsi_set_phase(s, PHASE_CMD); 990 break; 991 case 0x01: 992 len = lsi_get_msgbyte(s); 993 msg = lsi_get_msgbyte(s); 994 (void)len; /* avoid a warning about unused variable*/ 995 trace_lsi_do_msgout_extended(msg, len); 996 switch (msg) { 997 case 1: 998 trace_lsi_do_msgout_ignored("SDTR"); 999 lsi_skip_msgbytes(s, 2); 1000 break; 1001 case 3: 1002 trace_lsi_do_msgout_ignored("WDTR"); 1003 lsi_skip_msgbytes(s, 1); 1004 break; 1005 case 4: 1006 trace_lsi_do_msgout_ignored("PPR"); 1007 lsi_skip_msgbytes(s, 5); 1008 break; 1009 default: 1010 goto bad; 1011 } 1012 break; 1013 case 0x20: /* SIMPLE queue */ 1014 s->select_tag |= lsi_get_msgbyte(s) | LSI_TAG_VALID; 1015 trace_lsi_do_msgout_simplequeue(s->select_tag & 0xff); 1016 break; 1017 case 0x21: /* HEAD of queue */ 1018 qemu_log_mask(LOG_UNIMP, "lsi_scsi: HEAD queue not implemented\n"); 1019 s->select_tag |= lsi_get_msgbyte(s) | LSI_TAG_VALID; 1020 break; 1021 case 0x22: /* ORDERED queue */ 1022 qemu_log_mask(LOG_UNIMP, 1023 "lsi_scsi: ORDERED queue not implemented\n"); 1024 s->select_tag |= lsi_get_msgbyte(s) | LSI_TAG_VALID; 1025 break; 1026 case 0x0d: 1027 /* The ABORT TAG message clears the current I/O process only. */ 1028 trace_lsi_do_msgout_abort(current_tag); 1029 if (current_req) { 1030 scsi_req_cancel(current_req->req); 1031 } 1032 lsi_disconnect(s); 1033 break; 1034 case 0x06: 1035 case 0x0e: 1036 case 0x0c: 1037 /* The ABORT message clears all I/O processes for the selecting 1038 initiator on the specified logical unit of the target. */ 1039 if (msg == 0x06) { 1040 trace_lsi_do_msgout_abort(current_tag); 1041 } 1042 /* The CLEAR QUEUE message clears all I/O processes for all 1043 initiators on the specified logical unit of the target. */ 1044 if (msg == 0x0e) { 1045 trace_lsi_do_msgout_clearqueue(current_tag); 1046 } 1047 /* The BUS DEVICE RESET message clears all I/O processes for all 1048 initiators on all logical units of the target. */ 1049 if (msg == 0x0c) { 1050 trace_lsi_do_msgout_busdevicereset(current_tag); 1051 } 1052 1053 /* clear the current I/O process */ 1054 if (s->current) { 1055 scsi_req_cancel(s->current->req); 1056 } 1057 1058 /* As the current implemented devices scsi_disk and scsi_generic 1059 only support one LUN, we don't need to keep track of LUNs. 1060 Clearing I/O processes for other initiators could be possible 1061 for scsi_generic by sending a SG_SCSI_RESET to the /dev/sgX 1062 device, but this is currently not implemented (and seems not 1063 to be really necessary). So let's simply clear all queued 1064 commands for the current device: */ 1065 QTAILQ_FOREACH_SAFE(p, &s->queue, next, p_next) { 1066 if ((p->tag & 0x0000ff00) == (current_tag & 0x0000ff00)) { 1067 scsi_req_cancel(p->req); 1068 } 1069 } 1070 1071 lsi_disconnect(s); 1072 break; 1073 default: 1074 if ((msg & 0x80) == 0) { 1075 goto bad; 1076 } 1077 s->current_lun = msg & 7; 1078 trace_lsi_do_msgout_select(s->current_lun); 1079 lsi_set_phase(s, PHASE_CMD); 1080 break; 1081 } 1082 } 1083 return; 1084 bad: 1085 qemu_log_mask(LOG_UNIMP, "Unimplemented message 0x%02x\n", msg); 1086 lsi_set_phase(s, PHASE_MI); 1087 lsi_add_msg_byte(s, 7); /* MESSAGE REJECT */ 1088 s->msg_action = LSI_MSG_ACTION_COMMAND; 1089 } 1090 1091 #define LSI_BUF_SIZE 4096 1092 static void lsi_memcpy(LSIState *s, uint32_t dest, uint32_t src, int count) 1093 { 1094 int n; 1095 uint8_t buf[LSI_BUF_SIZE]; 1096 1097 trace_lsi_memcpy(dest, src, count); 1098 while (count) { 1099 n = (count > LSI_BUF_SIZE) ? LSI_BUF_SIZE : count; 1100 lsi_mem_read(s, src, buf, n); 1101 lsi_mem_write(s, dest, buf, n); 1102 src += n; 1103 dest += n; 1104 count -= n; 1105 } 1106 } 1107 1108 static void lsi_wait_reselect(LSIState *s) 1109 { 1110 lsi_request *p; 1111 1112 trace_lsi_wait_reselect(); 1113 1114 if (s->current) { 1115 return; 1116 } 1117 p = get_pending_req(s); 1118 if (p) { 1119 lsi_reselect(s, p); 1120 } 1121 if (s->current == NULL) { 1122 s->waiting = LSI_WAIT_RESELECT; 1123 } 1124 } 1125 1126 static void lsi_execute_script(LSIState *s) 1127 { 1128 PCIDevice *pci_dev = PCI_DEVICE(s); 1129 uint32_t insn; 1130 uint32_t addr, addr_high; 1131 int opcode; 1132 int insn_processed = 0; 1133 1134 s->istat1 |= LSI_ISTAT1_SRUN; 1135 again: 1136 insn_processed++; 1137 insn = read_dword(s, s->dsp); 1138 if (!insn) { 1139 /* If we receive an empty opcode increment the DSP by 4 bytes 1140 instead of 8 and execute the next opcode at that location */ 1141 s->dsp += 4; 1142 goto again; 1143 } 1144 addr = read_dword(s, s->dsp + 4); 1145 addr_high = 0; 1146 trace_lsi_execute_script(s->dsp, insn, addr); 1147 s->dsps = addr; 1148 s->dcmd = insn >> 24; 1149 s->dsp += 8; 1150 switch (insn >> 30) { 1151 case 0: /* Block move. */ 1152 if (s->sist1 & LSI_SIST1_STO) { 1153 trace_lsi_execute_script_blockmove_delayed(); 1154 lsi_stop_script(s); 1155 break; 1156 } 1157 s->dbc = insn & 0xffffff; 1158 s->rbc = s->dbc; 1159 /* ??? Set ESA. */ 1160 s->ia = s->dsp - 8; 1161 if (insn & (1 << 29)) { 1162 /* Indirect addressing. */ 1163 addr = read_dword(s, addr); 1164 } else if (insn & (1 << 28)) { 1165 uint32_t buf[2]; 1166 int32_t offset; 1167 /* Table indirect addressing. */ 1168 1169 /* 32-bit Table indirect */ 1170 offset = sextract32(addr, 0, 24); 1171 pci_dma_read(pci_dev, s->dsa + offset, buf, 8); 1172 /* byte count is stored in bits 0:23 only */ 1173 s->dbc = cpu_to_le32(buf[0]) & 0xffffff; 1174 s->rbc = s->dbc; 1175 addr = cpu_to_le32(buf[1]); 1176 1177 /* 40-bit DMA, upper addr bits [39:32] stored in first DWORD of 1178 * table, bits [31:24] */ 1179 if (lsi_dma_40bit(s)) 1180 addr_high = cpu_to_le32(buf[0]) >> 24; 1181 else if (lsi_dma_ti64bit(s)) { 1182 int selector = (cpu_to_le32(buf[0]) >> 24) & 0x1f; 1183 switch (selector) { 1184 case 0 ... 0x0f: 1185 /* offset index into scratch registers since 1186 * TI64 mode can use registers C to R */ 1187 addr_high = s->scratch[2 + selector]; 1188 break; 1189 case 0x10: 1190 addr_high = s->mmrs; 1191 break; 1192 case 0x11: 1193 addr_high = s->mmws; 1194 break; 1195 case 0x12: 1196 addr_high = s->sfs; 1197 break; 1198 case 0x13: 1199 addr_high = s->drs; 1200 break; 1201 case 0x14: 1202 addr_high = s->sbms; 1203 break; 1204 case 0x15: 1205 addr_high = s->dbms; 1206 break; 1207 default: 1208 qemu_log_mask(LOG_GUEST_ERROR, 1209 "lsi_scsi: Illegal selector specified (0x%x > 0x15) " 1210 "for 64-bit DMA block move", selector); 1211 break; 1212 } 1213 } 1214 } else if (lsi_dma_64bit(s)) { 1215 /* fetch a 3rd dword if 64-bit direct move is enabled and 1216 only if we're not doing table indirect or indirect addressing */ 1217 s->dbms = read_dword(s, s->dsp); 1218 s->dsp += 4; 1219 s->ia = s->dsp - 12; 1220 } 1221 if ((s->sstat1 & PHASE_MASK) != ((insn >> 24) & 7)) { 1222 trace_lsi_execute_script_blockmove_badphase( 1223 scsi_phase_name(s->sstat1), 1224 scsi_phase_name(insn >> 24)); 1225 lsi_script_scsi_interrupt(s, LSI_SIST0_MA, 0); 1226 break; 1227 } 1228 s->dnad = addr; 1229 s->dnad64 = addr_high; 1230 switch (s->sstat1 & 0x7) { 1231 case PHASE_DO: 1232 s->waiting = LSI_DMA_SCRIPTS; 1233 lsi_do_dma(s, 1); 1234 if (s->waiting) 1235 s->waiting = LSI_DMA_IN_PROGRESS; 1236 break; 1237 case PHASE_DI: 1238 s->waiting = LSI_DMA_SCRIPTS; 1239 lsi_do_dma(s, 0); 1240 if (s->waiting) 1241 s->waiting = LSI_DMA_IN_PROGRESS; 1242 break; 1243 case PHASE_CMD: 1244 lsi_do_command(s); 1245 break; 1246 case PHASE_ST: 1247 lsi_do_status(s); 1248 break; 1249 case PHASE_MO: 1250 lsi_do_msgout(s); 1251 break; 1252 case PHASE_MI: 1253 lsi_do_msgin(s); 1254 break; 1255 default: 1256 qemu_log_mask(LOG_UNIMP, "lsi_scsi: Unimplemented phase %s\n", 1257 scsi_phase_name(s->sstat1)); 1258 } 1259 s->dfifo = s->dbc & 0xff; 1260 s->ctest5 = (s->ctest5 & 0xfc) | ((s->dbc >> 8) & 3); 1261 s->sbc = s->dbc; 1262 s->rbc -= s->dbc; 1263 s->ua = addr + s->dbc; 1264 break; 1265 1266 case 1: /* IO or Read/Write instruction. */ 1267 opcode = (insn >> 27) & 7; 1268 if (opcode < 5) { 1269 uint32_t id; 1270 1271 if (insn & (1 << 25)) { 1272 id = read_dword(s, s->dsa + sextract32(insn, 0, 24)); 1273 } else { 1274 id = insn; 1275 } 1276 id = (id >> 16) & 0xf; 1277 if (insn & (1 << 26)) { 1278 addr = s->dsp + sextract32(addr, 0, 24); 1279 } 1280 s->dnad = addr; 1281 switch (opcode) { 1282 case 0: /* Select */ 1283 s->sdid = id; 1284 if (s->scntl1 & LSI_SCNTL1_CON) { 1285 trace_lsi_execute_script_io_alreadyreselected(); 1286 s->dsp = s->dnad; 1287 break; 1288 } 1289 s->sstat0 |= LSI_SSTAT0_WOA; 1290 s->scntl1 &= ~LSI_SCNTL1_IARB; 1291 if (!scsi_device_find(&s->bus, 0, id, 0)) { 1292 lsi_bad_selection(s, id); 1293 break; 1294 } 1295 trace_lsi_execute_script_io_selected(id, 1296 insn & (1 << 3) ? " ATN" : ""); 1297 /* ??? Linux drivers compain when this is set. Maybe 1298 it only applies in low-level mode (unimplemented). 1299 lsi_script_scsi_interrupt(s, LSI_SIST0_CMP, 0); */ 1300 s->select_tag = id << 8; 1301 s->scntl1 |= LSI_SCNTL1_CON; 1302 if (insn & (1 << 3)) { 1303 s->socl |= LSI_SOCL_ATN; 1304 s->sbcl |= LSI_SBCL_ATN; 1305 } 1306 s->sbcl |= LSI_SBCL_BSY; 1307 lsi_set_phase(s, PHASE_MO); 1308 s->waiting = LSI_NOWAIT; 1309 break; 1310 case 1: /* Disconnect */ 1311 trace_lsi_execute_script_io_disconnect(); 1312 s->scntl1 &= ~LSI_SCNTL1_CON; 1313 /* FIXME: this is not entirely correct; the target need not ask 1314 * for reselection until it has to send data, while here we force a 1315 * reselection as soon as the bus is free. The correct flow would 1316 * reselect before lsi_transfer_data and disconnect as soon as 1317 * DMA ends. 1318 */ 1319 if (!s->current) { 1320 lsi_request *p = get_pending_req(s); 1321 if (p) { 1322 lsi_reselect(s, p); 1323 } 1324 } 1325 break; 1326 case 2: /* Wait Reselect */ 1327 if (s->istat0 & LSI_ISTAT0_SIGP) { 1328 s->dsp = s->dnad; 1329 } else if (!lsi_irq_on_rsl(s)) { 1330 lsi_wait_reselect(s); 1331 } 1332 break; 1333 case 3: /* Set */ 1334 trace_lsi_execute_script_io_set( 1335 insn & (1 << 3) ? " ATN" : "", 1336 insn & (1 << 6) ? " ACK" : "", 1337 insn & (1 << 9) ? " TM" : "", 1338 insn & (1 << 10) ? " CC" : ""); 1339 if (insn & (1 << 3)) { 1340 s->socl |= LSI_SOCL_ATN; 1341 s->sbcl |= LSI_SBCL_ATN; 1342 lsi_set_phase(s, PHASE_MO); 1343 } 1344 1345 if (insn & (1 << 6)) { 1346 s->sbcl |= LSI_SBCL_ACK; 1347 } 1348 1349 if (insn & (1 << 9)) { 1350 qemu_log_mask(LOG_UNIMP, 1351 "lsi_scsi: Target mode not implemented\n"); 1352 } 1353 if (insn & (1 << 10)) 1354 s->carry = 1; 1355 break; 1356 case 4: /* Clear */ 1357 trace_lsi_execute_script_io_clear( 1358 insn & (1 << 3) ? " ATN" : "", 1359 insn & (1 << 6) ? " ACK" : "", 1360 insn & (1 << 9) ? " TM" : "", 1361 insn & (1 << 10) ? " CC" : ""); 1362 if (insn & (1 << 3)) { 1363 s->socl &= ~LSI_SOCL_ATN; 1364 s->sbcl &= ~LSI_SBCL_ATN; 1365 } 1366 1367 if (insn & (1 << 6)) { 1368 s->sbcl &= ~LSI_SBCL_ACK; 1369 } 1370 1371 if (insn & (1 << 10)) 1372 s->carry = 0; 1373 break; 1374 } 1375 } else { 1376 uint8_t op0; 1377 uint8_t op1; 1378 uint8_t data8; 1379 int reg; 1380 int operator; 1381 1382 static const char *opcode_names[3] = 1383 {"Write", "Read", "Read-Modify-Write"}; 1384 static const char *operator_names[8] = 1385 {"MOV", "SHL", "OR", "XOR", "AND", "SHR", "ADD", "ADC"}; 1386 1387 reg = ((insn >> 16) & 0x7f) | (insn & 0x80); 1388 data8 = (insn >> 8) & 0xff; 1389 opcode = (insn >> 27) & 7; 1390 operator = (insn >> 24) & 7; 1391 trace_lsi_execute_script_io_opcode( 1392 opcode_names[opcode - 5], reg, 1393 operator_names[operator], data8, s->sfbr, 1394 (insn & (1 << 23)) ? " SFBR" : ""); 1395 op0 = op1 = 0; 1396 switch (opcode) { 1397 case 5: /* From SFBR */ 1398 op0 = s->sfbr; 1399 op1 = data8; 1400 break; 1401 case 6: /* To SFBR */ 1402 if (operator) 1403 op0 = lsi_reg_readb(s, reg); 1404 op1 = data8; 1405 break; 1406 case 7: /* Read-modify-write */ 1407 if (operator) 1408 op0 = lsi_reg_readb(s, reg); 1409 if (insn & (1 << 23)) { 1410 op1 = s->sfbr; 1411 } else { 1412 op1 = data8; 1413 } 1414 break; 1415 } 1416 1417 switch (operator) { 1418 case 0: /* move */ 1419 op0 = op1; 1420 break; 1421 case 1: /* Shift left */ 1422 op1 = op0 >> 7; 1423 op0 = (op0 << 1) | s->carry; 1424 s->carry = op1; 1425 break; 1426 case 2: /* OR */ 1427 op0 |= op1; 1428 break; 1429 case 3: /* XOR */ 1430 op0 ^= op1; 1431 break; 1432 case 4: /* AND */ 1433 op0 &= op1; 1434 break; 1435 case 5: /* SHR */ 1436 op1 = op0 & 1; 1437 op0 = (op0 >> 1) | (s->carry << 7); 1438 s->carry = op1; 1439 break; 1440 case 6: /* ADD */ 1441 op0 += op1; 1442 s->carry = op0 < op1; 1443 break; 1444 case 7: /* ADC */ 1445 op0 += op1 + s->carry; 1446 if (s->carry) 1447 s->carry = op0 <= op1; 1448 else 1449 s->carry = op0 < op1; 1450 break; 1451 } 1452 1453 switch (opcode) { 1454 case 5: /* From SFBR */ 1455 case 7: /* Read-modify-write */ 1456 lsi_reg_writeb(s, reg, op0); 1457 break; 1458 case 6: /* To SFBR */ 1459 s->sfbr = op0; 1460 break; 1461 } 1462 } 1463 break; 1464 1465 case 2: /* Transfer Control. */ 1466 { 1467 int cond; 1468 int jmp; 1469 1470 if ((insn & 0x002e0000) == 0) { 1471 trace_lsi_execute_script_tc_nop(); 1472 break; 1473 } 1474 if (s->sist1 & LSI_SIST1_STO) { 1475 trace_lsi_execute_script_tc_delayedselect_timeout(); 1476 lsi_stop_script(s); 1477 break; 1478 } 1479 cond = jmp = (insn & (1 << 19)) != 0; 1480 if (cond == jmp && (insn & (1 << 21))) { 1481 trace_lsi_execute_script_tc_compc(s->carry == jmp); 1482 cond = s->carry != 0; 1483 } 1484 if (cond == jmp && (insn & (1 << 17))) { 1485 trace_lsi_execute_script_tc_compp(scsi_phase_name(s->sstat1), 1486 jmp ? '=' : '!', scsi_phase_name(insn >> 24)); 1487 cond = (s->sstat1 & PHASE_MASK) == ((insn >> 24) & 7); 1488 } 1489 if (cond == jmp && (insn & (1 << 18))) { 1490 uint8_t mask; 1491 1492 mask = (~insn >> 8) & 0xff; 1493 trace_lsi_execute_script_tc_compd( 1494 s->sfbr, mask, jmp ? '=' : '!', insn & mask); 1495 cond = (s->sfbr & mask) == (insn & mask); 1496 } 1497 if (cond == jmp) { 1498 if (insn & (1 << 23)) { 1499 /* Relative address. */ 1500 addr = s->dsp + sextract32(addr, 0, 24); 1501 } 1502 switch ((insn >> 27) & 7) { 1503 case 0: /* Jump */ 1504 trace_lsi_execute_script_tc_jump(addr); 1505 s->adder = addr; 1506 s->dsp = addr; 1507 break; 1508 case 1: /* Call */ 1509 trace_lsi_execute_script_tc_call(addr); 1510 s->temp = s->dsp; 1511 s->dsp = addr; 1512 break; 1513 case 2: /* Return */ 1514 trace_lsi_execute_script_tc_return(s->temp); 1515 s->dsp = s->temp; 1516 break; 1517 case 3: /* Interrupt */ 1518 trace_lsi_execute_script_tc_interrupt(s->dsps); 1519 if ((insn & (1 << 20)) != 0) { 1520 s->istat0 |= LSI_ISTAT0_INTF; 1521 lsi_update_irq(s); 1522 } else { 1523 lsi_script_dma_interrupt(s, LSI_DSTAT_SIR); 1524 } 1525 break; 1526 default: 1527 trace_lsi_execute_script_tc_illegal(); 1528 lsi_script_dma_interrupt(s, LSI_DSTAT_IID); 1529 break; 1530 } 1531 } else { 1532 trace_lsi_execute_script_tc_cc_failed(); 1533 } 1534 } 1535 break; 1536 1537 case 3: 1538 if ((insn & (1 << 29)) == 0) { 1539 /* Memory move. */ 1540 uint32_t dest; 1541 /* ??? The docs imply the destination address is loaded into 1542 the TEMP register. However the Linux drivers rely on 1543 the value being presrved. */ 1544 dest = read_dword(s, s->dsp); 1545 s->dsp += 4; 1546 lsi_memcpy(s, dest, addr, insn & 0xffffff); 1547 } else { 1548 uint8_t data[7]; 1549 int reg; 1550 int n; 1551 int i; 1552 1553 if (insn & (1 << 28)) { 1554 addr = s->dsa + sextract32(addr, 0, 24); 1555 } 1556 n = (insn & 7); 1557 reg = (insn >> 16) & 0xff; 1558 if (insn & (1 << 24)) { 1559 pci_dma_read(pci_dev, addr, data, n); 1560 trace_lsi_execute_script_mm_load(reg, n, addr, *(int *)data); 1561 for (i = 0; i < n; i++) { 1562 lsi_reg_writeb(s, reg + i, data[i]); 1563 } 1564 } else { 1565 trace_lsi_execute_script_mm_store(reg, n, addr); 1566 for (i = 0; i < n; i++) { 1567 data[i] = lsi_reg_readb(s, reg + i); 1568 } 1569 pci_dma_write(pci_dev, addr, data, n); 1570 } 1571 } 1572 } 1573 if (insn_processed > 10000 && s->waiting == LSI_NOWAIT) { 1574 /* Some windows drivers make the device spin waiting for a memory 1575 location to change. If we have been executed a lot of code then 1576 assume this is the case and force an unexpected device disconnect. 1577 This is apparently sufficient to beat the drivers into submission. 1578 */ 1579 if (!(s->sien0 & LSI_SIST0_UDC)) { 1580 qemu_log_mask(LOG_GUEST_ERROR, 1581 "lsi_scsi: inf. loop with UDC masked"); 1582 } 1583 lsi_script_scsi_interrupt(s, LSI_SIST0_UDC, 0); 1584 lsi_disconnect(s); 1585 } else if (s->istat1 & LSI_ISTAT1_SRUN && s->waiting == LSI_NOWAIT) { 1586 if (s->dcntl & LSI_DCNTL_SSM) { 1587 lsi_script_dma_interrupt(s, LSI_DSTAT_SSI); 1588 } else { 1589 goto again; 1590 } 1591 } 1592 trace_lsi_execute_script_stop(); 1593 } 1594 1595 static uint8_t lsi_reg_readb(LSIState *s, int offset) 1596 { 1597 uint8_t ret; 1598 1599 #define CASE_GET_REG24(name, addr) \ 1600 case addr: ret = s->name & 0xff; break; \ 1601 case addr + 1: ret = (s->name >> 8) & 0xff; break; \ 1602 case addr + 2: ret = (s->name >> 16) & 0xff; break; 1603 1604 #define CASE_GET_REG32(name, addr) \ 1605 case addr: ret = s->name & 0xff; break; \ 1606 case addr + 1: ret = (s->name >> 8) & 0xff; break; \ 1607 case addr + 2: ret = (s->name >> 16) & 0xff; break; \ 1608 case addr + 3: ret = (s->name >> 24) & 0xff; break; 1609 1610 switch (offset) { 1611 case 0x00: /* SCNTL0 */ 1612 ret = s->scntl0; 1613 break; 1614 case 0x01: /* SCNTL1 */ 1615 ret = s->scntl1; 1616 break; 1617 case 0x02: /* SCNTL2 */ 1618 ret = s->scntl2; 1619 break; 1620 case 0x03: /* SCNTL3 */ 1621 ret = s->scntl3; 1622 break; 1623 case 0x04: /* SCID */ 1624 ret = s->scid; 1625 break; 1626 case 0x05: /* SXFER */ 1627 ret = s->sxfer; 1628 break; 1629 case 0x06: /* SDID */ 1630 ret = s->sdid; 1631 break; 1632 case 0x07: /* GPREG0 */ 1633 ret = 0x7f; 1634 break; 1635 case 0x08: /* Revision ID */ 1636 ret = 0x00; 1637 break; 1638 case 0x09: /* SOCL */ 1639 ret = s->socl; 1640 break; 1641 case 0xa: /* SSID */ 1642 ret = s->ssid; 1643 break; 1644 case 0xb: /* SBCL */ 1645 ret = s->sbcl; 1646 break; 1647 case 0xc: /* DSTAT */ 1648 ret = s->dstat | LSI_DSTAT_DFE; 1649 if ((s->istat0 & LSI_ISTAT0_INTF) == 0) 1650 s->dstat = 0; 1651 lsi_update_irq(s); 1652 break; 1653 case 0x0d: /* SSTAT0 */ 1654 ret = s->sstat0; 1655 break; 1656 case 0x0e: /* SSTAT1 */ 1657 ret = s->sstat1; 1658 break; 1659 case 0x0f: /* SSTAT2 */ 1660 ret = s->scntl1 & LSI_SCNTL1_CON ? 0 : 2; 1661 break; 1662 CASE_GET_REG32(dsa, 0x10) 1663 case 0x14: /* ISTAT0 */ 1664 ret = s->istat0; 1665 break; 1666 case 0x15: /* ISTAT1 */ 1667 ret = s->istat1; 1668 break; 1669 case 0x16: /* MBOX0 */ 1670 ret = s->mbox0; 1671 break; 1672 case 0x17: /* MBOX1 */ 1673 ret = s->mbox1; 1674 break; 1675 case 0x18: /* CTEST0 */ 1676 ret = 0xff; 1677 break; 1678 case 0x19: /* CTEST1 */ 1679 ret = 0; 1680 break; 1681 case 0x1a: /* CTEST2 */ 1682 ret = s->ctest2 | LSI_CTEST2_DACK | LSI_CTEST2_CM; 1683 if (s->istat0 & LSI_ISTAT0_SIGP) { 1684 s->istat0 &= ~LSI_ISTAT0_SIGP; 1685 ret |= LSI_CTEST2_SIGP; 1686 } 1687 break; 1688 case 0x1b: /* CTEST3 */ 1689 ret = s->ctest3; 1690 break; 1691 CASE_GET_REG32(temp, 0x1c) 1692 case 0x20: /* DFIFO */ 1693 ret = s->dfifo; 1694 break; 1695 case 0x21: /* CTEST4 */ 1696 ret = s->ctest4; 1697 break; 1698 case 0x22: /* CTEST5 */ 1699 ret = s->ctest5; 1700 break; 1701 case 0x23: /* CTEST6 */ 1702 ret = 0; 1703 break; 1704 CASE_GET_REG24(dbc, 0x24) 1705 case 0x27: /* DCMD */ 1706 ret = s->dcmd; 1707 break; 1708 CASE_GET_REG32(dnad, 0x28) 1709 CASE_GET_REG32(dsp, 0x2c) 1710 CASE_GET_REG32(dsps, 0x30) 1711 CASE_GET_REG32(scratch[0], 0x34) 1712 case 0x38: /* DMODE */ 1713 ret = s->dmode; 1714 break; 1715 case 0x39: /* DIEN */ 1716 ret = s->dien; 1717 break; 1718 case 0x3a: /* SBR */ 1719 ret = s->sbr; 1720 break; 1721 case 0x3b: /* DCNTL */ 1722 ret = s->dcntl; 1723 break; 1724 /* ADDER Output (Debug of relative jump address) */ 1725 CASE_GET_REG32(adder, 0x3c) 1726 case 0x40: /* SIEN0 */ 1727 ret = s->sien0; 1728 break; 1729 case 0x41: /* SIEN1 */ 1730 ret = s->sien1; 1731 break; 1732 case 0x42: /* SIST0 */ 1733 ret = s->sist0; 1734 s->sist0 = 0; 1735 lsi_update_irq(s); 1736 break; 1737 case 0x43: /* SIST1 */ 1738 ret = s->sist1; 1739 s->sist1 = 0; 1740 lsi_update_irq(s); 1741 break; 1742 case 0x46: /* MACNTL */ 1743 ret = 0x0f; 1744 break; 1745 case 0x47: /* GPCNTL0 */ 1746 ret = 0x0f; 1747 break; 1748 case 0x48: /* STIME0 */ 1749 ret = s->stime0; 1750 break; 1751 case 0x4a: /* RESPID0 */ 1752 ret = s->respid0; 1753 break; 1754 case 0x4b: /* RESPID1 */ 1755 ret = s->respid1; 1756 break; 1757 case 0x4d: /* STEST1 */ 1758 ret = s->stest1; 1759 break; 1760 case 0x4e: /* STEST2 */ 1761 ret = s->stest2; 1762 break; 1763 case 0x4f: /* STEST3 */ 1764 ret = s->stest3; 1765 break; 1766 case 0x50: /* SIDL */ 1767 /* This is needed by the linux drivers. We currently only update it 1768 during the MSG IN phase. */ 1769 ret = s->sidl; 1770 break; 1771 case 0x52: /* STEST4 */ 1772 ret = 0xe0; 1773 break; 1774 case 0x56: /* CCNTL0 */ 1775 ret = s->ccntl0; 1776 break; 1777 case 0x57: /* CCNTL1 */ 1778 ret = s->ccntl1; 1779 break; 1780 case 0x58: /* SBDL */ 1781 /* Some drivers peek at the data bus during the MSG IN phase. */ 1782 if ((s->sstat1 & PHASE_MASK) == PHASE_MI) { 1783 assert(s->msg_len > 0); 1784 return s->msg[0]; 1785 } 1786 ret = 0; 1787 break; 1788 case 0x59: /* SBDL high */ 1789 ret = 0; 1790 break; 1791 CASE_GET_REG32(mmrs, 0xa0) 1792 CASE_GET_REG32(mmws, 0xa4) 1793 CASE_GET_REG32(sfs, 0xa8) 1794 CASE_GET_REG32(drs, 0xac) 1795 CASE_GET_REG32(sbms, 0xb0) 1796 CASE_GET_REG32(dbms, 0xb4) 1797 CASE_GET_REG32(dnad64, 0xb8) 1798 CASE_GET_REG32(pmjad1, 0xc0) 1799 CASE_GET_REG32(pmjad2, 0xc4) 1800 CASE_GET_REG32(rbc, 0xc8) 1801 CASE_GET_REG32(ua, 0xcc) 1802 CASE_GET_REG32(ia, 0xd4) 1803 CASE_GET_REG32(sbc, 0xd8) 1804 CASE_GET_REG32(csbc, 0xdc) 1805 case 0x5c ... 0x9f: 1806 { 1807 int n; 1808 int shift; 1809 n = (offset - 0x58) >> 2; 1810 shift = (offset & 3) * 8; 1811 ret = (s->scratch[n] >> shift) & 0xff; 1812 break; 1813 } 1814 default: 1815 { 1816 qemu_log_mask(LOG_GUEST_ERROR, 1817 "lsi_scsi: invalid read from reg %s %x\n", 1818 offset < ARRAY_SIZE(names) ? names[offset] : "???", 1819 offset); 1820 ret = 0xff; 1821 break; 1822 } 1823 } 1824 #undef CASE_GET_REG24 1825 #undef CASE_GET_REG32 1826 1827 trace_lsi_reg_read(offset < ARRAY_SIZE(names) ? names[offset] : "???", 1828 offset, ret); 1829 1830 return ret; 1831 } 1832 1833 static void lsi_reg_writeb(LSIState *s, int offset, uint8_t val) 1834 { 1835 #define CASE_SET_REG24(name, addr) \ 1836 case addr : s->name &= 0xffffff00; s->name |= val; break; \ 1837 case addr + 1: s->name &= 0xffff00ff; s->name |= val << 8; break; \ 1838 case addr + 2: s->name &= 0xff00ffff; s->name |= val << 16; break; 1839 1840 #define CASE_SET_REG32(name, addr) \ 1841 case addr : s->name &= 0xffffff00; s->name |= val; break; \ 1842 case addr + 1: s->name &= 0xffff00ff; s->name |= val << 8; break; \ 1843 case addr + 2: s->name &= 0xff00ffff; s->name |= val << 16; break; \ 1844 case addr + 3: s->name &= 0x00ffffff; s->name |= val << 24; break; 1845 1846 trace_lsi_reg_write(offset < ARRAY_SIZE(names) ? names[offset] : "???", 1847 offset, val); 1848 1849 switch (offset) { 1850 case 0x00: /* SCNTL0 */ 1851 s->scntl0 = val; 1852 if (val & LSI_SCNTL0_START) { 1853 qemu_log_mask(LOG_UNIMP, 1854 "lsi_scsi: Start sequence not implemented\n"); 1855 } 1856 break; 1857 case 0x01: /* SCNTL1 */ 1858 s->scntl1 = val & ~LSI_SCNTL1_SST; 1859 if (val & LSI_SCNTL1_IARB) { 1860 qemu_log_mask(LOG_UNIMP, 1861 "lsi_scsi: Immediate Arbritration not implemented\n"); 1862 } 1863 if (val & LSI_SCNTL1_RST) { 1864 if (!(s->sstat0 & LSI_SSTAT0_RST)) { 1865 qbus_reset_all(BUS(&s->bus)); 1866 s->sstat0 |= LSI_SSTAT0_RST; 1867 lsi_script_scsi_interrupt(s, LSI_SIST0_RST, 0); 1868 } 1869 } else { 1870 s->sstat0 &= ~LSI_SSTAT0_RST; 1871 } 1872 break; 1873 case 0x02: /* SCNTL2 */ 1874 val &= ~(LSI_SCNTL2_WSR | LSI_SCNTL2_WSS); 1875 s->scntl2 = val; 1876 break; 1877 case 0x03: /* SCNTL3 */ 1878 s->scntl3 = val; 1879 break; 1880 case 0x04: /* SCID */ 1881 s->scid = val; 1882 break; 1883 case 0x05: /* SXFER */ 1884 s->sxfer = val; 1885 break; 1886 case 0x06: /* SDID */ 1887 if ((s->ssid & 0x80) && (val & 0xf) != (s->ssid & 0xf)) { 1888 qemu_log_mask(LOG_GUEST_ERROR, 1889 "lsi_scsi: Destination ID does not match SSID\n"); 1890 } 1891 s->sdid = val & 0xf; 1892 break; 1893 case 0x07: /* GPREG0 */ 1894 break; 1895 case 0x08: /* SFBR */ 1896 /* The CPU is not allowed to write to this register. However the 1897 SCRIPTS register move instructions are. */ 1898 s->sfbr = val; 1899 break; 1900 case 0x0a: case 0x0b: 1901 /* Openserver writes to these readonly registers on startup */ 1902 return; 1903 case 0x0c: case 0x0d: case 0x0e: case 0x0f: 1904 /* Linux writes to these readonly registers on startup. */ 1905 return; 1906 CASE_SET_REG32(dsa, 0x10) 1907 case 0x14: /* ISTAT0 */ 1908 s->istat0 = (s->istat0 & 0x0f) | (val & 0xf0); 1909 if (val & LSI_ISTAT0_ABRT) { 1910 lsi_script_dma_interrupt(s, LSI_DSTAT_ABRT); 1911 } 1912 if (val & LSI_ISTAT0_INTF) { 1913 s->istat0 &= ~LSI_ISTAT0_INTF; 1914 lsi_update_irq(s); 1915 } 1916 if (s->waiting == LSI_WAIT_RESELECT && val & LSI_ISTAT0_SIGP) { 1917 trace_lsi_awoken(); 1918 s->waiting = LSI_NOWAIT; 1919 s->dsp = s->dnad; 1920 lsi_execute_script(s); 1921 } 1922 if (val & LSI_ISTAT0_SRST) { 1923 qdev_reset_all(DEVICE(s)); 1924 } 1925 break; 1926 case 0x16: /* MBOX0 */ 1927 s->mbox0 = val; 1928 break; 1929 case 0x17: /* MBOX1 */ 1930 s->mbox1 = val; 1931 break; 1932 case 0x18: /* CTEST0 */ 1933 /* nothing to do */ 1934 break; 1935 case 0x1a: /* CTEST2 */ 1936 s->ctest2 = val & LSI_CTEST2_PCICIE; 1937 break; 1938 case 0x1b: /* CTEST3 */ 1939 s->ctest3 = val & 0x0f; 1940 break; 1941 CASE_SET_REG32(temp, 0x1c) 1942 case 0x21: /* CTEST4 */ 1943 if (val & 7) { 1944 qemu_log_mask(LOG_UNIMP, 1945 "lsi_scsi: Unimplemented CTEST4-FBL 0x%x\n", val); 1946 } 1947 s->ctest4 = val; 1948 break; 1949 case 0x22: /* CTEST5 */ 1950 if (val & (LSI_CTEST5_ADCK | LSI_CTEST5_BBCK)) { 1951 qemu_log_mask(LOG_UNIMP, 1952 "lsi_scsi: CTEST5 DMA increment not implemented\n"); 1953 } 1954 s->ctest5 = val; 1955 break; 1956 CASE_SET_REG24(dbc, 0x24) 1957 CASE_SET_REG32(dnad, 0x28) 1958 case 0x2c: /* DSP[0:7] */ 1959 s->dsp &= 0xffffff00; 1960 s->dsp |= val; 1961 break; 1962 case 0x2d: /* DSP[8:15] */ 1963 s->dsp &= 0xffff00ff; 1964 s->dsp |= val << 8; 1965 break; 1966 case 0x2e: /* DSP[16:23] */ 1967 s->dsp &= 0xff00ffff; 1968 s->dsp |= val << 16; 1969 break; 1970 case 0x2f: /* DSP[24:31] */ 1971 s->dsp &= 0x00ffffff; 1972 s->dsp |= val << 24; 1973 if ((s->dmode & LSI_DMODE_MAN) == 0 1974 && (s->istat1 & LSI_ISTAT1_SRUN) == 0) 1975 lsi_execute_script(s); 1976 break; 1977 CASE_SET_REG32(dsps, 0x30) 1978 CASE_SET_REG32(scratch[0], 0x34) 1979 case 0x38: /* DMODE */ 1980 s->dmode = val; 1981 break; 1982 case 0x39: /* DIEN */ 1983 s->dien = val; 1984 lsi_update_irq(s); 1985 break; 1986 case 0x3a: /* SBR */ 1987 s->sbr = val; 1988 break; 1989 case 0x3b: /* DCNTL */ 1990 s->dcntl = val & ~(LSI_DCNTL_PFF | LSI_DCNTL_STD); 1991 if ((val & LSI_DCNTL_STD) && (s->istat1 & LSI_ISTAT1_SRUN) == 0) 1992 lsi_execute_script(s); 1993 break; 1994 case 0x40: /* SIEN0 */ 1995 s->sien0 = val; 1996 lsi_update_irq(s); 1997 break; 1998 case 0x41: /* SIEN1 */ 1999 s->sien1 = val; 2000 lsi_update_irq(s); 2001 break; 2002 case 0x47: /* GPCNTL0 */ 2003 break; 2004 case 0x48: /* STIME0 */ 2005 s->stime0 = val; 2006 break; 2007 case 0x49: /* STIME1 */ 2008 if (val & 0xf) { 2009 qemu_log_mask(LOG_UNIMP, 2010 "lsi_scsi: General purpose timer not implemented\n"); 2011 /* ??? Raising the interrupt immediately seems to be sufficient 2012 to keep the FreeBSD driver happy. */ 2013 lsi_script_scsi_interrupt(s, 0, LSI_SIST1_GEN); 2014 } 2015 break; 2016 case 0x4a: /* RESPID0 */ 2017 s->respid0 = val; 2018 break; 2019 case 0x4b: /* RESPID1 */ 2020 s->respid1 = val; 2021 break; 2022 case 0x4d: /* STEST1 */ 2023 s->stest1 = val; 2024 break; 2025 case 0x4e: /* STEST2 */ 2026 if (val & 1) { 2027 qemu_log_mask(LOG_UNIMP, 2028 "lsi_scsi: Low level mode not implemented\n"); 2029 } 2030 s->stest2 = val; 2031 break; 2032 case 0x4f: /* STEST3 */ 2033 if (val & 0x41) { 2034 qemu_log_mask(LOG_UNIMP, 2035 "lsi_scsi: SCSI FIFO test mode not implemented\n"); 2036 } 2037 s->stest3 = val; 2038 break; 2039 case 0x56: /* CCNTL0 */ 2040 s->ccntl0 = val; 2041 break; 2042 case 0x57: /* CCNTL1 */ 2043 s->ccntl1 = val; 2044 break; 2045 CASE_SET_REG32(mmrs, 0xa0) 2046 CASE_SET_REG32(mmws, 0xa4) 2047 CASE_SET_REG32(sfs, 0xa8) 2048 CASE_SET_REG32(drs, 0xac) 2049 CASE_SET_REG32(sbms, 0xb0) 2050 CASE_SET_REG32(dbms, 0xb4) 2051 CASE_SET_REG32(dnad64, 0xb8) 2052 CASE_SET_REG32(pmjad1, 0xc0) 2053 CASE_SET_REG32(pmjad2, 0xc4) 2054 CASE_SET_REG32(rbc, 0xc8) 2055 CASE_SET_REG32(ua, 0xcc) 2056 CASE_SET_REG32(ia, 0xd4) 2057 CASE_SET_REG32(sbc, 0xd8) 2058 CASE_SET_REG32(csbc, 0xdc) 2059 default: 2060 if (offset >= 0x5c && offset < 0xa0) { 2061 int n; 2062 int shift; 2063 n = (offset - 0x58) >> 2; 2064 shift = (offset & 3) * 8; 2065 s->scratch[n] = deposit32(s->scratch[n], shift, 8, val); 2066 } else { 2067 qemu_log_mask(LOG_GUEST_ERROR, 2068 "lsi_scsi: invalid write to reg %s %x (0x%02x)\n", 2069 offset < ARRAY_SIZE(names) ? names[offset] : "???", 2070 offset, val); 2071 } 2072 } 2073 #undef CASE_SET_REG24 2074 #undef CASE_SET_REG32 2075 } 2076 2077 static void lsi_mmio_write(void *opaque, hwaddr addr, 2078 uint64_t val, unsigned size) 2079 { 2080 LSIState *s = opaque; 2081 2082 lsi_reg_writeb(s, addr & 0xff, val); 2083 } 2084 2085 static uint64_t lsi_mmio_read(void *opaque, hwaddr addr, 2086 unsigned size) 2087 { 2088 LSIState *s = opaque; 2089 return lsi_reg_readb(s, addr & 0xff); 2090 } 2091 2092 static const MemoryRegionOps lsi_mmio_ops = { 2093 .read = lsi_mmio_read, 2094 .write = lsi_mmio_write, 2095 .endianness = DEVICE_LITTLE_ENDIAN, 2096 .impl = { 2097 .min_access_size = 1, 2098 .max_access_size = 1, 2099 }, 2100 }; 2101 2102 static void lsi_ram_write(void *opaque, hwaddr addr, 2103 uint64_t val, unsigned size) 2104 { 2105 LSIState *s = opaque; 2106 stn_le_p(s->script_ram + addr, size, val); 2107 } 2108 2109 static uint64_t lsi_ram_read(void *opaque, hwaddr addr, 2110 unsigned size) 2111 { 2112 LSIState *s = opaque; 2113 return ldn_le_p(s->script_ram + addr, size); 2114 } 2115 2116 static const MemoryRegionOps lsi_ram_ops = { 2117 .read = lsi_ram_read, 2118 .write = lsi_ram_write, 2119 .endianness = DEVICE_LITTLE_ENDIAN, 2120 }; 2121 2122 static uint64_t lsi_io_read(void *opaque, hwaddr addr, 2123 unsigned size) 2124 { 2125 LSIState *s = opaque; 2126 return lsi_reg_readb(s, addr & 0xff); 2127 } 2128 2129 static void lsi_io_write(void *opaque, hwaddr addr, 2130 uint64_t val, unsigned size) 2131 { 2132 LSIState *s = opaque; 2133 lsi_reg_writeb(s, addr & 0xff, val); 2134 } 2135 2136 static const MemoryRegionOps lsi_io_ops = { 2137 .read = lsi_io_read, 2138 .write = lsi_io_write, 2139 .endianness = DEVICE_LITTLE_ENDIAN, 2140 .impl = { 2141 .min_access_size = 1, 2142 .max_access_size = 1, 2143 }, 2144 }; 2145 2146 static void lsi_scsi_reset(DeviceState *dev) 2147 { 2148 LSIState *s = LSI53C895A(dev); 2149 2150 lsi_soft_reset(s); 2151 } 2152 2153 static int lsi_pre_save(void *opaque) 2154 { 2155 LSIState *s = opaque; 2156 2157 if (s->current) { 2158 assert(s->current->dma_buf == NULL); 2159 assert(s->current->dma_len == 0); 2160 } 2161 assert(QTAILQ_EMPTY(&s->queue)); 2162 2163 return 0; 2164 } 2165 2166 static int lsi_post_load(void *opaque, int version_id) 2167 { 2168 LSIState *s = opaque; 2169 2170 if (s->msg_len < 0 || s->msg_len > LSI_MAX_MSGIN_LEN) { 2171 return -EINVAL; 2172 } 2173 2174 return 0; 2175 } 2176 2177 static const VMStateDescription vmstate_lsi_scsi = { 2178 .name = "lsiscsi", 2179 .version_id = 1, 2180 .minimum_version_id = 0, 2181 .pre_save = lsi_pre_save, 2182 .post_load = lsi_post_load, 2183 .fields = (VMStateField[]) { 2184 VMSTATE_PCI_DEVICE(parent_obj, LSIState), 2185 2186 VMSTATE_INT32(carry, LSIState), 2187 VMSTATE_INT32(status, LSIState), 2188 VMSTATE_INT32(msg_action, LSIState), 2189 VMSTATE_INT32(msg_len, LSIState), 2190 VMSTATE_BUFFER(msg, LSIState), 2191 VMSTATE_INT32(waiting, LSIState), 2192 2193 VMSTATE_UINT32(dsa, LSIState), 2194 VMSTATE_UINT32(temp, LSIState), 2195 VMSTATE_UINT32(dnad, LSIState), 2196 VMSTATE_UINT32(dbc, LSIState), 2197 VMSTATE_UINT8(istat0, LSIState), 2198 VMSTATE_UINT8(istat1, LSIState), 2199 VMSTATE_UINT8(dcmd, LSIState), 2200 VMSTATE_UINT8(dstat, LSIState), 2201 VMSTATE_UINT8(dien, LSIState), 2202 VMSTATE_UINT8(sist0, LSIState), 2203 VMSTATE_UINT8(sist1, LSIState), 2204 VMSTATE_UINT8(sien0, LSIState), 2205 VMSTATE_UINT8(sien1, LSIState), 2206 VMSTATE_UINT8(mbox0, LSIState), 2207 VMSTATE_UINT8(mbox1, LSIState), 2208 VMSTATE_UINT8(dfifo, LSIState), 2209 VMSTATE_UINT8(ctest2, LSIState), 2210 VMSTATE_UINT8(ctest3, LSIState), 2211 VMSTATE_UINT8(ctest4, LSIState), 2212 VMSTATE_UINT8(ctest5, LSIState), 2213 VMSTATE_UINT8(ccntl0, LSIState), 2214 VMSTATE_UINT8(ccntl1, LSIState), 2215 VMSTATE_UINT32(dsp, LSIState), 2216 VMSTATE_UINT32(dsps, LSIState), 2217 VMSTATE_UINT8(dmode, LSIState), 2218 VMSTATE_UINT8(dcntl, LSIState), 2219 VMSTATE_UINT8(scntl0, LSIState), 2220 VMSTATE_UINT8(scntl1, LSIState), 2221 VMSTATE_UINT8(scntl2, LSIState), 2222 VMSTATE_UINT8(scntl3, LSIState), 2223 VMSTATE_UINT8(sstat0, LSIState), 2224 VMSTATE_UINT8(sstat1, LSIState), 2225 VMSTATE_UINT8(scid, LSIState), 2226 VMSTATE_UINT8(sxfer, LSIState), 2227 VMSTATE_UINT8(socl, LSIState), 2228 VMSTATE_UINT8(sdid, LSIState), 2229 VMSTATE_UINT8(ssid, LSIState), 2230 VMSTATE_UINT8(sfbr, LSIState), 2231 VMSTATE_UINT8(stest1, LSIState), 2232 VMSTATE_UINT8(stest2, LSIState), 2233 VMSTATE_UINT8(stest3, LSIState), 2234 VMSTATE_UINT8(sidl, LSIState), 2235 VMSTATE_UINT8(stime0, LSIState), 2236 VMSTATE_UINT8(respid0, LSIState), 2237 VMSTATE_UINT8(respid1, LSIState), 2238 VMSTATE_UINT8_V(sbcl, LSIState, 1), 2239 VMSTATE_UINT32(mmrs, LSIState), 2240 VMSTATE_UINT32(mmws, LSIState), 2241 VMSTATE_UINT32(sfs, LSIState), 2242 VMSTATE_UINT32(drs, LSIState), 2243 VMSTATE_UINT32(sbms, LSIState), 2244 VMSTATE_UINT32(dbms, LSIState), 2245 VMSTATE_UINT32(dnad64, LSIState), 2246 VMSTATE_UINT32(pmjad1, LSIState), 2247 VMSTATE_UINT32(pmjad2, LSIState), 2248 VMSTATE_UINT32(rbc, LSIState), 2249 VMSTATE_UINT32(ua, LSIState), 2250 VMSTATE_UINT32(ia, LSIState), 2251 VMSTATE_UINT32(sbc, LSIState), 2252 VMSTATE_UINT32(csbc, LSIState), 2253 VMSTATE_BUFFER_UNSAFE(scratch, LSIState, 0, 18 * sizeof(uint32_t)), 2254 VMSTATE_UINT8(sbr, LSIState), 2255 2256 VMSTATE_BUFFER_UNSAFE(script_ram, LSIState, 0, 8192), 2257 VMSTATE_END_OF_LIST() 2258 } 2259 }; 2260 2261 static const struct SCSIBusInfo lsi_scsi_info = { 2262 .tcq = true, 2263 .max_target = LSI_MAX_DEVS, 2264 .max_lun = 0, /* LUN support is buggy */ 2265 2266 .transfer_data = lsi_transfer_data, 2267 .complete = lsi_command_complete, 2268 .cancel = lsi_request_cancelled 2269 }; 2270 2271 static void lsi_scsi_realize(PCIDevice *dev, Error **errp) 2272 { 2273 LSIState *s = LSI53C895A(dev); 2274 DeviceState *d = DEVICE(dev); 2275 uint8_t *pci_conf; 2276 2277 pci_conf = dev->config; 2278 2279 /* PCI latency timer = 255 */ 2280 pci_conf[PCI_LATENCY_TIMER] = 0xff; 2281 /* Interrupt pin A */ 2282 pci_conf[PCI_INTERRUPT_PIN] = 0x01; 2283 2284 memory_region_init_io(&s->mmio_io, OBJECT(s), &lsi_mmio_ops, s, 2285 "lsi-mmio", 0x400); 2286 memory_region_init_io(&s->ram_io, OBJECT(s), &lsi_ram_ops, s, 2287 "lsi-ram", 0x2000); 2288 memory_region_init_io(&s->io_io, OBJECT(s), &lsi_io_ops, s, 2289 "lsi-io", 256); 2290 2291 address_space_init(&s->pci_io_as, pci_address_space_io(dev), "lsi-pci-io"); 2292 qdev_init_gpio_out(d, &s->ext_irq, 1); 2293 2294 pci_register_bar(dev, 0, PCI_BASE_ADDRESS_SPACE_IO, &s->io_io); 2295 pci_register_bar(dev, 1, PCI_BASE_ADDRESS_SPACE_MEMORY, &s->mmio_io); 2296 pci_register_bar(dev, 2, PCI_BASE_ADDRESS_SPACE_MEMORY, &s->ram_io); 2297 QTAILQ_INIT(&s->queue); 2298 2299 scsi_bus_new(&s->bus, sizeof(s->bus), d, &lsi_scsi_info, NULL); 2300 } 2301 2302 static void lsi_scsi_unrealize(DeviceState *dev, Error **errp) 2303 { 2304 LSIState *s = LSI53C895A(dev); 2305 2306 address_space_destroy(&s->pci_io_as); 2307 } 2308 2309 static void lsi_class_init(ObjectClass *klass, void *data) 2310 { 2311 DeviceClass *dc = DEVICE_CLASS(klass); 2312 PCIDeviceClass *k = PCI_DEVICE_CLASS(klass); 2313 2314 k->realize = lsi_scsi_realize; 2315 k->vendor_id = PCI_VENDOR_ID_LSI_LOGIC; 2316 k->device_id = PCI_DEVICE_ID_LSI_53C895A; 2317 k->class_id = PCI_CLASS_STORAGE_SCSI; 2318 k->subsystem_id = 0x1000; 2319 dc->unrealize = lsi_scsi_unrealize; 2320 dc->reset = lsi_scsi_reset; 2321 dc->vmsd = &vmstate_lsi_scsi; 2322 set_bit(DEVICE_CATEGORY_STORAGE, dc->categories); 2323 } 2324 2325 static const TypeInfo lsi_info = { 2326 .name = TYPE_LSI53C895A, 2327 .parent = TYPE_PCI_DEVICE, 2328 .instance_size = sizeof(LSIState), 2329 .class_init = lsi_class_init, 2330 .interfaces = (InterfaceInfo[]) { 2331 { INTERFACE_CONVENTIONAL_PCI_DEVICE }, 2332 { }, 2333 }, 2334 }; 2335 2336 static void lsi53c810_class_init(ObjectClass *klass, void *data) 2337 { 2338 PCIDeviceClass *k = PCI_DEVICE_CLASS(klass); 2339 2340 k->device_id = PCI_DEVICE_ID_LSI_53C810; 2341 } 2342 2343 static TypeInfo lsi53c810_info = { 2344 .name = TYPE_LSI53C810, 2345 .parent = TYPE_LSI53C895A, 2346 .class_init = lsi53c810_class_init, 2347 }; 2348 2349 static void lsi53c895a_register_types(void) 2350 { 2351 type_register_static(&lsi_info); 2352 type_register_static(&lsi53c810_info); 2353 } 2354 2355 type_init(lsi53c895a_register_types) 2356 2357 void lsi53c8xx_handle_legacy_cmdline(DeviceState *lsi_dev) 2358 { 2359 LSIState *s = LSI53C895A(lsi_dev); 2360 2361 scsi_bus_legacy_handle_cmdline(&s->bus); 2362 } 2363