Commit d5560238 authored by Ido Yariv's avatar Ido Yariv Committed by Luciano Coelho

wlcore: Allow memory access when the FW crashes

When the no_recovery flag is used, the recovery work will not restart
the FW and the state will not be set to 'on'. To enable post-mortem
analysis, allow memory access in the 'restarting' state.

Also, since the FW might not be operational, don't fail the read/write
operations if elp_wakeup fails.
Reported-by: default avatarArkady Miasnikov <a-miasnikov@ti.com>
Signed-off-by: default avatarIdo Yariv <ido@wizery.com>
Signed-off-by: default avatarLuciano Coelho <luca@coelho.fi>
parent 001e39a8
...@@ -1064,14 +1064,16 @@ static ssize_t dev_mem_read(struct file *file, ...@@ -1064,14 +1064,16 @@ static ssize_t dev_mem_read(struct file *file,
mutex_lock(&wl->mutex); mutex_lock(&wl->mutex);
if (unlikely(wl->state != WLCORE_STATE_ON)) { if (unlikely(wl->state == WLCORE_STATE_OFF)) {
ret = -EFAULT; ret = -EFAULT;
goto skip_read; goto skip_read;
} }
ret = wl1271_ps_elp_wakeup(wl); /*
if (ret < 0) * Don't fail if elp_wakeup returns an error, so the device's memory
goto skip_read; * could be read even if the FW crashed
*/
wl1271_ps_elp_wakeup(wl);
/* store current partition and switch partition */ /* store current partition and switch partition */
memcpy(&old_part, &wl->curr_part, sizeof(old_part)); memcpy(&old_part, &wl->curr_part, sizeof(old_part));
...@@ -1149,14 +1151,16 @@ static ssize_t dev_mem_write(struct file *file, const char __user *user_buf, ...@@ -1149,14 +1151,16 @@ static ssize_t dev_mem_write(struct file *file, const char __user *user_buf,
mutex_lock(&wl->mutex); mutex_lock(&wl->mutex);
if (unlikely(wl->state != WLCORE_STATE_ON)) { if (unlikely(wl->state == WLCORE_STATE_OFF)) {
ret = -EFAULT; ret = -EFAULT;
goto skip_write; goto skip_write;
} }
ret = wl1271_ps_elp_wakeup(wl); /*
if (ret < 0) * Don't fail if elp_wakeup returns an error, so the device's memory
goto skip_write; * could be read even if the FW crashed
*/
wl1271_ps_elp_wakeup(wl);
/* store current partition and switch partition */ /* store current partition and switch partition */
memcpy(&old_part, &wl->curr_part, sizeof(old_part)); memcpy(&old_part, &wl->curr_part, sizeof(old_part));
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment