public inbox for linux-scsi@vger.kernel.org
 help / color / mirror / Atom feed
From: Andi Kleen <andi@firstfloor.org>
To: James.Bottomley@suse.de, nab@linux-iscsi.org, linux-scsi@vger.kernel.org
Subject: Full hostlock pushdown available
Date: Thu, 28 Oct 2010 17:05:09 +0200	[thread overview]
Message-ID: <20101028150508.GA2385@basil.fritz.box> (raw)


Here's the promised attempt to do a full host_lock pushdown. This
was done using coccinelle and some manual adjustments.

This is just a dumb pushdown of host lock and serial number into
the driver, no attempt to remove any locks yet.

Currently lightly tested, but compiles with allmodconfig on 32bit x86.

I made no attempt to automatically add maintainers to Cc.

I'm not posting the patches because they are numerous and boring,
but it's available in git.

This will likely bitrot quickly so if it's decided to do it this
way I would prefer if this was merged quickly.

Issues found:
- I found a clear deadlock in aha1740, not sure if that driver ever
worked since host_lock was introduced. Anyways I attempted to work
around it. But if it's really that unused it may be better to 
simply drop it.
- I'm not sure how to compile cciss_scsi, is it even used?

-Andi

The following changes since commit 39764981e772adc832d8a96e6540be346a830ca2:

  Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6 (2010-10-27 20:54:34 +0200)

are available in the git repository at:

  ssh://master.kernel.org/pub/scm/linux/kernel/git/ak/linux-misc-2.6.git hostlock

