1. 09 1月, 2009 40 次提交
    • H
      [S390] hvc_iucv: Special handling of IUCV HVC devices · 6c089fd3
      Hendrik Brueckner 提交于
      This patch introduces special handling of the IUCV HVC console device.
      
      If the first IUCV HVC terminal is used as (preferred) Linux console, and
      needs some special handling for hangup.
      The hvc_iucv_private structure contains a flag to indicate whether a IUCV
      HVC device is used as a console.
      
      A terminal acting as "console" behaves different if a tty hangup occurs:
      If the iucv communication path is severed, a tty hangup is not
      triggered (because the HVC layer does not notify its back-end in that case).
      Instead, the console session is left unchanged and the IUCV HVC device is
      reset to allow re-connects.
      Note: Any output between the disconnect and a re-connect is discarded.
      Signed-off-by: NHendrik Brueckner <brueckner@linux.vnet.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      6c089fd3
    • H
      [S390] hvc_iucv: Refactor console and device initialization · 68c6b3d2
      Hendrik Brueckner 提交于
      The console_initcall() order might pick up the hvc_iucv device as preferred
      console even if it is not yet initialized.
      Move HVC console instantiation to hvc_iucv_init() and cleanup device driver
      initialization.
      Signed-off-by: NHendrik Brueckner <brueckner@linux.vnet.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      68c6b3d2
    • H
      [S390] hvc_iucv: Update function documentation · 17e19f04
      Hendrik Brueckner 提交于
      Update documentation of functions.
      Signed-off-by: NHendrik Brueckner <brueckner@linux.vnet.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      17e19f04
    • H
      [S390] hvc_iucv: Limit rate of outgoing IUCV messages · c45ce4b5
      Hendrik Brueckner 提交于
      This patch introduces a send buffer to limit outgoing IUCV messages up to
      a maximum of 25 IUCV messages per second.
      
      If no communication path to a IUCV HVC terminal exist, any data written to
      the terminal is discarded.
      Signed-off-by: NHendrik Brueckner <brueckner@linux.vnet.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      c45ce4b5
    • H
      [S390] hvc_iucv: Change IUCV term id and use one device as default · 2dc184c0
      Hendrik Brueckner 提交于
      The patch renames the IUCV application ID from "ihvc" to "lnxhvc".
      The device driver allocates one IUCV terminal device (lnxhvc0) as default.
      Signed-off-by: NHendrik Brueckner <brueckner@linux.vnet.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      2dc184c0
    • H
      [S390] Use unsigned long long for u64 on 64bit. · 33e19115
      Heiko Carstens 提交于
      As requested by Andrew. Same as what sparc did.
      Signed-off-by: NHeiko Carstens <heiko.carstens@de.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      33e19115
    • J
      [S390] qdio: fix broken pointer in case of CONFIG_DEBUG_FS is disabled · 19cdd08b
      Jan Glauber 提交于
      If CONFIG_DEBUG_FS is disabled debugfs_create_file returns -ENODEV instead
      of zero. Since the return value is stored and used at shutdown to remove
      existing entries an OOPS may be triggered.
      
      Add a check of the debugfs_create_file return value and in case of an error
      set the entry to NULL so it will be ignored at shutdown.
      Signed-off-by: NJan Glauber <jang@linux.vnet.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      19cdd08b
    • H
      [S390] vdso: compile fix · 81ffa041
      Heiko Carstens 提交于
      !CONFIG_SMP:
      
      arch/s390/kernel/vdso.c: In function 'vdso_init':
      arch/s390/kernel/vdso.c:325: error: incompatible type for argument 2 of 'vdso_alloc_per_cpu'
      
      Also move the code out of the BUG_ON statement since it won't be
      executed on !CONFIG_BUG. And that would be a bug.
      Signed-off-by: NHeiko Carstens <heiko.carstens@de.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      81ffa041
    • H
      [S390] remove code for oldselect system call · f47d52af
      Heiko Carstens 提交于
      The system call isn't wired up on s390. Just delete the dead code.
      Also we use the common code sys_ptrace system call, so the sys_ptrace
      declaration is pointless is well.
      Signed-off-by: NHeiko Carstens <heiko.carstens@de.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      f47d52af
    • H
      [S390] types: add/fix types.h include in header files · 0680ba01
      Heiko Carstens 提交于
      /include/asm/chpid.h:12: include of <linux/types.h> is preferred over <asm/types.h>
      /include/asm/chsc.h:15: found __[us]{8,16,32,64} type without #include <linux/types.h>
      /include/asm/cmb.h:28: found __[us]{8,16,32,64} type without #include <linux/types.h>
      /include/asm/dasd.h:195: found __[us]{8,16,32,64} type without #include <linux/types.h>
      /include/asm/kvm.h:16: include of <linux/types.h> is preferred over <asm/types.h>
      /include/asm/kvm.h:30: found __[us]{8,16,32,64} type without #include <linux/types.h>
      /include/asm/qeth.h:24: found __[us]{8,16,32,64} type without #include <linux/types.h>
      /include/asm/schid.h:5: found __[us]{8,16,32,64} type without #include <linux/types.h>
      /include/asm/swab.h:12: include of <linux/types.h> is preferred over <asm/types.h>
      /include/asm/swab.h:19: found __[us]{8,16,32,64} type without #include <linux/types.h>
      Signed-off-by: NHeiko Carstens <heiko.carstens@de.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      0680ba01
    • H
      [S390] dasd: add device attribute to disable blocking on lost paths · 13de227b
      Holger Smolinski 提交于
      When the connection between host and storage server is lost, the
      dasd device driver usually blocks all I/O on affected devices and
      waits for them to reappear. In some setups however it would be
      better if the I/O is returned as error so that device can be
      recovered by some other means, eg. in a raid or multipath setup.
      Signed-off-by: NHolger Smolinski <Holger.Smolinski@de.ibm.com>
      Signed-off-by: NStefan Weinhuber <wein@de.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      13de227b
    • S
      [S390] dasd: send change uevents for dasd block devices · 1301809b
      Stefan Weinhuber 提交于
      When a DASD device enters or leaves the 'online' state we need to
      trigger change events for the respective disk and partitions.
      These extra events are needed because when disk and partitions are
      first added, udev rules that try to read disk labels or other data
      may fail as the disk may not yet be ready.
      Signed-off-by: NStefan Weinhuber <wein@de.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      1301809b
    • K
      [S390] tape block: fix dependencies · d41bf2f6
      Kamalesh Babulal 提交于
        CC      drivers/s390/char/tape_block.o
      In file included from drivers/s390/char/tape_block.c:24:
      drivers/s390/char/tape.h:159: warning: 'struct request' declared inside
      parameter list
      
      Adding the dependency of CONFIG_BLOCK to CONFIG_S390_TAPE_BLOCK.
      Signed-off-by: NKamalesh Babulal <kamalesh@linux.vnet.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      d41bf2f6
    • M
      [S390] asm-s390/posix_types.h: drop __USE_ALL usage · dbb397d8
      Mike Frysinger 提交于
      Bring s390 in line with all the other ports.  Not sure how s390 missed
      this change as all the other arches were being updated ...
      
      CC: Heiko Carstens <heiko.carstens@de.ibm.com>
      CC: linux390@de.ibm.com
      CC: linux-s390@vger.kernel.org
      Signed-off-by: NMike Frysinger <vapier@gentoo.org>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      dbb397d8
    • H
      [S390] gettimeofday.S: removed duplicated #includes · 2020238b
      Huang Weiyi 提交于
      Removed duplicated #include's in arch/s390/kernel/vdso32/gettimeofday.S
      Signed-off-by: NHuang Weiyi <weiyi.huang@gmail.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      2020238b
    • H
      [S390] ptrace: no extern declarations for userspace · 16de0582
      Heiko Carstens 提交于
      /include/asm/ptrace.h:275: extern's make no sense in userspace
      /include/asm/ptrace.h:279: extern's make no sense in userspace
      /include/asm/ptrace.h:280: extern's make no sense in userspace
      Signed-off-by: NHeiko Carstens <heiko.carstens@de.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      16de0582
    • L
      Merge branch 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tytso/ext4 · 2150edc6
      Linus Torvalds 提交于
      * 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tytso/ext4: (57 commits)
        jbd2: Fix oops in jbd2_journal_init_inode() on corrupted fs
        ext4: Remove "extents" mount option
        block: Add Kconfig help which notes that ext4 needs CONFIG_LBD
        ext4: Make printk's consistently prefixed with "EXT4-fs: "
        ext4: Add sanity checks for the superblock before mounting the filesystem
        ext4: Add mount option to set kjournald's I/O priority
        jbd2: Submit writes to the journal using WRITE_SYNC
        jbd2: Add pid and journal device name to the "kjournald2 starting" message
        ext4: Add markers for better debuggability
        ext4: Remove code to create the journal inode
        ext4: provide function to release metadata pages under memory pressure
        ext3: provide function to release metadata pages under memory pressure
        add releasepage hooks to block devices which can be used by file systems
        ext4: Fix s_dirty_blocks_counter if block allocation failed with nodelalloc
        ext4: Init the complete page while building buddy cache
        ext4: Don't allow new groups to be added during block allocation
        ext4: mark the blocks/inode bitmap beyond end of group as used
        ext4: Use new buffer_head flag to check uninit group bitmaps initialization
        ext4: Fix the race between read_inode_bitmap() and ext4_new_inode()
        ext4: code cleanup
        ...
      2150edc6
    • L
      Merge git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-misc-2.6 · cd764695
      Linus Torvalds 提交于
      * git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-misc-2.6: (45 commits)
        [SCSI] qla2xxx: Update version number to 8.03.00-k1.
        [SCSI] qla2xxx: Add ISP81XX support.
        [SCSI] qla2xxx: Use proper request/response queues with MQ instantiations.
        [SCSI] qla2xxx: Correct MQ-chain information retrieval during a firmware dump.
        [SCSI] qla2xxx: Collapse EFT/FCE copy procedures during a firmware dump.
        [SCSI] qla2xxx: Don't pollute kernel logs with ZIO/RIO status messages.
        [SCSI] qla2xxx: Don't fallback to interrupt-polling during re-initialization with MSI-X enabled.
        [SCSI] qla2xxx: Remove support for reading/writing HW-event-log.
        [SCSI] cxgb3i: add missing include
        [SCSI] scsi_lib: fix DID_RESET status problems
        [SCSI] fc transport: restore missing dev_loss_tmo callback to LLDD
        [SCSI] aha152x_cs: Fix regression that keeps driver from using shared interrupts
        [SCSI] sd: Correctly handle 6-byte commands with DIX
        [SCSI] sd: DIF: Fix tagging on platforms with signed char
        [SCSI] sd: DIF: Show app tag on error
        [SCSI] Fix error handling for DIF/DIX
        [SCSI] scsi_lib: don't decrement busy counters when inserting commands
        [SCSI] libsas: fix test for negative unsigned and typos
        [SCSI] a2091, gvp11: kill warn_unused_result warnings
        [SCSI] fusion: Move a dereference below a NULL test
        ...
      
      Fixed up trivial conflict due to moving the async part of sd_probe
      around in the async probes vs using dev_set_name() in naming.
      cd764695
    • L
      Merge branch 'bkl-removal' of git://git.lwn.net/linux-2.6 · 97d61b8e
      Linus Torvalds 提交于
      * 'bkl-removal' of git://git.lwn.net/linux-2.6:
        RTC: Remove the BKL.
      97d61b8e
    • L
      Merge branch 'docs-next' of git://git.lwn.net/linux-2.6 · 1df2d017
      Linus Torvalds 提交于
      * 'docs-next' of git://git.lwn.net/linux-2.6:
        Fix a typo in the development process document.
        Document handling of bad memory
        Document RCU and unloadable modules
      1df2d017
    • D
      RTC: Remove the BKL. · 048cd588
      David John 提交于
      Remove calls to the BKL since concurrent access is protected
      by the spin lock rtc_lock.
      Signed-off-by: NDavid John <davidjon@xenontk.org>
      Cc: Ingo Molnar <mingo@elte.hu>
      Signed-off-by: NJonathan Corbet <corbet@lwn.net>
      048cd588
    • J
    • L
      Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/lrg/voltage-2.6 · 022992ee
      Linus Torvalds 提交于
      * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/lrg/voltage-2.6:
        regulator: fix kernel-doc warnings
        regulator: catch some registration errors
        regulator: Add basic DocBook manual
        regulator: Fix some kerneldoc rendering issues
        regulator: Add missing kerneldoc
        regulator: Clean up kerneldoc warnings
        regulator: Remove extraneous kerneldoc annotations
        regulator: init/link earlier
        regulator: move set_machine_constraints after regulator device initialization
        regulator: da903x: make da903x_is_enabled return 0 or 1
        regulator: da903x: add '\n' to error messages
        regulator: sysfs attribute reduction (v2)
        regulator: code shrink (v2)
        regulator: improved mode error checks
        regulator: enable/disable refcounting
        regulator: struct device - replace bus_id with dev_name(), dev_set_name()
      022992ee
    • L
      Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6 · 5fbbf5f6
      Linus Torvalds 提交于
      * git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6: (84 commits)
        wimax: fix kernel-doc for debufs_dentry member of struct wimax_dev
        net: convert pegasus driver to net_device_ops
        bnx2x: Prevent eeprom set when driver is down
        net: switch kaweth driver to netdevops
        pcnet32: round off carrier watch timer
        i2400m/usb: wrap USB power saving in #ifdef CONFIG_PM
        wimax: testing for rfkill support should also test for CONFIG_RFKILL_MODULE
        wimax: fix kconfig interactions with rfkill and input layers
        wimax: fix '#ifndef CONFIG_BUG' layout to avoid warning
        r6040: bump release number to 0.20
        r6040: warn about MAC address being unset
        r6040: check PHY status when bringing interface up
        r6040: make printks consistent with DRV_NAME
        gianfar: Fixup use of BUS_ID_SIZE
        mlx4_en: Returning real Max in get_ringparam
        mlx4_en: Consider inline packets on completion
        netdev: bfin_mac: enable bfin_mac net dev driver for BF51x
        qeth: convert to net_device_ops
        vlan: add neigh_setup
        dm9601: warn on invalid mac address
        ...
      5fbbf5f6
    • L
      Merge master.kernel.org:/home/rmk/linux-2.6-arm · ce279e6e
      Linus Torvalds 提交于
      * master.kernel.org:/home/rmk/linux-2.6-arm: (23 commits)
        [ARM] fix pxa930_trkball build errors
        [ARM] fix netx
        [ARM] fix pnx4008
        [ARM] fix pxa
        [ARM] remove missed CLPS7500 defconfig
        [ARM] clps711x: fix warning in edb7211-mm.c
        [ARM] clps711x: fix warning in fortunet
        [ARM] fix AT91, davinci, h720x, ks8695, msm, mx2, mx3, netx, omap1, omap2, pxa, s3c
        [ARM] Fix realview build
        [ARM] 5357/1: Kirkwood: add missing ge01 tclk initialization
        [ARM] 5358/1: AT2440EVB: Use new include path of mci.h
        [ARM] 5361/1: mv78xx0: fix compilation error
        [ARM] 5360/1: Orion: fix compilation error
        [ARM] 5359/1: Kirkwood: fix compilation error
        [ARM] S3C64XX: Fix EINT group macro definition
        [ARM] Ensure CONFIG_SERIAL_SAMSUNG_UARTS is always set.
        [ARM] S3C24XX: Add gpio_to_irq implementation
        [ARM] S3C24XX: Add gpio_to_irq() facility
        [ARM] footbridge: dc21285.c warning fixes
        [ARM] footbridge: add isa_init_irq() to common header
        ...
      ce279e6e
    • L
      Merge branch 'for-linus' of git://neil.brown.name/md · 894bcdfb
      Linus Torvalds 提交于
      * 'for-linus' of git://neil.brown.name/md:
        md: don't retry recovery of raid1 that fails due to error on source drive.
        md: Allow md devices to be created by name.
        md: make devices disappear when they are no longer needed.
        md: centralise all freeing of an 'mddev' in 'md_free'
        md: move allocation of ->queue from mddev_find to md_probe
        md: need another print_sb for mdp_superblock_1
        md: use list_for_each_entry macro directly
        md: raid0: make hash_spacing and preshift sector-based.
        md: raid0: Represent the size of strip zones in sectors.
        md: raid0 create_strip_zones(): Add KERN_INFO/KERN_ERR to printk's.
        md: raid0 create_strip_zones(): Make two local variables sector-based.
        md: raid0: Represent zone->zone_offset in sectors.
        md: raid0: Represent device offset in sectors.
        md: raid0_make_request(): Replace local variable block by sector.
        md: raid0_make_request(): Remove local variable chunk_size.
        md: raid0_make_request(): Replace chunksize_bits by chunksect_bits.
        md: use sysfs_notify_dirent to notify changes to md/sync_action.
        md: fix bitmap-on-external-file bug.
      894bcdfb
    • R
      Merge branch 'devel' · 97b5fe8e
      Russell King 提交于
      97b5fe8e
    • L
      Merge branch 'upstream-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jgarzik/libata-dev · a419df8a
      Linus Torvalds 提交于
      * 'upstream-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jgarzik/libata-dev:
        libata: clean up the SFF code for coding style
        libata: Add 32bit PIO support
        [libata] ahci: Withdraw IGN_SERR_INTERNAL for SB800 SATA
        pata_hpt366: reimplement mode programming
        [libata] pata_hpt3x3: correct _freeze() function declaration
        libata: Add special ata_pio_need_iordy() handling for Compact Flash.
        pata_platform: __pata_platform_remove() shouldn't be in discard section
        sata_sil24: remove unused sil24_port_multiplier
        [libata] ahci: Add SATA GEN3 related messages
        ata_piix: save, use saved and restore IOCFG
        pata_ali: Fix and workaround for FIFO DMA bug
        pata_ali: force initialise a few bits
        pata_hpt3x3: Workarounds for chipset
      a419df8a
    • R
    • A
      libata: clean up the SFF code for coding style · 0fe40ff8
      Alan Cox 提交于
      Signed-off-by: NAlan Cox <alan@redhat.com>
      Signed-off-by: NJeff Garzik <jgarzik@redhat.com>
      0fe40ff8
    • A
      libata: Add 32bit PIO support · 871af121
      Alan Cox 提交于
      This matters for some controllers and in one or two cases almost doubles
      PIO performance. Add a bmdma32 operations set we can inherit and activate
      it for some controllers
      Signed-off-by: NAlan Cox <alan@redhat.com>
      Signed-off-by: NJeff Garzik <jgarzik@redhat.com>
      871af121
    • S
      [libata] ahci: Withdraw IGN_SERR_INTERNAL for SB800 SATA · e427fe04
      Shane Huang 提交于
      There is an issue in ATI SB600/SB700 SATA that PxSERR.E should not be
      set on some conditions, which will lead to many SATA ODD error messages.
      commit 55a61604 is the workaround.
      Since SB800 fixed this HW issue, IGN_SERR_INTERNAL should be withdrawn
      for SB800.
      Signed-off-by: NShane Huang <shane.huang@amd.com>
      Signed-off-by: NJeff Garzik <jgarzik@redhat.com>
      e427fe04
    • N
      md: don't retry recovery of raid1 that fails due to error on source drive. · 4044ba58
      NeilBrown 提交于
      If a raid1 has only one working drive and it has a sector which
      gives an error on read, then an attempt to recover onto a spare will
      fail, but as the single remaining drive is not removed from the
      array, the recovery will be immediately re-attempted, resulting
      in an infinite recovery loop.
      
      So detect this situation and don't retry recovery once an error
      on the lone remaining drive is detected.
      
      Allow recovery to be retried once every time a spare is added
      in case the problem wasn't actually a media error.
      Signed-off-by: NNeilBrown <neilb@suse.de>
      4044ba58
    • N
      md: Allow md devices to be created by name. · efeb53c0
      NeilBrown 提交于
      Using sequential numbers to identify md devices is somewhat artificial.
      Using names can be a lot more user-friendly.
      
      Also, creating md devices by opening the device special file is a bit
      awkward.
      
      So this patch provides a new option for creating and naming devices.
      
      Writing a name such as "md_home" to
          /sys/modules/md_mod/parameters/new_array
      will cause an array with that name to be created.  It will appear in
      /sys/block/ /proc/partitions and /proc/mdstat as 'md_home'.
      It will have an arbitrary minor number allocated.
      
      md devices that a created by an open are destroyed on the last
      close when the device is inactive.
      For named md devices, they will not be destroyed until the array
      is explicitly stopped, either with the STOP_ARRAY ioctl or by
      writing 'clear' to /sys/block/md_XXXX/md/array_state.
      
      The name of the array must start 'md_' to avoid conflict with
      other devices.
      Signed-off-by: NNeilBrown <neilb@suse.de>
      efeb53c0
    • N
      md: make devices disappear when they are no longer needed. · d3374825
      NeilBrown 提交于
      Currently md devices, once created, never disappear until the module
      is unloaded.  This is essentially because the gendisk holds a
      reference to the mddev, and the mddev holds a reference to the
      gendisk, this a circular reference.
      
      If we drop the reference from mddev to gendisk, then we need to ensure
      that the mddev is destroyed when the gendisk is destroyed.  However it
      is not possible to hook into the gendisk destruction process to enable
      this.
      
      So we drop the reference from the gendisk to the mddev and destroy the
      gendisk when the mddev gets destroyed.  However this has a
      complication.
      Between the call
         __blkdev_get->get_gendisk->kobj_lookup->md_probe
      and the call
         __blkdev_get->md_open
      
      there is no obvious way to hold a reference on the mddev any more, so
      unless something is done, it will disappear and gendisk will be
      destroyed prematurely.
      
      Also, once we decide to destroy the mddev, there will be an unlockable
      moment before the gendisk is unlinked (blk_unregister_region) during
      which a new reference to the gendisk can be created.  We need to
      ensure that this reference can not be used.  i.e. the ->open must
      fail.
      
      So:
       1/  in md_probe we set a flag in the mddev (hold_active) which
           indicates that the array should be treated as active, even
           though there are no references, and no appearance of activity.
           This is cleared by md_release when the device is closed if it
           is no longer needed.
           This ensures that the gendisk will survive between md_probe and
           md_open.
      
       2/  In md_open we check if the mddev we expect to open matches
           the gendisk that we did open.
           If there is a mismatch we return -ERESTARTSYS and modify
           __blkdev_get to retry from the top in that case.
           In the -ERESTARTSYS sys case we make sure to wait until
           the old gendisk (that we succeeded in opening) is really gone so
           we loop at most once.
      
      Some udev configurations will always open an md device when it first
      appears.   If we allow an md device that was just created by an open
      to disappear on an immediate close, then this can race with such udev
      configurations and result in an infinite loop the device being opened
      and closed, then re-open due to the 'ADD' even from the first open,
      and then close and so on.
      So we make sure an md device, once created by an open, remains active
      at least until some md 'ioctl' has been made on it.  This means that
      all normal usage of md devices will allow them to disappear promptly
      when not needed, but the worst that an incorrect usage will do it
      cause an inactive md device to be left in existence (it can easily be
      removed).
      
      As an array can be stopped by writing to a sysfs attribute
        echo clear > /sys/block/mdXXX/md/array_state
      we need to use scheduled work for deleting the gendisk and other
      kobjects.  This allows us to wait for any pending gendisk deletion to
      complete by simply calling flush_scheduled_work().
      Signed-off-by: NNeilBrown <neilb@suse.de>
      d3374825
    • N
      md: centralise all freeing of an 'mddev' in 'md_free' · a21d1504
      NeilBrown 提交于
      md_free is the .release handler for the md kobj_type.
      So it makes sense to release all the objects referenced by
      the mddev in there, rather than just prior to calling kobject_put
      for what we think is the last time.
      Signed-off-by: NNeilBrown <neilb@suse.de>
      a21d1504
    • N
      md: move allocation of ->queue from mddev_find to md_probe · 8b765398
      NeilBrown 提交于
      It is more balanced to just do simple initialisation in mddev_find,
      which allocates and links a new md device, and leave all the
      more sophisticated allocation to md_probe (which calls mddev_find).
      md_probe already allocated the gendisk.  It should allocate the
      queue too.
      Signed-off-by: NNeilBrown <neilb@suse.de>
      8b765398
    • C
      md: need another print_sb for mdp_superblock_1 · cd2ac932
      Cheng Renquan 提交于
      md_print_devices is called in two code path: MD_BUG(...), and md_ioctl
      with PRINT_RAID_DEBUG.  it will dump out all in use md devices
      information;
      
      However, it wrongly processed two types of superblock in one:
      
      The header file <linux/raid/md_p.h> has defined two types of superblock,
      struct mdp_superblock_s (typedefed with mdp_super_t) according to md with
      metadata 0.90, and struct mdp_superblock_1 according to md with metadata
      1.0 and later,
      
      These two types of superblock are very different,
      
      The md_print_devices code processed them both in mdp_super_t, that would
      lead to wrong informaton dump like:
      
      	[ 6742.345877]
      	[ 6742.345887] md:	**********************************
      	[ 6742.345890] md:	* <COMPLETE RAID STATE PRINTOUT> *
      	[ 6742.345892] md:	**********************************
      	[ 6742.345896] md1: <ram7><ram6><ram5><ram4>
      	[ 6742.345907] md: rdev ram7, SZ:00065472 F:0 S:1 DN:3
      	[ 6742.345909] md: rdev superblock:
      	[ 6742.345914] md:  SB: (V:0.90.0) ID:<42ef13c7.598c059a.5f9f1645.801e9ee6> CT:4919856d
      	[ 6742.345918] md:     L5 S00065472 ND:4 RD:4 md1 LO:2 CS:65536
      	[ 6742.345922] md:     UT:4919856d ST:1 AD:4 WD:4 FD:0 SD:0 CSUM:b7992907 E:00000001
      	[ 6742.345924]      D  0:  DISK<N:0,(1,8),R:0,S:6>
      	[ 6742.345930]      D  1:  DISK<N:1,(1,10),R:1,S:6>
      	[ 6742.345933]      D  2:  DISK<N:2,(1,12),R:2,S:6>
      	[ 6742.345937]      D  3:  DISK<N:3,(1,14),R:3,S:6>
      	[ 6742.345942] md:     THIS:  DISK<N:3,(1,14),R:3,S:6>
      	...
      	[ 6742.346058] md0: <ram3><ram2><ram1><ram0>
      	[ 6742.346067] md: rdev ram3, SZ:00065472 F:0 S:1 DN:3
      	[ 6742.346070] md: rdev superblock:
      	[ 6742.346073] md:  SB: (V:1.0.0) ID:<369aad81.00000000.00000000.00000000> CT:9a322a9c
      	[ 6742.346077] md:     L-1507699579 S976570180 ND:48 RD:0 md0 LO:65536 CS:196610
      	[ 6742.346081] md:     UT:00000018 ST:0 AD:131048 WD:0 FD:8 SD:0 CSUM:00000000 E:00000000
      	[ 6742.346084]      D  0:  DISK<N:-1,(-1,-1),R:-1,S:-1>
      	[ 6742.346089]      D  1:  DISK<N:-1,(-1,-1),R:-1,S:-1>
      	[ 6742.346092]      D  2:  DISK<N:-1,(-1,-1),R:-1,S:-1>
      	[ 6742.346096]      D  3:  DISK<N:-1,(-1,-1),R:-1,S:-1>
      	[ 6742.346102] md:     THIS:  DISK<N:0,(0,0),R:0,S:0>
      	...
      	[ 6742.346219] md:	**********************************
      	[ 6742.346221]
      
      Here md1 is metadata 0.90.0, and md0 is metadata 1.2
      
      After some more code to distinguish these two types of superblock, in this patch,
      
      it will generate dump information like:
      
      	[ 7906.755790]
      	[ 7906.755799] md:	**********************************
      	[ 7906.755802] md:	* <COMPLETE RAID STATE PRINTOUT> *
      	[ 7906.755804] md:	**********************************
      	[ 7906.755808] md1: <ram7><ram6><ram5><ram4>
      	[ 7906.755819] md: rdev ram7, SZ:00065472 F:0 S:1 DN:3
      	[ 7906.755821] md: rdev superblock (MJ:0):
      	[ 7906.755826] md:  SB: (V:0.90.0) ID:<3fca7a0d.a612bfed.5f9f1645.801e9ee6> CT:491989f3
      	[ 7906.755830] md:     L5 S00065472 ND:4 RD:4 md1 LO:2 CS:65536
      	[ 7906.755834] md:     UT:491989f3 ST:1 AD:4 WD:4 FD:0 SD:0 CSUM:00fb52ad E:00000001
      	[ 7906.755836]      D  0:  DISK<N:0,(1,8),R:0,S:6>
      	[ 7906.755842]      D  1:  DISK<N:1,(1,10),R:1,S:6>
      	[ 7906.755845]      D  2:  DISK<N:2,(1,12),R:2,S:6>
      	[ 7906.755849]      D  3:  DISK<N:3,(1,14),R:3,S:6>
      	[ 7906.755855] md:     THIS:  DISK<N:3,(1,14),R:3,S:6>
      	...
      	[ 7906.755972] md0: <ram3><ram2><ram1><ram0>
      	[ 7906.755981] md: rdev ram3, SZ:00065472 F:0 S:1 DN:3
      	[ 7906.755984] md: rdev superblock (MJ:1):
      	[ 7906.755989] md:  SB: (V:1) (F:0) Array-ID:<5fbcf158:55aa:5fbe:9a79:1e939880dcbd>
      	[ 7906.755990] md:    Name: "DG5:0" CT:1226410480
      	[ 7906.755998] md:       L5 SZ130944 RD:4 LO:2 CS:128 DO:24 DS:131048 SO:8 RO:0
      	[ 7906.755999] md:     Dev:00000003 UUID: 9194d744:87f7:a448:85f2:7497b84ce30a
      	[ 7906.756001] md:       (F:0) UT:1226410480 Events:0 ResyncOffset:-1 CSUM:0dbcd829
      	[ 7906.756003] md:         (MaxDev:384)
      	...
      	[ 7906.756113] md:	**********************************
      	[ 7906.756116]
      
      this md0 (metadata 1.2) information dumping is exactly according to struct
      mdp_superblock_1.
      Signed-off-by: NCheng Renquan <crquan@gmail.com>
      Cc: Neil Brown <neilb@suse.de>
      Cc: Dan Williams <dan.j.williams@gmail.com>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NNeilBrown <neilb@suse.de>
      cd2ac932
    • C
      md: use list_for_each_entry macro directly · 159ec1fc
      Cheng Renquan 提交于
      The rdev_for_each macro defined in <linux/raid/md_k.h> is identical to
      list_for_each_entry_safe, from <linux/list.h>, it should be defined to
      use list_for_each_entry_safe, instead of reinventing the wheel.
      
      But some calls to each_entry_safe don't really need a safe version,
      just a direct list_for_each_entry is enough, this could save a temp
      variable (tmp) in every function that used rdev_for_each.
      
      In this patch, most rdev_for_each loops are replaced by list_for_each_entry,
      totally save many tmp vars; and only in the other situations that will call
      list_del to delete an entry, the safe version is used.
      Signed-off-by: NCheng Renquan <crquan@gmail.com>
      Signed-off-by: NNeilBrown <neilb@suse.de>
      159ec1fc
    • A
      md: raid0: make hash_spacing and preshift sector-based. · ccacc7d2
      Andre Noll 提交于
      This patch renames the hash_spacing and preshift members of struct
      raid0_private_data to spacing and sector_shift respectively and
      changes the semantics as follows:
      
      We always have spacing = 2 * hash_spacing. In case
      sizeof(sector_t) > sizeof(u32) we also have sector_shift = preshift + 1
      while sector_shift = preshift = 0 otherwise.
      
      Note that the values of nb_zone and zone are unaffected by these changes
      because in the sector_div() preceeding the assignement of these two
      variables both arguments double.
      Signed-off-by: NAndre Noll <maan@systemlinux.org>
      Signed-off-by: NNeilBrown <neilb@suse.de>
      ccacc7d2