提交 d76689e4 编写于 作者: J Jeff Skirvin 提交者: Dan Williams

isci: Fix RNC suspend call for SCI_RESUMING state.

Instead of immediately transitioning to the SCI_RNC_AWAIT_SUSPENSION
state, handle the SCI_RNC_RESUMING suspend transition from the
SCI_RNC_READY state like the SCI_RNC_INVALIDATING --> SCI_RNC_POSTING
transitions do now, by setting the destination state for the entry
into the READY state.
Signed-off-by: NJeff Skirvin <jeffrey.d.skirvin@intel.com>
Signed-off-by: NDan Williams <dan.j.williams@intel.com>
上级 621120ca
...@@ -321,8 +321,6 @@ static void sci_remote_node_context_ready_state_enter(struct sci_base_state_mach ...@@ -321,8 +321,6 @@ static void sci_remote_node_context_ready_state_enter(struct sci_base_state_mach
{ {
struct sci_remote_node_context *rnc = container_of(sm, typeof(*rnc), sm); struct sci_remote_node_context *rnc = container_of(sm, typeof(*rnc), sm);
enum sci_remote_node_context_destination_state dest_select; enum sci_remote_node_context_destination_state dest_select;
scics_sds_remote_node_context_callback usr_cb = rnc->user_callback;
void *usr_param = rnc->user_cookie;
int tell_user = 1; int tell_user = 1;
dest_select = rnc->destination_state; dest_select = rnc->destination_state;
...@@ -334,12 +332,10 @@ static void sci_remote_node_context_ready_state_enter(struct sci_base_state_mach ...@@ -334,12 +332,10 @@ static void sci_remote_node_context_ready_state_enter(struct sci_base_state_mach
rnc, rnc->suspend_reason, rnc, rnc->suspend_reason,
SCI_SOFTWARE_SUSPEND_EXPECTED_EVENT); SCI_SOFTWARE_SUSPEND_EXPECTED_EVENT);
if (dest_select == RNC_DEST_SUSPENDED_RESUME) { if (dest_select == RNC_DEST_SUSPENDED_RESUME)
sci_remote_node_context_resume(rnc, usr_cb, usr_param);
tell_user = 0; /* Wait until ready again. */ tell_user = 0; /* Wait until ready again. */
} }
} if (tell_user)
if (tell_user && rnc->user_callback)
sci_remote_node_context_notify_user(rnc); sci_remote_node_context_notify_user(rnc);
} }
...@@ -584,8 +580,6 @@ enum sci_status sci_remote_node_context_suspend( ...@@ -584,8 +580,6 @@ enum sci_status sci_remote_node_context_suspend(
dest_param = sci_rnc->destination_state; dest_param = sci_rnc->destination_state;
switch (state) { switch (state) {
case SCI_RNC_RESUMING:
break; /* The RNC has been posted, so start the suspend. */
case SCI_RNC_READY: case SCI_RNC_READY:
break; break;
case SCI_RNC_INVALIDATING: case SCI_RNC_INVALIDATING:
...@@ -596,6 +590,8 @@ enum sci_status sci_remote_node_context_suspend( ...@@ -596,6 +590,8 @@ enum sci_status sci_remote_node_context_suspend(
return SCI_FAILURE_INVALID_STATE; return SCI_FAILURE_INVALID_STATE;
} }
/* Fall through and handle like SCI_RNC_POSTING */ /* Fall through and handle like SCI_RNC_POSTING */
case SCI_RNC_RESUMING:
/* Fall through and handle like SCI_RNC_POSTING */
case SCI_RNC_POSTING: case SCI_RNC_POSTING:
/* Set the destination state to AWAIT - this signals the /* Set the destination state to AWAIT - this signals the
* entry into the SCI_RNC_READY state that a suspension * entry into the SCI_RNC_READY state that a suspension
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册