Commit 8f19e3da authored by Akira Takeuchi's avatar Akira Takeuchi Committed by David Howells

MN10300: AM34 erratum requires MMUCTR read and write on exception entry

An AM34 erratum requires MMUCTR read and write on entry to certain exceptions,
prior to EPSW.NMID being cleared to allow NMIs to happen.
Signed-off-by: default avatarAkira Takeuchi <takeuchi.akr@jp.panasonic.com>
Signed-off-by: default avatarKiyoshi Owada <owada.kiyoshi@jp.panasonic.com>
Signed-off-by: default avatarDavid Howells <dhowells@redhat.com>
parent 63317186
...@@ -20,6 +20,9 @@ config AM34_2 ...@@ -20,6 +20,9 @@ config AM34_2
select MN10300_HAS_ATOMIC_OPS_UNIT select MN10300_HAS_ATOMIC_OPS_UNIT
select MN10300_HAS_CACHE_SNOOP select MN10300_HAS_CACHE_SNOOP
config ERRATUM_NEED_TO_RELOAD_MMUCTR
def_bool y if AM33_3 || AM34_2
config MMU config MMU
def_bool y def_bool y
......
...@@ -251,6 +251,10 @@ double_fault_loop: ...@@ -251,6 +251,10 @@ double_fault_loop:
ENTRY(raw_bus_error) ENTRY(raw_bus_error)
add -4,sp add -4,sp
mov d0,(sp) mov d0,(sp)
#if defined(CONFIG_ERRATUM_NEED_TO_RELOAD_MMUCTR)
mov (MMUCTR),d0
mov d0,(MMUCTR)
#endif
mov (BCBERR),d0 # what mov (BCBERR),d0 # what
btst BCBERR_BEMR_DMA,d0 # see if it was an external bus error btst BCBERR_BEMR_DMA,d0 # see if it was an external bus error
beq __common_exception_aux # it wasn't beq __common_exception_aux # it wasn't
...@@ -282,6 +286,10 @@ ENTRY(nmi_handler) ...@@ -282,6 +286,10 @@ ENTRY(nmi_handler)
ENTRY(__common_exception) ENTRY(__common_exception)
add -4,sp add -4,sp
mov d0,(sp) mov d0,(sp)
#if defined(CONFIG_ERRATUM_NEED_TO_RELOAD_MMUCTR)
mov (MMUCTR),d0
mov d0,(MMUCTR)
#endif
__common_exception_aux: __common_exception_aux:
mov (TBR),d0 mov (TBR),d0
......
...@@ -27,7 +27,6 @@ ...@@ -27,7 +27,6 @@
############################################################################### ###############################################################################
.type itlb_miss,@function .type itlb_miss,@function
ENTRY(itlb_miss) ENTRY(itlb_miss)
and ~EPSW_NMID,epsw
#ifdef CONFIG_GDBSTUB #ifdef CONFIG_GDBSTUB
movm [d2,d3,a2],(sp) movm [d2,d3,a2],(sp)
#else #else
...@@ -38,6 +37,12 @@ ENTRY(itlb_miss) ...@@ -38,6 +37,12 @@ ENTRY(itlb_miss)
nop nop
#endif #endif
#if defined(CONFIG_ERRATUM_NEED_TO_RELOAD_MMUCTR)
mov (MMUCTR),d2
mov d2,(MMUCTR)
#endif
and ~EPSW_NMID,epsw
mov (IPTEU),d3 mov (IPTEU),d3
mov (PTBR),a2 mov (PTBR),a2
mov d3,d2 mov d3,d2
...@@ -79,7 +84,6 @@ itlb_miss_fault: ...@@ -79,7 +84,6 @@ itlb_miss_fault:
############################################################################### ###############################################################################
.type dtlb_miss,@function .type dtlb_miss,@function
ENTRY(dtlb_miss) ENTRY(dtlb_miss)
and ~EPSW_NMID,epsw
#ifdef CONFIG_GDBSTUB #ifdef CONFIG_GDBSTUB
movm [d2,d3,a2],(sp) movm [d2,d3,a2],(sp)
#else #else
...@@ -90,6 +94,12 @@ ENTRY(dtlb_miss) ...@@ -90,6 +94,12 @@ ENTRY(dtlb_miss)
nop nop
#endif #endif
#if defined(CONFIG_ERRATUM_NEED_TO_RELOAD_MMUCTR)
mov (MMUCTR),d2
mov d2,(MMUCTR)
#endif
and ~EPSW_NMID,epsw
mov (DPTEU),d3 mov (DPTEU),d3
mov (PTBR),a2 mov (PTBR),a2
mov d3,d2 mov d3,d2
...@@ -130,9 +140,15 @@ dtlb_miss_fault: ...@@ -130,9 +140,15 @@ dtlb_miss_fault:
############################################################################### ###############################################################################
.type itlb_aerror,@function .type itlb_aerror,@function
ENTRY(itlb_aerror) ENTRY(itlb_aerror)
and ~EPSW_NMID,epsw
add -4,sp add -4,sp
SAVE_ALL SAVE_ALL
#if defined(CONFIG_ERRATUM_NEED_TO_RELOAD_MMUCTR)
mov (MMUCTR),d1
mov d1,(MMUCTR)
#endif
and ~EPSW_NMID,epsw
add -4,sp # need to pass three params add -4,sp # need to pass three params
# calculate the fault code # calculate the fault code
...@@ -148,7 +164,6 @@ ENTRY(itlb_aerror) ...@@ -148,7 +164,6 @@ ENTRY(itlb_aerror)
clr d0 clr d0
mov d0,(IPTEL) mov d0,(IPTEL)
and ~EPSW_NMID,epsw
or EPSW_IE,epsw or EPSW_IE,epsw
mov fp,d0 mov fp,d0
call do_page_fault[],0 # do_page_fault(regs,code,addr call do_page_fault[],0 # do_page_fault(regs,code,addr
...@@ -163,10 +178,16 @@ ENTRY(itlb_aerror) ...@@ -163,10 +178,16 @@ ENTRY(itlb_aerror)
############################################################################### ###############################################################################
.type dtlb_aerror,@function .type dtlb_aerror,@function
ENTRY(dtlb_aerror) ENTRY(dtlb_aerror)
and ~EPSW_NMID,epsw
add -4,sp add -4,sp
SAVE_ALL SAVE_ALL
#if defined(CONFIG_ERRATUM_NEED_TO_RELOAD_MMUCTR)
mov (MMUCTR),d1
mov d1,(MMUCTR)
#endif
add -4,sp # need to pass three params add -4,sp # need to pass three params
and ~EPSW_NMID,epsw
# calculate the fault code # calculate the fault code
movhu (MMUFCR_DFC),d1 movhu (MMUFCR_DFC),d1
...@@ -180,7 +201,6 @@ ENTRY(dtlb_aerror) ...@@ -180,7 +201,6 @@ ENTRY(dtlb_aerror)
clr d0 clr d0
mov d0,(DPTEL) mov d0,(DPTEL)
and ~EPSW_NMID,epsw
or EPSW_IE,epsw or EPSW_IE,epsw
mov fp,d0 mov fp,d0
call do_page_fault[],0 # do_page_fault(regs,code,addr call do_page_fault[],0 # do_page_fault(regs,code,addr
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment