LSI53C895A: Handle empty SCRIPTS opcode (Justin Chevrier)

Basically after each DMA transfer the Openserver driver would issue an
empty (0) SCRIPTS opcode. As the opcode is essentially a NOP it has no
second DWORD and therefore the DSP should only be incremented by 4 bytes
instead of the 8 bytes we currently do.

Here's a snippet of the log:

lsi_scsi: Data ready tag=0x100d9 len=16384
...
lsi_scsi: SCRIPTS dsp=068c5e50 opcode 01000400 arg 07a09000
lsi_scsi: DMA addr=0x07a09000 len=1024
lsi_scsi: SCRIPTS dsp=068c5e58 opcode 00000000 arg 01000400
lsi_scsi: Wrong phase got 1 expected 0

Note the 2nd DWORD after the empty opcode; the next opcode in the DMA
transfer sequence. As can be expected the address after that has the next
DMA address to use.

After the attached patch the DMA transfer is able to complete successfully:

lsi_scsi: SCRIPTS dsp=068c5e50 opcode 01000400 arg 07a0d000
lsi_scsi: DMA addr=0x07a0d000 len=1024
lsi_scsi: SCRIPTS dsp=068c5e5c opcode 01000400 arg 07a0d400
lsi_scsi: DMA addr=0x07a0d400 len=1024
...

Tested againsted Openserver 5.0.5 and Debian ARM.

Signed-off-by: Justin Chevrier <address@hidden>
Acked-by: Ryan Harper <ryanh@us.ibm.com>
Signed-off-by: Andrzej Zaborowski <andrew.zaborowski@intel.com>


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@5902 c046a42c-6fe2-441c-8c8c-71466251a162
1 file changed
tree: 30b2100f3a43575d2867b57742cc9804871e8d62
  1. audio/
  2. bsd-user/
  3. darwin-user/
  4. fpu/
  5. gdb-xml/
  6. hw/
  7. keymaps/
  8. linux-user/
  9. pc-bios/
  10. slirp/
  11. target-alpha/
  12. target-arm/
  13. target-cris/
  14. target-i386/
  15. target-m68k/
  16. target-mips/
  17. target-ppc/
  18. target-sh4/
  19. target-sparc/
  20. tcg/
  21. tests/
  22. .gitignore
  23. a.out.h
  24. aes.c
  25. aes.h
  26. aio.c
  27. alpha-dis.c
  28. alpha.ld
  29. arm-dis.c
  30. arm-semi.c
  31. arm.ld
  32. balloon.h
  33. block-bochs.c
  34. block-cloop.c
  35. block-cow.c
  36. block-dmg.c
  37. block-nbd.c
  38. block-parallels.c
  39. block-qcow.c
  40. block-qcow2.c
  41. block-raw-posix.c
  42. block-raw-win32.c
  43. block-vmdk.c
  44. block-vpc.c
  45. block-vvfat.c
  46. block.c
  47. block.h
  48. block_int.h
  49. bswap.h
  50. bt-host.c
  51. bt-vhci.c
  52. buffered_file.c
  53. buffered_file.h
  54. Changelog
  55. check_ops.sh
  56. cocoa.m
  57. configure
  58. console.c
  59. console.h
  60. COPYING
  61. COPYING.LIB
  62. cpu-all.h
  63. cpu-defs.h
  64. cpu-exec.c
  65. cris-dis.c
  66. curses.c
  67. curses_keys.h
  68. cutils.c
  69. d3des.c
  70. d3des.h
  71. def-helper.h
  72. dis-asm.h
  73. disas.c
  74. disas.h
  75. dyngen-exec.h
  76. dyngen.c
  77. elf.h
  78. elf_ops.h
  79. exec-all.h
  80. exec.c
  81. feature_to_c.sh
  82. gdbstub.c
  83. gdbstub.h
  84. gen-icount.h
  85. host-utils.c
  86. host-utils.h
  87. hostregs_helper.h
  88. hpet.h
  89. hppa-dis.c
  90. hppa.ld
  91. i386-dis.c
  92. i386.ld
  93. ia64.ld
  94. keymaps.c
  95. kqemu.c
  96. kqemu.h
  97. kvm-all.c
  98. kvm.h
  99. LICENSE
  100. loader.c
  101. m68k-dis.c
  102. m68k-semi.c
  103. m68k.ld
  104. MAINTAINERS
  105. Makefile
  106. Makefile.target
  107. migration-exec.c
  108. migration-tcp.c
  109. migration.c
  110. migration.h
  111. mips-dis.c
  112. mips.ld
  113. mipsel.ld
  114. monitor.c
  115. nbd.c
  116. nbd.h
  117. net-checksum.c
  118. net.c
  119. net.h
  120. osdep.c
  121. osdep.h
  122. ppc-dis.c
  123. ppc.ld
  124. ppc64.ld
  125. qemu-aio.h
  126. qemu-binfmt-conf.sh
  127. qemu-char.c
  128. qemu-char.h
  129. qemu-common.h
  130. qemu-doc.texi
  131. qemu-img.c
  132. qemu-img.texi
  133. qemu-lock.h
  134. qemu-log.h
  135. qemu-malloc.c
  136. qemu-nbd.c
  137. qemu-nbd.texi
  138. qemu-sockets.c
  139. qemu-tech.texi
  140. qemu-timer.h
  141. qemu-tool.c
  142. qemu_socket.h
  143. readline.c
  144. README
  145. s390-dis.c
  146. s390.ld
  147. savevm.c
  148. sdl.c
  149. sdl_keysym.h
  150. sh4-dis.c
  151. softmmu-semi.h
  152. softmmu_defs.h
  153. softmmu_exec.h
  154. softmmu_header.h
  155. softmmu_template.h
  156. sparc-dis.c
  157. sparc.ld
  158. sparc64.ld
  159. sys-queue.h
  160. sysemu.h
  161. tap-win32.c
  162. texi2pod.pl
  163. thunk.c
  164. thunk.h
  165. TODO
  166. translate-all.c
  167. uboot_image.h
  168. usb-bsd.c
  169. usb-linux.c
  170. usb-stub.c
  171. VERSION
  172. vgafont.h
  173. vl.c
  174. vnc.c
  175. vnc_keysym.h
  176. vnchextile.h
  177. x86_64.ld
  178. x_keymap.c