summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGavin Shan <gwshan@linux.vnet.ibm.com>2014-09-30 04:39:06 +0200
committerMichael Ellerman <mpe@ellerman.id.au>2014-09-30 09:15:17 +0200
commit93e8b36d7bf5c54f1c52d8b78e34f88e52a3dfa2 (patch)
treea69f705f38ab690bf1dcc5d5f318f237b1593453
parentpowerpc/powernv: Sync OpalPciResetScope with firmware (diff)
downloadlinux-93e8b36d7bf5c54f1c52d8b78e34f88e52a3dfa2.tar.xz
linux-93e8b36d7bf5c54f1c52d8b78e34f88e52a3dfa2.zip
powerpc/eeh: Tag reset state for user owned PE
PE would be owned by userland, which probably request PE reset done in host side. During the reset, we should drop the PCI config accesses to the PE with help of flag EEH_PE_RESET. Signed-off-by: Gavin Shan <gwshan@linux.vnet.ibm.com> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
-rw-r--r--arch/powerpc/kernel/eeh.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/powerpc/kernel/eeh.c b/arch/powerpc/kernel/eeh.c
index eb266f4ee9be..693690827785 100644
--- a/arch/powerpc/kernel/eeh.c
+++ b/arch/powerpc/kernel/eeh.c
@@ -1463,6 +1463,7 @@ int eeh_pe_reset(struct eeh_pe *pe, int option)
switch (option) {
case EEH_RESET_DEACTIVATE:
ret = eeh_ops->reset(pe, option);
+ eeh_pe_state_clear(pe, EEH_PE_RESET);
if (ret)
break;
@@ -1477,6 +1478,7 @@ int eeh_pe_reset(struct eeh_pe *pe, int option)
*/
eeh_ops->set_option(pe, EEH_OPT_FREEZE_PE);
+ eeh_pe_state_mark(pe, EEH_PE_RESET);
ret = eeh_ops->reset(pe, option);
break;
default: