Skip to content
Permalink
Josef-Bacik/Pr…

Commits on Aug 9, 2016

  1. writeback: allow for dirty metadata accounting

    Provide a mechanism for file systems to indicate how much dirty metadata they
    are holding.  This introduces a few things
    
    1) Zone stats for dirty metadata, which is the same as the NR_FILE_DIRTY.
    2) WB stat for dirty metadata.  This way we know if we need to try and call into
    the file system to write out metadata.  This could potentially be used in the
    future to make balancing of dirty pages smarter.
    3) A super callback to handle writing back dirty metadata.
    
    A future patch will take advantage of this work in btrfs.  Thanks,
    
    Signed-off-by: Josef Bacik <jbacik@fb.com>
    Josef Bacik authored and fengguang committed Aug 9, 2016
  2. remove mapping from balance_dirty_pages*()

    The only reason we pass in the mapping is to get the inode in order to see if
    writeback cgroups is enabled, and even then it only checks the bdi and a super
    block flag.  balance_dirty_pages() doesn't even use the mapping.  Since
    balance_dirty_pages*() works on a bdi level, just pass in the bdi and super
    block directly so we can avoid using mapping.  This will allow us to still use
    balance_dirty_pages for dirty metadata pages that are not backed by an
    address_mapping.
    
    Signed-off-by: Josef Bacik <jbacik@fb.com>
    Josef Bacik authored and fengguang committed Aug 9, 2016
  3. Revert "printk: create pr_<level> functions"

    This reverts commit 874f9c7.
    
    Geert Uytterhoeven reports:
     "This change seems to have an (unintendent?) side-effect.
    
      Before, pr_*() calls without a trailing newline characters would be
      printed with a newline character appended, both on the console and in
      the output of the dmesg command.
    
      After this commit, no new line character is appended, and the output
      of the next pr_*() call of the same type may be appended, like in:
    
        - Truncating RAM at 0x0000000040000000-0x00000000c0000000 to -0x0000000070000000
        - Ignoring RAM at 0x0000000200000000-0x0000000240000000 (!CONFIG_HIGHMEM)
        + Truncating RAM at 0x0000000040000000-0x00000000c0000000 to -0x0000000070000000Ignoring RAM at 0x0000000200000000-0x0000000240000000 (!CONFIG_HIGHMEM)"
    
    Joe Perches says:
     "No, that is not intentional.
    
      The newline handling code inside vprintk_emit is a bit involved and
      for now I suggest a revert until this has all the same behavior as
      earlier"
    
    Reported-by: Geert Uytterhoeven <geert@linux-m68k.org>
    Requested-by: Joe Perches <joe@perches.com>
    Cc: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
    torvalds committed Aug 9, 2016
  4. Merge tag 'trace-v4.8-2' of git://git.kernel.org/pub/scm/linux/kernel…

    …/git/rostedt/linux-trace
    
    Pull tracing fix from Steven Rostedt:
     "Fix tick_stop tracepoint symbols for user export.
    
      Luiz Capitulino noticed that the tick_stop tracepoint wasn't being
      parsed properly by the tracing user space tools.
    
      This was due to the TRACE_DEFINE_ENUM() being set to a define, when it
      should have been set to the enum itself.  The define was of the MASK
      that used the BIT to shift.  The BIT was the enum and by adding that,
      everything gets converted nicely.  The MASK is still kept just in case
      it gets converted to an enum in the future"
    
    * tag 'trace-v4.8-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace:
      tracing: Fix tick_stop tracepoint symbols for user export
    torvalds committed Aug 9, 2016
  5. Merge tag 'gcc-plugin-infrastructure-v4.8-rc2' of git://git.kernel.or…

    …g/pub/scm/linux/kernel/git/kees/linux
    
    Pull gcc plugin improvements from Kees Cook:
     "Several fixes/improvements for the gcc plugin infrastructure:
    
       - fix a problem with gcc plugins interfering with cc-option tests.
    
       - abort more gracefully when gcc plugin headers or compiler support
         is missing.
    
       - improve the gcc plugin rule generation to be more dynamic, pass
         arguments, and build from subdirectories"
    
    * tag 'gcc-plugin-infrastructure-v4.8-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux:
      gcc-plugins: Add support for plugin subdirectories
      gcc-plugins: Automate make rule generation
      gcc-plugins: Add support for passing plugin arguments
      gcc-plugins: abort builds cleanly when not supported
      kbuild: no gcc-plugins during cc-option tests
    torvalds committed Aug 9, 2016
  6. Merge tag 'platform-drivers-x86-v4.8-3' of git://git.infradead.org/us…

    …ers/dvhart/linux-platform-drivers-x86
    
    Pull x86 platform driver update from Darren Hart:
     "dell-wmi: ignore battery remove/insert event"
    
    * tag 'platform-drivers-x86-v4.8-3' of git://git.infradead.org/users/dvhart/linux-platform-drivers-x86:
      dell-wmi: Ignore WMI event 0xe00e
    torvalds committed Aug 9, 2016
  7. Merge tag 'drm-fixes-for-4.8-rc2' of git://people.freedesktop.org/~ai…

    …rlied/linux
    
    Pull drm fixes from Dave Airlie:
     "This contains a bunch of amdgpu fixes, and some i915 regression fixes.
    
      It also contains some fixes for an older regression with some EDID
      changes and some 6bpc panels.
    
      Then there are the lockdep, cirrus and rcar-du regression fixes from
      this window"
    
    * tag 'drm-fixes-for-4.8-rc2' of git://people.freedesktop.org/~airlied/linux:
      drm/cirrus: Fix NULL pointer dereference when registering the fbdev
      drm/edid: Set 8 bpc color depth for displays with "DFP 1.x compliant TMDS".
      drm/i915/dp: Revert "drm/i915/dp: fall back to 18 bpp when sink capability is unknown"
      drm/edid: Add 6 bpc quirk for display AEO model 0.
      drm: Paper over locking inversion after registration rework
      drm: rcar-du: Link HDMI encoder with bridge
      drm/ttm: Wait for a BO to become idle before unbinding it from GTT
      drm/i915/fbdev: Check for the framebuffer before use
      drm/amdgpu: update golden setting of polaris10
      drm/amdgpu: update golden setting of stoney
      drm/amdgpu: update golden setting of polaris11
      drm/amdgpu: update golden setting of carrizo
      drm/amdgpu: update golden setting of iceland
      drm/amd/amdgpu: change pptable output format from ASCII to binary
      drm/amdgpu/ci: add mullins to default case for smc ucode
      drm/amdgpu/gmc7: add missing mullins case
      drm/i915: Never fully mask the the EI up rps interrupt on SNB/IVB
      drm/i915: Wait up to 3ms for the pcu to ack the cdclk change request on SKL
    torvalds committed Aug 9, 2016
  8. ipr: Fix sync scsi scan

    Commit b195d5e ("ipr: Wait to do async scan until scsi host is
    initialized") fixed async scan for ipr, but broke sync scan for ipr.
    
    This fixes sync scan back up.
    
    Signed-off-by: Brian King <brking@linux.vnet.ibm.com>
    Reported-and-tested-by: Michael Ellerman <mpe@ellerman.id.au>
    Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
    bjking1 authored and torvalds committed Aug 9, 2016
  9. mm: memcontrol: only mark charged pages with PageKmemcg

    To distinguish non-slab pages charged to kmemcg we mark them PageKmemcg,
    which sets page->_mapcount to -512.  Currently, we set/clear PageKmemcg
    in __alloc_pages_nodemask()/free_pages_prepare() for any page allocated
    with __GFP_ACCOUNT, including those that aren't actually charged to any
    cgroup, i.e. allocated from the root cgroup context.  To avoid overhead
    in case cgroups are not used, we only do that if memcg_kmem_enabled() is
    true.  The latter is set iff there are kmem-enabled memory cgroups
    (online or offline).  The root cgroup is not considered kmem-enabled.
    
    As a result, if a page is allocated with __GFP_ACCOUNT for the root
    cgroup when there are kmem-enabled memory cgroups and is freed after all
    kmem-enabled memory cgroups were removed, e.g.
    
      # no memory cgroups has been created yet, create one
      mkdir /sys/fs/cgroup/memory/test
      # run something allocating pages with __GFP_ACCOUNT, e.g.
      # a program using pipe
      dmesg | tail
      # remove the memory cgroup
      rmdir /sys/fs/cgroup/memory/test
    
    we'll get bad page state bug complaining about page->_mapcount != -1:
    
      BUG: Bad page state in process swapper/0  pfn:1fd945c
      page:ffffea007f651700 count:0 mapcount:-511 mapping:          (null) index:0x0
      flags: 0x1000000000000000()
    
    To avoid that, let's mark with PageKmemcg only those pages that are
    actually charged to and hence pin a non-root memory cgroup.
    
    Fixes: 4949148 ("mm: charge/uncharge kmemcg from generic page allocator paths")
    Reported-and-tested-by: Eric Dumazet <eric.dumazet@gmail.com>
    Signed-off-by: Vladimir Davydov <vdavydov@virtuozzo.com>
    Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
    Vladimir Davydov authored and torvalds committed Aug 9, 2016
  10. tracing: Fix tick_stop tracepoint symbols for user export

    The symbols used in the tick_stop tracepoint were not being converted
    properly into integers in the trace_stop format file. Instead we had this:
    
    print fmt: "success=%d dependency=%s", REC->success,
        __print_symbolic(REC->dependency, { 0, "NONE" },
         { (1 << TICK_DEP_BIT_POSIX_TIMER), "POSIX_TIMER" },
         { (1 << TICK_DEP_BIT_PERF_EVENTS), "PERF_EVENTS" },
         { (1 << TICK_DEP_BIT_SCHED), "SCHED" },
         { (1 << TICK_DEP_BIT_CLOCK_UNSTABLE), "CLOCK_UNSTABLE" })
    
    User space tools have no idea how to parse "TICK_DEP_BIT_SCHED" or the other
    symbols used to do the bit shifting. The reason is that the conversion was
    done with using the TICK_DEP_MASK_* symbols which are just macros that
    convert to the BIT shift itself (with the exception of NONE, which was
    converted properly, because it doesn't use bits, and is defined as zero).
    
    The TICK_DEP_BIT_* needs to be denoted by TRACE_DEFINE_ENUM() in order to
    have this properly converted for user space tools to parse this event.
    
    Cc: stable@vger.kernel.org
    Cc: Frederic Weisbecker <fweisbec@gmail.com>
    Fixes: e6e6cc2 ("nohz: Use enum code for tick stop failure tracing message")
    Reported-by: Luiz Capitulino <lcapitulino@redhat.com>
    Tested-by: Luiz Capitulino <lcapitulino@redhat.com>
    Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
    rostedt committed Aug 9, 2016
  11. drm/cirrus: Fix NULL pointer dereference when registering the fbdev

    cirrus_modeset_init() is initializing/registering the emulated fbdev
    and, since commit c61b93f ("drm/atomic: Fix remaining places where
    !funcs->best_encoder is valid"), DRM internals can access/test some of
    the fields in mode_config->funcs as part of the fbdev registration
    process.
    Make sure dev->mode_config.funcs is properly set to avoid dereferencing
    a NULL pointer.
    
    Reported-by: Mike Marshall <hubcap@omnibond.com>
    Reported-by: Eric W. Biederman <ebiederm@xmission.com>
    Signed-off-by: Boris Brezillon <boris.brezillon@free-electrons.com>
    Fixes: c61b93f ("drm/atomic: Fix remaining places where !funcs->best_encoder is valid")
    Signed-off-by: Dave Airlie <airlied@redhat.com>
    Boris Brezillon authored and airlied committed Aug 9, 2016
  12. gcc-plugins: Add support for plugin subdirectories

    This adds support for building more complex gcc plugins that live in a
    subdirectory instead of just in a single source file.
    
    Reported-by: PaX Team <pageexec@freemail.hu>
    Signed-off-by: Emese Revfy <re.emese@gmail.com>
    [kees: clarified commit message]
    Signed-off-by: Kees Cook <keescook@chromium.org>
    ephox-gcc-plugins authored and kees committed Aug 9, 2016
  13. gcc-plugins: Automate make rule generation

    There's no reason to repeat the same names in the Makefile when the .so
    files have already been listed. The .o list can be generated from them.
    
    Reported-by: PaX Team <pageexec@freemail.hu>
    Signed-off-by: Emese Revfy <re.emese@gmail.com>
    [kees: clarified commit message]
    Signed-off-by: Kees Cook <keescook@chromium.org>
    ephox-gcc-plugins authored and kees committed Aug 9, 2016
  14. gcc-plugins: Add support for passing plugin arguments

    The latent_entropy plugin needs to pass arguments, so this adds the
    support.
    
    Signed-off-by: Emese Revfy <re.emese@gmail.com>
    Signed-off-by: Kees Cook <keescook@chromium.org>
    ephox-gcc-plugins authored and kees committed Aug 9, 2016
  15. gcc-plugins: abort builds cleanly when not supported

    When the compiler doesn't support gcc plugins (either due to missing
    headers or too old a version), report the problem and abort the build
    instead of emitting a warning and letting the build founder with arcane
    compiler errors.
    
    Signed-off-by: Kees Cook <keescook@chromium.org>
    kees committed Aug 9, 2016
  16. kbuild: no gcc-plugins during cc-option tests

    The gcc-plugins arguments should not be included when performing
    cc-option tests.
    
    Steps to reproduce:
    1) make mrproper
    2) make defconfig
    3) enable GCC_PLUGINS, GCC_PLUGIN_CYC_COMPLEXITY
    4) enable FUNCTION_TRACER (it will select other options as well)
    5) make && make modules
    
    Build errors:
    MODPOST 18 modules
    ERROR: "__fentry__" [net/netfilter/xt_nat.ko] undefined!
    ERROR: "__fentry__" [net/netfilter/xt_mark.ko] undefined!
    ERROR: "__fentry__" [net/netfilter/xt_addrtype.ko] undefined!
    ERROR: "__fentry__" [net/netfilter/xt_LOG.ko] undefined!
    ERROR: "__fentry__" [net/netfilter/nf_nat_sip.ko] undefined!
    ERROR: "__fentry__" [net/netfilter/nf_nat_irc.ko] undefined!
    ERROR: "__fentry__" [net/netfilter/nf_nat_ftp.ko] undefined!
    ERROR: "__fentry__" [net/netfilter/nf_nat.ko] undefined!
    
    Reported-by: Laura Abbott <labbott@redhat.com>
    Signed-off-by: Emese Revfy <re.emese@gmail.com>
    [kees: renamed variable, clarified commit message]
    Signed-off-by: Kees Cook <keescook@chromium.org>
    ephox-gcc-plugins authored and kees committed Aug 9, 2016

