04 Nov, 2014

20 commits


03 Nov, 2014

16 commits

  • Linus Torvalds
     
  • Pull MTD fixes from Brian Norris:
    "Three main MTD fixes for 3.18:

    - A regression from 3.16 which was noticed in 3.17. With the
    restructuring of the m25p80.c driver and the SPI NOR library
    framework, we omitted proper listing of the SPI device IDs. This
    means m25p80.c wouldn't auto-load (modprobe) properly when built as
    a module. For now, we duplicate the device IDs into both modules.

    - The OMAP / ELM modules were depending on an implicit link ordering.
    Use deferred probing so that the new link order (in 3.18-rc) can
    still allow for successful probing.

    - Fix suspend/resume support for LH28F640BF NOR flash"

    * tag 'for-linus-20141102' of git://git.infradead.org/linux-mtd:
    mtd: cfi_cmdset_0001.c: fix resume for LH28F640BF chips
    mtd: omap: fix mtd devices not showing up
    mtd: m25p80,spi-nor: Fix module aliases for m25p80
    mtd: spi-nor: make spi_nor_scan() take a chip type name, not spi_device_id
    mtd: m25p80: get rid of spi_get_device_id

    Linus Torvalds
     
  • Pull SCSI fixes from James Bottomley:
    "This is a set of six patches consisting of:
    - two MAINTAINER updates
    - two scsi-mq fixs for the old parallel interface (not every request
    is tagged and we need to set the right flags to populate the SPI
    tag message)
    - a fix for a memory leak in scatterlist traversal caused by a
    preallocation update in 3.17
    - an ipv6 fix for cxgbi"

    [ The scatterlist fix also came in separately through the block layer tree ]

    * tag 'scsi-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi:
    MAINTAINERS: ufs - remove self
    MAINTAINERS: change hpsa and cciss maintainer
    libcxgbi : support ipv6 address host_param
    scsi: set REQ_QUEUE for the blk-mq case
    Revert "block: all blk-mq requests are tagged"
    lib/scatterlist: fix memory leak with scsi-mq

    Linus Torvalds
     
  • Pull drm fixes from Dave Airlie:
    "Nothing too astounding or major: radeon, i915, vmwgfx, armada and
    exynos.

    Biggest ones:
    - vmwgfx has one big locking regression fix
    - i915 has come displayport fixes
    - radeon has some stability and a memory alloc failure
    - armada and exynos have some vblank fixes"

    * 'drm-fixes' of git://people.freedesktop.org/~airlied/linux: (24 commits)
    drm/exynos: correct connector->dpms field before resuming
    drm/exynos: enable vblank after DPMS on
    drm/exynos: init kms poll at the end of initialization
    drm/exynos: propagate plane initialization errors
    drm/exynos: vidi: fix build warning
    drm/exynos: remove explicit encoder/connector de-initialization
    drm/exynos: init vblank with real number of crtcs
    drm/vmwgfx: Filter out modes those cannot be supported by the current VRAM size.
    drm/vmwgfx: Fix hash key computation
    drm/vmwgfx: fix lock breakage
    drm/i915/dp: only use training pattern 3 on platforms that support it
    drm/radeon: remove some buggy dead code
    drm/i915: Ignore VBT backlight check on Macbook 2, 1
    drm/radeon: remove invalid pci id
    drm/radeon: dpm fixes for asrock systems
    radeon: clean up coding style differences in radeon_get_bios()
    drm/radeon: Use drm_malloc_ab instead of kmalloc_array
    drm/radeon/dpm: disable ulv support on SI
    drm/i915: Fix GMBUSFREQ on vlv/chv
    drm/i915: Ignore long hpds on eDP ports
    ...

    Linus Torvalds
     
  • Pull ARM fixes from Russell King:
    - add the new bpf syscall to ARM.
    - drop a redundant return statement in __iommu_alloc_remap()
    - fix a performance issue noticed by Thomas Petazzoni with
    kmap_atomic().
    - fix an issue with the L2 cache OF parsing code which caused it to
    incorrectly print warnings on each boot, and make the warning text
    more consistent with the rest of the code

    * 'fixes' of git://ftp.arm.linux.org.uk/~rmk/linux-arm:
    ARM: 8180/1: mm: implement no-highmem fast path in kmap_atomic_pfn()
    ARM: 8183/1: l2c: Improve l2c310_of_parse() error message
    ARM: 8181/1: Drop extra return statement
    ARM: 8182/1: l2c: Make l2x0_cache_size_of_parse() return 'int'
    ARM: enable bpf syscall

    Linus Torvalds
     
  • Pull kvm fixes from Paolo Bonzini:
    "A small set of x86 fixes. The most serious is an SRCU lockdep fix.

    A bit late - needed some time to test the SRCU fix, which only came in
    on Friday"

    * tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm:
    KVM: vmx: defer load of APIC access page address during reset
    KVM: nVMX: Disable preemption while reading from shadow VMCS
    KVM: x86: Fix far-jump to non-canonical check
    KVM: emulator: fix execution close to the segment limit
    KVM: emulator: fix error code for __linearize

    Linus Torvalds
     
  • …/daeinki/drm-exynos into drm-fixes

    This pull-request includes some bug fixes and code cleanups.
    Especially, this fixes the bind failure issue occurred when it tries
    to re-bind Exynos drm driver after unbound, and the modetest failure
    issue incurred by not having a pair to vblank on and off requests.

    * 'exynos-drm-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/daeinki/drm-exynos:
    drm/exynos: correct connector->dpms field before resuming
    drm/exynos: enable vblank after DPMS on
    drm/exynos: init kms poll at the end of initialization
    drm/exynos: propagate plane initialization errors
    drm/exynos: vidi: fix build warning
    drm/exynos: remove explicit encoder/connector de-initialization
    drm/exynos: init vblank with real number of crtcs

    Dave Airlie
     
  • Pull VFS fixes from Al Viro:
    "A bunch of assorted fixes, most of them followups to overlayfs merge"

    * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs:
    ovl: initialize ->is_cursor
    Return short read or 0 at end of a raw device, not EIO
    isofs: don't bother with ->d_op for normal case
    isofs_cmp(): we'll never see a dentry for . or ..
    overlayfs: fix lockdep misannotation
    ovl: fix check for cursor
    overlayfs: barriers for opening upper-layer directory
    rcu: Provide counterpart to rcu_dereference() for non-RCU situations
    staging: android: logger: Fix log corruption regression

    Linus Torvalds
     
  • The sk_prot is irda's own set of protocol handlers, so irda should
    statically know what that function is anyway, without using an indirect
    pointer. And as it happens, we know *exactly* what that pointer is
    statically: it's NULL, because irda doesn't define a disconnect
    operation.

    So calling that function is doubly wrong, and will just cause an oops.

    Reported-by: Martin Lang
    Cc: Samuel Ortiz
    Cc: David Miller
    Signed-off-by: Linus Torvalds

    Linus Torvalds
     
  • During system suspend after connector switch off its dpms field
    is set to connector previous dpms state. To properly resume dpms field
    should be set to its actual state (off) before resuming to previous dpms state.

    Signed-off-by: Andrzej Hajda
    Signed-off-by: Inki Dae

    Andrzej Hajda
     
  • Before DPMS off driver disables vblank.
    It should be balanced by vblank enable after DPMS on.
    The patch fixes issue with page_flip ioctl not being able
    to acquire vblank counter introduced by patch:
    drm: Always reject drm_vblank_get() after drm_vblank_off()

    Signed-off-by: Andrzej Hajda
    Signed-off-by: Inki Dae

    Andrzej Hajda
     
  • HPD events can be generated by components even if drm_dev is not fully
    initialized, to skip such events kms poll initialization should
    be performed at the end of load callback followed directly by forced
    connection detection.

    Signed-off-by: Andrzej Hajda
    Signed-off-by: Inki Dae

    Andrzej Hajda
     
  • In case of error during plane initialization load callback
    incorrectly return success, this patch fixes it.

    Signed-off-by: Andrzej Hajda
    Signed-off-by: Inki Dae

    Andrzej Hajda
     
  • encoder object isn't used anymore so remove it.

    Signed-off-by: Inki Dae

    Inki Dae
     
  • All KMS objects are destroyed by drm_mode_config_cleanup in proper order
    so component drivers should not care about it.

    Signed-off-by: Andrzej Hajda
    Signed-off-by: Inki Dae

    Andrzej Hajda
     
  • Initialization of vblank with MAX_CRTC caused attempts
    to disabling vblanks for non-existing crtcs in case
    drm used fewer crtcs. The patch fixes it.

    Signed-off-by: Andrzej Hajda
    Signed-off-by: Inki Dae

    Andrzej Hajda
     

