aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/misc
diff options
context:
space:
mode:
authorTomas Winkler <tomas.winkler@intel.com>2014-05-12 05:19:41 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2014-05-27 17:15:25 -0400
commitc40765d919d25d2d44d99c4ce39e48808f137e1e (patch)
tree4be1e385deaca595360f327f40931e372350b418 /drivers/misc
parent07cd7be3d92eeeae1f92a017f2cfe4fdd9256526 (diff)
mei: me: read H_CSR after asserting reset
According the spec the host should read H_CSR again after asserting reset H_RST to ensure that reset was read by the firmware Cc: stable@vger.kernel.org Signed-off-by: Tomas Winkler <tomas.winkler@intel.com> Signed-off-by: Alexander Usyskin <alexander.usyskin@intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/misc')
-rw-r--r--drivers/misc/mei/hw-me.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/drivers/misc/mei/hw-me.c b/drivers/misc/mei/hw-me.c
index 031efcfed39e..016ad88a2887 100644
--- a/drivers/misc/mei/hw-me.c
+++ b/drivers/misc/mei/hw-me.c
@@ -206,6 +206,18 @@ static int mei_me_hw_reset(struct mei_device *dev, bool intr_enable)
206 dev->recvd_hw_ready = false; 206 dev->recvd_hw_ready = false;
207 mei_me_reg_write(hw, H_CSR, hcsr); 207 mei_me_reg_write(hw, H_CSR, hcsr);
208 208
209 /*
210 * Host reads the H_CSR once to ensure that the
211 * posted write to H_CSR completes.
212 */
213 hcsr = mei_hcsr_read(hw);
214
215 if ((hcsr & H_RST) == 0)
216 dev_warn(&dev->pdev->dev, "H_RST is not set = 0x%08X", hcsr);
217
218 if ((hcsr & H_RDY) == H_RDY)
219 dev_warn(&dev->pdev->dev, "H_RDY is not cleared 0x%08X", hcsr);
220
209 if (intr_enable == false) 221 if (intr_enable == false)
210 mei_me_hw_reset_release(dev); 222 mei_me_hw_reset_release(dev);
211 223