1. 20 3月, 2018 1 次提交
  2. 01 3月, 2018 20 次提交
    • S
      cpufreq: scmi: add support for fast frequency switching · 02f208c5
      Sudeep Holla 提交于
      The cpufreq core provides option for drivers to implement fast_switch
      callback which is invoked for frequency switching from interrupt context.
      
      This patch adds support for fast_switch callback in SCMI cpufreq driver
      by making use of polling based SCMI transfer. It also sets the flag
      fast_switch_possible.
      
      Cc: linux-pm@vger.kernel.org
      Acked-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
      Acked-by: NViresh Kumar <viresh.kumar@linaro.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      02f208c5
    • S
      cpufreq: add support for CPU DVFS based on SCMI message protocol · 99d6bdf3
      Sudeep Holla 提交于
      On some ARM based systems, a separate Cortex-M based System Control
      Processor(SCP) provides the overall power, clock, reset and system
      control including CPU DVFS. SCMI Message Protocol is used to
      communicate with the SCP.
      
      This patch adds a cpufreq driver for such systems using SCMI interface
      to drive CPU DVFS.
      
      Cc: linux-pm@vger.kernel.org
      Acked-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
      Acked-by: NViresh Kumar <viresh.kumar@linaro.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      99d6bdf3
    • S
      hwmon: add support for sensors exported via ARM SCMI · b23688ae
      Sudeep Holla 提交于
      Create a driver to add support for SoC sensors exported by the System
      Control Processor (SCP) via the System Control and Management Interface
      (SCMI). The supported sensor types is one of voltage, temperature,
      current, and power.
      
      The sensor labels and values provided by the SCP are exported via the
      hwmon sysfs interface.
      
      Cc: linux-hwmon@vger.kernel.org
      Acked-by: NGuenter Roeck <linux@roeck-us.net>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      b23688ae
    • S
      hwmon: (core) Add hwmon_max to hwmon_sensor_types enumeration · d5753800
      Sudeep Holla 提交于
      It's useful to know the maximum types of sensor supported by hwmon
      framework. It can be used to allocate some data structures when sorting
      the monitors based on their type.
      
      This will be used by scmi hwmon support.
      
      Cc: linux-hwmon@vger.kernel.org
      Acked-by: NGuenter Roeck <linux@roeck-us.net>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      d5753800
    • S
      clk: add support for clocks provided by SCMI · 6d6a1d82
      Sudeep Holla 提交于
      On some ARM based systems, a separate Cortex-M based System Control
      Processor(SCP) provides the overall power, clock, reset and system
      control. System Control and Management Interface(SCMI) Message Protocol
      is defined for the communication between the Application Cores(AP)
      and the SCP.
      
      This patch adds support for the clocks provided by SCP using SCMI
      protocol.
      
      Cc: linux-clk@vger.kernel.org
      Cc: Michael Turquette <mturquette@baylibre.com>
      Acked-by: NStephen Boyd <sboyd@codeaurora.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      6d6a1d82
    • S
      firmware: arm_scmi: add device power domain support using genpd · 898216c9
      Sudeep Holla 提交于
      This patch hooks up the support for device power domain provided by
      SCMI using the Linux generic power domain infrastructure.
      
      Cc: Kevin Hilman <khilman@baylibre.com>
      Reviewed-by: NUlf Hansson <ulf.hansson@linaro.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      898216c9
    • S
      firmware: arm_scmi: add per-protocol channels support using idr objects · 907b6d14
      Sudeep Holla 提交于
      In order to maintain the channel information per protocol, we need
      some sort of list or hashtable to hold all this information. IDR
      provides sparse array mapping of small integer ID numbers onto arbitrary
      pointers. In this case the arbitrary pointers can be pointers to the
      channel information.
      
      This patch adds support for per-protocol channels using those idr
      objects.
      
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      907b6d14
    • S
      firmware: arm_scmi: refactor in preparation to support per-protocol channels · fbc4d81a
      Sudeep Holla 提交于
      In order to support per-protocol channels if available, we need to
      factor out all the mailbox channel information(Tx/Rx payload and
      channel handle) out of the main SCMI instance information structure.
      
      This patch refactors the existing channel information into a separate
      chan_info structure.
      
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      fbc4d81a
    • S
      firmware: arm_scmi: add option for polling based performance domain operations · 5c4ba3cc
      Sudeep Holla 提交于
      In order to implement fast CPU DVFS switching, we need to perform all
      DVFS operations atomically. Since SCMI transfer already provide option
      to choose between pooling vs interrupt driven(default), we can opt for
      polling based transfers for set,get performance domain operations.
      
      This patch adds option to choose between polling vs interrupt driven
      SCMI transfers for set,get performance level operations.
      
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      5c4ba3cc
    • S
      firmware: arm_scmi: add support for polling based SCMI transfers · d4c3751a
      Sudeep Holla 提交于
      It would be useful to have options to perform some SCMI transfers
      atomically by polling for the completion flag instead of interrupt
      driven. The SCMI specification has option to disable the interrupt and
      poll for the completion flag in the shared memory.
      
      This patch adds support for polling based SCMI transfers using that
      option. This might be used for uninterrupted/atomic DVFS operations
      from the scheduler context.
      
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      d4c3751a
    • S
      firmware: arm_scmi: probe and initialise all the supported protocols · bc40081d
      Sudeep Holla 提交于
      Now that we have basic support for all the protocols in the
      specification, let's probe them individually and initialise them.
      
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      bc40081d
    • S
      firmware: arm_scmi: add initial support for sensor protocol · 5179c523
      Sudeep Holla 提交于
      The sensor protocol provides functions to manage platform sensors, and
      provides the commands to describe the protocol version and the various
      attribute flags. It also provides commands to discover various sensors
      implemented and managed by the platform, read any sensor synchronously
      or asynchronously as allowed by the platform, program sensor attributes
      and/or configurations, if applicable.
      
      This patch adds support for most of the above features.
      
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      5179c523
    • S
      firmware: arm_scmi: add initial support for power protocol · 76a65509
      Sudeep Holla 提交于
      The power protocol is intended for management of power states of various
      power domains. The power domain management protocol provides commands to
      describe the protocol version, discover the implementation specific
      attributes, set and get the power state of a domain.
      
      This patch adds support for the above mention features of the protocol.
      
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      --
       drivers/firmware/arm_scmi/Makefile |   2 +-
       drivers/firmware/arm_scmi/power.c  | 242 +++++++++++++++++++++++++++++++++++++
       include/linux/scmi_protocol.h      |  28 +++++
       3 files changed, 271 insertions(+), 1 deletion(-)
       create mode 100644 drivers/firmware/arm_scmi/power.c
      76a65509
    • S
      firmware: arm_scmi: add initial support for clock protocol · 5f6c6430
      Sudeep Holla 提交于
      The clock protocol is intended for management of clocks. It is used to
      enable or disable clocks, and to set and get the clock rates. This
      protocol provides commands to describe the protocol version, discover
      various implementation specific attributes, describe a clock, enable
      and disable a clock and get/set the rate of the clock synchronously or
      asynchronously.
      
      This patch adds initial support for the clock protocol.
      
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      5f6c6430
    • S
      firmware: arm_scmi: add initial support for performance protocol · a9e3fbfa
      Sudeep Holla 提交于
      The performance protocol is intended for the performance management of
      group(s) of device(s) that run in the same performance domain. It
      includes even the CPUs. A performance domain is defined by a set of
      devices that always have to run at the same performance level.
      For example, a set of CPUs that share a voltage domain, and have a
      common frequency control, is said to be in the same performance domain.
      
      The commands in this protocol provide functionality to describe the
      protocol version, describe various attribute flags, set and get the
      performance level of a domain. It also supports discovery of the list
      of performance levels supported by a performance domain, and the
      properties of each performance level.
      
      This patch adds basic support for the performance protocol.
      
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      a9e3fbfa
    • S
      firmware: arm_scmi: add scmi protocol bus to enumerate protocol devices · 933c5044
      Sudeep Holla 提交于
      The SCMI specification encompasses various protocols. However, not every
      protocol has to be present on a given platform/implementation as not
      every protocol is relevant for it.
      
      Furthermore, the platform chooses which protocols it exposes to a given
      agent. The only protocol that must be implemented is the base protocol.
      The base protocol is used by an agent to discover which protocols are
      available to it.
      
      In order to enumerate the discovered implemented protocols, this patch
      adds support for a separate scmi protocol bus. It also adds mechanism to
      register support for different protocols.
      
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      933c5044
    • S
      firmware: arm_scmi: add common infrastructure and support for base protocol · b6f20ff8
      Sudeep Holla 提交于
      The base protocol describes the properties of the implementation and
      provide generic error management. The base protocol provides commands
      to describe protocol version, discover implementation specific
      attributes and vendor/sub-vendor identification, list of protocols
      implemented and the various agents are in the system including OSPM
      and the platform. It also supports registering for notifications of
      platform errors.
      
      This protocol is mandatory. This patch adds support for the same along
      with some basic infrastructure to add support for other protocols.
      
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      b6f20ff8
    • S
      firmware: arm_scmi: add basic driver infrastructure for SCMI · aa4f886f
      Sudeep Holla 提交于
      The SCMI is intended to allow OSPM to manage various functions that are
      provided by the hardware platform it is running on, including power and
      performance functions. SCMI provides two levels of abstraction, protocols
      and transports. Protocols define individual groups of system control and
      management messages. A protocol specification describes the messages
      that it supports. Transports describe the method by which protocol
      messages are communicated between agents and the platform.
      
      This patch adds basic infrastructure to manage the message allocation,
      initialisation, packing/unpacking and shared memory management.
      
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      aa4f886f
    • S
      dt-bindings: arm: add support for ARM System Control and Management Interface(SCMI) protocol · fe7be8b2
      Sudeep Holla 提交于
      This patch adds devicetree binding for System Control and Management
      Interface (SCMI) Message Protocol used between the Application Cores(AP)
      and the System Control Processor(SCP). The MHU peripheral provides a
      mechanism for inter-processor communication between SCP's M3 processor
      and AP.
      
      SCP offers control and management of the core/cluster power states,
      various power domain DVFS including the core/cluster, certain system
      clocks configuration, thermal sensors and many others.
      
      SCMI protocol is developed as better replacement to the existing SCPI
      which is not flexible and easily extensible.
      
      Cc: Mark Rutland <mark.rutland@arm.com>
      Acked-by: NRob Herring <robh@kernel.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      fe7be8b2
    • S
      dt-bindings: mailbox: add support for mailbox client shared memory · 07455e4e
      Sudeep Holla 提交于
      Many users of the mailbox controllers depend on the shared memory
      between the two end points to exchange the main data while using simple
      doorbell mechanism to alert the end points of the presence of a message.
      
      This patch defines device tree bindings to represent such shared memory
      in a generic way.
      
      Cc: Mark Rutland <mark.rutland@arm.com>
      Acked-by: NRob Herring <robh@kernel.org>
      Signed-off-by: NSudeep Holla <sudeep.holla@arm.com>
      07455e4e
  3. 12 2月, 2018 7 次提交
    • L
      Linux 4.16-rc1 · 7928b2cb
      Linus Torvalds 提交于
      7928b2cb
    • A
      unify {de,}mangle_poll(), get rid of kernel-side POLL... · 7a163b21
      Al Viro 提交于
      except, again, POLLFREE and POLL_BUSY_LOOP.
      
      With this, we finally get to the promised end result:
      
       - POLL{IN,OUT,...} are plain integers and *not* in __poll_t, so any
         stray instances of ->poll() still using those will be caught by
         sparse.
      
       - eventpoll.c and select.c warning-free wrt __poll_t
      
       - no more kernel-side definitions of POLL... - userland ones are
         visible through the entire kernel (and used pretty much only for
         mangle/demangle)
      
       - same behavior as after the first series (i.e. sparc et.al. epoll(2)
         working correctly).
      Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      7a163b21
    • L
      vfs: do bulk POLL* -> EPOLL* replacement · a9a08845
      Linus Torvalds 提交于
      This is the mindless scripted replacement of kernel use of POLL*
      variables as described by Al, done by this script:
      
          for V in IN OUT PRI ERR RDNORM RDBAND WRNORM WRBAND HUP RDHUP NVAL MSG; do
              L=`git grep -l -w POLL$V | grep -v '^t' | grep -v /um/ | grep -v '^sa' | grep -v '/poll.h$'|grep -v '^D'`
              for f in $L; do sed -i "-es/^\([^\"]*\)\(\<POLL$V\>\)/\\1E\\2/" $f; done
          done
      
      with de-mangling cleanups yet to come.
      
      NOTE! On almost all architectures, the EPOLL* constants have the same
      values as the POLL* constants do.  But they keyword here is "almost".
      For various bad reasons they aren't the same, and epoll() doesn't
      actually work quite correctly in some cases due to this on Sparc et al.
      
      The next patch from Al will sort out the final differences, and we
      should be all done.
      Scripted-by: NAl Viro <viro@zeniv.linux.org.uk>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      a9a08845
    • L
      Merge branch 'work.poll2' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs · ee5daa13
      Linus Torvalds 提交于
      Pull more poll annotation updates from Al Viro:
       "This is preparation to solving the problems you've mentioned in the
        original poll series.
      
        After this series, the kernel is ready for running
      
            for V in IN OUT PRI ERR RDNORM RDBAND WRNORM WRBAND HUP RDHUP NVAL MSG; do
                  L=`git grep -l -w POLL$V | grep -v '^t' | grep -v /um/ | grep -v '^sa' | grep -v '/poll.h$'|grep -v '^D'`
                  for f in $L; do sed -i "-es/^\([^\"]*\)\(\<POLL$V\>\)/\\1E\\2/" $f; done
            done
      
        as a for bulk search-and-replace.
      
        After that, the kernel is ready to apply the patch to unify
        {de,}mangle_poll(), and then get rid of kernel-side POLL... uses
        entirely, and we should be all done with that stuff.
      
        Basically, that's what you suggested wrt KPOLL..., except that we can
        use EPOLL... instead - they already are arch-independent (and equal to
        what is currently kernel-side POLL...).
      
        After the preparations (in this series) switch to returning EPOLL...
        from ->poll() instances is completely mechanical and kernel-side
        POLL... can go away. The last step (killing kernel-side POLL... and
        unifying {de,}mangle_poll() has to be done after the
        search-and-replace job, since we need userland-side POLL... for
        unified {de,}mangle_poll(), thus the cherry-pick at the last step.
      
        After that we will have:
      
         - POLL{IN,OUT,...} *not* in __poll_t, so any stray instances of
           ->poll() still using those will be caught by sparse.
      
         - eventpoll.c and select.c warning-free wrt __poll_t
      
         - no more kernel-side definitions of POLL... - userland ones are
           visible through the entire kernel (and used pretty much only for
           mangle/demangle)
      
         - same behavior as after the first series (i.e. sparc et.al. epoll(2)
           working correctly)"
      
      * 'work.poll2' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs:
        annotate ep_scan_ready_list()
        ep_send_events_proc(): return result via esed->res
        preparation to switching ->poll() to returning EPOLL...
        add EPOLLNVAL, annotate EPOLL... and event_poll->event
        use linux/poll.h instead of asm/poll.h
        xen: fix poll misannotation
        smc: missing poll annotations
      ee5daa13
    • L
      Merge tag 'xtensa-20180211' of git://github.com/jcmvbkbc/linux-xtensa · 3fc928dc
      Linus Torvalds 提交于
      Pull xtense fix from Max Filippov:
       "Build fix for xtensa architecture with KASAN enabled"
      
      * tag 'xtensa-20180211' of git://github.com/jcmvbkbc/linux-xtensa:
        xtensa: fix build with KASAN
      3fc928dc
    • L
      Merge tag 'nios2-v4.16-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/lftan/nios2 · 60d7a21a
      Linus Torvalds 提交于
      Pull nios2 update from Ley Foon Tan:
      
       - clean up old Kconfig options from defconfig
      
       - remove leading 0x and 0s from bindings notation in dts files
      
      * tag 'nios2-v4.16-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/lftan/nios2:
        nios2: defconfig: Cleanup from old Kconfig options
        nios2: dts: Remove leading 0x and 0s from bindings notation
      60d7a21a
    • M
      xtensa: fix build with KASAN · f8d0cbf2
      Max Filippov 提交于
      The commit 917538e2 ("kasan: clean up KASAN_SHADOW_SCALE_SHIFT
      usage") removed KASAN_SHADOW_SCALE_SHIFT definition from
      include/linux/kasan.h and added it to architecture-specific headers,
      except for xtensa. This broke the xtensa build with KASAN enabled.
      Define KASAN_SHADOW_SCALE_SHIFT in arch/xtensa/include/asm/kasan.h
      
      Reported by: kbuild test robot <fengguang.wu@intel.com>
      Fixes: 917538e2 ("kasan: clean up KASAN_SHADOW_SCALE_SHIFT usage")
      Acked-by: NAndrey Konovalov <andreyknvl@google.com>
      Signed-off-by: NMax Filippov <jcmvbkbc@gmail.com>
      f8d0cbf2
  4. 11 2月, 2018 8 次提交
    • K
      nios2: defconfig: Cleanup from old Kconfig options · e0691ebb
      Krzysztof Kozlowski 提交于
      Remove old, dead Kconfig option INET_LRO. It is gone since
      commit 7bbf3cae ("ipv4: Remove inet_lro library").
      Signed-off-by: NKrzysztof Kozlowski <krzk@kernel.org>
      Acked-by: NLey Foon Tan <ley.foon.tan@intel.com>
      e0691ebb
    • M
      nios2: dts: Remove leading 0x and 0s from bindings notation · 5d13c731
      Mathieu Malaterre 提交于
      Improve the DTS files by removing all the leading "0x" and zeros to fix the
      following dtc warnings:
      
      Warning (unit_address_format): Node /XXX unit name should not have leading "0x"
      
      and
      
      Warning (unit_address_format): Node /XXX unit name should not have leading 0s
      
      Converted using the following command:
      
      find . -type f \( -iname *.dts -o -iname *.dtsi \) -exec sed -E -i -e "s/@0x([0-9a-fA-F\.]+)\s?\{/@\L\1 \{/g" -e "s/@0+([0-9a-fA-F\.]+)\s?\{/@\L\1 \{/g" {} +
      
      For simplicity, two sed expressions were used to solve each warnings separately.
      
      To make the regex expression more robust a few other issues were resolved,
      namely setting unit-address to lower case, and adding a whitespace before the
      the opening curly brace:
      
      https://elinux.org/Device_Tree_Linux#Linux_conventions
      
      This is a follow up to commit 4c9847b7 ("dt-bindings: Remove leading 0x from bindings notation")
      Reported-by: NDavid Daney <ddaney@caviumnetworks.com>
      Suggested-by: NRob Herring <robh@kernel.org>
      Signed-off-by: NMathieu Malaterre <malat@debian.org>
      Acked-by: NLey Foon Tan <ley.foon.tan@intel.com>
      5d13c731
    • L
      Merge tag 'pci-v4.16-fixes-1' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci · d48fcbd8
      Linus Torvalds 提交于
      Pull PCI fix from Bjorn Helgaas:
       "Fix a POWER9/powernv INTx regression from the merge window (Alexey
        Kardashevskiy)"
      
      * tag 'pci-v4.16-fixes-1' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci:
        powerpc/pci: Fix broken INTx configuration via OF
      d48fcbd8
    • L
      Merge tag 'for-linus-20180210' of git://git.kernel.dk/linux-block · 9454473c
      Linus Torvalds 提交于
      Pull block fixes from Jens Axboe:
       "A few fixes to round off the merge window on the block side:
      
         - a set of bcache fixes by way of Michael Lyle, from the usual bcache
           suspects.
      
         - add a simple-to-hook-into function for bpf EIO error injection.
      
         - fix blk-wbt that mischarectized flushes as reads. Improve the logic
           so that flushes and writes are accounted as writes, and only reads
           as reads. From me.
      
         - fix requeue crash in BFQ, from Paolo"
      
      * tag 'for-linus-20180210' of git://git.kernel.dk/linux-block:
        block, bfq: add requeue-request hook
        bcache: fix for data collapse after re-attaching an attached device
        bcache: return attach error when no cache set exist
        bcache: set writeback_rate_update_seconds in range [1, 60] seconds
        bcache: fix for allocator and register thread race
        bcache: set error_limit correctly
        bcache: properly set task state in bch_writeback_thread()
        bcache: fix high CPU occupancy during journal
        bcache: add journal statistic
        block: Add should_fail_bio() for bpf error injection
        blk-wbt: account flush requests correctly
      9454473c
    • L
      Merge tag 'platform-drivers-x86-v4.16-3' of git://github.com/dvhart/linux-pdx86 · cc5cb5af
      Linus Torvalds 提交于
      Pull x86 platform driver updates from Darren Hart:
       "Mellanox fixes and new system type support.
      
        Mostly data for new system types with a correction and an
        uninitialized variable fix"
      
      [ Pulling from github because git.infradead.org currently seems to be
        down for some reason, but Darren had a backup location    - Linus ]
      
      * tag 'platform-drivers-x86-v4.16-3' of git://github.com/dvhart/linux-pdx86:
        platform/x86: mlx-platform: Add support for new 200G IB and Ethernet systems
        platform/x86: mlx-platform: Add support for new msn201x system type
        platform/x86: mlx-platform: Add support for new msn274x system type
        platform/x86: mlx-platform: Fix power cable setting for msn21xx family
        platform/x86: mlx-platform: Add define for the negative bus
        platform/x86: mlx-platform: Use defines for bus assignment
        platform/mellanox: mlxreg-hotplug: Fix uninitialized variable
      cc5cb5af
    • L
      Merge tag 'chrome-platform-for-linus-4.16' of... · e9d46f74
      Linus Torvalds 提交于
      Merge tag 'chrome-platform-for-linus-4.16' of git://git.kernel.org/pub/scm/linux/kernel/git/bleung/chrome-platform
      
      Pull chrome platform updates from Benson Leung:
      
       - move cros_ec_dev to drivers/mfd
      
       - other small maintenance fixes
      
      [ The cros_ec_dev movement came in earlier through the MFD tree  - Linus ]
      
      * tag 'chrome-platform-for-linus-4.16' of git://git.kernel.org/pub/scm/linux/kernel/git/bleung/chrome-platform:
        platform/chrome: Use proper protocol transfer function
        platform/chrome: cros_ec_lpc: Add support for Google Glimmer
        platform/chrome: cros_ec_lpc: Register the driver if ACPI entry is missing.
        platform/chrome: cros_ec_lpc: remove redundant pointer request
        cros_ec: fix nul-termination for firmware build info
        platform/chrome: chromeos_laptop: make chromeos_laptop const
      e9d46f74
    • L
      Merge tag 'kvm-4.16-1' of git://git.kernel.org/pub/scm/virt/kvm/kvm · 15303ba5
      Linus Torvalds 提交于
      Pull KVM updates from Radim Krčmář:
       "ARM:
      
         - icache invalidation optimizations, improving VM startup time
      
         - support for forwarded level-triggered interrupts, improving
           performance for timers and passthrough platform devices
      
         - a small fix for power-management notifiers, and some cosmetic
           changes
      
        PPC:
      
         - add MMIO emulation for vector loads and stores
      
         - allow HPT guests to run on a radix host on POWER9 v2.2 CPUs without
           requiring the complex thread synchronization of older CPU versions
      
         - improve the handling of escalation interrupts with the XIVE
           interrupt controller
      
         - support decrement register migration
      
         - various cleanups and bugfixes.
      
        s390:
      
         - Cornelia Huck passed maintainership to Janosch Frank
      
         - exitless interrupts for emulated devices
      
         - cleanup of cpuflag handling
      
         - kvm_stat counter improvements
      
         - VSIE improvements
      
         - mm cleanup
      
        x86:
      
         - hypervisor part of SEV
      
         - UMIP, RDPID, and MSR_SMI_COUNT emulation
      
         - paravirtualized TLB shootdown using the new KVM_VCPU_PREEMPTED bit
      
         - allow guests to see TOPOEXT, GFNI, VAES, VPCLMULQDQ, and more
           AVX512 features
      
         - show vcpu id in its anonymous inode name
      
         - many fixes and cleanups
      
         - per-VCPU MSR bitmaps (already merged through x86/pti branch)
      
         - stable KVM clock when nesting on Hyper-V (merged through
           x86/hyperv)"
      
      * tag 'kvm-4.16-1' of git://git.kernel.org/pub/scm/virt/kvm/kvm: (197 commits)
        KVM: PPC: Book3S: Add MMIO emulation for VMX instructions
        KVM: PPC: Book3S HV: Branch inside feature section
        KVM: PPC: Book3S HV: Make HPT resizing work on POWER9
        KVM: PPC: Book3S HV: Fix handling of secondary HPTEG in HPT resizing code
        KVM: PPC: Book3S PR: Fix broken select due to misspelling
        KVM: x86: don't forget vcpu_put() in kvm_arch_vcpu_ioctl_set_sregs()
        KVM: PPC: Book3S PR: Fix svcpu copying with preemption enabled
        KVM: PPC: Book3S HV: Drop locks before reading guest memory
        kvm: x86: remove efer_reload entry in kvm_vcpu_stat
        KVM: x86: AMD Processor Topology Information
        x86/kvm/vmx: do not use vm-exit instruction length for fast MMIO when running nested
        kvm: embed vcpu id to dentry of vcpu anon inode
        kvm: Map PFN-type memory regions as writable (if possible)
        x86/kvm: Make it compile on 32bit and with HYPYERVISOR_GUEST=n
        KVM: arm/arm64: Fixup userspace irqchip static key optimization
        KVM: arm/arm64: Fix userspace_irqchip_in_use counting
        KVM: arm/arm64: Fix incorrect timer_is_pending logic
        MAINTAINERS: update KVM/s390 maintainers
        MAINTAINERS: add Halil as additional vfio-ccw maintainer
        MAINTAINERS: add David as a reviewer for KVM/s390
        ...
      15303ba5
    • A
      powerpc/pci: Fix broken INTx configuration via OF · c591c2e3
      Alexey Kardashevskiy 提交于
      59f47eff ("powerpc/pci: Use of_irq_parse_and_map_pci() helper")
      replaced of_irq_parse_pci() + irq_create_of_mapping() with
      of_irq_parse_and_map_pci(), but neglected to capture the virq
      returned by irq_create_of_mapping(), so virq remained zero, which
      caused INTx configuration to fail.
      
      Save the virq value returned by of_irq_parse_and_map_pci() and correct
      the virq declaration to match the of_irq_parse_and_map_pci() signature.
      
      Fixes: 59f47eff "powerpc/pci: Use of_irq_parse_and_map_pci() helper"
      Signed-off-by: NAlexey Kardashevskiy <aik@ozlabs.ru>
      [bhelgaas: changelog]
      Signed-off-by: NBjorn Helgaas <bhelgaas@google.com>
      c591c2e3
  5. 10 2月, 2018 4 次提交