Commits on Aug 8, 2016

  1. drm/edid: Set 8 bpc color depth for displays with "DFP 1.x compliant …

    …TMDS".
    
    According to E-EDID spec 1.3, table 3.9, a digital video sink with the
    "DFP 1.x compliant TMDS" bit set is "signal compatible with VESA DFP 1.x
    TMDS CRGB, 1 pixel / clock, up to 8 bits / color MSB aligned".
    
    For such displays, the DFP spec 1.0, section 3.10 "EDID support" says:
    
    "If the DFP monitor only supports EDID 1.X (1.1, 1.2, etc.)
     without extensions, the host will make the following assumptions:
    
     1. 24-bit MSB-aligned RGB TFT
     2. DE polarity is active high
     3. H and V syncs are active high
     4. Established CRT timings will be used
     5. Dithering will not be enabled on the host"
    
    So if we don't know the bit depth of the display from additional
    colorimetry info we should assume 8 bpc / 24 bpp by default.
    
    This patch adds info->bpc = 8 assignement for that case.
    
    Signed-off-by: Mario Kleiner <mario.kleiner.de@gmail.com>
    Cc: Jani Nikula <jani.nikula@intel.com>
    Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
    Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
    Signed-off-by: Dave Airlie <airlied@redhat.com>
    kleinerm authored and airlied committed Aug 8, 2016
  2. drm/i915/dp: Revert "drm/i915/dp: fall back to 18 bpp when sink capab…

    …ility is unknown"
    
    This reverts commit 013dd9e
    ("drm/i915/dp: fall back to 18 bpp when sink capability is unknown")
    
    This commit introduced a regression into stable kernels,
    as it reduces output color depth to 6 bpc for any video
    sink connected to a Displayport connector if that sink
    doesn't report a specific color depth via EDID, or if
    our EDID parser doesn't actually recognize the proper
    bpc from EDID.
    
    Affected are active DisplayPort->VGA converters and
    active DisplayPort->DVI converters. Both should be
    able to handle 8 bpc, but are degraded to 6 bpc with
    this patch.
    
    The reverted commit was meant to fix
    Bugzilla: https://bugzilla.kernel.org/show_bug.cgi?id=105331
    
    A followup patch implements a fix for that specific bug,
    which is caused by a faulty EDID of the affected DP panel
    by adding a new EDID quirk for that panel.
    
    DP 18 bpp fallback handling and other improvements to
    DP sink bpc detection will be handled for future
    kernels in a separate series of patches.
    
    Please backport to stable.
    
    Signed-off-by: Mario Kleiner <mario.kleiner.de@gmail.com>
    Acked-by: Jani Nikula <jani.nikula@intel.com>
    Cc: stable@vger.kernel.org
    Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
    Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
    Signed-off-by: Dave Airlie <airlied@redhat.com>
    kleinerm authored and airlied committed Aug 8, 2016
  3. drm/edid: Add 6 bpc quirk for display AEO model 0.

    Bugzilla https://bugzilla.kernel.org/show_bug.cgi?id=105331
    reports that the "AEO model 0" display is driven with 8 bpc
    without dithering by default, which looks bad because that
    panel is apparently a 6 bpc DP panel with faulty EDID.
    
    A fix for this was made by commit 013dd9e
    ("drm/i915/dp: fall back to 18 bpp when sink capability is unknown").
    
    That commit triggers new regressions in precision for DP->DVI and
    DP->VGA displays. A patch is out to revert that commit, but it will
    revert video output for the AEO model 0 panel to 8 bpc without
    dithering.
    
    The EDID 1.3 of that panel, as decoded from the xrandr output
    attached to that bugzilla bug report, is somewhat faulty, and beyond
    other problems also sets the "DFP 1.x compliant TMDS" bit, which
    according to DFP spec means to drive the panel with 8 bpc and
    no dithering in absence of other colorimetry information.
    
    Try to make the original bug reporter happy despite the
    faulty EDID by adding a quirk to mark that panel as 6 bpc,
    so 6 bpc output with dithering creates a nice picture.
    
    Tested by injecting the edid from the fdo bug into a DP connector
    via drm_kms_helper.edid_firmware and verifying the 6 bpc + dithering
    is selected.
    
    This patch should be backported to stable.
    
    Signed-off-by: Mario Kleiner <mario.kleiner.de@gmail.com>
    Cc: stable@vger.kernel.org
    Cc: Jani Nikula <jani.nikula@intel.com>
    Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
    Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
    Signed-off-by: Dave Airlie <airlied@redhat.com>
    kleinerm authored and airlied committed Aug 8, 2016
  4. Merge tag 'lkdtm-v4.8-rc1' of git://git.kernel.org/pub/scm/linux/kern…

    …el/git/kees/linux
    
    Pull lkdtm update from Kees Cook:
     "Fix rebuild problem with LKDTM's rodata test"
    
    [ This, and the usercopy branch, both came in before the merge window
      closed, but ended up in my 'need to look more' queue and thus got
      merged only after rc1 was out ]
    
    * tag 'lkdtm-v4.8-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux:
      lkdtm: Fix targets for objcopy usage
      lkdtm: fix false positive warning from -Wmaybe-uninitialized
    torvalds committed Aug 8, 2016
  5. Merge tag 'usercopy-v4.8' of git://git.kernel.org/pub/scm/linux/kerne…

    …l/git/kees/linux
    
    Pull usercopy protection from Kees Cook:
     "Tbhis implements HARDENED_USERCOPY verification of copy_to_user and
      copy_from_user bounds checking for most architectures on SLAB and
      SLUB"
    
    * tag 'usercopy-v4.8' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux:
      mm: SLUB hardened usercopy support
      mm: SLAB hardened usercopy support
      s390/uaccess: Enable hardened usercopy
      sparc/uaccess: Enable hardened usercopy
      powerpc/uaccess: Enable hardened usercopy
      ia64/uaccess: Enable hardened usercopy
      arm64/uaccess: Enable hardened usercopy
      ARM: uaccess: Enable hardened usercopy
      x86/uaccess: Enable hardened usercopy
      mm: Hardened usercopy
      mm: Implement stack frame object validation
      mm: Add is_migrate_cma_page
    torvalds committed Aug 8, 2016
  6. unsafe_[get|put]_user: change interface to use a error target label

    When I initially added the unsafe_[get|put]_user() helpers in commit
    5b24a7a ("Add 'unsafe' user access functions for batched
    accesses"), I made the mistake of modeling the interface on our
    traditional __[get|put]_user() functions, which return zero on success,
    or -EFAULT on failure.
    
    That interface is fairly easy to use, but it's actually fairly nasty for
    good code generation, since it essentially forces the caller to check
    the error value for each access.
    
    In particular, since the error handling is already internally
    implemented with an exception handler, and we already use "asm goto" for
    various other things, we could fairly easily make the error cases just
    jump directly to an error label instead, and avoid the need for explicit
    checking after each operation.
    
    So switch the interface to pass in an error label, rather than checking
    the error value in the caller.  Best do it now before we start growing
    more users (the signal handling code in particular would be a good place
    to use the new interface).
    
    So rather than
    
    	if (unsafe_get_user(x, ptr))
    		... handle error ..
    
    the interface is now
    
    	unsafe_get_user(x, ptr, label);
    
    where an error during the user mode fetch will now just cause a jump to
    'label' in the caller.
    
    Right now the actual _implementation_ of this all still ends up being a
    "if (err) goto label", and does not take advantage of any exception
    label tricks, but for "unsafe_put_user()" in particular it should be
    fairly straightforward to convert to using the exception table model.
    
    Note that "unsafe_get_user()" is much harder to convert to a clever
    exception table model, because current versions of gcc do not allow the
    use of "asm goto" (for the exception) with output values (for the actual
    value to be fetched).  But that is hopefully not a limitation in the
    long term.
    
    [ Also note that it might be a good idea to switch unsafe_get_user() to
      actually _return_ the value it fetches from user space, but this
      commit only changes the error handling semantics ]
    
    Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
    torvalds committed Aug 8, 2016
  7. printk: Remove unnecessary #ifdef CONFIG_PRINTK

    In commit 874f9c7 ("printk: create pr_<level> functions"), new
    pr_level defines were added to printk.c.
    
    These new defines are guarded by an #ifdef CONFIG_PRINTK - however,
    there is already a surrounding #ifdef CONFIG_PRINTK starting a lot
    earlier in line 249 which means the newly introduced #ifdef is
    unnecessary.
    
    Let's remove it to avoid confusion.
    
    Signed-off-by: Andreas Ziegler <andreas.ziegler@fau.de>
    Cc: Joe Perches <joe@perches.com>
    Cc: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
    rupran authored and torvalds committed Aug 8, 2016
  8. dell-wmi: Ignore WMI event 0xe00e

    WMI event 0xe00e is received when battery was removed or inserted.
    
    Signed-off-by: Pali Rohár <pali.rohar@gmail.com>
    Signed-off-by: Darren Hart <dvhart@linux.intel.com>
    pali authored and Darren Hart committed Aug 8, 2016
  9. x86/hweight: Don't clobber %rdi

    The caller expects %rdi to remain intact, push+pop it make that happen.
    
    Fixes the following kind of explosions on my core2duo machine when
    trying to reboot or shut down:
    
      general protection fault: 0000 [#1] PREEMPT SMP
      Modules linked in: i915 i2c_algo_bit drm_kms_helper cfbfillrect syscopyarea cfbimgblt sysfillrect sysimgblt fb_sys_fops cfbcopyarea drm netconsole configfs binfmt_misc iTCO_wdt psmouse pcspkr snd_hda_codec_idt e100 coretemp hwmon snd_hda_codec_generic i2c_i801 mii i2c_smbus lpc_ich mfd_core snd_hda_intel uhci_hcd snd_hda_codec snd_hwdep snd_hda_core ehci_pci 8250 ehci_hcd snd_pcm 8250_base usbcore evdev serial_core usb_common parport_pc parport snd_timer snd soundcore
      CPU: 0 PID: 3070 Comm: reboot Not tainted 4.8.0-rc1-perf-dirty torvalds#69
      Hardware name:                  /D946GZIS, BIOS TS94610J.86A.0087.2007.1107.1049 11/07/2007
      task: ffff88012a0b4080 task.stack: ffff880123850000
      RIP: 0010:[<ffffffff81003c92>]  [<ffffffff81003c92>] x86_perf_event_update+0x52/0xc0
      RSP: 0018:ffff880123853b60  EFLAGS: 00010087
      RAX: 0000000000000001 RBX: ffff88012fc0a3c0 RCX: 000000000000001e
      RDX: 0000000000000000 RSI: 0000000040000000 RDI: ffff88012b014800
      RBP: ffff880123853b88 R08: ffffffffffffffff R09: 0000000000000000
      R10: ffffea0004a012c0 R11: ffffea0004acedc0 R12: ffffffff80000001
      R13: ffff88012b0149c0 R14: ffff88012b014800 R15: 0000000000000018
      FS:  00007f8b155cd700(0000) GS:ffff88012fc00000(0000) knlGS:0000000000000000
      CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
      CR2: 00007f8b155f5000 CR3: 000000012a2d7000 CR4: 00000000000006f0
      Stack:
       ffff88012fc0a3c0 ffff88012b014800 0000000000000004 0000000000000001
       ffff88012fc1b750 ffff880123853bb0 ffffffff81003d59 ffff88012b014800
       ffff88012fc0a3c0 ffff88012b014800 ffff880123853bd8 ffffffff81003e13
      Call Trace:
       [<ffffffff81003d59>] x86_pmu_stop+0x59/0xd0
       [<ffffffff81003e13>] x86_pmu_del+0x43/0x140
       [<ffffffff8111705d>] event_sched_out.isra.105+0xbd/0x260
       [<ffffffff8111738d>] __perf_remove_from_context+0x2d/0xb0
       [<ffffffff8111745d>] __perf_event_exit_context+0x4d/0x70
       [<ffffffff810c8826>] generic_exec_single+0xb6/0x140
       [<ffffffff81117410>] ? __perf_remove_from_context+0xb0/0xb0
       [<ffffffff81117410>] ? __perf_remove_from_context+0xb0/0xb0
       [<ffffffff810c898f>] smp_call_function_single+0xdf/0x140
       [<ffffffff81113d27>] perf_event_exit_cpu_context+0x87/0xc0
       [<ffffffff81113d73>] perf_reboot+0x13/0x40
       [<ffffffff8107578a>] notifier_call_chain+0x4a/0x70
       [<ffffffff81075ad7>] __blocking_notifier_call_chain+0x47/0x60
       [<ffffffff81075b06>] blocking_notifier_call_chain+0x16/0x20
       [<ffffffff81076a1d>] kernel_restart_prepare+0x1d/0x40
       [<ffffffff81076ae2>] kernel_restart+0x12/0x60
       [<ffffffff81076d56>] SYSC_reboot+0xf6/0x1b0
       [<ffffffff811a823c>] ? mntput_no_expire+0x2c/0x1b0
       [<ffffffff811a83e4>] ? mntput+0x24/0x40
       [<ffffffff811894fc>] ? __fput+0x16c/0x1e0
       [<ffffffff811895ae>] ? ____fput+0xe/0x10
       [<ffffffff81072fc3>] ? task_work_run+0x83/0xa0
       [<ffffffff81001623>] ? exit_to_usermode_loop+0x53/0xc0
       [<ffffffff8100105a>] ? trace_hardirqs_on_thunk+0x1a/0x1c
       [<ffffffff81076e6e>] SyS_reboot+0xe/0x10
       [<ffffffff814c4ba5>] entry_SYSCALL_64_fastpath+0x18/0xa3
      Code: 7c 4c 8d af c0 01 00 00 49 89 fe eb 10 48 09 c2 4c 89 e0 49 0f b1 55 00 4c 39 e0 74 35 4d 8b a6 c0 01 00 00 41 8b 8e 60 01 00 00 <0f> 33 8b 35 6e 02 8c 00 48 c1 e2 20 85 f6 7e d2 48 89 d3 89 cf
      RIP  [<ffffffff81003c92>] x86_perf_event_update+0x52/0xc0
       RSP <ffff880123853b60>
      ---[ end trace 7ec95181faf211be ]---
      note: reboot[3070] exited with preempt_count 2
    
    Cc: Borislav Petkov <bp@suse.de>
    Cc: H. Peter Anvin <hpa@zytor.com>
    Cc: Andy Lutomirski <luto@amacapital.net>
    Cc: Brian Gerst <brgerst@gmail.com>
    Cc: Denys Vlasenko <dvlasenk@redhat.com>
    Cc: Peter Zijlstra <peterz@infradead.org>
    Cc: Thomas Gleixner <tglx@linutronix.de>
    Cc: Ingo Molnar <mingo@kernel.org>
    Fixes: f596710 ("x86/hweight: Get rid of the special calling convention")
    Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
    Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
    vsyrjala authored and torvalds committed Aug 8, 2016
  10. Merge branch 'drm-next-4.8' of git://people.freedesktop.org/~agd5f/li…

    …nux into drm-next
    
    A few fixes for amdgpu and ttm for 4.8
    - fix a ttm regression caused by the new pipelining code
    - fixes for mullins on amdgpu
    - updated golden settings for amdgpu
    
    * 'drm-next-4.8' of git://people.freedesktop.org/~agd5f/linux:
      drm/ttm: Wait for a BO to become idle before unbinding it from GTT
      drm/amdgpu: update golden setting of polaris10
      drm/amdgpu: update golden setting of stoney
      drm/amdgpu: update golden setting of polaris11
      drm/amdgpu: update golden setting of carrizo
      drm/amdgpu: update golden setting of iceland
      drm/amd/amdgpu: change pptable output format from ASCII to binary
      drm/amdgpu/ci: add mullins to default case for smc ucode
      drm/amdgpu/gmc7: add missing mullins case
    airlied committed Aug 8, 2016
  11. Merge tag 'drm-intel-next-fixes-2016-08-05' of git://anongit.freedesk…

    …top.org/drm-intel into drm-next
    
    3 intel fixes.
    
    * tag 'drm-intel-next-fixes-2016-08-05' of git://anongit.freedesktop.org/drm-intel:
      drm/i915/fbdev: Check for the framebuffer before use
      drm/i915: Never fully mask the the EI up rps interrupt on SNB/IVB
      drm/i915: Wait up to 3ms for the pcu to ack the cdclk change request on SKL
    airlied committed Aug 8, 2016
  12. drm: Paper over locking inversion after registration rework

    drm_connector_register_all requires a few too many locks because our
    connector_list locking is busted. Add another FIXME+hack to work
    around this. This should address the below lockdep splat:
    
    ======================================================
    [ INFO: possible circular locking dependency detected ]
    4.7.0-rc5+ torvalds#524 Tainted: G           O
    -------------------------------------------------------
    kworker/u8:0/6 is trying to acquire lock:
     (&dev->mode_config.mutex){+.+.+.}, at: [<ffffffff815afde0>] drm_modeset_lock_all+0x40/0x120
    
    but task is already holding lock:
     ((fb_notifier_list).rwsem){++++.+}, at: [<ffffffff810ac195>] __blocking_notifier_call_chain+0x35/0x70
    
    which lock already depends on the new lock.
    
    the existing dependency chain (in reverse order) is:
    
    -> #1 ((fb_notifier_list).rwsem){++++.+}:
           [<ffffffff810df611>] lock_acquire+0xb1/0x200
           [<ffffffff819a55b4>] down_write+0x44/0x80
           [<ffffffff810abf91>] blocking_notifier_chain_register+0x21/0xb0
           [<ffffffff814c7448>] fb_register_client+0x18/0x20
           [<ffffffff814c6c86>] backlight_device_register+0x136/0x260
           [<ffffffffa0127eb2>] intel_backlight_device_register+0xa2/0x160 [i915]
           [<ffffffffa00f46be>] intel_connector_register+0xe/0x10 [i915]
           [<ffffffffa0112bfb>] intel_dp_connector_register+0x1b/0x80 [i915]
           [<ffffffff8159dfea>] drm_connector_register+0x4a/0x80
           [<ffffffff8159fe44>] drm_connector_register_all+0x64/0xf0
           [<ffffffff815a2a64>] drm_modeset_register_all+0x174/0x1c0
           [<ffffffff81599b72>] drm_dev_register+0xc2/0xd0
           [<ffffffffa00621d7>] i915_driver_load+0x1547/0x2200 [i915]
           [<ffffffffa006d80f>] i915_pci_probe+0x4f/0x70 [i915]
           [<ffffffff814a2135>] local_pci_probe+0x45/0xa0
           [<ffffffff814a349b>] pci_device_probe+0xdb/0x130
           [<ffffffff815c07e3>] driver_probe_device+0x223/0x440
           [<ffffffff815c0ad5>] __driver_attach+0xd5/0x100
           [<ffffffff815be386>] bus_for_each_dev+0x66/0xa0
           [<ffffffff815c002e>] driver_attach+0x1e/0x20
           [<ffffffff815bf9be>] bus_add_driver+0x1ee/0x280
           [<ffffffff815c1810>] driver_register+0x60/0xe0
           [<ffffffff814a1a10>] __pci_register_driver+0x60/0x70
           [<ffffffffa01a905b>] i915_init+0x5b/0x62 [i915]
           [<ffffffff8100042d>] do_one_initcall+0x3d/0x150
           [<ffffffff811a935b>] do_init_module+0x5f/0x1d9
           [<ffffffff81124416>] load_module+0x20e6/0x27e0
           [<ffffffff81124d63>] SYSC_finit_module+0xc3/0xf0
           [<ffffffff81124dae>] SyS_finit_module+0xe/0x10
           [<ffffffff819a83a9>] entry_SYSCALL_64_fastpath+0x1c/0xac
    
    -> #0 (&dev->mode_config.mutex){+.+.+.}:
           [<ffffffff810df0ac>] __lock_acquire+0x10fc/0x1260
           [<ffffffff810df611>] lock_acquire+0xb1/0x200
           [<ffffffff819a3097>] mutex_lock_nested+0x67/0x3c0
           [<ffffffff815afde0>] drm_modeset_lock_all+0x40/0x120
           [<ffffffff8158f79b>] drm_fb_helper_restore_fbdev_mode_unlocked+0x2b/0x80
           [<ffffffff8158f81d>] drm_fb_helper_set_par+0x2d/0x50
           [<ffffffffa0105f7a>] intel_fbdev_set_par+0x1a/0x60 [i915]
           [<ffffffff814c13c6>] fbcon_init+0x586/0x610
           [<ffffffff8154d16a>] visual_init+0xca/0x130
           [<ffffffff8154e611>] do_bind_con_driver+0x1c1/0x3a0
           [<ffffffff8154eaf6>] do_take_over_console+0x116/0x180
           [<ffffffff814bd3a7>] do_fbcon_takeover+0x57/0xb0
           [<ffffffff814c1e48>] fbcon_event_notify+0x658/0x750
           [<ffffffff810abcae>] notifier_call_chain+0x3e/0xb0
           [<ffffffff810ac1ad>] __blocking_notifier_call_chain+0x4d/0x70
           [<ffffffff810ac1e6>] blocking_notifier_call_chain+0x16/0x20
           [<ffffffff814c748b>] fb_notifier_call_chain+0x1b/0x20
           [<ffffffff814c86b1>] register_framebuffer+0x251/0x330
           [<ffffffff8158fa9f>] drm_fb_helper_initial_config+0x25f/0x3f0
           [<ffffffffa0106b48>] intel_fbdev_initial_config+0x18/0x30 [i915]
           [<ffffffff810adfd8>] async_run_entry_fn+0x48/0x150
           [<ffffffff810a3947>] process_one_work+0x1e7/0x750
           [<ffffffff810a3efb>] worker_thread+0x4b/0x4f0
           [<ffffffff810aad4f>] kthread+0xef/0x110
           [<ffffffff819a85ef>] ret_from_fork+0x1f/0x40
    
    other info that might help us debug this:
    
     Possible unsafe locking scenario:
    
           CPU0                    CPU1
           ----                    ----
      lock((fb_notifier_list).rwsem);
                                   lock(&dev->mode_config.mutex);
                                   lock((fb_notifier_list).rwsem);
      lock(&dev->mode_config.mutex);
    
     *** DEADLOCK ***
    
    6 locks held by kworker/u8:0/6:
     #0:  ("events_unbound"){.+.+.+}, at: [<ffffffff810a38c9>] process_one_work+0x169/0x750
     #1:  ((&entry->work)){+.+.+.}, at: [<ffffffff810a38c9>] process_one_work+0x169/0x750
     #2:  (registration_lock){+.+.+.}, at: [<ffffffff814c8487>] register_framebuffer+0x27/0x330
     #3:  (console_lock){+.+.+.}, at: [<ffffffff814c86ce>] register_framebuffer+0x26e/0x330
     #4:  (&fb_info->lock){+.+.+.}, at: [<ffffffff814c78dd>] lock_fb_info+0x1d/0x40
     #5:  ((fb_notifier_list).rwsem){++++.+}, at: [<ffffffff810ac195>] __blocking_notifier_call_chain+0x35/0x70
    
    stack backtrace:
    CPU: 2 PID: 6 Comm: kworker/u8:0 Tainted: G           O    4.7.0-rc5+ torvalds#524
    Hardware name: Intel Corp. Broxton P/NOTEBOOK, BIOS APLKRVPA.X64.0138.B33.1606250842 06/25/2016
    Workqueue: events_unbound async_run_entry_fn
     0000000000000000 ffff8800758577f0 ffffffff814507a5 ffffffff828b9900
     ffffffff828b9900 ffff880075857830 ffffffff810dc6fa ffff880075857880
     ffff88007584d688 0000000000000005 0000000000000006 ffff88007584d6b0
    Call Trace:
     [<ffffffff814507a5>] dump_stack+0x67/0x92
     [<ffffffff810dc6fa>] print_circular_bug+0x1aa/0x200
     [<ffffffff810df0ac>] __lock_acquire+0x10fc/0x1260
     [<ffffffff810df611>] lock_acquire+0xb1/0x200
     [<ffffffff815afde0>] ? drm_modeset_lock_all+0x40/0x120
     [<ffffffff815afde0>] ? drm_modeset_lock_all+0x40/0x120
     [<ffffffff819a3097>] mutex_lock_nested+0x67/0x3c0
     [<ffffffff815afde0>] ? drm_modeset_lock_all+0x40/0x120
     [<ffffffff810fa85f>] ? rcu_read_lock_sched_held+0x7f/0x90
     [<ffffffff81208218>] ? kmem_cache_alloc_trace+0x248/0x2b0
     [<ffffffff815afdc5>] ? drm_modeset_lock_all+0x25/0x120
     [<ffffffff815afde0>] drm_modeset_lock_all+0x40/0x120
     [<ffffffff8158f79b>] drm_fb_helper_restore_fbdev_mode_unlocked+0x2b/0x80
     [<ffffffff8158f81d>] drm_fb_helper_set_par+0x2d/0x50
     [<ffffffffa0105f7a>] intel_fbdev_set_par+0x1a/0x60 [i915]
     [<ffffffff814c13c6>] fbcon_init+0x586/0x610
     [<ffffffff8154d16a>] visual_init+0xca/0x130
     [<ffffffff8154e611>] do_bind_con_driver+0x1c1/0x3a0
     [<ffffffff8154eaf6>] do_take_over_console+0x116/0x180
     [<ffffffff814bd3a7>] do_fbcon_takeover+0x57/0xb0
     [<ffffffff814c1e48>] fbcon_event_notify+0x658/0x750
     [<ffffffff810abcae>] notifier_call_chain+0x3e/0xb0
     [<ffffffff810ac1ad>] __blocking_notifier_call_chain+0x4d/0x70
     [<ffffffff810ac1e6>] blocking_notifier_call_chain+0x16/0x20
     [<ffffffff814c748b>] fb_notifier_call_chain+0x1b/0x20
     [<ffffffff814c86b1>] register_framebuffer+0x251/0x330
     [<ffffffff815b7e8d>] ? vga_switcheroo_client_fb_set+0x5d/0x70
     [<ffffffff8158fa9f>] drm_fb_helper_initial_config+0x25f/0x3f0
     [<ffffffffa0106b48>] intel_fbdev_initial_config+0x18/0x30 [i915]
     [<ffffffff810adfd8>] async_run_entry_fn+0x48/0x150
     [<ffffffff810a3947>] process_one_work+0x1e7/0x750
     [<ffffffff810a38c9>] ? process_one_work+0x169/0x750
     [<ffffffff810a3efb>] worker_thread+0x4b/0x4f0
     [<ffffffff810a3eb0>] ? process_one_work+0x750/0x750
     [<ffffffff810aad4f>] kthread+0xef/0x110
     [<ffffffff819a85ef>] ret_from_fork+0x1f/0x40
     [<ffffffff810aac60>] ? kthread_stop+0x2e0/0x2e0
    
    v2: Rebase onto the right branch (hand-editing patches ftw) and add more
    reporters.
    
    Reported-by: Imre Deak <imre.deak@intel.com>
    Cc: Imre Deak <imre.deak@intel.com>
    Cc: Chris Wilson <chris@chris-wilson.co.uk>
    Acked-by: Chris Wilson <chris@chris-wilson.co.uk>
    Reported-by: Jiri Kosina <jikos@kernel.org>
    Cc: Jiri Kosina <jikos@kernel.org>
    Signed-off-by: Daniel Vetter <daniel.vetter@intel.com>
    Signed-off-by: Dave Airlie <airlied@redhat.com>
    danvet authored and airlied committed Aug 8, 2016
  13. drm: rcar-du: Link HDMI encoder with bridge

    The conversion of the rcar-du driver from the I2C slave encoder to the
    DRM bridge API left the HDMI encoder's bridge pointer NULL, preventing
    the bridge from being handled automatically by the DRM core. Fix it.
    
    Fixes: 1d92611 ("drm: rcar-du: Remove i2c slave encoder interface for hdmi encoder")
    Signed-off-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
    Signed-off-by: Dave Airlie <airlied@redhat.com>
    Laurent Pinchart authored and airlied committed Aug 8, 2016
  14. Linux 4.8-rc1

    torvalds committed Aug 8, 2016

Commits on Aug 7, 2016

  1. Merge branch 'for-linus' of git://git.kernel.dk/linux-block

    Pull more block fixes from Jens Axboe:
     "As mentioned in the pull the other day, a few more fixes for this
      round, all related to the bio op changes in this series.
    
      Two fixes, and then a cleanup, renaming bio->bi_rw to bio->bi_opf.  I
      wanted to do that change right after or right before -rc1, so that
      risk of conflict was reduced.  I just rebased the series on top of
      current master, and no new ->bi_rw usage has snuck in"
    
    * 'for-linus' of git://git.kernel.dk/linux-block:
      block: rename bio bi_rw to bi_opf
      target: iblock_execute_sync_cache() should use bio_set_op_attrs()
      mm: make __swap_writepage() use bio_set_op_attrs()
      block/mm: make bdev_ops->rw_page() take a bool for read/write
    torvalds committed Aug 7, 2016
  2. Merge tag 'drm-for-v4.8-zpos' of git://people.freedesktop.org/~airlie…

    …d/linux
    
    Pull drm zpos property support from Dave Airlie:
     "This tree was waiting on some media stuff I hadn't had time to get a
      stable branchpoint off, so I just waited until it was all in your tree
      first.
    
      It's been around a bit on the list and shouldn't affect anything
      outside adding the generic API and moving some ARM drivers to using
      it"
    
    * tag 'drm-for-v4.8-zpos' of git://people.freedesktop.org/~airlied/linux:
      drm: rcar: use generic code for managing zpos plane property
      drm/exynos: use generic code for managing zpos plane property
      drm: sti: use generic zpos for plane
      drm: add generic zpos property
    torvalds committed Aug 7, 2016
  3. block: rename bio bi_rw to bi_opf

    Since commit 63a4cc2, bio->bi_rw contains flags in the lower
    portion and the op code in the higher portions. This means that
    old code that relies on manually setting bi_rw is most likely
    going to be broken. Instead of letting that brokeness linger,
    rename the member, to force old and out-of-tree code to break
    at compile time instead of at runtime.
    
    No intended functional changes in this commit.
    
    Signed-off-by: Jens Axboe <axboe@fb.com>
    axboe committed Aug 7, 2016
  4. target: iblock_execute_sync_cache() should use bio_set_op_attrs()

    The original commit missed this function, it needs to mark it a
    write flush.
    
    Cc: Mike Christie <mchristi@redhat.com>
    Fixes: e742fc3 ("target: use bio op accessors")
    Signed-off-by: Jens Axboe <axboe@fb.com>
    axboe committed Aug 7, 2016
  5. mm: make __swap_writepage() use bio_set_op_attrs()

    Cleaner than manipulating bio->bi_rw flags directly.
    
    Signed-off-by: Jens Axboe <axboe@fb.com>
    axboe committed Aug 7, 2016
Older
You can’t perform that action at this time.