[prev in list] [next in list] [prev in thread] [next in thread] 

List:       linux-mips-cvs
Subject:    MIPS: Fix C0_Pagegrain[IEC] support.
From:       linux-mips () linux-mips ! org
Date:       2015-01-30 23:38:40
Message-ID: S27012354AbbA3XimjEQrP/20150130233842Z+544 () eddie ! linux-mips ! org
[Download RAW message or body]

Author: David Daney <david.daney@cavium.com> Tue Jan 6 10:42:23 2015 -0800
Comitter: Ralf Baechle <ralf@linux-mips.org> Fri Jan 30 23:23:53 2015 +0100
Commit: 43def7e15b952d497af07a1290bc71ea15f6e812
Gitweb: http://git.linux-mips.org/g/ralf/linux/43def7e15b95
Branch: linux-3.18-stable

The following commits:

  5890f70f15c52d (MIPS: Use dedicated exception handler if CPU supports RI/XI exceptions)
  6575b1d4173eae (MIPS: kernel: cpu-probe: Detect unique RI/XI exceptions)

break the kernel for *all* existing MIPS CPUs that implement the
CP0_PageGrain[IEC] bit.  They cause the TLB exception handlers to be
generated without the legacy execute-inhibit handling, but never set
the CP0_PageGrain[IEC] bit to activate the use of dedicated exception
vectors for execute-inhibit exceptions.  The result is that upon
detection of an execute-inhibit violation, we loop forever in the TLB
exception handlers instead of sending SIGSEGV to the task.

If we are generating TLB exception handlers expecting separate
vectors, we must also enable the CP0_PageGrain[IEC] feature.

The bug was introduced in kernel version 3.17.

Signed-off-by: David Daney <david.daney@cavium.com>
Cc: <stable@vger.kernel.org>
Cc: Leonid Yegoshin <Leonid.Yegoshin@imgtec.com>
Cc: linux-mips@linux-mips.org
Patchwork: http://patchwork.linux-mips.org/patch/8880/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
(cherry picked from commit 4caaf26cad00604b6f5a60dc376c1e73134c534a)

---

 arch/mips/mm/tlb-r4k.c |    2 ++
 1 file changed, 2 insertions(+)

[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic