1. 27 6月, 2018 7 次提交
    • T
      wlcore: Make sure firmware is initialized in wl1271_op_add_interface() · c40aad28
      Tony Lindgren 提交于
      We have wl12xx_boot() call wl12xx_enable_interrupts() and if we have
      wl1271_op_add_interface() call pm_runtime_get_sync() before the interrupts
      are enabled. And then we get the following error during boot:
      
      wlcore: ERROR ELP wakeup timeout!
      
      Let's fix this by first checking if we need to boot the firmware. And
      only after that call pm_runtime_get_sync() when interrupts are enabled.
      And only after that do the check for wl12xx_need_fw_change().
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NKalle Valo <kvalo@codeaurora.org>
      c40aad28
    • E
      wlcore: Use generic runtime pm calls for wowlan elp configuration · 45aa7f07
      Eyal Reizer 提交于
      With runtime PM enabled, we can now use calls to pm_runtime_force_suspend
      and pm_runtime_force_resume for enabling elp during suspend when wowlan
      is enabled and waking the chip from elp on resume.
      
      Remove the custom API that was used to ensure that the command
      that is used to allow ELP during suspend is completed before the system
      suspend.
      Signed-off-by: NEyal Reizer <eyalr@ti.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NKalle Valo <kvalo@codeaurora.org>
      45aa7f07
    • T
      wlcore: Fix timout errors after recovery · db68052b
      Tony Lindgren 提交于
      After enabling runtime PM, if we force hardware reset multiple times with:
      
      # echo 1 > /sys/kernel/debug/ieee80211/phy0/wlcore/start_recovery
      
      We will after few tries get the following error:
      
      wlcore: ERROR timeout waiting for the hardware to complete initialization
      
      And then wlcore is unable to reconnect until after the wlcore related modules
      are reloaded.
      
      Let's fix this by moving pm_runtime_put() earlier before we restart the hardware.
      And let's use the sync version to make sure we're done before we restart.
      
      Note that we still will get -EBUSY warning from wl12xx_sdio_set_power() but let's
      fix that separately once we know exactly why we get the warning.
      Reported-by: NEyal Reizer <eyalr@ti.com>
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NKalle Valo <kvalo@codeaurora.org>
      db68052b
    • T
      wlcore: Fix misplaced PM call for scan_complete_work() · 3ebbabea
      Tony Lindgren 提交于
      With runtime PM enabled, we now need to have wlcore enabled longer
      until after we're done calling wlcore_cmd_regdomain_config_locked():
      
      scan_complete_work()
       wlcore_cmd_regdomain_config_locked()
         wlcore_cmd_send_failsafe()
           wl12xx_sdio_raw_read()
      
      Note that this is not needed before runtime PM support as the
      custom PM code had it's own timer. We have not yet enabled runtime
      PM autosuspend for wlcore and this is why this issue now shows up.
      
      Let's fix the issues first before we enable runtime PM autosuspend.
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NKalle Valo <kvalo@codeaurora.org>
      3ebbabea
    • T
      wlcore: Add support for runtime PM · fa2648a3
      Tony Lindgren 提交于
      We can update wlcore to use PM runtime by adding functions for
      wlcore_runtime_suspend() and wlcore_runtime_resume() and replacing
      calls to wl1271_ps_elp_wakeup() and wl1271_ps_elp_sleep() with calls
      to pm_runtime_get_sync() and pm_runtime_put().
      
      Note that the new wlcore_runtime_suspend() and wlcore_runtime_resume()
      functions are based on simplified versions of wl1271_ps_elp_sleep() and
      wl1271_ps_elp_wakeup().
      
      We don't want to use the old functions as we can now take advantage of
      the runtime PM usage count. And we don't need the old elp_work at all.
      And we can also remove WL1271_FLAG_ELP_REQUESTED that is no longer needed.
      
      Pretty much the only place where we are not just converting the existing
      functions is wl1271_op_suspend() where we add pm_runtime_put_noidle()
      to keep the calls paired.
      
      As the next step is to implement runtime PM autosuspend, let's not add
      wrapper functions for the generic runtime PM calls. We would be getting
      rid of any wrapper functions anyways.
      
      After autoidle we should be able to start using Linux generic wakeirqs
      for the padconf interrupt.
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NKalle Valo <kvalo@codeaurora.org>
      fa2648a3
    • T
      wlcore: Make sure PM calls are paired · 02edf813
      Tony Lindgren 提交于
      The call to wl1271_ps_elp_wakeup() in wl12xx_queue_recovery_work() is
      unpaired. Let's remove it and add paired calls to wl1271_recovery_work()
      instead in preparation for changing things to use runtime PM.
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NKalle Valo <kvalo@codeaurora.org>
      02edf813
    • T
      wlcore: Add missing PM call for wlcore_cmd_wait_for_event_or_timeout() · 4ec7cece
      Tony Lindgren 提交于
      Otherwise we can get:
      
      WARNING: CPU: 0 PID: 55 at drivers/net/wireless/ti/wlcore/io.h:84
      
      I've only seen this few times with the runtime PM patches enabled
      so this one is probably not needed before that. This seems to
      work currently based on the current PM implementation timer. Let's
      apply this separately though in case others are hitting this issue.
      Signed-off-by: NTony Lindgren <tony@atomide.com>
      Signed-off-by: NKalle Valo <kvalo@codeaurora.org>
      4ec7cece
  2. 18 6月, 2018 1 次提交
  3. 17 6月, 2018 5 次提交
    • L
      Linux 4.18-rc1 · ce397d21
      Linus Torvalds 提交于
      ce397d21
    • L
      Merge tag 'for-linus-20180616' of git://git.kernel.dk/linux-block · 265c5596
      Linus Torvalds 提交于
      Pull block fixes from Jens Axboe:
       "A collection of fixes that should go into -rc1. This contains:
      
         - bsg_open vs bsg_unregister race fix (Anatoliy)
      
         - NVMe pull request from Christoph, with fixes for regressions in
           this window, FC connect/reconnect path code unification, and a
           trace point addition.
      
         - timeout fix (Christoph)
      
         - remove a few unused functions (Christoph)
      
         - blk-mq tag_set reinit fix (Roman)"
      
      * tag 'for-linus-20180616' of git://git.kernel.dk/linux-block:
        bsg: fix race of bsg_open and bsg_unregister
        block: remov blk_queue_invalidate_tags
        nvme-fabrics: fix and refine state checks in __nvmf_check_ready
        nvme-fabrics: handle the admin-only case properly in nvmf_check_ready
        nvme-fabrics: refactor queue ready check
        blk-mq: remove blk_mq_tagset_iter
        nvme: remove nvme_reinit_tagset
        nvme-fc: fix nulling of queue data on reconnect
        nvme-fc: remove reinit_request routine
        blk-mq: don't time out requests again that are in the timeout handler
        nvme-fc: change controllers first connect to use reconnect path
        nvme: don't rely on the changed namespace list log
        nvmet: free smart-log buffer after use
        nvme-rdma: fix error flow during mapping request data
        nvme: add bio remapping tracepoint
        nvme: fix NULL pointer dereference in nvme_init_subsystem
        blk-mq: reinit q->tag_set_list entry only after grace period
      265c5596
    • L
      Merge tag 'docs-broken-links' of git://linuxtv.org/mchehab/experimental · 5e7b9212
      Linus Torvalds 提交于
      Pull documentation fixes from Mauro Carvalho Chehab:
       "This solves a series of broken links for files under Documentation,
        and improves a script meant to detect such broken links (see
        scripts/documentation-file-ref-check).
      
        The changes on this series are:
      
         - can.rst: fix a footnote reference;
      
         - crypto_engine.rst: Fix two parsing warnings;
      
         - Fix a lot of broken references to Documentation/*;
      
         - improve the scripts/documentation-file-ref-check script, in order
           to help detecting/fixing broken references, preventing
           false-positives.
      
        After this patch series, only 33 broken references to doc files are
        detected by scripts/documentation-file-ref-check"
      
      * tag 'docs-broken-links' of git://linuxtv.org/mchehab/experimental: (26 commits)
        fix a series of Documentation/ broken file name references
        Documentation: rstFlatTable.py: fix a broken reference
        ABI: sysfs-devices-system-cpu: remove a broken reference
        devicetree: fix a series of wrong file references
        devicetree: fix name of pinctrl-bindings.txt
        devicetree: fix some bindings file names
        MAINTAINERS: fix location of DT npcm files
        MAINTAINERS: fix location of some display DT bindings
        kernel-parameters.txt: fix pointers to sound parameters
        bindings: nvmem/zii: Fix location of nvmem.txt
        docs: Fix more broken references
        scripts/documentation-file-ref-check: check tools/*/Documentation
        scripts/documentation-file-ref-check: get rid of false-positives
        scripts/documentation-file-ref-check: hint: dash or underline
        scripts/documentation-file-ref-check: add a fix logic for DT
        scripts/documentation-file-ref-check: accept more wildcards at filenames
        scripts/documentation-file-ref-check: fix help message
        media: max2175: fix location of driver's companion documentation
        media: v4l: fix broken video4linux docs locations
        media: dvb: point to the location of the old README.dvb-usb file
        ...
      5e7b9212
    • L
      Merge tag 'fsnotify_for_v4.18-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/jack/linux-fs · dbb2816f
      Linus Torvalds 提交于
      Pull fsnotify updates from Jan Kara:
       "fsnotify cleanups unifying handling of different watch types.
      
        This is the shortened fsnotify series from Amir with the last five
        patches pulled out. Amir has modified those patches to not change
        struct inode but obviously it's too late for those to go into this
        merge window"
      
      * tag 'fsnotify_for_v4.18-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/jack/linux-fs:
        fsnotify: add fsnotify_add_inode_mark() wrappers
        fanotify: generalize fanotify_should_send_event()
        fsnotify: generalize send_to_group()
        fsnotify: generalize iteration of marks by object type
        fsnotify: introduce marks iteration helpers
        fsnotify: remove redundant arguments to handle_event()
        fsnotify: use type id to identify connector object type
      dbb2816f
    • L
      Merge tag 'fbdev-v4.18' of git://github.com/bzolnier/linux · 644f2639
      Linus Torvalds 提交于
      Pull fbdev updates from Bartlomiej Zolnierkiewicz:
       "There is nothing really major here, few small fixes, some cleanups and
        dead drivers removal:
      
         - mark omapfb drivers as orphans in MAINTAINERS file (Tomi Valkeinen)
      
         - add missing module license tags to omap/omapfb driver (Arnd
           Bergmann)
      
         - add missing GPIOLIB dependendy to omap2/omapfb driver (Arnd
           Bergmann)
      
         - convert savagefb, aty128fb & radeonfb drivers to use msleep & co.
           (Jia-Ju Bai)
      
         - allow COMPILE_TEST build for viafb driver (media part was reviewed
           by media subsystem Maintainer)
      
         - remove unused MERAM support from sh_mobile_lcdcfb and shmob-drm
           drivers (drm parts were acked by shmob-drm driver Maintainer)
      
         - remove unused auo_k190xfb drivers
      
         - misc cleanups (Souptick Joarder, Wolfram Sang, Markus Elfring, Andy
           Shevchenko, Colin Ian King)"
      
      * tag 'fbdev-v4.18' of git://github.com/bzolnier/linux: (26 commits)
        fb_omap2: add gpiolib dependency
        video/omap: add module license tags
        MAINTAINERS: make omapfb orphan
        video: fbdev: pxafb: match_string() conversion fixup
        video: fbdev: nvidia: fix spelling mistake: "scaleing" -> "scaling"
        video: fbdev: fix spelling mistake: "frambuffer" -> "framebuffer"
        video: fbdev: pxafb: Convert to use match_string() helper
        video: fbdev: via: allow COMPILE_TEST build
        video: fbdev: remove unused sh_mobile_meram driver
        drm: shmobile: remove unused MERAM support
        video: fbdev: sh_mobile_lcdcfb: remove unused MERAM support
        video: fbdev: remove unused auo_k190xfb drivers
        video: omap: Improve a size determination in omapfb_do_probe()
        video: sm501fb: Improve a size determination in sm501fb_probe()
        video: fbdev-MMP: Improve a size determination in path_init()
        video: fbdev-MMP: Delete an error message for a failed memory allocation in two functions
        video: auo_k190x: Delete an error message for a failed memory allocation in auok190x_common_probe()
        video: sh_mobile_lcdcfb: Delete an error message for a failed memory allocation in two functions
        video: sh_mobile_meram: Delete an error message for a failed memory allocation in sh_mobile_meram_probe()
        video: fbdev: sh_mobile_meram: Drop SUPERH platform dependency
        ...
      644f2639
  4. 16 6月, 2018 27 次提交