1. 17 7月, 2016 17 次提交
  2. 15 7月, 2016 16 次提交
  3. 14 7月, 2016 7 次提交
    • D
      powerpc: Make ppc_md.{halt, restart} __noreturn · 95ec77c0
      Daniel Axtens 提交于
      powernv marks it's halt and restart calls as __noreturn. However,
      ppc_md does not have this annotation. Add the annotation to ppc_md,
      and then to every halt/restart function that is missing it.
      
      Additionally, I have verified that all of these functions do not
      return. Occasionally I have added a spin loop to be sure.
      Signed-off-by: NDaniel Axtens <dja@axtens.net>
      Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
      95ec77c0
    • D
      powerpc/sparse: Pass endianness to sparse · 62c2c5cf
      Daniel Axtens 提交于
      Explicitly give sparse an endianness in the Makefile, so that it
      doesn't get confused.
      
      Normally we have #ifdef one and #else the other, so it doesn't usually
      matter, but we have been bitten by it before, and indeed this patch
      fixes a number of sparse errors.
      Suggested-by: NArnd Bergmann <arnd@arndb.de>
      Signed-off-by: NDaniel Axtens <dja@axtens.net>
      Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
      62c2c5cf
    • D
      powerpc/kvm: Clarify __user annotations · f8750513
      Daniel Axtens 提交于
      kvmppc_h_put_tce_indirect labels a u64 pointer as __user. It also
      labelled the u64 where get_user puts the result as __user. This isn't
      a pointer and so doesn't need to be labelled __user.
      
      Split the u64 value definition onto a new line to make it clear that
      it doesn't get the annotation.
      Signed-off-by: NDaniel Axtens <dja@axtens.net>
      Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
      f8750513
    • A
      powerpc/pmac/smp: Add missing FROZEN hotplug notifier transitions · c011926f
      Anna-Maria Gleixner 提交于
      The FROZEN transitions are used when a CPU suspends/resumes. In case
      of a suspend/resume, only the up prepare (CPU_UP_PREPARE_FROZEN) is
      handled. The error handling transition CPU_UP_CANCELED_FROZEN as well
      as the CPU_ONLINE_FROZEN transition are not handled.
      
      Masking the switch case action argument with ~CPU_TASKS_FROZEN, to
      handle all FROZEN tasks the same way than the corresponding non frozen
      tasks.
      
      Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
      Cc: linuxppc-dev@lists.ozlabs.org
      Signed-off-by: NAnna-Maria Gleixner <anna-maria@linutronix.de>
      Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
      c011926f
    • A
      PCI/hotplug: pnv_php: export symbols and move struct types needed by cxl · 89379f16
      Andrew Donnellan 提交于
      The cxl driver will use infrastructure from pnv_php to handle device tree
      updates when switching bi-modal CAPI cards into CAPI mode.
      
      To enable this, export pnv_php_find_slot() and
      pnv_php_set_slot_power_state(), and add corresponding declarations, as well
      as the definition of struct pnv_php_slot, to asm/pnv-pci.h.
      
      Cc: Gavin Shan <gwshan@linux.vnet.ibm.com>
      Cc: linux-pci@vger.kernel.org
      Cc: Bjorn Helgaas <bhelgaas@google.com>
      Signed-off-by: NAndrew Donnellan <andrew.donnellan@au1.ibm.com>
      Signed-off-by: NIan Munsie <imunsie@au1.ibm.com>
      Acked-by: NGavin Shan <gwshan@linux.vnet.ibm.com>
      Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
      89379f16
    • I
      cxl: Add support for interrupts on the Mellanox CX4 · a2f67d5e
      Ian Munsie 提交于
      The Mellanox CX4 in cxl mode uses a hybrid interrupt model, where
      interrupts are routed from the networking hardware to the XSL using the
      MSIX table, and from there will be transformed back into an MSIX
      interrupt using the cxl style interrupts (i.e. using IVTE entries and
      ranges to map a PE and AFU interrupt number to an MSIX address).
      
      We want to hide the implementation details of cxl interrupts as much as
      possible. To this end, we use a special version of the MSI setup &
      teardown routines in the PHB while in cxl mode to allocate the cxl
      interrupts and configure the IVTE entries in the process element.
      
      This function does not configure the MSIX table - the CX4 card uses a
      custom format in that table and it would not be appropriate to fill that
      out in generic code. The rest of the functionality is similar to the
      "Full MSI-X mode" described in the CAIA, and this could be easily
      extended to support other adapters that use that mode in the future.
      
      The interrupts will be associated with the default context. If the
      maximum number of interrupts per context has been limited (e.g. by the
      mlx5 driver), it will automatically allocate additional kernel contexts
      to associate extra interrupts as required. These contexts will be
      started using the same WED that was used to start the default context.
      Signed-off-by: NIan Munsie <imunsie@au1.ibm.com>
      Reviewed-by: NAndrew Donnellan <andrew.donnellan@au1.ibm.com>
      Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
      a2f67d5e
    • I
      powerpc/powernv: Add support for the cxl kernel api on the real phb · 4361b034
      Ian Munsie 提交于
      This adds support for the peer model of the cxl kernel api to the
      PowerNV PHB, in which physical function 0 represents the cxl function on
      the card (an XSL in the case of the CX4), which other physical functions
      will use for memory access and interrupt services. It is referred to as
      the peer model as these functions are peers of one another, as opposed
      to the Virtual PHB model which forms a hierarchy.
      
      This patch exports APIs to enable the peer mode, check if a PCI device
      is attached to a PHB in this mode, and to set and get the peer AFU for
      this mode.
      
      The cxl driver will enable this mode for supported cards by calling
      pnv_cxl_enable_phb_kernel_api(). This will set a flag in the PHB to note
      that this mode is enabled, and switch out it's controller_ops for the
      cxl version.
      
      The cxl version of the controller_ops struct implements it's own
      versions of the enable_device_hook and release_device to handle
      refcounting on the peer AFU and to allocate a default context for the
      device.
      
      Once enabled, the cxl kernel API may not be disabled on a PHB. Currently
      there is no safe way to disable cxl mode short of a reboot, so until
      that changes there is no reason to support the disable path.
      Signed-off-by: NIan Munsie <imunsie@au1.ibm.com>
      Reviewed-by: NAndrew Donnellan <andrew.donnellan@au1.ibm.com>
      Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
      4361b034