diff options
| -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" |
