1. 09 11月, 2005 1 次提交
  2. 07 11月, 2005 1 次提交
  3. 06 11月, 2005 1 次提交
  4. 05 11月, 2005 1 次提交
    • J
      [libata] ATAPI pad allocation fixes/cleanup · 6037d6bb
      Jeff Garzik 提交于
      Use ata_pad_{alloc,free} in two drivers, to factor out common code.
      
      Add ata_pad_{alloc,free} to two other drivers, which needed the padding
      but had not been updated.
      6037d6bb
  5. 31 10月, 2005 2 次提交
    • J
      [libata] locking rewrite (== fix) · 005a5a06
      Jeff Garzik 提交于
      A lot of power packed into a little patch.
      
      This change eliminates the sharing between our controller-wide spinlock
      and the SCSI core's Scsi_Host lock.  As the locking in libata was
      already highly compartmentalized, always referencing our own lock, and
      never scsi_host::host_lock.
      
      As a side effect, this change eliminates a deadlock from calling
      scsi_finish_command() while inside our spinlock.
      005a5a06
    • J
      [libata] ata_tf_to_host cleanups · e5338254
      Jeff Garzik 提交于
      Integrate ata_exec() and ata_tf_to_host() into their only caller,
      ata_bus_edd().
      
      Rename ata_tf_to_host_nolock() to ata_tf_to_host().
      
      This makes locking a bit easier to review, and may help pave the way for
      future changes.
      e5338254
  6. 30 10月, 2005 6 次提交
  7. 27 10月, 2005 1 次提交
  8. 25 10月, 2005 1 次提交
  9. 23 10月, 2005 1 次提交
  10. 22 10月, 2005 2 次提交
  11. 19 10月, 2005 3 次提交
  12. 09 10月, 2005 4 次提交
  13. 06 10月, 2005 2 次提交
  14. 05 10月, 2005 2 次提交
  15. 04 10月, 2005 3 次提交
    • A
      libata: bitmask based pci init functions for one or two ports · 47a86593
      Alan Cox 提交于
      This redoes the n_ports logic I proposed before as a bitmask.
      ata_pci_init_native_mode is now used with a mask allowing for mixed mode
      stuff later on. ata_pci_init_legacy_port is called with port number and
      does one port now not two. Instead it is called twice by the ata init
      logic which cleans both of them up.
      
      There are stil limits in the original code left over
      
      - IRQ/port mapping for legacy mode should be arch specific values
      - You can have one legacy mode IDE adapter per PCI root bridge on some systems
      - Doesn't handle mixed mode devices yet (but is now a lot closer to it)
      47a86593
    • A
      libata: move atapi_send_cdb() and ata_dataout_task() · c71c1857
      Albert Lee 提交于
      to be near ata_pio_*() functions
      c71c1857
    • J
      [libata] improve device scan · 644dd0cc
      Jeff Garzik 提交于
      Replace SCSI's legacy "bang at the door" method of probing with one
      directly controlled by the underlying ATA transport layer.
      
      We now only call scsi_scan_target() for devices we find, rather than
      probing every possible channel/id within a certain range.
      644dd0cc
  16. 30 9月, 2005 4 次提交
  17. 29 9月, 2005 2 次提交
    • A
      [PATCH] libata: interrupt driven pio for LLD · e50362ec
      Albert Lee 提交于
      libata.h:
      libata-core:
        Add ATA_FLAG_PIO_POLLING flag for LLDs that expect interrupt for
      command completion only.
      
      sata_nv.c:
      sata_vsc.c:
        irq handler is wrapper around ata_host_intr(), can handle PIO interrupts.
      
      sata_promise.c:
      sata_sx4.c:
      sata_qstor.c:
      sata_mv.c:
        Private irq handler.
        Polling mode ATA_FLAG_PIO_POLLING used for compatibility.
      Signed-off-by: NAlbert Lee <albertcc@tw.ibm.com>
      Signed-off-by: NJeff Garzik <jgarzik@pobox.com>
      e50362ec
    • A
      [PATCH] libata: interrupt driven pio for libata-core · 312f7da2
      Albert Lee 提交于
      - add PIO_ST_FIRST for the state before sending ATAPI CDB or sending
      "ATA PIO data out" first data block.
      - add ATA_TFLAG_POLLING and ATA_DFLAG_CDB_INTR flags
      - remove the ATA_FLAG_NOINTR flag since the interrupt handler is now
      aware of the states
      - modify ata_pio_sector() and atapi_pio_bytes() to work in the interrupt
      context
      - modify the ata_host_intr() to handle PIO interrupts
      - modify ata_qc_issue_prot() to initialize states
      - atapi_packet_task() changed to handle "ATA PIO data out" first data block
      - support the pre-ATA4 ATAPI device which raise interrupt when ready to
      receive CDB
      Signed-off-by: NAlbert Lee <albertcc@tw.ibm.com>
      Signed-off-by: NJeff Garzik <jgarzik@pobox.com>
      312f7da2
  18. 28 9月, 2005 2 次提交
  19. 16 9月, 2005 1 次提交
    • J
      [libata] fix PIO completion race · 7fb6ec28
      Jeff Garzik 提交于
      Make sure we that completion is the final action we take; prior to this
      change, another CPU may have changed ap->pio_task_state before we tested
      it a final time.
      
      Spotted by, and original patch by Albert Lee @ IBM.
      
      Also includes a minor optimization:  eliminate a ton of unnecessary
      queue_work() calls, simply by jumping to the beginning of the FSM
      function ata_pio_task().
      7fb6ec28