[POWERPC] Split out iSeries specific exception macros
Signed-off-by: Stephen Rothwell <sfr@canb.auug.org.au> Signed-off-by: Paul Mackerras <paulus@samba.org>
This commit is contained in:
committed by
Paul Mackerras
parent
dc8f571a26
commit
7180e3e636
@@ -30,9 +30,10 @@
|
|||||||
#include <asm/asm-offsets.h>
|
#include <asm/asm-offsets.h>
|
||||||
#include <asm/thread_info.h>
|
#include <asm/thread_info.h>
|
||||||
#include <asm/ptrace.h>
|
#include <asm/ptrace.h>
|
||||||
#include <asm/exception.h>
|
|
||||||
#include <asm/cputable.h>
|
#include <asm/cputable.h>
|
||||||
|
|
||||||
|
#include "exception.h"
|
||||||
|
|
||||||
.text
|
.text
|
||||||
|
|
||||||
.globl system_reset_iSeries
|
.globl system_reset_iSeries
|
||||||
@@ -104,15 +105,15 @@ BEGIN_FTR_SECTION
|
|||||||
mtcrf 0x80,r12
|
mtcrf 0x80,r12
|
||||||
mfspr r12,SPRN_SPRG2
|
mfspr r12,SPRN_SPRG2
|
||||||
END_FTR_SECTION_IFCLR(CPU_FTR_SLB)
|
END_FTR_SECTION_IFCLR(CPU_FTR_SLB)
|
||||||
EXCEPTION_PROLOG_ISERIES_1(PACA_EXGEN)
|
EXCEPTION_PROLOG_1(PACA_EXGEN)
|
||||||
EXCEPTION_PROLOG_ISERIES_2
|
EXCEPTION_PROLOG_ISERIES_1
|
||||||
b data_access_common
|
b data_access_common
|
||||||
|
|
||||||
.do_stab_bolted_iSeries:
|
.do_stab_bolted_iSeries:
|
||||||
mtcrf 0x80,r12
|
mtcrf 0x80,r12
|
||||||
mfspr r12,SPRN_SPRG2
|
mfspr r12,SPRN_SPRG2
|
||||||
EXCEPTION_PROLOG_ISERIES_1(PACA_EXSLB)
|
EXCEPTION_PROLOG_1(PACA_EXSLB)
|
||||||
EXCEPTION_PROLOG_ISERIES_2
|
EXCEPTION_PROLOG_ISERIES_1
|
||||||
b .do_stab_bolted
|
b .do_stab_bolted
|
||||||
|
|
||||||
.globl data_access_slb_iSeries
|
.globl data_access_slb_iSeries
|
||||||
@@ -171,7 +172,7 @@ slb_miss_user_iseries:
|
|||||||
std r10,PACA_EXGEN+EX_R13(r13)
|
std r10,PACA_EXGEN+EX_R13(r13)
|
||||||
std r11,PACA_EXGEN+EX_R9(r13)
|
std r11,PACA_EXGEN+EX_R9(r13)
|
||||||
std r12,PACA_EXGEN+EX_R3(r13)
|
std r12,PACA_EXGEN+EX_R3(r13)
|
||||||
EXCEPTION_PROLOG_ISERIES_2
|
EXCEPTION_PROLOG_ISERIES_1
|
||||||
b slb_miss_user_common
|
b slb_miss_user_common
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -187,7 +188,7 @@ slb_miss_user_iseries:
|
|||||||
system_call_iSeries:
|
system_call_iSeries:
|
||||||
mr r9,r13
|
mr r9,r13
|
||||||
mfspr r13,SPRN_SPRG3
|
mfspr r13,SPRN_SPRG3
|
||||||
EXCEPTION_PROLOG_ISERIES_2
|
EXCEPTION_PROLOG_ISERIES_1
|
||||||
b system_call_common
|
b system_call_common
|
||||||
|
|
||||||
STD_EXCEPTION_ISERIES( 0xd00, single_step, PACA_EXGEN)
|
STD_EXCEPTION_ISERIES( 0xd00, single_step, PACA_EXGEN)
|
||||||
|
58
arch/powerpc/platforms/iseries/exception.h
Normal file
58
arch/powerpc/platforms/iseries/exception.h
Normal file
@@ -0,0 +1,58 @@
|
|||||||
|
#ifndef _ASM_POWERPC_ISERIES_EXCEPTION_H
|
||||||
|
#define _ASM_POWERPC_ISERIES_EXCEPTION_H
|
||||||
|
/*
|
||||||
|
* Extracted from head_64.S
|
||||||
|
*
|
||||||
|
* PowerPC version
|
||||||
|
* Copyright (C) 1995-1996 Gary Thomas (gdt@linuxppc.org)
|
||||||
|
*
|
||||||
|
* Rewritten by Cort Dougan (cort@cs.nmt.edu) for PReP
|
||||||
|
* Copyright (C) 1996 Cort Dougan <cort@cs.nmt.edu>
|
||||||
|
* Adapted for Power Macintosh by Paul Mackerras.
|
||||||
|
* Low-level exception handlers and MMU support
|
||||||
|
* rewritten by Paul Mackerras.
|
||||||
|
* Copyright (C) 1996 Paul Mackerras.
|
||||||
|
*
|
||||||
|
* Adapted for 64bit PowerPC by Dave Engebretsen, Peter Bergner, and
|
||||||
|
* Mike Corrigan {engebret|bergner|mikejc}@us.ibm.com
|
||||||
|
*
|
||||||
|
* This file contains the low-level support and setup for the
|
||||||
|
* PowerPC-64 platform, including trap and interrupt dispatch.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License
|
||||||
|
* as published by the Free Software Foundation; either version
|
||||||
|
* 2 of the License, or (at your option) any later version.
|
||||||
|
*/
|
||||||
|
#include <asm/exception.h>
|
||||||
|
|
||||||
|
#define EXCEPTION_PROLOG_ISERIES_1 \
|
||||||
|
mfmsr r10; \
|
||||||
|
ld r12,PACALPPACAPTR(r13); \
|
||||||
|
ld r11,LPPACASRR0(r12); \
|
||||||
|
ld r12,LPPACASRR1(r12); \
|
||||||
|
ori r10,r10,MSR_RI; \
|
||||||
|
mtmsrd r10,1
|
||||||
|
|
||||||
|
#define STD_EXCEPTION_ISERIES(n, label, area) \
|
||||||
|
.globl label##_iSeries; \
|
||||||
|
label##_iSeries: \
|
||||||
|
HMT_MEDIUM; \
|
||||||
|
mtspr SPRN_SPRG1,r13; /* save r13 */ \
|
||||||
|
EXCEPTION_PROLOG_1(area); \
|
||||||
|
EXCEPTION_PROLOG_ISERIES_1; \
|
||||||
|
b label##_common
|
||||||
|
|
||||||
|
#define MASKABLE_EXCEPTION_ISERIES(n, label) \
|
||||||
|
.globl label##_iSeries; \
|
||||||
|
label##_iSeries: \
|
||||||
|
HMT_MEDIUM; \
|
||||||
|
mtspr SPRN_SPRG1,r13; /* save r13 */ \
|
||||||
|
EXCEPTION_PROLOG_1(PACA_EXGEN); \
|
||||||
|
lbz r10,PACASOFTIRQEN(r13); \
|
||||||
|
cmpwi 0,r10,0; \
|
||||||
|
beq- label##_iSeries_masked; \
|
||||||
|
EXCEPTION_PROLOG_ISERIES_1; \
|
||||||
|
b label##_common; \
|
||||||
|
|
||||||
|
#endif /* _ASM_POWERPC_ISERIES_EXCEPTION_H */
|
@@ -62,6 +62,16 @@
|
|||||||
ori reg,reg,(label)@l; /* virt addr of handler ... */
|
ori reg,reg,(label)@l; /* virt addr of handler ... */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define EXCEPTION_PROLOG_1(area) \
|
||||||
|
mfspr r13,SPRN_SPRG3; /* get paca address into r13 */ \
|
||||||
|
std r9,area+EX_R9(r13); /* save r9 - r12 */ \
|
||||||
|
std r10,area+EX_R10(r13); \
|
||||||
|
std r11,area+EX_R11(r13); \
|
||||||
|
std r12,area+EX_R12(r13); \
|
||||||
|
mfspr r9,SPRN_SPRG1; \
|
||||||
|
std r9,area+EX_R13(r13); \
|
||||||
|
mfcr r9
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Equal to EXCEPTION_PROLOG_PSERIES, except that it forces 64bit mode.
|
* Equal to EXCEPTION_PROLOG_PSERIES, except that it forces 64bit mode.
|
||||||
* The firmware calls the registered system_reset_fwnmi and
|
* The firmware calls the registered system_reset_fwnmi and
|
||||||
@@ -70,14 +80,7 @@
|
|||||||
* This firmware bug is present on POWER4 and JS20.
|
* This firmware bug is present on POWER4 and JS20.
|
||||||
*/
|
*/
|
||||||
#define EXCEPTION_PROLOG_PSERIES_FORCE_64BIT(area, label) \
|
#define EXCEPTION_PROLOG_PSERIES_FORCE_64BIT(area, label) \
|
||||||
mfspr r13,SPRN_SPRG3; /* get paca address into r13 */ \
|
EXCEPTION_PROLOG_1(area); \
|
||||||
std r9,area+EX_R9(r13); /* save r9 - r12 */ \
|
|
||||||
std r10,area+EX_R10(r13); \
|
|
||||||
std r11,area+EX_R11(r13); \
|
|
||||||
std r12,area+EX_R12(r13); \
|
|
||||||
mfspr r9,SPRN_SPRG1; \
|
|
||||||
std r9,area+EX_R13(r13); \
|
|
||||||
mfcr r9; \
|
|
||||||
clrrdi r12,r13,32; /* get high part of &label */ \
|
clrrdi r12,r13,32; /* get high part of &label */ \
|
||||||
mfmsr r10; \
|
mfmsr r10; \
|
||||||
/* force 64bit mode */ \
|
/* force 64bit mode */ \
|
||||||
@@ -94,14 +97,7 @@
|
|||||||
b . /* prevent speculative execution */
|
b . /* prevent speculative execution */
|
||||||
|
|
||||||
#define EXCEPTION_PROLOG_PSERIES(area, label) \
|
#define EXCEPTION_PROLOG_PSERIES(area, label) \
|
||||||
mfspr r13,SPRN_SPRG3; /* get paca address into r13 */ \
|
EXCEPTION_PROLOG_1(area); \
|
||||||
std r9,area+EX_R9(r13); /* save r9 - r12 */ \
|
|
||||||
std r10,area+EX_R10(r13); \
|
|
||||||
std r11,area+EX_R11(r13); \
|
|
||||||
std r12,area+EX_R12(r13); \
|
|
||||||
mfspr r9,SPRN_SPRG1; \
|
|
||||||
std r9,area+EX_R13(r13); \
|
|
||||||
mfcr r9; \
|
|
||||||
clrrdi r12,r13,32; /* get high part of &label */ \
|
clrrdi r12,r13,32; /* get high part of &label */ \
|
||||||
mfmsr r10; \
|
mfmsr r10; \
|
||||||
mfspr r11,SPRN_SRR0; /* save SRR0 */ \
|
mfspr r11,SPRN_SRR0; /* save SRR0 */ \
|
||||||
@@ -113,28 +109,6 @@
|
|||||||
rfid; \
|
rfid; \
|
||||||
b . /* prevent speculative execution */
|
b . /* prevent speculative execution */
|
||||||
|
|
||||||
/*
|
|
||||||
* This is the start of the interrupt handlers for iSeries
|
|
||||||
* This code runs with relocation on.
|
|
||||||
*/
|
|
||||||
#define EXCEPTION_PROLOG_ISERIES_1(area) \
|
|
||||||
mfspr r13,SPRN_SPRG3; /* get paca address into r13 */ \
|
|
||||||
std r9,area+EX_R9(r13); /* save r9 - r12 */ \
|
|
||||||
std r10,area+EX_R10(r13); \
|
|
||||||
std r11,area+EX_R11(r13); \
|
|
||||||
std r12,area+EX_R12(r13); \
|
|
||||||
mfspr r9,SPRN_SPRG1; \
|
|
||||||
std r9,area+EX_R13(r13); \
|
|
||||||
mfcr r9
|
|
||||||
|
|
||||||
#define EXCEPTION_PROLOG_ISERIES_2 \
|
|
||||||
mfmsr r10; \
|
|
||||||
ld r12,PACALPPACAPTR(r13); \
|
|
||||||
ld r11,LPPACASRR0(r12); \
|
|
||||||
ld r12,LPPACASRR1(r12); \
|
|
||||||
ori r10,r10,MSR_RI; \
|
|
||||||
mtmsrd r10,1
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The common exception prolog is used for all except a few exceptions
|
* The common exception prolog is used for all except a few exceptions
|
||||||
* such as a segment miss on a kernel address. We have to be prepared
|
* such as a segment miss on a kernel address. We have to be prepared
|
||||||
@@ -247,27 +221,6 @@ label##_pSeries: \
|
|||||||
rfid; \
|
rfid; \
|
||||||
b . /* prevent speculative execution */
|
b . /* prevent speculative execution */
|
||||||
|
|
||||||
#define STD_EXCEPTION_ISERIES(n, label, area) \
|
|
||||||
.globl label##_iSeries; \
|
|
||||||
label##_iSeries: \
|
|
||||||
HMT_MEDIUM; \
|
|
||||||
mtspr SPRN_SPRG1,r13; /* save r13 */ \
|
|
||||||
EXCEPTION_PROLOG_ISERIES_1(area); \
|
|
||||||
EXCEPTION_PROLOG_ISERIES_2; \
|
|
||||||
b label##_common
|
|
||||||
|
|
||||||
#define MASKABLE_EXCEPTION_ISERIES(n, label) \
|
|
||||||
.globl label##_iSeries; \
|
|
||||||
label##_iSeries: \
|
|
||||||
HMT_MEDIUM; \
|
|
||||||
mtspr SPRN_SPRG1,r13; /* save r13 */ \
|
|
||||||
EXCEPTION_PROLOG_ISERIES_1(PACA_EXGEN); \
|
|
||||||
lbz r10,PACASOFTIRQEN(r13); \
|
|
||||||
cmpwi 0,r10,0; \
|
|
||||||
beq- label##_iSeries_masked; \
|
|
||||||
EXCEPTION_PROLOG_ISERIES_2; \
|
|
||||||
b label##_common; \
|
|
||||||
|
|
||||||
#ifdef CONFIG_PPC_ISERIES
|
#ifdef CONFIG_PPC_ISERIES
|
||||||
#define DISABLE_INTS \
|
#define DISABLE_INTS \
|
||||||
li r11,0; \
|
li r11,0; \
|
||||||
|
Reference in New Issue
Block a user