lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite for Android: free password hash cracker in your pocket
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <11787925152319-git-send-email-jens.axboe@oracle.com>
Date:	Thu, 10 May 2007 12:21:42 +0200
From:	Jens Axboe <jens.axboe@...cle.com>
To:	linux-kernel@...r.kernel.org
Subject: [PATCH 0/13] Chaining sg lists for bio IO commands v3

Hi,

Third version of the patchset. Changes since v2:

- Get rid of ->next and use the ->page field as a next pointer.
  This saves some space in the scatterlist structure, at the cost
  of one extra sg segment per chained list. Should definitely be
  a space win.

- Cleanup linux/scatterlist.h, most of the stuff is outside
  the ARCH_HAS_SG_CHAIN ifdef now.

- Convert the x86-64 iommu code, enable it on x86-64.

- Convert all (hopefully) SCSI drivers to use the sg helpers so
  chaining can be supported globally. I collated all the SCSI
  driver patches into the 13/13 patch, as not to post a huge
  patch series. I would much appreciate some eye balls on this part,
  catching any dumb mistakes I may have made. The changes are usually
  trivial, but some are not and I do clown around occasionally :-)

Like v2, you still need to enable large commands manually for a
device, ala:

# cd /sys/block/sda/queue
# echo 1024 > max_segments
# cat max_hw_sectors_kb > max_sectors_kb

which would limit you to 1024 segments (effectively 8 scatterlists
chained), and should give you IO's of at least 4mb. You can go larger
than 1024, there's no real limit.

 arch/ia64/hp/sim/simscsi.c            |   23 +-
 arch/x86_64/kernel/pci-calgary.c      |   25 +-
 arch/x86_64/kernel/pci-gart.c         |   44 ++--
 arch/x86_64/kernel/pci-nommu.c        |    5 
 block/ll_rw_blk.c                     |   41 +++-
 crypto/digest.c                       |    2 
 crypto/scatterwalk.c                  |    2 
 crypto/scatterwalk.h                  |    2 
 drivers/ata/libata-core.c             |   30 +--
 drivers/infiniband/ulp/srp/ib_srp.c   |   22 +-
 drivers/scsi/3w-9xxx.c                |    8 
 drivers/scsi/3w-xxxx.c                |    8 
 drivers/scsi/53c700.c                 |   16 -
 drivers/scsi/BusLogic.c               |    7 
 drivers/scsi/NCR53c406a.c             |   18 +-
 drivers/scsi/a100u2w.c                |    9 -
 drivers/scsi/aacraid/aachba.c         |   29 +--
 drivers/scsi/advansys.c               |   21 +-
 drivers/scsi/aha1542.c                |   21 +-
 drivers/scsi/aha1740.c                |    8 
 drivers/scsi/aic7xxx/aic79xx_osm.c    |    3 
 drivers/scsi/aic7xxx/aic7xxx_osm.c    |   12 -
 drivers/scsi/aic94xx/aic94xx_task.c   |    6 
 drivers/scsi/arcmsr/arcmsr_hba.c      |   11 -
 drivers/scsi/dc395x.c                 |    7 
 drivers/scsi/dpt_i2o.c                |   13 -
 drivers/scsi/eata.c                   |    8 
 drivers/scsi/esp_scsi.c               |    5 
 drivers/scsi/gdth.c                   |   45 ++---
 drivers/scsi/hptiop.c                 |    8 
 drivers/scsi/ibmmca.c                 |   11 -
 drivers/scsi/ibmvscsi/ibmvscsi.c      |    4 
 drivers/scsi/ide-scsi.c               |   31 ++-
 drivers/scsi/initio.c                 |   12 -
 drivers/scsi/ipr.c                    |    9 -
 drivers/scsi/ips.c                    |   74 ++++----
 drivers/scsi/iscsi_tcp.c              |   43 ++--
 drivers/scsi/jazz_esp.c               |   27 +--
 drivers/scsi/lpfc/lpfc_scsi.c         |    9 -
 drivers/scsi/mac53c94.c               |    9 -
 drivers/scsi/megaraid.c               |   13 -
 drivers/scsi/megaraid/megaraid_mbox.c |    7 
 drivers/scsi/megaraid/megaraid_sas.c  |   16 -
 drivers/scsi/mesh.c                   |   12 -
 drivers/scsi/ncr53c8xx.c              |    7 
 drivers/scsi/nsp32.c                  |    9 -
 drivers/scsi/pcmcia/sym53c500_cs.c    |   18 +-
 drivers/scsi/qla1280.c                |   66 ++++---
 drivers/scsi/qla2xxx/qla_iocb.c       |    9 -
 drivers/scsi/qla4xxx/ql4_iocb.c       |    8 
 drivers/scsi/qlogicfas408.c           |    9 -
 drivers/scsi/qlogicpti.c              |   15 -
 drivers/scsi/scsi_debug.c             |   14 -
 drivers/scsi/scsi_lib.c               |  230 +++++++++++++++++++-------
 drivers/scsi/scsi_tgt_lib.c           |    4 
 drivers/scsi/sym53c416.c              |    9 -
 drivers/scsi/sym53c8xx_2/sym_glue.c   |    7 
 drivers/scsi/u14-34f.c                |   10 -
 drivers/scsi/ultrastor.c              |   10 -
 drivers/scsi/wd7000.c                 |    7 
 include/asm-i386/dma-mapping.h        |   13 -
 include/asm-i386/scatterlist.h        |    2 
 include/asm-x86_64/dma-mapping.h      |    3 
 include/asm-x86_64/scatterlist.h      |    2 
 include/linux/libata.h                |   16 +
 include/linux/scatterlist.h           |   55 ++++++
 include/scsi/scsi.h                   |    7 
 include/scsi/scsi_cmnd.h              |    3 
 68 files changed, 753 insertions(+), 516 deletions(-)


-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