1. 23 Mar, 2012 39 commits
    • Jeff Layton's avatar
    • Jeff Layton's avatar
      cifs: call cifs_update_eof with i_lock held · 597b027f
      Jeff Layton authored
      cifs_update_eof has the potential to be racy if multiple threads are
      trying to modify it at the same time. Protect modifications of the
      server_eof value with the inode->i_lock.
      Signed-off-by: default avatarJeff Layton <jlayton@redhat.com>
      597b027f
    • Jeff Layton's avatar
      cifs: abstract out function to marshal up the iovec array for async writes · e9492871
      Jeff Layton authored
      We'll need to do something a bit different depending on the caller.
      Abstract the code that marshals the page array into an iovec.
      Signed-off-by: default avatarJeff Layton <jlayton@redhat.com>
      Reviewed-by: default avatarPavel Shilovsky <piastry@etersoft.ru>
      e9492871
    • Jeff Layton's avatar
      cifs: fix up get_numpages · a7103b99
      Jeff Layton authored
      Use DIV_ROUND_UP. Also, PAGE_SIZE is more appropriate here since these
      aren't pagecache pages.
      Signed-off-by: default avatarJeff Layton <jlayton@redhat.com>
      Reviewed-by: default avatarPavel Shilovsky <piastry@etersoft.ru>
      a7103b99
    • Jeff Layton's avatar
    • Jeff Layton's avatar
      cifs: fix allocation in cifs_write_allocate_pages · e94f7ba1
      Jeff Layton authored
      The gfp flags are currently set to __GPF_HIGHMEM, which doesn't allow
      for any reclaim. Make this more resilient by or'ing that with
      GFP_KERNEL. Also, get rid of the goto and unify the exit codepath.
      Signed-off-by: default avatarJeff Layton <jlayton@redhat.com>
      Acked-by: default avatarPavel Shilovsky <piastry@etersoft.ru>
      e94f7ba1
    • Jeff Layton's avatar
      cifs: allow caller to specify completion op when allocating writedata · c2e87640
      Jeff Layton authored
      We'll need a different set of write completion ops when not writing out
      of the pagecache.
      Signed-off-by: default avatarJeff Layton <jlayton@redhat.com>
      Reviewed-by: default avatarPavel Shilovsky <piastry@etersoft.ru>
      c2e87640
    • Jeff Layton's avatar
      cifs: add pid field to cifs_writedata · fe5f5d2e
      Jeff Layton authored
      We'll need this to handle rwpidforward option correctly when we use
      async writes in the aio_write op.
      Signed-off-by: default avatarJeff Layton <jlayton@redhat.com>
      Reviewed-by: default avatarPavel Shilovsky <piastry@etersoft.ru>
      fe5f5d2e
    • Jeff Layton's avatar
      cifs: add new cifsiod_wq workqueue · da472fc8
      Jeff Layton authored
      ...and convert existing cifs users of system_nrt_wq to use that instead.
      
      Also, make it freezable, and set WQ_MEM_RECLAIM since we use it to
      deal with write reply handling.
      Signed-off-by: default avatarJeff Layton <jlayton@redhat.com>
      Acked-by: default avatarShirish Pargaonkar <shirishpargaonkar@gmail.com>
      da472fc8
    • Pavel Shilovsky's avatar
      CIFS: Change mid_q_entry structure fields · 7c9421e1
      Pavel Shilovsky authored
      to be protocol-unspecific and big enough to keep both CIFS
      and SMB2 values.
      Signed-off-by: default avatarPavel Shilovsky <piastry@etersoft.ru>
      7c9421e1
    • Pavel Shilovsky's avatar
      CIFS: Expand CurrentMid field · 243d04b6
      Pavel Shilovsky authored
      While in CIFS/SMB we have 16 bit mid, in SMB2 it is 64 bit.
      Convert the existing field to 64 bit and mask off higher bits
      for CIFS/SMB.
      Signed-off-by: default avatarPavel Shilovsky <piastry@etersoft.ru>
      243d04b6
    • Pavel Shilovsky's avatar
    • Pavel Shilovsky's avatar
    • Pavel Shilovsky's avatar
      CIFS: Separate protocol-specific code from transport routines · 792af7b0
      Pavel Shilovsky authored
      that lets us use this functions for SMB2.
      Signed-off-by: default avatarPavel Shilovsky <piastry@etersoft.ru>
      792af7b0
    • Linus Torvalds's avatar
      Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net · 934e18b5
      Linus Torvalds authored
      Pull networking fixes from David Miller:
      
       1) L2TP doesn't get autoloaded when you try to open an L2TP socket due
          to a missing module alias, fix from Benjamin LaHaise.
      
       2) Netlabel and RDS should propagate gfp flags given to them by
          callers, fixes from Dan Carpeneter.
      
       3) Recursive locking fix in usbnet wasn't bulletproof and can result in
          objects going away mid-flight due to races, fix from Ming Lei.
      
       4) Fix up some confusion about a bool module parameter in netfilter's
          iptable_filter and ip6table_filter, from Rusty Russell.
      
       5) If SKB recycling is used via napi_reuse_skb() we end up with
          different amounts of headroom reserved than we had at the original
          SKB allocation.  Fix from Eric Dumazet.
      
       6) Fix races in TG3 driver ring refilling, from Michael Chan.
      
       7) We have callbacks for IPSEC replay notifiers, but some call sites
          were not using the ops method and instead were calling one of the
          implementations directly.  Oops.  Fix from Steffen Klassert.
      
       8) Fix IP address validation properly in the bonding driver, the
          previous fix only works with netlink where the subnet mask and IP
          address are changed in one atomic operation.  When 'ifconfig' ioctls
          are used the IP address and the subnet mask are changed in two
          distinct operations.  Fix from Andy Gospodarek.
      
       9) Provide a sky2 module operation to work around power management
          issues with some BIOSes.  From Stephen Hemminger.
      
      * git://git.kernel.org/pub/scm/linux/kernel/git/davem/net:
        usbnet: consider device busy at each recieved packet
        bonding: remove entries for master_ip and vlan_ip and query devices instead
        netfilter: remove forward module param confusion.
        usbnet: don't clear urb->dev in tx_complete
        usbnet: increase URB reference count before usb_unlink_urb
        xfrm: Access the replay notify functions via the registered callbacks
        xfrm: Remove unused xfrm_state from xfrm_state_check_space
        RDS: use gfp flags from caller in conn_alloc()
        netlabel: use GFP flags from caller instead of GFP_ATOMIC
        l2tp: enable automatic module loading for l2tp_ppp
        cnic: Fix parity error code conflict
        tg3: Fix RSS ring refill race condition
        sky2: override for PCI legacy power management
        net: fix napi_reuse_skb() skb reserve
      934e18b5
    • Linus Torvalds's avatar
      Merge tag 'for_linus-3.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/jwessel/kgdb · a20ae85a
      Linus Torvalds authored
      Pull KGDB/KDB updates from Jason Wessel:
       "Fixes:
         - Fix KDB keyboard repeat scan codes and leaked keyboard events
         - Fix kernel crash with kdb_printf() for users who compile new
           kdb_printf()'s in early code
         - Return all segment registers to gdb on x86_64
      
        Features:
         - KDB/KGDB hook the reboot notifier and end user can control if it
           stops, detaches or does nothing (updated docs as well)
         - Notify users who use CONFIG_DEBUG_RODATA to use hw breakpoints"
      
      * tag 'for_linus-3.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/jwessel/kgdb:
        kdb: Add message about CONFIG_DEBUG_RODATA on failure to install breakpoint
        kdb: Avoid using dbg_io_ops until it is initialized
        kgdb,debug_core: add the ability to control the reboot notifier
        KDB: Fix usability issues relating to the 'enter' key.
        kgdb,debug-core,gdbstub: Hook the reboot notifier for debugger detach
        kgdb: Respect that flush op is optional
        kgdb: x86: Return all segment registers also in 64-bit mode
      a20ae85a
    • Linus Torvalds's avatar
      Merge tag 'ktest-v3.4' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-ktest · f0a5ec0e
      Linus Torvalds authored
      Pull ktest changes from Steven Rostedt.
      
      * tag 'ktest-v3.4' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-ktest:
        ktest: Allow a test to override REBOOT_ON_SUCCESS
        ktest: Fix SWITCH_TO_GOOD to also reboot the machine
        ktest: Add SCP_TO_TARGET_INSTALL option
        ktest: Add warning when bugs are ignored
        ktest: Add INSTALL_MOD_STRIP=1 when installing modules
      f0a5ec0e
    • Linus Torvalds's avatar
      Merge tag 'upstream-3.4-rc1' of git://git.infradead.org/linux-ubifs · e57f146b
      Linus Torvalds authored
      Pull UBIFS changes from Artem Bityutskiy:
       - Improve error messages
       - Clean-up i_nlink management
       - Minor clean-ups
      
      * tag 'upstream-3.4-rc1' of git://git.infradead.org/linux-ubifs:
        UBIFS: improve error messages
        UBIFS: kill CUR_MAX_KEY_LEN macro
        UBIFS: do not use inc_link when i_nlink is zero
        UBIFS: make the dbg_lock spinlock static
        UBIFS: increase dumps loglevel
        UBIFS: amend recovery debugging message
      e57f146b
    • Linus Torvalds's avatar
      Merge tag 'upstream-3.4-rc1' of git://git.infradead.org/linux-ubi · 7e61b3ff
      Linus Torvalds authored
      Pull UBI changes from Artem Bityutskiy:
       - Reduce memory consumption
       - Fix picking unknown blocks
       - Fix error-path in 'ubi_scan()'
       - Minor clean-ups
      
      * tag 'upstream-3.4-rc1' of git://git.infradead.org/linux-ubi:
        UBI: rename MOVE_CANCEL_BITFLIPS to MOVE_TARGET_BITFLIPS
        UBI: rename peb_buf1 to peb_buf
        UBI: reduce memory consumption
        UBI: fix eraseblock picking criteria
        UBI: fix documentation and improve readability
        UBI: fix error handling in ubi_scan()
      7e61b3ff
    • Linus Torvalds's avatar
      Merge tag 'pstore-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/aegl/linux · 6e55f8ed
      Linus Torvalds authored
      Pull one pstore patch from Tony Luck
      
      * tag 'pstore-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/aegl/linux:
        pstore: Introduce get_reason_str() to pstore
      6e55f8ed
    • Linus Torvalds's avatar
      Merge branch 'for-linus' of git://oss.sgi.com/xfs/xfs · 49d99a2f
      Linus Torvalds authored
      Pull XFS updates from Ben Myers:
       "Scalability improvements for dquots, log grant code cleanups, plus
        bugfixes and cleanups large and small"
      
      Fix up various trivial conflicts that were due to some of the earlier
      patches already having been integrated into v3.3 as bugfixes, and then
      there were development patches on top of those.  Easily merged by just
      taking the newer version from the pulled branch.
      
      * 'for-linus' of git://oss.sgi.com/xfs/xfs: (45 commits)
        xfs: fallback to vmalloc for large buffers in xfs_getbmap
        xfs: fallback to vmalloc for large buffers in xfs_attrmulti_attr_get
        xfs: remove remaining scraps of struct xfs_iomap
        xfs: fix inode lookup race
        xfs: clean up minor sparse warnings
        xfs: remove the global xfs_Gqm structure
        xfs: remove the per-filesystem list of dquots
        xfs: use per-filesystem radix trees for dquot lookup
        xfs: per-filesystem dquot LRU lists
        xfs: use common code for quota statistics
        xfs: reimplement fdatasync support
        xfs: split in-core and on-disk inode log item fields
        xfs: make xfs_inode_item_size idempotent
        xfs: log timestamp updates
        xfs: log file size updates at I/O completion time
        xfs: log file size updates as part of unwritten extent conversion
        xfs: do not require an ioend for new EOF calculation
        xfs: use per-filesystem I/O completion workqueues
        quota: make Q_XQUOTASYNC a noop
        xfs: include reservations in quota reporting
        ...
      49d99a2f
    • Linus Torvalds's avatar
      Merge git://git.samba.org/sfrench/cifs-2.6 · 1c3ddfe5
      Linus Torvalds authored
      Pull CIFS fixes from Steve French
      
      * git://git.samba.org/sfrench/cifs-2.6:
        cifs: clean up ordering in exit_cifs
        cifs: clean up call to cifs_dfs_release_automount_timer()
        CIFS: Delete echo_retries module parm
        CIFS: Prepare credits code for a slot reservation
        CIFS: Make wait_for_free_request killable
        CIFS: Introduce credit-based flow control
        CIFS: Simplify inFlight logic
        cifs: fix issue mounting of DFS ROOT when redirecting from one domain controller to the next
        CIFS: Respect negotiated MaxMpxCount
        CIFS: Fix a spurious error in cifs_push_posix_locks
      1c3ddfe5
    • Linus Torvalds's avatar
      Merge tag 'nfs-for-3.4-1' of git://git.linux-nfs.org/projects/trondmy/linux-nfs · f63d395d
      Linus Torvalds authored
      Pull NFS client updates for Linux 3.4 from Trond Myklebust:
       "New features include:
         - Add NFS client support for containers.
      
           This should enable most of the necessary functionality, including
           lockd support, and support for rpc.statd, NFSv4 idmapper and
           RPCSEC_GSS upcalls into the correct network namespace from which
           the mount system call was issued.
      
         - NFSv4 idmapper scalability improvements
      
           Base the idmapper cache on the keyring interface to allow
           concurrent access to idmapper entries.  Start the process of
           migrating users from the single-threaded daemon-based approach to
           the multi-threaded request-key based approach.
      
         - NFSv4.1 implementation id.
      
           Allows the NFSv4.1 client and server to mutually identify each
           other for logging and debugging purposes.
      
         - Support the 'vers=4.1' mount option for mounting NFSv4.1 instead of
           having to use the more counterintuitive 'vers=4,minorversion=1'.
      
         - SUNRPC tracepoints.
      
           Start the process of adding tracepoints in order to improve
           debugging of the RPC layer.
      
         - pNFS object layout support for autologin.
      
        Important bugfixes include:
      
         - Fix a bug in rpc_wake_up/rpc_wake_up_status that caused them to
           fail to wake up all tasks when applied to priority waitqueues.
      
         - Ensure that we handle read delegations correctly, when we try to
           truncate a file.
      
         - A number of fixes for NFSv4 state manager loops (mostly to do with
           delegation recovery)."
      
      * tag 'nfs-for-3.4-1' of git://git.linux-nfs.org/projects/trondmy/linux-nfs: (224 commits)
        NFS: fix sb->s_id in nfs debug prints
        xprtrdma: Remove assumption that each segment is <= PAGE_SIZE
        xprtrdma: The transport should not bug-check when a dup reply is received
        pnfs-obj: autologin: Add support for protocol autologin
        NFS: Remove nfs4_setup_sequence from generic rename code
        NFS: Remove nfs4_setup_sequence from generic unlink code
        NFS: Remove nfs4_setup_sequence from generic read code
        NFS: Remove nfs4_setup_sequence from generic write code
        NFS: Fix more NFS debug related build warnings
        SUNRPC/LOCKD: Fix build warnings when CONFIG_SUNRPC_DEBUG is undefined
        nfs: non void functions must return a value
        SUNRPC: Kill compiler warning when RPC_DEBUG is unset
        SUNRPC/NFS: Add Kbuild dependencies for NFS_DEBUG/RPC_DEBUG
        NFS: Use cond_resched_lock() to reduce latencies in the commit scans
        NFSv4: It is not safe to dereference lsp->ls_state in release_lockowner
        NFS: ncommit count is being double decremented
        SUNRPC: We must not use list_for_each_entry_safe() in rpc_wake_up()
        Try using machine credentials for RENEW calls
        NFSv4.1: Fix a few issues in filelayout_commit_pagelist
        NFSv4.1: Clean ups and bugfixes for the pNFS read/writeback/commit code
        ...
      f63d395d
    • Hugh Dickins's avatar
      mm: fix testorder interaction between two kswapd patches · 643ac9fc
      Hugh Dickins authored
      Adjusting cc715d99 "mm: vmscan: forcibly scan highmem if there are
      too many buffer_heads pinning highmem" for -stable reveals that it was
      slightly wrong once on top of fe2c2a10 "vmscan: reclaim at order 0
      when compaction is enabled", which specifically adds testorder for the
      zone_watermark_ok_safe() test.
      Signed-off-by: default avatarHugh Dickins <hughd@google.com>
      Acked-by: default avatarMel Gorman <mel@csn.ul.ie>
      Acked-by: default avatarRik van Riel <riel@redhat.com>
      Cc: Andrew Morton <akpm@linux-foundation.org>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      643ac9fc
    • Linus Torvalds's avatar
      Merge tag 'fbdev-updates-for-3.4' of git://github.com/schandinat/linux-2.6 · 43753826
      Linus Torvalds authored
      Pull fbdev updates for 3.4 from Florian Tobias Schandinat:
       - drivers for Samsung Exynos MIPI DSI and display port
       - i740fb to support those old Intel chips
       - large updates to OMAP, viafb and sh_mobile_lcdcfb
       - some updates to s3c-fb and udlfb, few patches to others
      
      Fix up conflicts in drivers/video/udlfb.c due to Key Sievers' fix making
      it in twice.
      
      * tag 'fbdev-updates-for-3.4' of git://github.com/schandinat/linux-2.6: (156 commits)
        Revert "video:uvesafb: Fix oops that uvesafb try to execute NX-protected page"
        OMAPDSS: register dss drivers in module init
        video: pxafb: add clk_prepare/clk_unprepare calls
        fbdev: bfin_adv7393fb: Drop needless include
        fbdev: sh_mipi_dsi: add extra phyctrl for sh_mipi_dsi_info
        fbdev: remove dependency of FB_SH_MOBILE_MERAM from FB_SH_MOBILE_LCDC
        Revert "MAINTAINERS: add entry for exynos mipi display drivers"
        fbdev: da8xx: add support for SP10Q010 display
        fbdev: da8xx:: fix reporting of the display timing info
        drivers/video/pvr2fb.c: ensure arguments to request_irq and free_irq are compatible
        OMAPDSS: APPLY: fix clearing shadow dirty flag with manual update
        fbdev: sh_mobile_meram: Implement system suspend/resume
        fbdev: sh_mobile_meram: Remove unneeded sanity checks
        fbdev: sh_mobile_meram: Don't perform update in register operation
        arm: mach-shmobile: Constify sh_mobile_meram_cfg structures
        fbdev: sh_mobile_lcdc: Don't store copy of platform data
        fbdev: sh_mobile_meram: Remove unused sh_mobile_meram_icb_cfg fields
        arm: mach-shmobile: Don't set MERAM ICB numbers in platform data
        fbdev: sh_mobile_meram: Allocate ICBs automatically
        fbdev: sh_mobile_meram: Use genalloc to manage MERAM allocation
        ...
      43753826
    • Linus Torvalds's avatar
      Merge tag 'regmap-3.4' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regmap · 9586c959
      Linus Torvalds authored
      Pull regmap updates from Mark Brown:
       "Things are really quieting down with the regmap API, while we're still
        seeing a trickle of new features coming in they're getting much
        smaller than they were.  It's also nice to have some features which
        support other subsystems building infrastructure on top of regmap.
        Highlights include:
      
        - Support for padding between the register and the value when
          interacting with the device, sometimes needed for fast interfaces.
        - Support for applying register updates to the device when restoring
          the register state.  This is intended to be used to apply updates
          supplied by manufacturers for tuning the performance of the device
          (many of which are to undocumented registers which aren't otherwise
          covered).
        - Support for multi-register operations on cached registers.
        - Support for syncing only part of the register cache.
        - Stubs and parameter query functions intended to make it easier for
          other subsystems to build infrastructure on top of the regmap API.
      
        plus a few driver updates making use of the new features which it was
        easier to merge via this tree."
      
      * tag 'regmap-3.4' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regmap: (41 commits)
        regmap: Fix future missing prototype of devres_alloc() and friends
        regmap: Rejig struct declarations for stubbed API
        regmap: Fix rbtree block base in sync
        regcache: Make sure we sync register 0 in an rbtree cache
        regmap: delete unused module.h from drivers/base/regmap files
        regmap: Add stub for regcache_sync_region()
        mfd: Improve performance of later WM1811 revisions
        regmap: Fix x86_64 breakage
        regmap: Allow drivers to sync only part of the register cache
        regmap: Supply ranges to the sync operations
        regmap: Add tracepoints for cache only and cache bypass
        regmap: Mark the cache as clean after a successful sync
        regmap: Remove default cache sync implementation
        regmap: Skip hardware defaults for LZO caches
        regmap: Expose the driver name in debugfs
        mfd: wm8400: Convert to devm_regmap_init_i2c()
        mfd: wm831x: Convert to devm_regmap_init()
        mfd: wm8994: Convert to devm_regmap_init()
        mfd/ASoC: Convert WM8994 driver to use regmap patches
        mfd: Add __devinit and __devexit annotations in wm8994
        ...
      9586c959
    • Linus Torvalds's avatar
      Merge tag 'firewire-updates' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394 · 34699403
      Linus Torvalds authored
      Pull IEEE 1394 (FireWire) subsystem updates post v3.3 from Stefan Richter:
      
       - Some SBP-2 initiator fixes, side product from ongoing work on a target.
      
       - Reintroduction of an isochronous I/O feature of the older ieee1394 driver
         stack (flush buffer completions); it was evidently rarely used but not
         actually unused.  Matching libraw1394 code is already available.
      
       - Be sure to prefix all kernel log messages with device name or card name,
         and other logging related cleanups.
      
       - Misc other small cleanups, among them a small API change that affects
         sound/firewire/ too. Clemens Ladisch is aware of it.
      
      * tag 'firewire-updates' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394: (26 commits)
        firewire: allow explicit flushing of iso packet completions
        firewire: prevent dropping of completed iso packet header data
        firewire: ohci: factor out iso completion flushing code
        firewire: ohci: simplify iso header pointer arithmetic
        firewire: ohci: optimize control bit checks
        firewire: ohci: remove unused excess_bytes field
        firewire: ohci: copy_iso_headers(): make comment match the code
        firewire: cdev: fix IR multichannel event documentation
        firewire: ohci: fix too-early completion of IR multichannel buffers
        firewire: ohci: move runtime debug facility out of #ifdef
        firewire: tone down some diagnostic log messages
        firewire: sbp2: replace a GFP_ATOMIC allocation
        firewire: sbp2: Fix SCSI sense data mangling
        firewire: sbp2: Ignore SBP-2 targets on the local node
        firewire: sbp2: Take into account Unit_Unique_ID
        firewire: nosy: Use the macro DMA_BIT_MASK().
        firewire: core: convert AR-req handler lock from _irqsave to _bh
        firewire: core: fix race at address_handler unregistration
        firewire: core: remove obsolete comment
        firewire: core: prefix log messages with card name
        ...
      34699403
    • Linus Torvalds's avatar
      Merge tag 'pinctrl-for-3.4' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl · 7fc86a79
      Linus Torvalds authored
      Pull pinctrl updates for v3.4 from Linus Walleij (*):
       - Switches the PXA 168, 910 and MMP over to use pinctrl
       - Locking revamped
       - Massive refactorings...
       - Reform the driver API to use multiple states
       - Support pin config in the mapping tables
       - Pinctrl drivers for the nVidia Tegra series
       - Generic pin config support lib for simple pin controllers
       - Implement pin config for the U300
      
      * tag 'pinctrl-for-3.4' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl: (48 commits)
        ARM: u300: configure some pins as an example
        pinctrl: support pinconfig on the U300
        pinctrl/coh901: use generic pinconf enums and parameters
        pinctrl: introduce generic pin config
        pinctrl: fix error path in pinconf_map_to_setting()
        pinctrl: allow concurrent gpio and mux function ownership of pins
        pinctrl: forward-declare struct device
        pinctrl: split pincontrol states into its own header
        pinctrl: include machine header to core.h
        ARM: tegra: Select PINCTRL Kconfig variables
        pinctrl: add a driver for NVIDIA Tegra
        pinctrl: Show selected function and group in pinmux-pins debugfs
        pinctrl: enhance mapping table to support pin config operations
        pinctrl: API changes to support multiple states per device
        pinctrl: add usecount to pins for muxing
        pinctrl: refactor struct pinctrl handling in core.c vs pinmux.c
        pinctrl: fix and simplify locking
        pinctrl: fix the pin descriptor kerneldoc
        pinctrl: assume map table entries can't have a NULL name field
        pinctrl: introduce PINCTRL_STATE_DEFAULT, define hogs as that state
        ...
      
      (*) What is it with all these Linuses these days? There's a Linus at
          google too.  Some day I will get myself my own broadsword, and run
          around screaming "There can be only one".
      
          I used to be _special_ dammit. Snif.
      7fc86a79
    • Linus Torvalds's avatar
      Merge tag 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jgarzik/libata-dev · 90597b6c
      Linus Torvalds authored
      Pull libata updates from Jeff Garzik:
      
       1) AHCI regression fix.  A recent "make driver conform to spec" change
          broke on deployed hardware.  Make new behavior optional, rather than
          default, turning it on only for specific embedded platforms that
          need this.
      
          Everybody else runs in the famous "non conformant but working" mode.
      
       2) pata_cmd64x, pata_legacy cleanups
      
       3) new Intel SATA PCI IDs
      
       4) misc minor vendor feature additions
      
      * tag 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jgarzik/libata-dev:
        pata_cmd64x: implement sff_irq_check() method
        pata_cmd64x: implement sff_irq_clear() method
        pata_cmd64x: use interrupt status from MRDMODE register
        pata_cmd64x: turn string of *if* statements into *switch*
        drivers/ata/pata_mpc52xx.c: clean up error handling code
        ahci_platform: add STRICT_AHCI platform type
        ahci: move AHCI_HFLAGS() macro to ahci.h
        ahci: add AHCI_HFLAG_DELAY_ENGINE host flag
        sata_fsl: add support for interrupt coalsecing feature
        ata/pata_arasan_cf: Add Hibernation support
        pata_legacy: correctly mask recovery field for HT6560B
        ata_piix: IDE-mode SATA patch for Intel Lynx Point DeviceIDs
        ahci: AHCI-mode SATA patch for Intel Lynx Point DeviceIDs
      90597b6c
    • Linus Torvalds's avatar
      Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input · 7bfe0e66
      Linus Torvalds authored
      Pull input subsystem updates from Dmitry Torokhov:
       "- we finally merged driver for USB version of Synaptics touchpads
          (I guess most commonly found in IBM/Lenovo keyboard/touchpad combo);
      
         - a bunch of new drivers for embedded platforms (Cypress
           touchscreens, DA9052 OnKey, MAX8997-haptic, Ilitek ILI210x
           touchscreens, TI touchscreen);
      
         - input core allows clients to specify desired clock source for
           timestamps on input events (EVIOCSCLOCKID ioctl);
      
         - input core allows querying state of all MT slots for given event
           code via EVIOCGMTSLOTS ioctl;
      
         - various driver fixes and improvements."
      
      * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input: (45 commits)
        Input: ili210x - add support for Ilitek ILI210x based touchscreens
        Input: altera_ps2 - use of_match_ptr()
        Input: synaptics_usb - switch to module_usb_driver()
        Input: convert I2C drivers to use module_i2c_driver()
        Input: convert SPI drivers to use module_spi_driver()
        Input: omap4-keypad - move platform_data to <linux/platform_data>
        Input: kxtj9 - who_am_i check value and initial data rate fixes
        Input: add driver support for MAX8997-haptic
        Input: tegra-kbc - revise device tree support
        Input: of_keymap - add device tree bindings for simple key matrices
        Input: wacom - fix physical size calculation for 3rd-gen Bamboo
        Input: twl4030-vibra - really switch from #if to #ifdef
        Input: hp680_ts_input - ensure arguments to request_irq and free_irq are compatible
        Input: max8925_onkey - avoid accessing input device too early
        Input: max8925_onkey - allow to be used as a wakeup source
        Input: atmel-wm97xx - convert to dev_pm_ops
        Input: atmel-wm97xx - set driver owner
        Input: add cyttsp touchscreen maintainer entry
        Input: cyttsp - remove useless checks in cyttsp_probe()
        Input: usbtouchscreen - add support for Data Modul EasyTouch TP 72037
        ...
      7bfe0e66
    • Linus Torvalds's avatar
      Merge git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6 · 6a76a699
      Linus Torvalds authored
      Pull crypto fixes from Herbert Xu:
       "This fixes a build problem where two crypto modules both try to export
        the same symbols (which shouldn't have been exported in the first
        place)."
      
      * git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6:
        crypto: twofish-x86_64-3way - module init/exit functions should be static
        crypto: camellia-x86_64 - module init/exit functions should be static
      6a76a699
    • Linus Torvalds's avatar
      Merge tag 'stable/for-linus-3.4-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/konrad/xen · d4c6fa73
      Linus Torvalds authored
      Pull xen updates from Konrad Rzeszutek Wilk:
       "which has three neat features:
      
         - PV multiconsole support, so that there can be hvc1, hvc2, etc; This
           can be used in HVM and in PV mode.
      
         - P-state and C-state power management driver that uploads said power
           management data to the hypervisor.  It also inhibits cpufreq
           scaling drivers to load so that only the hypervisor can make power
           management decisions - fixing a weird perf bug.
      
           There is one thing in the Kconfig that you won't like: "default y
           if (X86_ACPI_CPUFREQ = y || X86_POWERNOW_K8 = y)" (note, that it
           all depends on CONFIG_XEN which depends on CONFIG_PARAVIRT which by
           default is off).  I've a fix to convert that boolean expression
           into "default m" which I am going to post after the cpufreq git
           pull - as the two patches to make this work depend on a fix in Dave
           Jones's tree.
      
         - Function Level Reset (FLR) support in the Xen PCI backend.
      
        Fixes:
      
         - Kconfig dependencies for Xen PV keyboard and video
         - Compile warnings and constify fixes
         - Change over to use percpu_xxx instead of this_cpu_xxx"
      
      Fix up trivial conflicts in drivers/tty/hvc/hvc_xen.c due to changes to
      a removed commit.
      
      * tag 'stable/for-linus-3.4-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/konrad/xen:
        xen kconfig: relax INPUT_XEN_KBDDEV_FRONTEND deps
        xen/acpi-processor: C and P-state driver that uploads said data to hypervisor.
        xen: constify all instances of "struct attribute_group"
        xen/xenbus: ignore console/0
        hvc_xen: introduce HVC_XEN_FRONTEND
        hvc_xen: implement multiconsole support
        hvc_xen: support PV on HVM consoles
        xenbus: don't free other end details too early
        xen/enlighten: Expose MWAIT and MWAIT_LEAF if hypervisor OKs it.
        xen/setup/pm/acpi: Remove the call to boot_option_idle_override.
        xenbus: address compiler warnings
        xen: use this_cpu_xxx replace percpu_xxx funcs
        xen/pciback: Support pci_reset_function, aka FLR or D3 support.
        pci: Introduce __pci_reset_function_locked to be used when holding device_lock.
        xen: Utilize the restore_msi_irqs hook.
      d4c6fa73
    • Oliver Neukum's avatar
      usbnet: consider device busy at each recieved packet · 8a783354
      Oliver Neukum authored
      usbnet should centrally handle busy reporting in the rx path
      so subdrivers need not worry. This hurts use cases which do
      rx only or predominantly.
      Signed-off-by: default avatarOliver Neukum <oneukum@suse.de>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      8a783354
    • Linus Torvalds's avatar
      Merge tag 'stable/for-linus-3.4' of git://git.kernel.org/pub/scm/linux/kernel/git/konrad/mm · aab008db
      Linus Torvalds authored
      Pull cleancache changes from Konrad Rzeszutek Wilk:
       "This has some patches for the cleancache API that should have been
        submitted a _long_ time ago.  They are basically cleanups:
      
         - rename of flush to invalidate
      
         - moving reporting of statistics into debugfs
      
         - use __read_mostly as necessary.
      
        Oh, and also the MAINTAINERS file change.  The files (except the
        MAINTAINERS file) have been in #linux-next for months now.  The late
        addition of MAINTAINERS file is a brain-fart on my side - didn't
        realize I needed that just until I was typing this up - and I based
        that patch on v3.3 - so the tree is on top of v3.3."
      
      * tag 'stable/for-linus-3.4' of git://git.kernel.org/pub/scm/linux/kernel/git/konrad/mm:
        MAINTAINERS: Adding cleancache API to the list.
        mm: cleancache: Use __read_mostly as appropiate.
        mm: cleancache: report statistics via debugfs instead of sysfs.
        mm: zcache/tmem/cleancache: s/flush/invalidate/
        mm: cleancache: s/flush/invalidate/
      aab008db
    • Andy Gospodarek's avatar
      bonding: remove entries for master_ip and vlan_ip and query devices instead · eaddcd76
      Andy Gospodarek authored
      The following patch aimed to resolve an issue where secondary, tertiary,
      etc. addresses added to bond interfaces could overwrite the
      bond->master_ip and vlan_ip values.
      
              commit 917fbdb3
              Author: Henrik Saavedra Persson <henrik.e.persson@ericsson.com>
              Date:   Wed Nov 23 23:37:15 2011 +0000
      
                  bonding: only use primary address for ARP
      
      That patch was good because it prevented bonds using ARP monitoring from
      sending frames with an invalid source IP address.  Unfortunately, it
      didn't always work as expected.
      
      When using an ioctl (like ifconfig does) to set the IP address and
      netmask, 2 separate ioctls are actually called to set the IP and netmask
      if the mask chosen doesn't match the standard mask for that class of
      address.  The first ioctl did not have a mask that matched the one in
      the primary address and would still cause the device address to be
      overwritten.  The second ioctl that was called to set the mask would
      then detect as secondary and ignored, but the damage was already done.
      
      This was not an issue when using an application that used netlink
      sockets as the setting of IP and netmask came down at once.  The
      inconsistent behavior between those two interfaces was something that
      needed to be resolved.
      
      While I was thinking about how I wanted to resolve this, Ralf Zeidler
      came with a patch that resolved this on a RHEL kernel by keeping a full
      shadow of the entries in dev->ifa_list for the bonding device and vlan
      devices in the bonding driver.  I didn't like the duplication of the
      list as I want to see the 'bonding' struct and code shrink rather than
      grow, but liked the general idea.
      
      As the Subject indicates this patch drops the master_ip and vlan_ip
      elements from the 'bonding' and 'vlan_entry' structs, respectively.
      This can be done because a device's address-list is now traversed to
      determine the optimal source IP address for ARP requests and for checks
      to see if the bonding device has a particular IP address.  This code
      could have all be contained inside the bonding driver, but it made more
      sense to me to EXPORT and call inet_confirm_addr since it did exactly
      what was needed.
      
      I tested this and a backported patch and everything works as expected.
      Ralf also helped with verification of the backported patch.
      
      Thanks to Ralf for all his help on this.
      
      v2: Whitespace and organizational changes based on suggestions from Jay
      Vosburgh and Dave Miller.
      
      v3: Fixup incorrect usage of rcu_read_unlock based on Dave Miller's
      suggestion.
      Signed-off-by: default avatarAndy Gospodarek <andy@greyhouse.net>
      CC: Ralf Zeidler <ralf.zeidler@nsn.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      eaddcd76
    • Rusty Russell's avatar
      netfilter: remove forward module param confusion. · 523f610e
      Rusty Russell authored
      It used to be an int, and it got changed to a bool parameter at least
      7 years ago.  It happens that NF_ACCEPT and NF_DROP are 0 and 1, so
      this works, but it's unclear, and the check that it's in range is not
      required.
      Reported-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
      Signed-off-by: default avatarRusty Russell <rusty@rustcorp.com.au>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      523f610e
    • Linus Torvalds's avatar
      Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/lliubbo/blackfin · 4f5b1aff
      Linus Torvalds authored
      Pull blackfin updates from Bob Liu
      
      * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/lliubbo/blackfin: (24 commits)
        blackfin: clean up string bfin_dma_5xx after rename.
        blackfin:dma: rename bfin_dma_5xx.c to bfin_dma.c
        bf548: ssm2602: Add ssm2602 platform data into bf548 ezkit board file.
        Blackfin: s/#if CONFIG/#ifdef CONFIG/
        Blackfin: pnav: delete duplicate linux/export.h include
        bf561: add ppi DLEN macro for 10bits to 16bits
        arch: blackfin: udpate defconfig
        Disintegrate asm/system.h for Blackfin [ver #2]
        arch/blackfin: don't generate random mac in bfin_get_ether_addr()
        Blackfin: wire up new process_vm syscalls
        blackfin: cleanup anomaly workarounds
        blackfin: update default defconfig
        blackfin: thread_info: add suspend flag
        bfin: add bfin_ad73311_machine platform device
        blackfin: bf537: stamp: update board file for 193x
        blackfin: kgdb: skip hardware watchpoint test
        bf548: add ppi interrupt mask and blanking clocks
        blackfin: bf561: forgot CSYNC in get_core_lock_noflush
        spi/bfin_spi: drop bits_per_word from client data
        blackfin: cplb-mpu: fix page mask table overflow
        ...
      4f5b1aff
    • Linus Torvalds's avatar
      Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux · db141796
      Linus Torvalds authored
      Pull s390 patches from Martin Schwidefsky:
       "The biggest patch is the rework of the smp code, something I wanted to
        do for some time.  There are some patches for our various dump methods
        and one new thing: z/VM LGR detection.  LGR stands for linux-guest-
        relocation and is the guest migration feature of z/VM.  For debugging
        purposes we keep a log of the systems where a specific guest has lived."
      
      Fix up trivial conflict in arch/s390/kernel/smp.c due to the scheduler
      cleanup having removed some code next to removed s390 code.
      
      * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux:
        [S390] kernel: Pass correct stack for smp_call_ipl_cpu()
        [S390] Ensure that vmcore_info pointer is never accessed directly
        [S390] dasd: prevent validate server for offline devices
        [S390] Remove monolithic build option for zcrypt driver.
        [S390] stack dump: fix indentation in output
        [S390] kernel: Add OS info memory interface
        [S390] Use block_sigmask()
        [S390] kernel: Add z/VM LGR detection
        [S390] irq: external interrupt code passing
        [S390] irq: set __ARCH_IRQ_EXIT_IRQS_DISABLED
        [S390] zfcpdump: Implement async sdias event processing
        [S390] Use copy_to_absolute_zero() instead of "stura/sturg"
        [S390] rework idle code
        [S390] rework smp code
        [S390] rename lowcore field
        [S390] Fix gcc 4.6.0 compile warning
      db141796
    • Linus Torvalds's avatar
      security: optimize avc_audit() common path · 48aab2f7
      Linus Torvalds authored
      avc_audit() did a lot of jumping around and had a big stack frame, all
      for the uncommon case.
      
      Split up the uncommon case (which we really can't make go fast anyway)
      into its own slow function, and mark the conditional branches
      appropriately for the common likely case.
      
      This causes avc_audit() to no longer show up as one of the hottest
      functions on the branch profiles (the new "perf -b" thing), and makes
      the cycle profiles look really nice and dense too.
      
      The whole audit path is still annoyingly very much one of the biggest
      costs of name lookup, so these things are worth optimizing for.  I wish
      we could just tell people to turn it off, but realistically we do need
      it: we just need to make sure that the overhead of the necessary evil is
      as low as possible.
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      48aab2f7
  2. 22 Mar, 2012 1 commit