Andi Kleen (87):
      SCSI: Remove hostlock for queuecommand
      SCSI: ibmmca: hostlock pushdown
      SCSI: ipr: hostlock pushdown
      SCSI: ultrastor: hostlock pushdown
      SCSI: aha1740: hostlock pushdown
      SCSI: ia64 simscsi: hostlock pushdown
      SCSI: sun3_NCR5380: pushdown of hostlock
      SCSI: staging/hv/storvsc_drv: pushdown of hostlock
      SCSI: s390/zfcp_scsi: hostlock pushdown
      SCSI: libiscsi: hostlock pushdown
      SCSI: libiscsi: remove hostlock drop
      SCSI: NCR5380: hostlock pushdown
      SCSI: libsas: hostlock pushdown
      SCSI: stex: hostlock pushdown
      SCSI: wd33c93: hostlock pushdown
      SCSI: aha152x: hostlock pushdown
      SCSI: microtek: hostlock pushdown
      SCSI: scsiglue: hostlock pushdown
      SCSI: uas: hostlock pushdown
      SCSI: i2o_scsi: hostlock pushdown
      SCSI: mptspi: hostlock pushdown
      SCSI: mptsas: hostlock pushdown
      SCSI: mptfc: hostlock pushdown
      SCSI: sbp2: hostlock pushdown
      SCSI: ib_srp: hostlock pushdown
      SCSI: mesh: hostlock pushdown
      SCSI: fd_mcs: hostlock pushdown
      SCSI: fnic_main: hostlock pushdown
      SCSI: gdth: hostlock pushdown
      SCSI: ppa: hostlock pushdown
      SCSI: qlogicpti: hostlock pushdown
      SCSI: 3w-sas: hostlock pushdown
      SCSI: 3w-9xxx: hostlock pushdown
      SCSI: fcoe: hostlock pushdown
      SCSI: ips: hostlock pushdown
      SCSI: sym_glue: hostlock pushdown
      SCSI: ql4_os: hostlock pushdown
      SCSI: mpt2sas_scsih: hostlock pushdown
      SCSI: fdomain: hostlock pushdown
      SCSI: initio: hostlock pushdown
      SCSI: in2000: hostlock pushdown
      SCSI: nsp32: hostlock pushdown
      SCSI: megaraid_sas: hostlock pushdown
      SCSI: megaraid_mbox: hostlock pushdown
      SCSI: BusLogic: hostlock pushdown
      SCSI: dpt_i2o: hostlock pushdown
      SCSI: 3w-xxxx: hostlock pushdown
      SCSI: atp870u: hostlock pushdown
      SCSI: qlogicfas: hostlock pushdown
      SCSI: qla1280: hostlock pushdown
      SCSI: dc395x: hostlock pushdown
      SCSI: linit: hostlock pushdown
      SCSI: ibmvfc: hostlock pushdown
      SCSI: ibmvscsi: hostlock pushdown
      SCSI: lpfc_scsi: hostlock pushdown
      SCSI: ps3rom: hostlock pushdown
      SCSI: pmcraid: hostlock pushdown
      SCSI: eata: hostlock pushdown
      SCSI: tmscsim: hostlock pushdown
      SCSI: imm: hostlock pushdown
      SCSI: wd7000: hostlock pushdown
      SCSI: sym53c416: hostlock pushdown
      SCSI: aic7xxx_old: hostlock pushdown
      SCSI: megaraid: hostlock pushdown
      SCSI: aha1542: hostlock pushdown
      SCSI: eata_pio: hostlock pushdown
      SCSI: esp_scsi: hostlock pushdown
      SCSI: a100u2w: hostlock pushdown
      SCSI: hpsa: hostlock pushdown
      SCSI: NCR53c406a: hostlock pushdown
      SCSI: mac53c94: hostlock pushdown
      SCSI: vmw_pvscsi: hostlock pushdown
      SCSI: 53c700: hostlock pushdown
      SCSI: u14-34f: hostlock pushdown
      SCSI: ncr53c8xx: hostlock pushdown
      SCSI: advansys: hostlock pushdown
      SCSI: hptiop: hostlock pushdown
      SCSI: arcmsr_hba: hostlock pushdown
      SCSI: aic79xx_osm: hostlock pushdown
      SCSI: aic7xxx_osm: hostlock pushdown
      SCSI: arm: hostlock pushdown
      SCSI: qla_os: hostlock pushdown
      SCSI: nsp_cs: hostlock pushdown
      SCSI: sym53c500_cs: hostlock pushdown
      SCSI: bfad_im: hostlock pushdown
      SCSI: cciss_scsi: hostlock pushdown
      SCSI: aha1740: Avoid instant deadlock

 arch/ia64/hp/sim/simscsi.c            |    7 +++++++
 drivers/block/cciss_scsi.c            |    6 ++++++
 drivers/firewire/sbp2.c               |    5 +++++
 drivers/infiniband/ulp/srp/ib_srp.c   |    6 ++++++
 drivers/message/fusion/mptfc.c        |    6 ++++++
 drivers/message/fusion/mptsas.c       |    8 +++++++-
 drivers/message/fusion/mptspi.c       |    5 +++++
 drivers/message/i2o/i2o_scsi.c        |    5 +++++
 drivers/s390/scsi/zfcp_scsi.c         |    8 ++++++++
 drivers/scsi/3w-9xxx.c                |    4 ++++
 drivers/scsi/3w-sas.c                 |    4 ++++
 drivers/scsi/3w-xxxx.c                |    4 ++++
 drivers/scsi/53c700.c                 |    6 ++++++
 drivers/scsi/BusLogic.c               |    5 +++++
 drivers/scsi/NCR5380.c                |    6 ++++++
 drivers/scsi/NCR53c406a.c             |    4 ++++
 drivers/scsi/a100u2w.c                |    9 ++++++++-
 drivers/scsi/aacraid/linit.c          |   10 ++++++++--
 drivers/scsi/advansys.c               |    4 ++++
 drivers/scsi/aha152x.c                |   10 +++++++++-
 drivers/scsi/aha1542.c                |   12 ++++++++++--
 drivers/scsi/aha1740.c                |   11 +++++++++++
 drivers/scsi/aic7xxx/aic79xx_osm.c    |    4 ++++
 drivers/scsi/aic7xxx/aic7xxx_osm.c    |    4 ++++
 drivers/scsi/aic7xxx_old.c            |    5 +++++
 drivers/scsi/arcmsr/arcmsr_hba.c      |   18 +++++++++++++++---
 drivers/scsi/arm/acornscsi.c          |    6 ++++++
 drivers/scsi/arm/fas216.c             |    8 ++++++++
 drivers/scsi/atp870u.c                |    8 ++++++++
 drivers/scsi/bfa/bfad_im.c            |   11 ++++++++++-
 drivers/scsi/dc395x.c                 |    6 ++++++
 drivers/scsi/dpt_i2o.c                |    9 +++++++++
 drivers/scsi/eata.c                   |    7 +++++++
 drivers/scsi/eata_pio.c               |    5 +++++
 drivers/scsi/esp_scsi.c               |    8 +++++++-
 drivers/scsi/fd_mcs.c                 |    4 ++++
 drivers/scsi/fdomain.c                |    4 ++++
 drivers/scsi/fnic/fnic_scsi.c         |    9 ++++++++-
 drivers/scsi/gdth.c                   |    4 ++++
 drivers/scsi/hpsa.c                   |    7 +++++++
 drivers/scsi/hptiop.c                 |    6 ++++++
 drivers/scsi/ibmmca.c                 |   12 ++++++++++++
 drivers/scsi/ibmvscsi/ibmvfc.c        |   12 ++++++++++--
 drivers/scsi/ibmvscsi/ibmvscsi.c      |    9 ++++++++-
 drivers/scsi/imm.c                    |    4 ++++
 drivers/scsi/in2000.c                 |    4 ++++
 drivers/scsi/initio.c                 |    8 +++++++-
 drivers/scsi/ipr.c                    |   17 ++++++++++++++---
 drivers/scsi/ips.c                    |   18 ++++++++++++++++--
 drivers/scsi/libfc/fc_fcp.c           |    5 +++++
 drivers/scsi/libiscsi.c               |   10 ++++++----
 drivers/scsi/libsas/sas_scsi_host.c   |    7 +++++--
 drivers/scsi/lpfc/lpfc_scsi.c         |    6 ++++++
 drivers/scsi/mac53c94.c               |    4 ++++
 drivers/scsi/megaraid.c               |    4 ++++
 drivers/scsi/megaraid/megaraid_mbox.c |    5 +++++
 drivers/scsi/megaraid/megaraid_sas.c  |   14 ++++++++++++--
 drivers/scsi/mesh.c                   |    4 ++++
 drivers/scsi/mpt2sas/mpt2sas_scsih.c  |   17 +++++++++++++++--
 drivers/scsi/ncr53c8xx.c              |    4 ++++
 drivers/scsi/nsp32.c                  |    8 ++++++++
 drivers/scsi/pcmcia/nsp_cs.c          |    6 ++++++
 drivers/scsi/pcmcia/sym53c500_cs.c    |    4 ++++
 drivers/scsi/pmcraid.c                |   11 ++++++++++-
 drivers/scsi/ppa.c                    |    4 ++++
 drivers/scsi/ps3rom.c                 |    4 ++++
 drivers/scsi/qla1280.c                |    4 ++++
 drivers/scsi/qla2xxx/qla_os.c         |    7 +++++++
 drivers/scsi/qla4xxx/ql4_os.c         |    7 +++++++
 drivers/scsi/qlogicfas408.c           |    4 ++++
 drivers/scsi/qlogicpti.c              |    5 +++++
 drivers/scsi/scsi.c                   |   15 +++------------
 drivers/scsi/stex.c                   |   20 ++++++++++++++++++--
 drivers/scsi/sun3_NCR5380.c           |    8 ++++++++
 drivers/scsi/sym53c416.c              |    4 ++++
 drivers/scsi/sym53c8xx_2/sym_glue.c   |   12 ++++++++++--
 drivers/scsi/tmscsim.c                |    5 +++++
 drivers/scsi/u14-34f.c                |    7 +++++++
 drivers/scsi/ultrastor.c              |    7 +++++++
 drivers/scsi/vmw_pvscsi.c             |    5 +++++
 drivers/scsi/wd33c93.c                |    6 +++++-
 drivers/scsi/wd7000.c                 |    4 ++++
 drivers/staging/hv/storvsc_drv.c      |    8 ++++++++
 drivers/usb/image/microtek.c          |    4 ++++
 drivers/usb/storage/scsiglue.c        |    6 ++++++
 drivers/usb/storage/uas.c             |    9 ++++++++-
 include/scsi/scsi_host.h              |    1 +
 87 files changed, 576 insertions(+), 51 deletions(-)

