1. 23 2月, 2017 2 次提交
    • A
      powerpc/mm/hash: Always clear UPRT and Host Radix bits when setting up CPU · fda2d27d
      Aneesh Kumar K.V 提交于
      We will set LPCR with correct value for radix during int. This make sure we
      start with a sanitized value of LPCR. In case of kexec, cpus can have LPCR
      value based on the previous translation mode we were running.
      
      Fixes: fe036a06 ("powerpc/64/kexec: Fix MMU cleanup on radix")
      Cc: stable@vger.kernel.org # v4.9+
      Acked-by: NMichael Neuling <mikey@neuling.org>
      Signed-off-by: NAneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com>
      Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
      fda2d27d
    • N
      powerpc/optprobes: Fix TOC handling in optprobes trampoline · f558b37b
      Naveen N. Rao 提交于
      Optprobes on powerpc are limited to kernel text area. We decided to also
      optimize kretprobe_trampoline since that is also in kernel text area.
      However,we failed to take into consideration the fact that the same
      trampoline is also used to catch function returns from kernel modules.
      As an example:
      
        $ sudo modprobe kobject-example
        $ sudo bash -c "echo 'r foo_show+8' > /sys/kernel/debug/tracing/kprobe_events"
        $ sudo bash -c "echo 1 > /sys/kernel/debug/tracing/events/kprobes/enable"
        $ sudo cat /sys/kernel/debug/kprobes/list
        c000000000041350  k  kretprobe_trampoline+0x0    [OPTIMIZED]
        d000000000e00200  r  foo_show+0x8  kobject_example
        $ cat /sys/kernel/kobject_example/foo
        Segmentation fault
      
      With the below (trimmed) splat in dmesg:
      
        Unable to handle kernel paging request for data at address 0xfec40000
        Faulting instruction address: 0xc000000000041540
        Oops: Kernel access of bad area, sig: 11 [#1]
        ...
        NIP [c000000000041540] optimized_callback+0x70/0xe0
        LR [c000000000041e60] optinsn_slot+0xf8/0x10000
        Call Trace:
        [c0000000c7327850] [c000000000289af4] alloc_set_pte+0x1c4/0x860 (unreliable)
        [c0000000c7327890] [c000000000041e60] optinsn_slot+0xf8/0x10000
        --- interrupt: 700 at 0xc0000000c7327a80
      	       LR = kretprobe_trampoline+0x0/0x10
        [c0000000c7327ba0] [c0000000003a30d4] sysfs_kf_seq_show+0x104/0x1d0
        [c0000000c7327bf0] [c0000000003a0bb4] kernfs_seq_show+0x44/0x60
        [c0000000c7327c10] [c000000000330578] seq_read+0xf8/0x560
        [c0000000c7327cb0] [c0000000003a1e64] kernfs_fop_read+0x194/0x260
        [c0000000c7327d00] [c0000000002f9954] __vfs_read+0x44/0x1a0
        [c0000000c7327d90] [c0000000002fb4cc] vfs_read+0xbc/0x1b0
        [c0000000c7327de0] [c0000000002fd138] SyS_read+0x68/0x110
        [c0000000c7327e30] [c00000000000b8e0] system_call+0x38/0xfc
      
      Fix this by loading up the kernel TOC before calling into the kernel.
      The original TOC gets restored as part of the usual pt_regs restore.
      
      Fixes: 762df10b ("powerpc/kprobes: Optimize kprobe in kretprobe_trampoline()")
      Signed-off-by: NNaveen N. Rao <naveen.n.rao@linux.vnet.ibm.com>
      Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
      f558b37b
  2. 21 2月, 2017 1 次提交
    • M
      powerpc/pseries: Advertise Hot Plug Event support to firmware · 3dbbaf20
      Michael Roth 提交于
      With the inclusion of commit 333f7b76 ("powerpc/pseries: Implement
      indexed-count hotplug memory add") and commit 75384347
      ("powerpc/pseries: Implement indexed-count hotplug memory remove"), we
      now have complete handling of the RTAS hotplug event format as described
      by PAPR via ACR "PAPR Changes for Hotplug RTAS Events".
      
      This capability is indicated by byte 6, bit 2 (5 in IBM numbering) of
      architecture option vector 5, and allows for greater control over
      cpu/memory/pci hot plug/unplug operations.
      
      Existing pseries kernels will utilize this capability based on the
      existence of the /event-sources/hot-plug-events DT property, so we
      only need to advertise it via CAS and do not need a corresponding
      FW_FEATURE_* value to test for.
      Signed-off-by: NMichael Roth <mdroth@linux.vnet.ibm.com>
      Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
      3dbbaf20
  3. 17 2月, 2017 2 次提交
  4. 15 2月, 2017 4 次提交
  5. 10 2月, 2017 4 次提交
  6. 07 2月, 2017 4 次提交
  7. 06 2月, 2017 8 次提交
  8. 03 2月, 2017 1 次提交
  9. 02 2月, 2017 1 次提交
  10. 31 1月, 2017 9 次提交
  11. 30 1月, 2017 1 次提交
    • M
      powerpc/fadump: Fix the race in crash_fadump(). · f2a5e8f0
      Mahesh Salgaonkar 提交于
      There are chances that multiple CPUs can call crash_fadump() simultaneously
      and would start duplicating same info to vmcoreinfo ELF note section. This
      causes makedumpfile to fail during kdump capture. One example is,
      triggering dumprestart from HMC which sends system reset to all the CPUs at
      once.
      
      makedumpfile --dump-dmesg /proc/vmcore
      read_vmcoreinfo_basic_info: Invalid data in /tmp/vmcoreinfoyjgxlL: CRASHTIME=1475605971CRASHTIME=1475605971CRASHTIME=1475605971CRASHTIME=1475605971CRASHTIME=1475605971CRASHTIME=1475605971CRASHTIME=1475605971CRASHTIME=1475605971
      makedumpfile Failed.
      Running makedumpfile --dump-dmesg /proc/vmcore failed (1).
      
      makedumpfile  -d 31 -l /proc/vmcore
      read_vmcoreinfo_basic_info: Invalid data in /tmp/vmcoreinfo1mmVdO: CRASHTIME=1475605971CRASHTIME=1475605971CRASHTIME=1475605971CRASHTIME=1475605971CRASHTIME=1475605971CRASHTIME=1475605971CRASHTIME=1475605971CRASHTIME=1475605971
      makedumpfile Failed.
      Running makedumpfile  -d 31 -l /proc/vmcore failed (1).
      Signed-off-by: NMahesh Salgaonkar <mahesh@linux.vnet.ibm.com>
      Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
      f2a5e8f0
  12. 27 1月, 2017 3 次提交
    • N
      KVM: PPC: Book3S: Move 64-bit KVM interrupt handler out from alt section · 7ede5317
      Nicholas Piggin 提交于
      A subsequent patch to make KVM handlers relocation-safe makes them
      unusable from within alt section "else" cases (due to the way fixed
      addresses are taken from within fixed section head code).
      
      Stop open-coding the KVM handlers, and add them both as normal. A more
      optimal fix may be to allow some level of alternate feature patching in
      the exception macros themselves, but for now this will do.
      
      The TRAMP_KVM handlers must be moved to the "virt" fixed section area
      (name is arbitrary) in order to be closer to .text and avoid the dreaded
      "relocation truncated to fit" error.
      Signed-off-by: NNicholas Piggin <npiggin@gmail.com>
      Acked-by: NPaul Mackerras <paulus@ozlabs.org>
      Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
      7ede5317
    • C
      powerpc/8xx: Perf events on PPC 8xx · 75b82472
      Christophe Leroy 提交于
      This patch has been reworked since RFC version. In the RFC, this patch
      was preceded by a patch clearing MSR RI for all PPC32 at all time at
      exception prologs. Now MSR RI clearing is done only when this 8xx perf
      events functionality is compiled in, it is therefore limited to 8xx
      and merged inside this patch.
      Other main changes have been to take into account detailed review from
      Peter Zijlstra. The instructions counter has been reworked to behave
      as a free running counter like the three other counters.
      
      The 8xx has no PMU, however some events can be emulated by other means.
      
      This patch implements the following events (as reported by 'perf list'):
        cpu-cycles OR cycles				[Hardware event]
        instructions					[Hardware event]
        dTLB-load-misses				[Hardware cache event]
        iTLB-load-misses				[Hardware cache event]
      
      'cycles' event is implemented using the timebase clock. Timebase clock
      corresponds to CPU clock divided by 16, so number of cycles is
      approximatly 16 times the number of TB ticks
      
      On the 8xx, TLB misses are handled by software. It is therefore
      easy to count all TLB misses each time the TLB miss exception is
      called.
      
      'instructions' is calculated by using instruction watchpoint counter.
      This patch sets counter A to count instructions at address greater
      than 0, hence we count all instructions executed while MSR RI bit is
      set. The counter is set to the maximum which is 0xffff. Every 65535
      instructions, debug instruction breakpoint exception fires. The
      exception handler increments a counter in memory which then
      represent the upper part of the instruction counter. We therefore
      end up with a 48 bits counter. In order to avoid unnecessary overhead
      while no perf event is active, this counter is started when the first
      event referring to this counter is added, and the counter is stopped
      when the last event referring to it is deleted. In order to properly
      support breakpoint exceptions, MSR RI bit has to be unset in exception
      epilogs in order to avoid breakpoint exceptions during critical
      sections during changes to SRR0 and SRR1 would be problematic.
      
      All counters are handled as free running counters.
      Signed-off-by: NChristophe Leroy <christophe.leroy@c-s.fr>
      Signed-off-by: NScott Wood <oss@buserror.net>
      75b82472
    • C
      powerpc/32: Remove FIX_SRR1 · 2add2031
      Christophe Leroy 提交于
      FIX_SRR1() is defined as blank. Last useful instance of FIX_SRR1()
      was removed by commit 40ef8cbc ("powerpc: Get 64-bit configs to
      compile with ARCH=powerpc") in 2005.
      Signed-off-by: NChristophe Leroy <christophe.leroy@c-s.fr>
      Signed-off-by: NScott Wood <oss@buserror.net>
      2add2031