diff options
author | Tomas Winkler <tomas.winkler@intel.com> | 2013-01-08 16:07:29 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2013-01-08 19:40:47 -0500 |
commit | 115ba28c5e075c6bffd8106a2b5e23db88d0c3b5 (patch) | |
tree | 20e0f51fbbc9669f960e40ddc443fa2a4e3a4f56 /drivers/misc/mei | |
parent | 9ea73ddd4f144952b8f69fac93dc592ea48e4113 (diff) |
mei: abstract host and device readieness
Add mei_host_set_ready function to enable the device
and is_ready function to query the host and me readiness
Signed-off-by: Tomas Winkler <tomas.winkler@intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/misc/mei')
-rw-r--r-- | drivers/misc/mei/hw-me.c | 35 | ||||
-rw-r--r-- | drivers/misc/mei/init.c | 14 | ||||
-rw-r--r-- | drivers/misc/mei/interrupt.c | 19 | ||||
-rw-r--r-- | drivers/misc/mei/mei_dev.h | 4 |
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 | |||
182 | void 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 | */ | ||
193 | bool 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 | */ | ||
204 | bool 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 | ||
167 | out: | 165 | out: |
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); | |||
396 | void mei_enable_interrupts(struct mei_device *dev); | 396 | void mei_enable_interrupts(struct mei_device *dev); |
397 | void mei_disable_interrupts(struct mei_device *dev); | 397 | void mei_disable_interrupts(struct mei_device *dev); |
398 | 398 | ||
399 | void mei_host_set_ready(struct mei_device *dev); | ||
400 | bool mei_host_is_ready(struct mei_device *dev); | ||
401 | bool 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" |