1. 07 5月, 2014 2 次提交
  2. 06 5月, 2014 4 次提交
  3. 05 5月, 2014 1 次提交
  4. 02 5月, 2014 5 次提交
  5. 01 5月, 2014 8 次提交
  6. 30 4月, 2014 6 次提交
  7. 29 4月, 2014 14 次提交
    • D
      drm/i915: Sanitize the enable_ppgtt module option once · cfa7c862
      Daniel Vetter 提交于
      Otherwise we'll end up spamming dmesg on every context creation on snb
      with vt-d enabled. This regression was introduced in
      
      commit 246cbfb5
      Author: Ben Widawsky <benjamin.widawsky@intel.com>
      Date:   Fri Dec 6 14:11:14 2013 -0800
      
          drm/i915: Reorganize intel_enable_ppgtt
      
      As the i915.enable_ppgtt is read-only it cannot be changed after the
      module is loaded and so we can perform an early sanitization of the
      values.
      
      v2:
      - Add comment and pimp commit message (Chris)
      - Use the param consistently (Jani)
      
      v3:
      - Fix init sequence on pre-gen6 by moving the sanitize_ppgtt call to
        gtt_init. Fixes boot hangs on pre-gen6.
      - Add a debug output for the sanitize ppgtt mode.
      
      References: https://lkml.org/lkml/2014/4/17/599
      Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=77916
      Cc: Alessandro Suardi <alessandro.suardi@gmail.com>
      Cc: Ben Widawsky <ben@bwidawsk.net>
      Cc: Chris Wilson <chris@chris-wilson.co.uk>
      Reviewed-by: NChris Wilson <chris@chris-wilson.co.uk>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      Signed-off-by: NJani Nikula <jani.nikula@intel.com>
      cfa7c862
    • M
      dm thin: use INIT_WORK_ONSTACK in noflush_work to avoid ODEBUG warning · fbcde3d8
      Mike Snitzer 提交于
      Use INIT_WORK_ONSTACK to silence "ODEBUG: object is on stack, but not
      annotated".
      Reported-by: NZdeněk Kabeláč <zkabelac@redhat.com>
      Signed-off-by: NMike Snitzer <snitzer@redhat.com>
      Acked-by: NJoe Thornber <ejt@redhat.com>
      fbcde3d8
    • G
      drivercore: deferral race condition fix · 58b116bc
      Grant Likely 提交于
      When the kernel is built with CONFIG_PREEMPT it is possible to reach a state
      when all modules loaded but some driver still stuck in the deferred list
      and there is a need for external event to kick the deferred queue to probe
      these drivers.
      
      The issue has been observed on embedded systems with CONFIG_PREEMPT enabled,
      audio support built as modules and using nfsroot for root filesystem.
      
      The following log fragment shows such sequence when all audio modules
      were loaded but the sound card is not present since the machine driver has
      failed to probe due to missing dependency during it's probe.
      The board is am335x-evmsk (McASP<->tlv320aic3106 codec) with davinci-evm
      machine driver:
      
      ...
      [   12.615118] davinci-mcasp 4803c000.mcasp: davinci_mcasp_probe: ENTER
      [   12.719969] davinci_evm sound.3: davinci_evm_probe: ENTER
      [   12.725753] davinci_evm sound.3: davinci_evm_probe: snd_soc_register_card
      [   12.753846] davinci-mcasp 4803c000.mcasp: davinci_mcasp_probe: snd_soc_register_component
      [   12.922051] davinci-mcasp 4803c000.mcasp: davinci_mcasp_probe: snd_soc_register_component DONE
      [   12.950839] davinci_evm sound.3: ASoC: platform (null) not registered
      [   12.957898] davinci_evm sound.3: davinci_evm_probe: snd_soc_register_card DONE (-517)
      [   13.099026] davinci-mcasp 4803c000.mcasp: Kicking the deferred list
      [   13.177838] davinci-mcasp 4803c000.mcasp: really_probe: probe_count = 2
      [   13.194130] davinci_evm sound.3: snd_soc_register_card failed (-517)
      [   13.346755] davinci_mcasp_driver_init: LEAVE
      [   13.377446] platform sound.3: Driver davinci_evm requests probe deferral
      [   13.592527] platform sound.3: really_probe: probe_count = 0
      
      In the log the machine driver enters it's probe at 12.719969 (this point it
      has been removed from the deferred lists). McASP driver already executing
      it's probing (since 12.615118).
      The machine driver tries to construct the sound card (12.950839) but did
      not found one of the components so it fails. After this McASP driver
      registers all the ASoC components (the machine driver still in it's probe
      function after it failed to construct the card) and the deferred work is
      prepared at 13.099026 (note that this time the machine driver is not in the
      lists so it is not going to be handled when the work is executing).
      Lastly the machine driver exit from it's probe and the core places it to
      the deferred list but there will be no other driver going to load and the
      deferred queue is not going to be kicked again - till we have external event
      like connecting USB stick, etc.
      
      The proposed solution is to try the deferred queue once more when the last
      driver is asking for deferring and we had drivers loaded while this last
      driver was probing.
      
      This way we can avoid drivers stuck in the deferred queue.
      Signed-off-by: NGrant Likely <grant.likely@linaro.org>
      Reviewed-by: NPeter Ujfalusi <peter.ujfalusi@ti.com>
      Tested-by: NPeter Ujfalusi <peter.ujfalusi@ti.com>
      Acked-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      Cc: Mark Brown <broonie@kernel.org>
      Cc: Stable <stable@vger.kernel.org> # v3.4+
      58b116bc
    • A
      clocksource: nspire: Fix compiler warning · 9afa27ce
      Alexander Shiyan 提交于
      CC      drivers/clocksource/zevio-timer.o
      drivers/clocksource/zevio-timer.c:215:1: warning: comparison of distinct pointer types lacks a cast [enabled by default]
      Signed-off-by: NAlexander Shiyan <shc_work@mail.ru>
      Signed-off-by: NDaniel Lezcano <daniel.lezcano@linaro.org>
      9afa27ce
    • L
      clocksource: arch_arm_timer: Fix age-old arch timer C3STOP detection issue · 82a56194
      Lorenzo Pieralisi 提交于
      ARM arch timers are tightly coupled with the CPU logic and lose context
      on platform implementing HW power management when cores are powered
      down at run-time. Marking the arch timers as C3STOP regardless of power
      management capabilities causes issues on platforms with no power management,
      since in that case the arch timers cannot possibly enter states where the
      timer loses context at runtime and therefore can always be used as a high
      resolution clockevent device.
      
      In order to fix the C3STOP issue in a way compliant with how real HW
      works, this patch adds a boolean property to the arch timer bindings
      to define if the arch timer is managed by an always-on power domain.
      
      This power domain is present on all ARM platforms to date, and manages
      HW that must not be turned off, whatever the state of other HW
      components (eg power controller). On platforms with no power management
      capabilities, it is the only power domain present, which encompasses
      and manages power supply for all HW components in the system.
      
      If the timer is powered by the always-on power domain, the always-on
      property must be present in the bindings which means that the timer cannot
      be shutdown at runtime, so it is not a C3STOP clockevent device.
      If the timer binding does not contain the always-on property, the timer is
      assumed to be power-gateable, hence it must be defined as a C3STOP
      clockevent device.
      
      Cc: Daniel Lezcano <daniel.lezcano@linaro.org>
      Cc: Magnus Damm <damm@opensource.se>
      Cc: Marc Carino <marc.ceeeee@gmail.com>
      Cc: Mark Rutland <mark.rutland@arm.com>
      Acked-by: NMarc Zyngier <marc.zyngier@arm.com>
      Acked-by: NRob Herring <robh@kernel.org>
      Signed-off-by: NLorenzo Pieralisi <lorenzo.pieralisi@arm.com>
      Signed-off-by: NDaniel Lezcano <daniel.lezcano@linaro.org>
      82a56194
    • H
    • S
      RDMA/cxgb4: Only allow kernel db ringing for T4 devs · c2f9da92
      Steve Wise 提交于
      The whole db drop avoidance stuff is for T4 only.  So we cannot allow
      that to be enabled for T5 devices.
      Signed-off-by: NSteve Wise <swise@opengridcomputing.com>
      Signed-off-by: NRoland Dreier <roland@purestorage.com>
      c2f9da92
    • S
      RDMA/cxgb4: Force T5 connections to use TAHOE congestion control · 92e5011a
      Steve Wise 提交于
      This is required to work around a T5 HW issue.
      Signed-off-by: NSteve Wise <swise@opengridcomputing.com>
      Signed-off-by: NRoland Dreier <roland@purestorage.com>
      92e5011a
    • S
      RDMA/cxgb4: Fix endpoint mutex deadlocks · cc18b939
      Steve Wise 提交于
      In cases where the cm calls c4iw_modify_rc_qp() with the endpoint
      mutex held, they must be called with internal == 1.  rx_data() and
      process_mpa_reply() are not doing this.  This causes a deadlock
      because c4iw_modify_rc_qp() might call c4iw_ep_disconnect() in some
      !internal cases, and c4iw_ep_disconnect() acquires the endpoint mutex.
      The design was intended to only do the disconnect for !internal calls.
      
      Change rx_data(), FPDU_MODE case, to call c4iw_modify_rc_qp() with
      internal == 1, and then disconnect only after releasing the mutex.
      
      Change process_mpa_reply() to call c4iw_modify_rc_qp(TERMINATE) with
      internal == 1 and set a new attr flag telling it to send a TERMINATE
      message.  Previously this was implied by !internal.
      
      Change process_mpa_reply() to return whether the caller should
      disconnect after releasing the endpoint mutex.  Now rx_data() will do
      the disconnect in the cases where process_mpa_reply() wants to
      disconnect after the TERMINATE is sent.
      
      Change c4iw_modify_rc_qp() RTS->TERM to only disconnect if !internal,
      and to send a TERMINATE message if attrs->send_term is 1.
      
      Change abort_connection() to not aquire the ep mutex for setting the
      state, and make all calls to abort_connection() do so with the mutex
      held.
      Signed-off-by: NSteve Wise <swise@opengridcomputing.com>
      Signed-off-by: NRoland Dreier <roland@purestorage.com>
      cc18b939
    • T
      cpufreq: ppc-corenet-cpufreq: Fix __udivdi3 modpost error · 6712d293
      Tim Gardner 提交于
      bfa709bc (cpufreq: powerpc: add cpufreq
      transition latency for FSL e500mc SoCs) introduced a modpost error:
      
      ERROR: "__udivdi3" [drivers/cpufreq/ppc-corenet-cpufreq.ko] undefined!
      make[1]: *** [__modpost] Error 1
      
      Fix this by avoiding 64 bit integer division.
      
      gcc version 4.8.2
      
      Fixes: bfa709bc (cpufreq: powerpc: add cpufreq transition latency for FSL e500mc SoCs)
      Signed-off-by: NTim Gardner <tim.gardner@canonical.com>
      Signed-off-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
      6712d293
    • S
      cpufreq: powernow-k7: Fix double invocation of cpufreq_freq_transition_begin/end · 8997b185
      Srivatsa S. Bhat 提交于
      During frequency transitions, the cpufreq core takes the responsibility of
      invoking cpufreq_freq_transition_begin() and cpufreq_freq_transition_end()
      for those cpufreq drivers that define the ->target_index callback but don't
      set the ASYNC_NOTIFICATION flag.
      
      The powernow-k7 cpufreq driver falls under this category, but this driver was
      invoking the _begin() and _end() APIs itself around frequency transitions,
      which led to double invocation of the _begin() API. The _begin API makes
      contending callers wait until the previous invocation is complete. Hence,
      the powernow-k7 driver ended up waiting on itself, leading to system hangs
      during boot.
      
      Fix this by removing the calls to the _begin() and _end() APIs from the
      powernow-k7 driver, since they rightly belong to the cpufreq core.
      
      Fixes: 12478cf0 (cpufreq: Make sure frequency transitions are serialized)
      Signed-off-by: NSrivatsa S. Bhat <srivatsa.bhat@linux.vnet.ibm.com>
      Acked-by: NViresh Kumar <viresh.kumar@linaro.org>
      Signed-off-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
      8997b185
    • S
      cpufreq: powernow-k6: Fix double invocation of cpufreq_freq_transition_begin/end · 3221e55b
      Srivatsa S. Bhat 提交于
      During frequency transitions, the cpufreq core takes the responsibility of
      invoking cpufreq_freq_transition_begin() and cpufreq_freq_transition_end()
      for those cpufreq drivers that define the ->target_index callback but don't
      set the ASYNC_NOTIFICATION flag.
      
      The powernow-k6 cpufreq driver falls under this category, but this driver was
      invoking the _begin() and _end() APIs itself around frequency transitions,
      which led to double invocation of the _begin() API. The _begin API makes
      contending callers wait until the previous invocation is complete. Hence,
      the powernow-k6 driver ended up waiting on itself, leading to system hangs
      during boot.
      
      Fix this by removing the calls to the _begin() and _end() APIs from the
      powernow-k6 driver, since they rightly belong to the cpufreq core.
      
      (Note that during ->exit(), the powernow-k6 driver sets the frequency
       without any help from the cpufreq core. So add explicit calls to the
       _begin() and _end() APIs around that frequency transition alone, to take
       care of that special case. Also, add a missing 'break' statement there.)
      
      Fixes: 12478cf0 (cpufreq: Make sure frequency transitions are serialized)
      Signed-off-by: NSrivatsa S. Bhat <srivatsa.bhat@linux.vnet.ibm.com>
      Acked-by: NViresh Kumar <viresh.kumar@linaro.org>
      Signed-off-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
      3221e55b
    • S
      cpufreq: powernow-k6: Fix incorrect comparison with max_multipler · 237ede16
      Srivatsa S. Bhat 提交于
      The value of 'max_multiplier' is meant to be used for comparison with
      clock_ratio[index].driver_data, not the index itself! Fix the code in
      powernow_k6_cpu_exit() that has this bug.
      
      Also, while at it, make the for-loop condition look for CPUFREQ_TABLE_END,
      instead of hard-coding the loop count to 8.
      Reported-by: NViresh Kumar <viresh.kumar@linaro.org>
      Signed-off-by: NSrivatsa S. Bhat <srivatsa.bhat@linux.vnet.ibm.com>
      Acked-by: NViresh Kumar <viresh.kumar@linaro.org>
      Signed-off-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
      237ede16
    • S
      cpufreq: longhaul: Fix double invocation of cpufreq_freq_transition_begin/end · 7aa0557f
      Srivatsa S. Bhat 提交于
      During frequency transitions, the cpufreq core takes the responsibility of
      invoking cpufreq_freq_transition_begin() and cpufreq_freq_transition_end()
      for those cpufreq drivers that define the ->target_index callback but don't
      set the ASYNC_NOTIFICATION flag.
      
      The longhaul cpufreq driver falls under this category, but this driver was
      invoking the _begin() and _end() APIs itself around frequency transitions,
      which led to double invocation of the _begin() API. The _begin API makes
      contending callers wait until the previous invocation is complete. Hence,
      the longhaul driver ended up waiting on itself, leading to system hangs
      during boot.
      
      Fix this by removing the calls to the _begin() and _end() APIs from the
      longhaul driver, since they rightly belong to the cpufreq core.
      
      (Note that during module_exit(), the longhaul driver sets the frequency
       without any help from the cpufreq core. So add explicit calls to the
       _begin() and _end() APIs around that frequency transition alone, to take
       care of that special case.)
      
      Fixes: 12478cf0 (cpufreq: Make sure frequency transitions are serialized)
      Reported-and-tested-by: NMeelis Roos <mroos@linux.ee>
      Signed-off-by: NSrivatsa S. Bhat <srivatsa.bhat@linux.vnet.ibm.com>
      Signed-off-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
      7aa0557f