-- 
ak@linux.intel.com -- Speaking for myself only.

             reply	other threads:[~2010-10-28 15:05 UTC|newest]

Thread overview: 26+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-10-28 15:05 Andi Kleen [this message]
2010-10-28 19:28 ` Full hostlock pushdown available James Bottomley
2010-10-28 19:32   ` Nicholas A. Bellinger
2010-11-01 14:06     ` Andi Kleen
2010-11-01 14:29       ` James Bottomley
2010-10-28 20:10   ` Andi Kleen
2010-10-28 20:22     ` James Bottomley
2010-10-28 21:50       ` Andi Kleen
2010-10-28 22:37         ` Nicholas A. Bellinger
2010-10-31 12:22 ` Boaz Harrosh
2010-10-31 18:48   ` Stefan Richter
2010-11-01  2:34     ` Jeff Garzik
2010-11-01 13:53       ` Andi Kleen
2010-11-01 15:56         ` Jeff Garzik
2010-11-01 17:57           ` Andi Kleen
2010-11-01 18:42             ` Jeff Garzik
2010-11-02 15:05               ` Andi Kleen
2010-11-01 18:59             ` Jeff Garzik
2010-11-01 21:06               ` Nicholas A. Bellinger
2010-11-02  9:21               ` Andi Kleen
2010-11-02 15:59                 ` Jeff Garzik
2010-11-02 17:53                   ` Andi Kleen
2010-11-02 18:13                     ` Jeff Garzik
2010-11-02 18:38                     ` Nicholas A. Bellinger
2010-11-02 18:50                       ` Jeff Garzik
2010-11-01 13:54     ` Andi Kleen

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20101028150508.GA2385@basil.fritz.box \
    --to=andi@firstfloor.org \
    --cc=James.Bottomley@suse.de \
    --cc=linux-scsi@vger.kernel.org \
    --cc=nab@linux-iscsi.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox