aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/misc/mei
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/misc/mei')
-rw-r--r--drivers/misc/mei/hw-me.c35
-rw-r--r--drivers/misc/mei/init.c14
-rw-r--r--drivers/misc/mei/interrupt.c19
-rw-r--r--drivers/misc/mei/mei_dev.h4
4 files changed, 54 insertions, 18 deletions
diff --git a/drivers/misc/mei/hw-me.c b/drivers/misc/mei/hw-me.c
index ed61659fd388..49b558ddf5b5 100644
--- a/drivers/misc/mei/hw-me.c
+++ b/drivers/misc/mei/hw-me.c
@@ -172,6 +172,39 @@ void mei_hw_reset(struct mei_device *dev, bool intr_enable)
172 dev_dbg(&dev->pdev->dev, "current HCSR = 0x%08x.\n", hcsr); 172 dev_dbg(&dev->pdev->dev, "current HCSR = 0x%08x.\n", hcsr);
173} 173}
174 174
175/**
176 * mei_host_set_ready - enable device
177 *
178 * @dev - mei device
179 * returns bool
180 */
181
182void mei_host_set_ready(struct mei_device *dev)
183{
184 dev->host_hw_state |= H_IE | H_IG | H_RDY;
185 mei_hcsr_set(dev);
186}
187/**
188 * mei_host_is_ready - check whether the host has turned ready
189 *
190 * @dev - mei device
191 * returns bool
192 */
193bool mei_host_is_ready(struct mei_device *dev)
194{
195 return (dev->host_hw_state & H_RDY) == H_RDY;
196}
197
198/**
199 * mei_me_is_ready - check whether the me has turned ready
200 *
201 * @dev - mei device
202 * returns bool
203 */
204bool mei_me_is_ready(struct mei_device *dev)
205{
206 return (dev->me_hw_state & ME_RDY_HRA) == ME_RDY_HRA;
207}
175 208
176/** 209/**
177 * mei_interrupt_quick_handler - The ISR of the MEI device 210 * mei_interrupt_quick_handler - The ISR of the MEI device
@@ -290,7 +323,7 @@ int mei_write_message(struct mei_device *dev, struct mei_msg_hdr *header,
290 dev->host_hw_state |= H_IG; 323 dev->host_hw_state |= H_IG;
291 mei_hcsr_set(dev); 324 mei_hcsr_set(dev);
292 dev->me_hw_state = mei_mecsr_read(dev); 325 dev->me_hw_state = mei_mecsr_read(dev);
293 if ((dev->me_hw_state & ME_RDY_HRA) != ME_RDY_HRA) 326 if (!mei_me_is_ready(dev))
294 return -EIO; 327 return -EIO;
295 328
296 return 0; 329 return 0;
diff --git a/drivers/misc/mei/init.c b/drivers/misc/mei/init.c
index 5c2054d06f6b..d0ee02ac8201 100644
--- a/drivers/misc/mei/init.c
+++ b/drivers/misc/mei/init.c
@@ -131,18 +131,18 @@ int mei_hw_init(struct mei_device *dev)
131 goto out; 131 goto out;
132 } 132 }
133 133
134 if (!(((dev->host_hw_state & H_RDY) == H_RDY) && 134 if (!(mei_host_is_ready(dev) && mei_me_is_ready(dev))) {
135 ((dev->me_hw_state & ME_RDY_HRA) == ME_RDY_HRA))) {
136 dev->dev_state = MEI_DEV_DISABLED; 135 dev->dev_state = MEI_DEV_DISABLED;
136
137 dev_dbg(&dev->pdev->dev, 137 dev_dbg(&dev->pdev->dev,
138 "host_hw_state = 0x%08x, me_hw_state = 0x%08x.\n", 138 "host_hw_state = 0x%08x, me_hw_state = 0x%08x.\n",
139 dev->host_hw_state, dev->me_hw_state); 139 dev->host_hw_state, dev->me_hw_state);
140 140
141 if (!(dev->host_hw_state & H_RDY)) 141 if (!mei_host_is_ready(dev))
142 dev_dbg(&dev->pdev->dev, "host turn off H_RDY.\n"); 142 dev_dbg(&dev->pdev->dev, "host is not ready.\n");
143 143
144 if (!(dev->me_hw_state & ME_RDY_HRA)) 144 if (!mei_me_is_ready(dev))
145 dev_dbg(&dev->pdev->dev, "ME turn off ME_RDY.\n"); 145 dev_dbg(&dev->pdev->dev, "ME is not ready.\n");
146 146
147 dev_err(&dev->pdev->dev, "link layer initialization failed.\n"); 147 dev_err(&dev->pdev->dev, "link layer initialization failed.\n");
148 ret = -ENODEV; 148 ret = -ENODEV;
@@ -159,9 +159,7 @@ int mei_hw_init(struct mei_device *dev)
159 dev->recvd_msg = false; 159 dev->recvd_msg = false;
160 dev_dbg(&dev->pdev->dev, "host_hw_state = 0x%08x, me_hw_state = 0x%08x.\n", 160 dev_dbg(&dev->pdev->dev, "host_hw_state = 0x%08x, me_hw_state = 0x%08x.\n",
161 dev->host_hw_state, dev->me_hw_state); 161 dev->host_hw_state, dev->me_hw_state);
162 dev_dbg(&dev->pdev->dev, "ME turn on ME_RDY and host turn on H_RDY.\n");
163 dev_dbg(&dev->pdev->dev, "link layer has been established.\n"); 162 dev_dbg(&dev->pdev->dev, "link layer has been established.\n");
164 dev_dbg(&dev->pdev->dev, "MEI start success.\n");
165 ret = 0; 163 ret = 0;
166 164
167out: 165out:
diff --git a/drivers/misc/mei/interrupt.c b/drivers/misc/mei/interrupt.c
index d7e1b797e87b..27374b6b6424 100644
--- a/drivers/misc/mei/interrupt.c
+++ b/drivers/misc/mei/interrupt.c
@@ -700,7 +700,7 @@ irqreturn_t mei_interrupt_thread_handler(int irq, void *dev_id)
700 dev->me_hw_state = mei_mecsr_read(dev); 700 dev->me_hw_state = mei_mecsr_read(dev);
701 701
702 /* check if ME wants a reset */ 702 /* check if ME wants a reset */
703 if ((dev->me_hw_state & ME_RDY_HRA) == 0 && 703 if (!mei_me_is_ready(dev) &&
704 dev->dev_state != MEI_DEV_RESETING && 704 dev->dev_state != MEI_DEV_RESETING &&
705 dev->dev_state != MEI_DEV_INITIALIZING) { 705 dev->dev_state != MEI_DEV_INITIALIZING) {
706 dev_dbg(&dev->pdev->dev, "FW not ready.\n"); 706 dev_dbg(&dev->pdev->dev, "FW not ready.\n");
@@ -711,16 +711,17 @@ irqreturn_t mei_interrupt_thread_handler(int irq, void *dev_id)
711 711
712 dev->host_hw_state = mei_hcsr_read(dev); 712 dev->host_hw_state = mei_hcsr_read(dev);
713 /* check if we need to start the dev */ 713 /* check if we need to start the dev */
714 if ((dev->host_hw_state & H_RDY) == 0) { 714 if (!mei_host_is_ready(dev)) {
715 if ((dev->me_hw_state & ME_RDY_HRA) == ME_RDY_HRA) { 715 if (mei_me_is_ready(dev)) {
716 dev_dbg(&dev->pdev->dev, "we need to start the dev.\n"); 716 dev_dbg(&dev->pdev->dev, "we need to start the dev.\n");
717 dev->host_hw_state |= (H_IE | H_IG | H_RDY); 717
718 mei_hcsr_set(dev); 718 mei_host_set_ready(dev);
719 dev->dev_state = MEI_DEV_INIT_CLIENTS; 719
720 dev_dbg(&dev->pdev->dev, "link is established start sending messages.\n"); 720 dev_dbg(&dev->pdev->dev, "link is established start sending messages.\n");
721 /* link is established 721 /* link is established * start sending messages. */
722 * start sending messages. 722
723 */ 723 dev->dev_state = MEI_DEV_INIT_CLIENTS;
724
724 mei_hbm_start_req(dev); 725 mei_hbm_start_req(dev);
725 mutex_unlock(&dev->device_lock); 726 mutex_unlock(&dev->device_lock);
726 return IRQ_HANDLED; 727 return IRQ_HANDLED;
diff --git a/drivers/misc/mei/mei_dev.h b/drivers/misc/mei/mei_dev.h
index 8692ac8c98d4..7b4365952be5 100644
--- a/drivers/misc/mei/mei_dev.h
+++ b/drivers/misc/mei/mei_dev.h
@@ -396,6 +396,10 @@ void mei_clear_interrupts(struct mei_device *dev);
396void mei_enable_interrupts(struct mei_device *dev); 396void mei_enable_interrupts(struct mei_device *dev);
397void mei_disable_interrupts(struct mei_device *dev); 397void mei_disable_interrupts(struct mei_device *dev);
398 398
399void mei_host_set_ready(struct mei_device *dev);
400bool mei_host_is_ready(struct mei_device *dev);
401bool mei_me_is_ready(struct mei_device *dev);
402
399 403
400 404
401#define MEI_HDR_FMT "hdr:host=%02d me=%02d len=%d comp=%1d" 405#define MEI_HDR_FMT "hdr:host=%02d me=%02d len=%d comp=%1d"