02 Nov, 2014

4 commits

  • Most call paths to vmx_vcpu_reset do not hold the SRCU lock. Defer loading
    the APIC access page to the next vmentry.

    This avoids the following lockdep splat:

    [ INFO: suspicious RCU usage. ]
    3.18.0-rc2-test2+ #70 Not tainted
    -------------------------------
    include/linux/kvm_host.h:474 suspicious rcu_dereference_check() usage!

    other info that might help us debug this:

    rcu_scheduler_active = 1, debug_locks = 0
    1 lock held by qemu-system-x86/2371:
    #0: (&vcpu->mutex){+.+...}, at: [] vcpu_load+0x20/0xd0 [kvm]

    stack backtrace:
    CPU: 4 PID: 2371 Comm: qemu-system-x86 Not tainted 3.18.0-rc2-test2+ #70
    Hardware name: Dell Inc. OptiPlex 9010/0M9KCM, BIOS A12 01/10/2013
    0000000000000001 ffff880209983ca8 ffffffff816f514f 0000000000000000
    ffff8802099b8990 ffff880209983cd8 ffffffff810bd687 00000000000fee00
    ffff880208a2c000 ffff880208a10000 ffff88020ef50040 ffff880209983d08
    Call Trace:
    [] dump_stack+0x4e/0x71
    [] lockdep_rcu_suspicious+0xe7/0x120
    [] gfn_to_memslot+0xd5/0xe0 [kvm]
    [] __gfn_to_pfn+0x33/0x60 [kvm]
    [] gfn_to_page+0x25/0x90 [kvm]
    [] kvm_vcpu_reload_apic_access_page+0x3c/0x80 [kvm]
    [] vmx_vcpu_reset+0x20c/0x460 [kvm_intel]
    [] kvm_vcpu_reset+0x15e/0x1b0 [kvm]
    [] kvm_arch_vcpu_setup+0x2c/0x50 [kvm]
    [] kvm_vm_ioctl+0x1d0/0x780 [kvm]
    [] ? __lock_is_held+0x54/0x80
    [] do_vfs_ioctl+0x300/0x520
    [] ? __fget+0x5/0x250
    [] ? __fget_light+0x2a/0xe0
    [] SyS_ioctl+0x81/0xa0
    [] system_call_fastpath+0x16/0x1b

    Reported-by: Takashi Iwai
    Reported-by: Alexei Starovoitov
    Reviewed-by: Wanpeng Li
    Tested-by: Wanpeng Li
    Fixes: 38b9917350cb2946e368ba684cfc33d1672f104e
    Signed-off-by: Paolo Bonzini

    Paolo Bonzini
     
  • In order to access the shadow VMCS, we need to load it. At this point,
    vmx->loaded_vmcs->vmcs and the actually loaded one start to differ. If
    we now get preempted by Linux, vmx_vcpu_put and, on return, the
    vmx_vcpu_load will work against the wrong vmcs. That can cause
    copy_shadow_to_vmcs12 to corrupt the vmcs12 state.

    Fix the issue by disabling preemption during the copy operation.
    copy_vmcs12_to_shadow is safe from this issue as it is executed by
    vmx_vcpu_run when preemption is already disabled before vmentry.

    This bug is exposed by running Jailhouse within KVM on CPUs with
    shadow VMCS support. Jailhouse never expects an interrupt pending
    vmexit, but the bug can cause it if, after copy_shadow_to_vmcs12
    is preempted, the active VMCS happens to have the virtual interrupt
    pending flag set in the CPU-based execution controls.

    Signed-off-by: Jan Kiszka
    Signed-off-by: Paolo Bonzini

    Jan Kiszka
     
  • Commit d1442d85cc30 ("KVM: x86: Handle errors when RIP is set during far
    jumps") introduced a bug that caused the fix to be incomplete. Due to
    incorrect evaluation, far jump to segment with L bit cleared (i.e., 32-bit
    segment) and RIP with any of the high bits set (i.e, RIP[63:32] != 0) set may
    not trigger #GP. As we know, this imposes a security problem.

    In addition, the condition for two warnings was incorrect.

    Fixes: d1442d85cc30ea75f7d399474ca738e0bc96f715
    Reported-by: Dan Carpenter
    Signed-off-by: Nadav Amit
    [Add #ifdef CONFIG_X86_64 to avoid complaints of undefined behavior. - Paolo]
    Signed-off-by: Paolo Bonzini

    Nadav Amit
     
  • A critical 3.18 regression fix from Rob, (thanks!)
    A fix to avoid advertizing modes we can't support from Sinclair
    (welcome Sinclair!)
    and a fix for an incorrect hash key computation from me that is
    completely harmless, but can wait 'til the next merge window if necessary.
    (I can't really bother stable with this one).

    * 'vmwgfx-fixes-3.18' of git://people.freedesktop.org/~thomash/linux:
    drm/vmwgfx: Filter out modes those cannot be supported by the current VRAM size.
    drm/vmwgfx: Fix hash key computation
    drm/vmwgfx: fix lock breakage

    Dave Airlie