提交 2bf94cab 编写于 作者: T Tomas Winkler 提交者: Greg Kroah-Hartman

mei: get rid of most of the pci dependencies in mei

For purpose of adding testing HW we would like
to get rid of pci dependency in generic mei code
This patch provides only straight forward changes
FW status and prob quirks need to be handled separately
Signed-off-by: NTomas Winkler <tomas.winkler@intel.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 3a7e9b6c
...@@ -78,7 +78,7 @@ int mei_amthif_host_init(struct mei_device *dev) ...@@ -78,7 +78,7 @@ int mei_amthif_host_init(struct mei_device *dev)
me_cl = mei_me_cl_by_uuid(dev, &mei_amthif_guid); me_cl = mei_me_cl_by_uuid(dev, &mei_amthif_guid);
if (!me_cl) { if (!me_cl) {
dev_info(&dev->pdev->dev, "amthif: failed to find the client"); dev_info(dev->dev, "amthif: failed to find the client");
return -ENOTTY; return -ENOTTY;
} }
...@@ -88,7 +88,7 @@ int mei_amthif_host_init(struct mei_device *dev) ...@@ -88,7 +88,7 @@ int mei_amthif_host_init(struct mei_device *dev)
/* Assign iamthif_mtu to the value received from ME */ /* Assign iamthif_mtu to the value received from ME */
dev->iamthif_mtu = me_cl->props.max_msg_length; dev->iamthif_mtu = me_cl->props.max_msg_length;
dev_dbg(&dev->pdev->dev, "IAMTHIF_MTU = %d\n", dev->iamthif_mtu); dev_dbg(dev->dev, "IAMTHIF_MTU = %d\n", dev->iamthif_mtu);
kfree(dev->iamthif_msg_buf); kfree(dev->iamthif_msg_buf);
dev->iamthif_msg_buf = NULL; dev->iamthif_msg_buf = NULL;
...@@ -104,7 +104,7 @@ int mei_amthif_host_init(struct mei_device *dev) ...@@ -104,7 +104,7 @@ int mei_amthif_host_init(struct mei_device *dev)
ret = mei_cl_link(cl, MEI_IAMTHIF_HOST_CLIENT_ID); ret = mei_cl_link(cl, MEI_IAMTHIF_HOST_CLIENT_ID);
if (ret < 0) { if (ret < 0) {
dev_err(&dev->pdev->dev, dev_err(dev->dev,
"amthif: failed link client %d\n", ret); "amthif: failed link client %d\n", ret);
return ret; return ret;
} }
...@@ -164,11 +164,11 @@ int mei_amthif_read(struct mei_device *dev, struct file *file, ...@@ -164,11 +164,11 @@ int mei_amthif_read(struct mei_device *dev, struct file *file,
/* Only possible if we are in timeout */ /* Only possible if we are in timeout */
if (!cl) { if (!cl) {
dev_err(&dev->pdev->dev, "bad file ext.\n"); dev_err(dev->dev, "bad file ext.\n");
return -ETIME; return -ETIME;
} }
dev_dbg(&dev->pdev->dev, "checking amthif data\n"); dev_dbg(dev->dev, "checking amthif data\n");
cb = mei_amthif_find_read_list_entry(dev, file); cb = mei_amthif_find_read_list_entry(dev, file);
/* Check for if we can block or not*/ /* Check for if we can block or not*/
...@@ -176,7 +176,7 @@ int mei_amthif_read(struct mei_device *dev, struct file *file, ...@@ -176,7 +176,7 @@ int mei_amthif_read(struct mei_device *dev, struct file *file,
return -EAGAIN; return -EAGAIN;
dev_dbg(&dev->pdev->dev, "waiting for amthif data\n"); dev_dbg(dev->dev, "waiting for amthif data\n");
while (cb == NULL) { while (cb == NULL) {
/* unlock the Mutex */ /* unlock the Mutex */
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
...@@ -190,21 +190,21 @@ int mei_amthif_read(struct mei_device *dev, struct file *file, ...@@ -190,21 +190,21 @@ int mei_amthif_read(struct mei_device *dev, struct file *file,
if (wait_ret) if (wait_ret)
return -ERESTARTSYS; return -ERESTARTSYS;
dev_dbg(&dev->pdev->dev, "woke up from sleep\n"); dev_dbg(dev->dev, "woke up from sleep\n");
} }
dev_dbg(&dev->pdev->dev, "Got amthif data\n"); dev_dbg(dev->dev, "Got amthif data\n");
dev->iamthif_timer = 0; dev->iamthif_timer = 0;
if (cb) { if (cb) {
timeout = cb->read_time + timeout = cb->read_time +
mei_secs_to_jiffies(MEI_IAMTHIF_READ_TIMER); mei_secs_to_jiffies(MEI_IAMTHIF_READ_TIMER);
dev_dbg(&dev->pdev->dev, "amthif timeout = %lud\n", dev_dbg(dev->dev, "amthif timeout = %lud\n",
timeout); timeout);
if (time_after(jiffies, timeout)) { if (time_after(jiffies, timeout)) {
dev_dbg(&dev->pdev->dev, "amthif Time out\n"); dev_dbg(dev->dev, "amthif Time out\n");
/* 15 sec for the message has expired */ /* 15 sec for the message has expired */
list_del(&cb->list); list_del(&cb->list);
rets = -ETIME; rets = -ETIME;
...@@ -224,16 +224,16 @@ int mei_amthif_read(struct mei_device *dev, struct file *file, ...@@ -224,16 +224,16 @@ int mei_amthif_read(struct mei_device *dev, struct file *file,
* remove message from deletion list * remove message from deletion list
*/ */
dev_dbg(&dev->pdev->dev, "amthif cb->response_buffer size - %d\n", dev_dbg(dev->dev, "amthif cb->response_buffer size - %d\n",
cb->response_buffer.size); cb->response_buffer.size);
dev_dbg(&dev->pdev->dev, "amthif cb->buf_idx - %lu\n", cb->buf_idx); dev_dbg(dev->dev, "amthif cb->buf_idx - %lu\n", cb->buf_idx);
/* length is being truncated to PAGE_SIZE, however, /* length is being truncated to PAGE_SIZE, however,
* the buf_idx may point beyond */ * the buf_idx may point beyond */
length = min_t(size_t, length, (cb->buf_idx - *offset)); length = min_t(size_t, length, (cb->buf_idx - *offset));
if (copy_to_user(ubuf, cb->response_buffer.data + *offset, length)) { if (copy_to_user(ubuf, cb->response_buffer.data + *offset, length)) {
dev_dbg(&dev->pdev->dev, "failed to copy data to userland\n"); dev_dbg(dev->dev, "failed to copy data to userland\n");
rets = -EFAULT; rets = -EFAULT;
} else { } else {
rets = length; rets = length;
...@@ -243,7 +243,7 @@ int mei_amthif_read(struct mei_device *dev, struct file *file, ...@@ -243,7 +243,7 @@ int mei_amthif_read(struct mei_device *dev, struct file *file,
} }
} }
free: free:
dev_dbg(&dev->pdev->dev, "free amthif cb memory.\n"); dev_dbg(dev->dev, "free amthif cb memory.\n");
*offset = 0; *offset = 0;
mei_io_cb_free(cb); mei_io_cb_free(cb);
out: out:
...@@ -267,7 +267,7 @@ static int mei_amthif_send_cmd(struct mei_device *dev, struct mei_cl_cb *cb) ...@@ -267,7 +267,7 @@ static int mei_amthif_send_cmd(struct mei_device *dev, struct mei_cl_cb *cb)
if (!dev || !cb) if (!dev || !cb)
return -ENODEV; return -ENODEV;
dev_dbg(&dev->pdev->dev, "write data to amthif client.\n"); dev_dbg(dev->dev, "write data to amthif client.\n");
dev->iamthif_state = MEI_IAMTHIF_WRITING; dev->iamthif_state = MEI_IAMTHIF_WRITING;
dev->iamthif_current_cb = cb; dev->iamthif_current_cb = cb;
...@@ -306,12 +306,12 @@ static int mei_amthif_send_cmd(struct mei_device *dev, struct mei_cl_cb *cb) ...@@ -306,12 +306,12 @@ static int mei_amthif_send_cmd(struct mei_device *dev, struct mei_cl_cb *cb)
return -EIO; return -EIO;
dev->iamthif_flow_control_pending = true; dev->iamthif_flow_control_pending = true;
dev->iamthif_state = MEI_IAMTHIF_FLOW_CONTROL; dev->iamthif_state = MEI_IAMTHIF_FLOW_CONTROL;
dev_dbg(&dev->pdev->dev, "add amthif cb to write waiting list\n"); dev_dbg(dev->dev, "add amthif cb to write waiting list\n");
dev->iamthif_current_cb = cb; dev->iamthif_current_cb = cb;
dev->iamthif_file_object = cb->file_object; dev->iamthif_file_object = cb->file_object;
list_add_tail(&cb->list, &dev->write_waiting_list.list); list_add_tail(&cb->list, &dev->write_waiting_list.list);
} else { } else {
dev_dbg(&dev->pdev->dev, "message does not complete, so add amthif cb to write list.\n"); dev_dbg(dev->dev, "message does not complete, so add amthif cb to write list.\n");
list_add_tail(&cb->list, &dev->write_list.list); list_add_tail(&cb->list, &dev->write_list.list);
} }
} else { } else {
...@@ -344,9 +344,9 @@ int mei_amthif_write(struct mei_device *dev, struct mei_cl_cb *cb) ...@@ -344,9 +344,9 @@ int mei_amthif_write(struct mei_device *dev, struct mei_cl_cb *cb)
if (!list_empty(&dev->amthif_cmd_list.list) || if (!list_empty(&dev->amthif_cmd_list.list) ||
dev->iamthif_state != MEI_IAMTHIF_IDLE) { dev->iamthif_state != MEI_IAMTHIF_IDLE) {
dev_dbg(&dev->pdev->dev, dev_dbg(dev->dev,
"amthif state = %d\n", dev->iamthif_state); "amthif state = %d\n", dev->iamthif_state);
dev_dbg(&dev->pdev->dev, "AMTHIF: add cb to the wait list\n"); dev_dbg(dev->dev, "AMTHIF: add cb to the wait list\n");
list_add_tail(&cb->list, &dev->amthif_cmd_list.list); list_add_tail(&cb->list, &dev->amthif_cmd_list.list);
return 0; return 0;
} }
...@@ -376,7 +376,7 @@ void mei_amthif_run_next_cmd(struct mei_device *dev) ...@@ -376,7 +376,7 @@ void mei_amthif_run_next_cmd(struct mei_device *dev)
dev->iamthif_timer = 0; dev->iamthif_timer = 0;
dev->iamthif_file_object = NULL; dev->iamthif_file_object = NULL;
dev_dbg(&dev->pdev->dev, "complete amthif cmd_list cb.\n"); dev_dbg(dev->dev, "complete amthif cmd_list cb.\n");
list_for_each_entry_safe(cb, next, &dev->amthif_cmd_list.list, list) { list_for_each_entry_safe(cb, next, &dev->amthif_cmd_list.list, list) {
list_del(&cb->list); list_del(&cb->list);
...@@ -384,7 +384,7 @@ void mei_amthif_run_next_cmd(struct mei_device *dev) ...@@ -384,7 +384,7 @@ void mei_amthif_run_next_cmd(struct mei_device *dev)
continue; continue;
status = mei_amthif_send_cmd(dev, cb); status = mei_amthif_send_cmd(dev, cb);
if (status) if (status)
dev_warn(&dev->pdev->dev, "amthif write failed status = %d\n", dev_warn(dev->dev, "amthif write failed status = %d\n",
status); status);
break; break;
} }
...@@ -407,7 +407,7 @@ unsigned int mei_amthif_poll(struct mei_device *dev, ...@@ -407,7 +407,7 @@ unsigned int mei_amthif_poll(struct mei_device *dev,
dev->iamthif_file_object == file) { dev->iamthif_file_object == file) {
mask |= (POLLIN | POLLRDNORM); mask |= (POLLIN | POLLRDNORM);
dev_dbg(&dev->pdev->dev, "run next amthif cb\n"); dev_dbg(dev->dev, "run next amthif cb\n");
mei_amthif_run_next_cmd(dev); mei_amthif_run_next_cmd(dev);
} }
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
...@@ -467,7 +467,7 @@ int mei_amthif_irq_write(struct mei_cl *cl, struct mei_cl_cb *cb, ...@@ -467,7 +467,7 @@ int mei_amthif_irq_write(struct mei_cl *cl, struct mei_cl_cb *cb,
return 0; return 0;
} }
dev_dbg(&dev->pdev->dev, MEI_HDR_FMT, MEI_HDR_PRM(&mei_hdr)); dev_dbg(dev->dev, MEI_HDR_FMT, MEI_HDR_PRM(&mei_hdr));
rets = mei_write_message(dev, &mei_hdr, rets = mei_write_message(dev, &mei_hdr,
dev->iamthif_msg_buf + dev->iamthif_msg_buf_index); dev->iamthif_msg_buf + dev->iamthif_msg_buf_index);
...@@ -529,10 +529,10 @@ int mei_amthif_irq_read_msg(struct mei_device *dev, ...@@ -529,10 +529,10 @@ int mei_amthif_irq_read_msg(struct mei_device *dev,
if (!mei_hdr->msg_complete) if (!mei_hdr->msg_complete)
return 0; return 0;
dev_dbg(&dev->pdev->dev, "amthif_message_buffer_index =%d\n", dev_dbg(dev->dev, "amthif_message_buffer_index =%d\n",
mei_hdr->length); mei_hdr->length);
dev_dbg(&dev->pdev->dev, "completed amthif read.\n "); dev_dbg(dev->dev, "completed amthif read.\n ");
if (!dev->iamthif_current_cb) if (!dev->iamthif_current_cb)
return -ENODEV; return -ENODEV;
...@@ -547,8 +547,8 @@ int mei_amthif_irq_read_msg(struct mei_device *dev, ...@@ -547,8 +547,8 @@ int mei_amthif_irq_read_msg(struct mei_device *dev,
cb->read_time = jiffies; cb->read_time = jiffies;
if (dev->iamthif_ioctl) { if (dev->iamthif_ioctl) {
/* found the iamthif cb */ /* found the iamthif cb */
dev_dbg(&dev->pdev->dev, "complete the amthif read cb.\n "); dev_dbg(dev->dev, "complete the amthif read cb.\n ");
dev_dbg(&dev->pdev->dev, "add the amthif read cb to complete.\n "); dev_dbg(dev->dev, "add the amthif read cb to complete.\n ");
list_add_tail(&cb->list, &complete_list->list); list_add_tail(&cb->list, &complete_list->list);
} }
return 0; return 0;
...@@ -572,11 +572,11 @@ int mei_amthif_irq_read(struct mei_device *dev, s32 *slots) ...@@ -572,11 +572,11 @@ int mei_amthif_irq_read(struct mei_device *dev, s32 *slots)
*slots -= msg_slots; *slots -= msg_slots;
if (mei_hbm_cl_flow_control_req(dev, &dev->iamthif_cl)) { if (mei_hbm_cl_flow_control_req(dev, &dev->iamthif_cl)) {
dev_dbg(&dev->pdev->dev, "iamthif flow control failed\n"); dev_dbg(dev->dev, "iamthif flow control failed\n");
return -EIO; return -EIO;
} }
dev_dbg(&dev->pdev->dev, "iamthif flow control success\n"); dev_dbg(dev->dev, "iamthif flow control success\n");
dev->iamthif_state = MEI_IAMTHIF_READING; dev->iamthif_state = MEI_IAMTHIF_READING;
dev->iamthif_flow_control_pending = false; dev->iamthif_flow_control_pending = false;
dev->iamthif_msg_buf_index = 0; dev->iamthif_msg_buf_index = 0;
...@@ -601,15 +601,15 @@ void mei_amthif_complete(struct mei_device *dev, struct mei_cl_cb *cb) ...@@ -601,15 +601,15 @@ void mei_amthif_complete(struct mei_device *dev, struct mei_cl_cb *cb)
dev->iamthif_msg_buf, dev->iamthif_msg_buf,
dev->iamthif_msg_buf_index); dev->iamthif_msg_buf_index);
list_add_tail(&cb->list, &dev->amthif_rd_complete_list.list); list_add_tail(&cb->list, &dev->amthif_rd_complete_list.list);
dev_dbg(&dev->pdev->dev, "amthif read completed\n"); dev_dbg(dev->dev, "amthif read completed\n");
dev->iamthif_timer = jiffies; dev->iamthif_timer = jiffies;
dev_dbg(&dev->pdev->dev, "dev->iamthif_timer = %ld\n", dev_dbg(dev->dev, "dev->iamthif_timer = %ld\n",
dev->iamthif_timer); dev->iamthif_timer);
} else { } else {
mei_amthif_run_next_cmd(dev); mei_amthif_run_next_cmd(dev);
} }
dev_dbg(&dev->pdev->dev, "completing amthif call back.\n"); dev_dbg(dev->dev, "completing amthif call back.\n");
wake_up_interruptible(&dev->iamthif_cl.wait); wake_up_interruptible(&dev->iamthif_cl.wait);
} }
...@@ -715,11 +715,11 @@ int mei_amthif_release(struct mei_device *dev, struct file *file) ...@@ -715,11 +715,11 @@ int mei_amthif_release(struct mei_device *dev, struct file *file)
if (dev->iamthif_file_object == file && if (dev->iamthif_file_object == file &&
dev->iamthif_state != MEI_IAMTHIF_IDLE) { dev->iamthif_state != MEI_IAMTHIF_IDLE) {
dev_dbg(&dev->pdev->dev, "amthif canceled iamthif state %d\n", dev_dbg(dev->dev, "amthif canceled iamthif state %d\n",
dev->iamthif_state); dev->iamthif_state);
dev->iamthif_canceled = true; dev->iamthif_canceled = true;
if (dev->iamthif_state == MEI_IAMTHIF_READ_COMPLETE) { if (dev->iamthif_state == MEI_IAMTHIF_READ_COMPLETE) {
dev_dbg(&dev->pdev->dev, "run next amthif iamthif cb\n"); dev_dbg(dev->dev, "run next amthif iamthif cb\n");
mei_amthif_run_next_cmd(dev); mei_amthif_run_next_cmd(dev);
} }
} }
......
...@@ -172,7 +172,7 @@ struct mei_cl_device *mei_cl_add_device(struct mei_device *dev, ...@@ -172,7 +172,7 @@ struct mei_cl_device *mei_cl_add_device(struct mei_device *dev,
device->cl = cl; device->cl = cl;
device->ops = ops; device->ops = ops;
device->dev.parent = &dev->pdev->dev; device->dev.parent = dev->dev;
device->dev.bus = &mei_cl_bus_type; device->dev.bus = &mei_cl_bus_type;
device->dev.type = &mei_cl_device_type; device->dev.type = &mei_cl_device_type;
...@@ -180,7 +180,7 @@ struct mei_cl_device *mei_cl_add_device(struct mei_device *dev, ...@@ -180,7 +180,7 @@ struct mei_cl_device *mei_cl_add_device(struct mei_device *dev,
status = device_register(&device->dev); status = device_register(&device->dev);
if (status) { if (status) {
dev_err(&dev->pdev->dev, "Failed to register MEI device\n"); dev_err(dev->dev, "Failed to register MEI device\n");
kfree(device); kfree(device);
return NULL; return NULL;
} }
...@@ -430,7 +430,7 @@ int mei_cl_enable_device(struct mei_cl_device *device) ...@@ -430,7 +430,7 @@ int mei_cl_enable_device(struct mei_cl_device *device)
err = mei_cl_connect(cl, NULL); err = mei_cl_connect(cl, NULL);
if (err < 0) { if (err < 0) {
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
dev_err(&dev->pdev->dev, "Could not connect to the ME client"); dev_err(dev->dev, "Could not connect to the ME client");
return err; return err;
} }
...@@ -462,7 +462,7 @@ int mei_cl_disable_device(struct mei_cl_device *device) ...@@ -462,7 +462,7 @@ int mei_cl_disable_device(struct mei_cl_device *device)
if (cl->state != MEI_FILE_CONNECTED) { if (cl->state != MEI_FILE_CONNECTED) {
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
dev_err(&dev->pdev->dev, "Already disconnected"); dev_err(dev->dev, "Already disconnected");
return 0; return 0;
} }
...@@ -472,7 +472,7 @@ int mei_cl_disable_device(struct mei_cl_device *device) ...@@ -472,7 +472,7 @@ int mei_cl_disable_device(struct mei_cl_device *device)
err = mei_cl_disconnect(cl); err = mei_cl_disconnect(cl);
if (err < 0) { if (err < 0) {
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
dev_err(&dev->pdev->dev, dev_err(dev->dev,
"Could not disconnect from the ME client"); "Could not disconnect from the ME client");
return err; return err;
......
...@@ -363,13 +363,13 @@ int mei_cl_link(struct mei_cl *cl, int id) ...@@ -363,13 +363,13 @@ int mei_cl_link(struct mei_cl *cl, int id)
MEI_CLIENTS_MAX); MEI_CLIENTS_MAX);
if (id >= MEI_CLIENTS_MAX) { if (id >= MEI_CLIENTS_MAX) {
dev_err(&dev->pdev->dev, "id exceeded %d", MEI_CLIENTS_MAX); dev_err(dev->dev, "id exceeded %d", MEI_CLIENTS_MAX);
return -EMFILE; return -EMFILE;
} }
open_handle_count = dev->open_handle_count + dev->iamthif_open_count; open_handle_count = dev->open_handle_count + dev->iamthif_open_count;
if (open_handle_count >= MEI_MAX_OPEN_HANDLE_COUNT) { if (open_handle_count >= MEI_MAX_OPEN_HANDLE_COUNT) {
dev_err(&dev->pdev->dev, "open_handle_count exceeded %d", dev_err(dev->dev, "open_handle_count exceeded %d",
MEI_MAX_OPEN_HANDLE_COUNT); MEI_MAX_OPEN_HANDLE_COUNT);
return -EMFILE; return -EMFILE;
} }
...@@ -449,9 +449,9 @@ void mei_host_client_init(struct work_struct *work) ...@@ -449,9 +449,9 @@ void mei_host_client_init(struct work_struct *work)
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
pm_runtime_mark_last_busy(&dev->pdev->dev); pm_runtime_mark_last_busy(dev->dev);
dev_dbg(&dev->pdev->dev, "rpm: autosuspend\n"); dev_dbg(dev->dev, "rpm: autosuspend\n");
pm_runtime_autosuspend(&dev->pdev->dev); pm_runtime_autosuspend(dev->dev);
} }
/** /**
...@@ -464,12 +464,12 @@ bool mei_hbuf_acquire(struct mei_device *dev) ...@@ -464,12 +464,12 @@ bool mei_hbuf_acquire(struct mei_device *dev)
{ {
if (mei_pg_state(dev) == MEI_PG_ON || if (mei_pg_state(dev) == MEI_PG_ON ||
dev->pg_event == MEI_PG_EVENT_WAIT) { dev->pg_event == MEI_PG_EVENT_WAIT) {
dev_dbg(&dev->pdev->dev, "device is in pg\n"); dev_dbg(dev->dev, "device is in pg\n");
return false; return false;
} }
if (!dev->hbuf_is_ready) { if (!dev->hbuf_is_ready) {
dev_dbg(&dev->pdev->dev, "hbuf is not ready\n"); dev_dbg(dev->dev, "hbuf is not ready\n");
return false; return false;
} }
...@@ -503,9 +503,9 @@ int mei_cl_disconnect(struct mei_cl *cl) ...@@ -503,9 +503,9 @@ int mei_cl_disconnect(struct mei_cl *cl)
if (cl->state != MEI_FILE_DISCONNECTING) if (cl->state != MEI_FILE_DISCONNECTING)
return 0; return 0;
rets = pm_runtime_get(&dev->pdev->dev); rets = pm_runtime_get(dev->dev);
if (rets < 0 && rets != -EINPROGRESS) { if (rets < 0 && rets != -EINPROGRESS) {
pm_runtime_put_noidle(&dev->pdev->dev); pm_runtime_put_noidle(dev->dev);
cl_err(dev, cl, "rpm: get failed %d\n", rets); cl_err(dev, cl, "rpm: get failed %d\n", rets);
return rets; return rets;
} }
...@@ -552,8 +552,8 @@ int mei_cl_disconnect(struct mei_cl *cl) ...@@ -552,8 +552,8 @@ int mei_cl_disconnect(struct mei_cl *cl)
mei_io_list_flush(&dev->ctrl_wr_list, cl); mei_io_list_flush(&dev->ctrl_wr_list, cl);
free: free:
cl_dbg(dev, cl, "rpm: autosuspend\n"); cl_dbg(dev, cl, "rpm: autosuspend\n");
pm_runtime_mark_last_busy(&dev->pdev->dev); pm_runtime_mark_last_busy(dev->dev);
pm_runtime_put_autosuspend(&dev->pdev->dev); pm_runtime_put_autosuspend(dev->dev);
mei_io_cb_free(cb); mei_io_cb_free(cb);
return rets; return rets;
...@@ -609,9 +609,9 @@ int mei_cl_connect(struct mei_cl *cl, struct file *file) ...@@ -609,9 +609,9 @@ int mei_cl_connect(struct mei_cl *cl, struct file *file)
dev = cl->dev; dev = cl->dev;
rets = pm_runtime_get(&dev->pdev->dev); rets = pm_runtime_get(dev->dev);
if (rets < 0 && rets != -EINPROGRESS) { if (rets < 0 && rets != -EINPROGRESS) {
pm_runtime_put_noidle(&dev->pdev->dev); pm_runtime_put_noidle(dev->dev);
cl_err(dev, cl, "rpm: get failed %d\n", rets); cl_err(dev, cl, "rpm: get failed %d\n", rets);
return rets; return rets;
} }
...@@ -659,8 +659,8 @@ int mei_cl_connect(struct mei_cl *cl, struct file *file) ...@@ -659,8 +659,8 @@ int mei_cl_connect(struct mei_cl *cl, struct file *file)
out: out:
cl_dbg(dev, cl, "rpm: autosuspend\n"); cl_dbg(dev, cl, "rpm: autosuspend\n");
pm_runtime_mark_last_busy(&dev->pdev->dev); pm_runtime_mark_last_busy(dev->dev);
pm_runtime_put_autosuspend(&dev->pdev->dev); pm_runtime_put_autosuspend(dev->dev);
mei_io_cb_free(cb); mei_io_cb_free(cb);
return rets; return rets;
...@@ -772,9 +772,9 @@ int mei_cl_read_start(struct mei_cl *cl, size_t length) ...@@ -772,9 +772,9 @@ int mei_cl_read_start(struct mei_cl *cl, size_t length)
return -ENOTTY; return -ENOTTY;
} }
rets = pm_runtime_get(&dev->pdev->dev); rets = pm_runtime_get(dev->dev);
if (rets < 0 && rets != -EINPROGRESS) { if (rets < 0 && rets != -EINPROGRESS) {
pm_runtime_put_noidle(&dev->pdev->dev); pm_runtime_put_noidle(dev->dev);
cl_err(dev, cl, "rpm: get failed %d\n", rets); cl_err(dev, cl, "rpm: get failed %d\n", rets);
return rets; return rets;
} }
...@@ -806,8 +806,8 @@ int mei_cl_read_start(struct mei_cl *cl, size_t length) ...@@ -806,8 +806,8 @@ int mei_cl_read_start(struct mei_cl *cl, size_t length)
out: out:
cl_dbg(dev, cl, "rpm: autosuspend\n"); cl_dbg(dev, cl, "rpm: autosuspend\n");
pm_runtime_mark_last_busy(&dev->pdev->dev); pm_runtime_mark_last_busy(dev->dev);
pm_runtime_put_autosuspend(&dev->pdev->dev); pm_runtime_put_autosuspend(dev->dev);
if (rets) if (rets)
mei_io_cb_free(cb); mei_io_cb_free(cb);
...@@ -928,9 +928,9 @@ int mei_cl_write(struct mei_cl *cl, struct mei_cl_cb *cb, bool blocking) ...@@ -928,9 +928,9 @@ int mei_cl_write(struct mei_cl *cl, struct mei_cl_cb *cb, bool blocking)
cl_dbg(dev, cl, "mei_cl_write %d\n", buf->size); cl_dbg(dev, cl, "mei_cl_write %d\n", buf->size);
rets = pm_runtime_get(&dev->pdev->dev); rets = pm_runtime_get(dev->dev);
if (rets < 0 && rets != -EINPROGRESS) { if (rets < 0 && rets != -EINPROGRESS) {
pm_runtime_put_noidle(&dev->pdev->dev); pm_runtime_put_noidle(dev->dev);
cl_err(dev, cl, "rpm: get failed %d\n", rets); cl_err(dev, cl, "rpm: get failed %d\n", rets);
return rets; return rets;
} }
...@@ -1005,8 +1005,8 @@ int mei_cl_write(struct mei_cl *cl, struct mei_cl_cb *cb, bool blocking) ...@@ -1005,8 +1005,8 @@ int mei_cl_write(struct mei_cl *cl, struct mei_cl_cb *cb, bool blocking)
rets = buf->size; rets = buf->size;
err: err:
cl_dbg(dev, cl, "rpm: autosuspend\n"); cl_dbg(dev, cl, "rpm: autosuspend\n");
pm_runtime_mark_last_busy(&dev->pdev->dev); pm_runtime_mark_last_busy(dev->dev);
pm_runtime_put_autosuspend(&dev->pdev->dev); pm_runtime_put_autosuspend(dev->dev);
return rets; return rets;
} }
......
...@@ -110,9 +110,9 @@ void mei_cl_all_write_clear(struct mei_device *dev); ...@@ -110,9 +110,9 @@ void mei_cl_all_write_clear(struct mei_device *dev);
#define MEI_CL_PRM(cl) (cl)->host_client_id, (cl)->me_client_id #define MEI_CL_PRM(cl) (cl)->host_client_id, (cl)->me_client_id
#define cl_dbg(dev, cl, format, arg...) \ #define cl_dbg(dev, cl, format, arg...) \
dev_dbg(&(dev)->pdev->dev, MEI_CL_FMT format, MEI_CL_PRM(cl), ##arg) dev_dbg((dev)->dev, MEI_CL_FMT format, MEI_CL_PRM(cl), ##arg)
#define cl_err(dev, cl, format, arg...) \ #define cl_err(dev, cl, format, arg...) \
dev_err(&(dev)->pdev->dev, MEI_CL_FMT format, MEI_CL_PRM(cl), ##arg) dev_err((dev)->dev, MEI_CL_FMT format, MEI_CL_PRM(cl), ##arg)
#endif /* _MEI_CLIENT_H_ */ #endif /* _MEI_CLIENT_H_ */
...@@ -187,19 +187,19 @@ int mei_dbgfs_register(struct mei_device *dev, const char *name) ...@@ -187,19 +187,19 @@ int mei_dbgfs_register(struct mei_device *dev, const char *name)
f = debugfs_create_file("meclients", S_IRUSR, dir, f = debugfs_create_file("meclients", S_IRUSR, dir,
dev, &mei_dbgfs_fops_meclients); dev, &mei_dbgfs_fops_meclients);
if (!f) { if (!f) {
dev_err(&dev->pdev->dev, "meclients: registration failed\n"); dev_err(dev->dev, "meclients: registration failed\n");
goto err; goto err;
} }
f = debugfs_create_file("active", S_IRUSR, dir, f = debugfs_create_file("active", S_IRUSR, dir,
dev, &mei_dbgfs_fops_active); dev, &mei_dbgfs_fops_active);
if (!f) { if (!f) {
dev_err(&dev->pdev->dev, "meclients: registration failed\n"); dev_err(dev->dev, "meclients: registration failed\n");
goto err; goto err;
} }
f = debugfs_create_file("devstate", S_IRUSR, dir, f = debugfs_create_file("devstate", S_IRUSR, dir,
dev, &mei_dbgfs_fops_devstate); dev, &mei_dbgfs_fops_devstate);
if (!f) { if (!f) {
dev_err(&dev->pdev->dev, "devstate: registration failed\n"); dev_err(dev->dev, "devstate: registration failed\n");
goto err; goto err;
} }
dev->dbgfs_dir = dir; dev->dbgfs_dir = dir;
......
...@@ -248,7 +248,7 @@ int mei_hbm_start_wait(struct mei_device *dev) ...@@ -248,7 +248,7 @@ int mei_hbm_start_wait(struct mei_device *dev)
if (ret == 0 && (dev->hbm_state <= MEI_HBM_STARTING)) { if (ret == 0 && (dev->hbm_state <= MEI_HBM_STARTING)) {
dev->hbm_state = MEI_HBM_IDLE; dev->hbm_state = MEI_HBM_IDLE;
dev_err(&dev->pdev->dev, "waiting for mei start failed\n"); dev_err(dev->dev, "waiting for mei start failed\n");
return -ETIME; return -ETIME;
} }
return 0; return 0;
...@@ -282,7 +282,7 @@ int mei_hbm_start_req(struct mei_device *dev) ...@@ -282,7 +282,7 @@ int mei_hbm_start_req(struct mei_device *dev)
dev->hbm_state = MEI_HBM_IDLE; dev->hbm_state = MEI_HBM_IDLE;
ret = mei_write_message(dev, mei_hdr, dev->wr_msg.data); ret = mei_write_message(dev, mei_hdr, dev->wr_msg.data);
if (ret) { if (ret) {
dev_err(&dev->pdev->dev, "version message write failed: ret = %d\n", dev_err(dev->dev, "version message write failed: ret = %d\n",
ret); ret);
return ret; return ret;
} }
...@@ -315,7 +315,7 @@ static int mei_hbm_enum_clients_req(struct mei_device *dev) ...@@ -315,7 +315,7 @@ static int mei_hbm_enum_clients_req(struct mei_device *dev)
ret = mei_write_message(dev, mei_hdr, dev->wr_msg.data); ret = mei_write_message(dev, mei_hdr, dev->wr_msg.data);
if (ret) { if (ret) {
dev_err(&dev->pdev->dev, "enumeration request write failed: ret = %d.\n", dev_err(dev->dev, "enumeration request write failed: ret = %d.\n",
ret); ret);
return ret; return ret;
} }
...@@ -388,7 +388,7 @@ static int mei_hbm_prop_req(struct mei_device *dev) ...@@ -388,7 +388,7 @@ static int mei_hbm_prop_req(struct mei_device *dev)
ret = mei_write_message(dev, mei_hdr, dev->wr_msg.data); ret = mei_write_message(dev, mei_hdr, dev->wr_msg.data);
if (ret) { if (ret) {
dev_err(&dev->pdev->dev, "properties request write failed: ret = %d\n", dev_err(dev->dev, "properties request write failed: ret = %d\n",
ret); ret);
return ret; return ret;
} }
...@@ -426,7 +426,7 @@ int mei_hbm_pg(struct mei_device *dev, u8 pg_cmd) ...@@ -426,7 +426,7 @@ int mei_hbm_pg(struct mei_device *dev, u8 pg_cmd)
ret = mei_write_message(dev, mei_hdr, dev->wr_msg.data); ret = mei_write_message(dev, mei_hdr, dev->wr_msg.data);
if (ret) if (ret)
dev_err(&dev->pdev->dev, "power gate command write failed.\n"); dev_err(dev->dev, "power gate command write failed.\n");
return ret; return ret;
} }
EXPORT_SYMBOL_GPL(mei_hbm_pg); EXPORT_SYMBOL_GPL(mei_hbm_pg);
...@@ -486,7 +486,7 @@ static int mei_hbm_add_single_flow_creds(struct mei_device *dev, ...@@ -486,7 +486,7 @@ static int mei_hbm_add_single_flow_creds(struct mei_device *dev,
me_cl = mei_me_cl_by_id(dev, flow->me_addr); me_cl = mei_me_cl_by_id(dev, flow->me_addr);
if (!me_cl) { if (!me_cl) {
dev_err(&dev->pdev->dev, "no such me client %d\n", dev_err(dev->dev, "no such me client %d\n",
flow->me_addr); flow->me_addr);
return -ENOENT; return -ENOENT;
} }
...@@ -495,7 +495,7 @@ static int mei_hbm_add_single_flow_creds(struct mei_device *dev, ...@@ -495,7 +495,7 @@ static int mei_hbm_add_single_flow_creds(struct mei_device *dev,
return -EINVAL; return -EINVAL;
me_cl->mei_flow_ctrl_creds++; me_cl->mei_flow_ctrl_creds++;
dev_dbg(&dev->pdev->dev, "recv flow ctrl msg ME %d (single) creds = %d.\n", dev_dbg(dev->dev, "recv flow ctrl msg ME %d (single) creds = %d.\n",
flow->me_addr, me_cl->mei_flow_ctrl_creds); flow->me_addr, me_cl->mei_flow_ctrl_creds);
return 0; return 0;
...@@ -570,7 +570,7 @@ static void mei_hbm_cl_disconnect_res(struct mei_cl *cl, ...@@ -570,7 +570,7 @@ static void mei_hbm_cl_disconnect_res(struct mei_cl *cl,
struct hbm_client_connect_response *rs = struct hbm_client_connect_response *rs =
(struct hbm_client_connect_response *)cmd; (struct hbm_client_connect_response *)cmd;
dev_dbg(&cl->dev->pdev->dev, "hbm: disconnect response cl:host=%02d me=%02d status=%d\n", dev_dbg(cl->dev->dev, "hbm: disconnect response cl:host=%02d me=%02d status=%d\n",
rs->me_addr, rs->host_addr, rs->status); rs->me_addr, rs->host_addr, rs->status);
if (rs->status == MEI_CL_DISCONN_SUCCESS) if (rs->status == MEI_CL_DISCONN_SUCCESS)
...@@ -606,7 +606,7 @@ static void mei_hbm_cl_connect_res(struct mei_cl *cl, ...@@ -606,7 +606,7 @@ static void mei_hbm_cl_connect_res(struct mei_cl *cl,
struct hbm_client_connect_response *rs = struct hbm_client_connect_response *rs =
(struct hbm_client_connect_response *)cmd; (struct hbm_client_connect_response *)cmd;
dev_dbg(&cl->dev->pdev->dev, "hbm: connect response cl:host=%02d me=%02d status=%s\n", dev_dbg(cl->dev->dev, "hbm: connect response cl:host=%02d me=%02d status=%s\n",
rs->me_addr, rs->host_addr, rs->me_addr, rs->host_addr,
mei_cl_conn_status_str(rs->status)); mei_cl_conn_status_str(rs->status));
...@@ -763,19 +763,19 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr) ...@@ -763,19 +763,19 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
* hbm is put to idle during system reset * hbm is put to idle during system reset
*/ */
if (dev->hbm_state == MEI_HBM_IDLE) { if (dev->hbm_state == MEI_HBM_IDLE) {
dev_dbg(&dev->pdev->dev, "hbm: state is idle ignore spurious messages\n"); dev_dbg(dev->dev, "hbm: state is idle ignore spurious messages\n");
return 0; return 0;
} }
switch (mei_msg->hbm_cmd) { switch (mei_msg->hbm_cmd) {
case HOST_START_RES_CMD: case HOST_START_RES_CMD:
dev_dbg(&dev->pdev->dev, "hbm: start: response message received.\n"); dev_dbg(dev->dev, "hbm: start: response message received.\n");
dev->init_clients_timer = 0; dev->init_clients_timer = 0;
version_res = (struct hbm_host_version_response *)mei_msg; version_res = (struct hbm_host_version_response *)mei_msg;
dev_dbg(&dev->pdev->dev, "HBM VERSION: DRIVER=%02d:%02d DEVICE=%02d:%02d\n", dev_dbg(dev->dev, "HBM VERSION: DRIVER=%02d:%02d DEVICE=%02d:%02d\n",
HBM_MAJOR_VERSION, HBM_MINOR_VERSION, HBM_MAJOR_VERSION, HBM_MINOR_VERSION,
version_res->me_max_version.major_version, version_res->me_max_version.major_version,
version_res->me_max_version.minor_version); version_res->me_max_version.minor_version);
...@@ -791,11 +791,11 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr) ...@@ -791,11 +791,11 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
} }
if (!mei_hbm_version_is_supported(dev)) { if (!mei_hbm_version_is_supported(dev)) {
dev_warn(&dev->pdev->dev, "hbm: start: version mismatch - stopping the driver.\n"); dev_warn(dev->dev, "hbm: start: version mismatch - stopping the driver.\n");
dev->hbm_state = MEI_HBM_STOPPED; dev->hbm_state = MEI_HBM_STOPPED;
if (mei_hbm_stop_req(dev)) { if (mei_hbm_stop_req(dev)) {
dev_err(&dev->pdev->dev, "hbm: start: failed to send stop request\n"); dev_err(dev->dev, "hbm: start: failed to send stop request\n");
return -EIO; return -EIO;
} }
break; break;
...@@ -805,7 +805,7 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr) ...@@ -805,7 +805,7 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
if (dev->dev_state != MEI_DEV_INIT_CLIENTS || if (dev->dev_state != MEI_DEV_INIT_CLIENTS ||
dev->hbm_state != MEI_HBM_STARTING) { dev->hbm_state != MEI_HBM_STARTING) {
dev_err(&dev->pdev->dev, "hbm: start: state mismatch, [%d, %d]\n", dev_err(dev->dev, "hbm: start: state mismatch, [%d, %d]\n",
dev->dev_state, dev->hbm_state); dev->dev_state, dev->hbm_state);
return -EPROTO; return -EPROTO;
} }
...@@ -813,7 +813,7 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr) ...@@ -813,7 +813,7 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
dev->hbm_state = MEI_HBM_STARTED; dev->hbm_state = MEI_HBM_STARTED;
if (mei_hbm_enum_clients_req(dev)) { if (mei_hbm_enum_clients_req(dev)) {
dev_err(&dev->pdev->dev, "hbm: start: failed to send enumeration request\n"); dev_err(dev->dev, "hbm: start: failed to send enumeration request\n");
return -EIO; return -EIO;
} }
...@@ -821,31 +821,31 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr) ...@@ -821,31 +821,31 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
break; break;
case CLIENT_CONNECT_RES_CMD: case CLIENT_CONNECT_RES_CMD:
dev_dbg(&dev->pdev->dev, "hbm: client connect response: message received.\n"); dev_dbg(dev->dev, "hbm: client connect response: message received.\n");
mei_hbm_cl_res(dev, cl_cmd, MEI_FOP_CONNECT); mei_hbm_cl_res(dev, cl_cmd, MEI_FOP_CONNECT);
break; break;
case CLIENT_DISCONNECT_RES_CMD: case CLIENT_DISCONNECT_RES_CMD:
dev_dbg(&dev->pdev->dev, "hbm: client disconnect response: message received.\n"); dev_dbg(dev->dev, "hbm: client disconnect response: message received.\n");
mei_hbm_cl_res(dev, cl_cmd, MEI_FOP_DISCONNECT); mei_hbm_cl_res(dev, cl_cmd, MEI_FOP_DISCONNECT);
break; break;
case MEI_FLOW_CONTROL_CMD: case MEI_FLOW_CONTROL_CMD:
dev_dbg(&dev->pdev->dev, "hbm: client flow control response: message received.\n"); dev_dbg(dev->dev, "hbm: client flow control response: message received.\n");
flow_control = (struct hbm_flow_control *) mei_msg; flow_control = (struct hbm_flow_control *) mei_msg;
mei_hbm_cl_flow_control_res(dev, flow_control); mei_hbm_cl_flow_control_res(dev, flow_control);
break; break;
case MEI_PG_ISOLATION_ENTRY_RES_CMD: case MEI_PG_ISOLATION_ENTRY_RES_CMD:
dev_dbg(&dev->pdev->dev, "power gate isolation entry response received\n"); dev_dbg(dev->dev, "power gate isolation entry response received\n");
dev->pg_event = MEI_PG_EVENT_RECEIVED; dev->pg_event = MEI_PG_EVENT_RECEIVED;
if (waitqueue_active(&dev->wait_pg)) if (waitqueue_active(&dev->wait_pg))
wake_up(&dev->wait_pg); wake_up(&dev->wait_pg);
break; break;
case MEI_PG_ISOLATION_EXIT_REQ_CMD: case MEI_PG_ISOLATION_EXIT_REQ_CMD:
dev_dbg(&dev->pdev->dev, "power gate isolation exit request received\n"); dev_dbg(dev->dev, "power gate isolation exit request received\n");
dev->pg_event = MEI_PG_EVENT_RECEIVED; dev->pg_event = MEI_PG_EVENT_RECEIVED;
if (waitqueue_active(&dev->wait_pg)) if (waitqueue_active(&dev->wait_pg))
wake_up(&dev->wait_pg); wake_up(&dev->wait_pg);
...@@ -855,17 +855,17 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr) ...@@ -855,17 +855,17 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
* this is HW initiated exit from PG. * this is HW initiated exit from PG.
* Start runtime pm resume sequence to exit from PG. * Start runtime pm resume sequence to exit from PG.
*/ */
pm_request_resume(&dev->pdev->dev); pm_request_resume(dev->dev);
break; break;
case HOST_CLIENT_PROPERTIES_RES_CMD: case HOST_CLIENT_PROPERTIES_RES_CMD:
dev_dbg(&dev->pdev->dev, "hbm: properties response: message received.\n"); dev_dbg(dev->dev, "hbm: properties response: message received.\n");
dev->init_clients_timer = 0; dev->init_clients_timer = 0;
if (dev->dev_state != MEI_DEV_INIT_CLIENTS || if (dev->dev_state != MEI_DEV_INIT_CLIENTS ||
dev->hbm_state != MEI_HBM_CLIENT_PROPERTIES) { dev->hbm_state != MEI_HBM_CLIENT_PROPERTIES) {
dev_err(&dev->pdev->dev, "hbm: properties response: state mismatch, [%d, %d]\n", dev_err(dev->dev, "hbm: properties response: state mismatch, [%d, %d]\n",
dev->dev_state, dev->hbm_state); dev->dev_state, dev->hbm_state);
return -EPROTO; return -EPROTO;
} }
...@@ -873,7 +873,7 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr) ...@@ -873,7 +873,7 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
props_res = (struct hbm_props_response *)mei_msg; props_res = (struct hbm_props_response *)mei_msg;
if (props_res->status) { if (props_res->status) {
dev_err(&dev->pdev->dev, "hbm: properties response: wrong status = %d %s\n", dev_err(dev->dev, "hbm: properties response: wrong status = %d %s\n",
props_res->status, props_res->status,
mei_hbm_status_str(props_res->status)); mei_hbm_status_str(props_res->status));
return -EPROTO; return -EPROTO;
...@@ -891,7 +891,7 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr) ...@@ -891,7 +891,7 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
break; break;
case HOST_ENUM_RES_CMD: case HOST_ENUM_RES_CMD:
dev_dbg(&dev->pdev->dev, "hbm: enumeration response: message received\n"); dev_dbg(dev->dev, "hbm: enumeration response: message received\n");
dev->init_clients_timer = 0; dev->init_clients_timer = 0;
...@@ -903,7 +903,7 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr) ...@@ -903,7 +903,7 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
if (dev->dev_state != MEI_DEV_INIT_CLIENTS || if (dev->dev_state != MEI_DEV_INIT_CLIENTS ||
dev->hbm_state != MEI_HBM_ENUM_CLIENTS) { dev->hbm_state != MEI_HBM_ENUM_CLIENTS) {
dev_err(&dev->pdev->dev, "hbm: enumeration response: state mismatch, [%d, %d]\n", dev_err(dev->dev, "hbm: enumeration response: state mismatch, [%d, %d]\n",
dev->dev_state, dev->hbm_state); dev->dev_state, dev->hbm_state);
return -EPROTO; return -EPROTO;
} }
...@@ -917,34 +917,34 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr) ...@@ -917,34 +917,34 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
break; break;
case HOST_STOP_RES_CMD: case HOST_STOP_RES_CMD:
dev_dbg(&dev->pdev->dev, "hbm: stop response: message received\n"); dev_dbg(dev->dev, "hbm: stop response: message received\n");
dev->init_clients_timer = 0; dev->init_clients_timer = 0;
if (dev->hbm_state != MEI_HBM_STOPPED) { if (dev->hbm_state != MEI_HBM_STOPPED) {
dev_err(&dev->pdev->dev, "hbm: stop response: state mismatch, [%d, %d]\n", dev_err(dev->dev, "hbm: stop response: state mismatch, [%d, %d]\n",
dev->dev_state, dev->hbm_state); dev->dev_state, dev->hbm_state);
return -EPROTO; return -EPROTO;
} }
dev->dev_state = MEI_DEV_POWER_DOWN; dev->dev_state = MEI_DEV_POWER_DOWN;
dev_info(&dev->pdev->dev, "hbm: stop response: resetting.\n"); dev_info(dev->dev, "hbm: stop response: resetting.\n");
/* force the reset */ /* force the reset */
return -EPROTO; return -EPROTO;
break; break;
case CLIENT_DISCONNECT_REQ_CMD: case CLIENT_DISCONNECT_REQ_CMD:
dev_dbg(&dev->pdev->dev, "hbm: disconnect request: message received\n"); dev_dbg(dev->dev, "hbm: disconnect request: message received\n");
disconnect_req = (struct hbm_client_connect_request *)mei_msg; disconnect_req = (struct hbm_client_connect_request *)mei_msg;
mei_hbm_fw_disconnect_req(dev, disconnect_req); mei_hbm_fw_disconnect_req(dev, disconnect_req);
break; break;
case ME_STOP_REQ_CMD: case ME_STOP_REQ_CMD:
dev_dbg(&dev->pdev->dev, "hbm: stop request: message received\n"); dev_dbg(dev->dev, "hbm: stop request: message received\n");
dev->hbm_state = MEI_HBM_STOPPED; dev->hbm_state = MEI_HBM_STOPPED;
if (mei_hbm_stop_req(dev)) { if (mei_hbm_stop_req(dev)) {
dev_err(&dev->pdev->dev, "hbm: stop request: failed to send stop request\n"); dev_err(dev->dev, "hbm: stop request: failed to send stop request\n");
return -EIO; return -EIO;
} }
break; break;
......
...@@ -217,10 +217,10 @@ static int mei_me_hw_reset(struct mei_device *dev, bool intr_enable) ...@@ -217,10 +217,10 @@ static int mei_me_hw_reset(struct mei_device *dev, bool intr_enable)
hcsr = mei_hcsr_read(hw); hcsr = mei_hcsr_read(hw);
if ((hcsr & H_RST) == 0) if ((hcsr & H_RST) == 0)
dev_warn(&dev->pdev->dev, "H_RST is not set = 0x%08X", hcsr); dev_warn(dev->dev, "H_RST is not set = 0x%08X", hcsr);
if ((hcsr & H_RDY) == H_RDY) if ((hcsr & H_RDY) == H_RDY)
dev_warn(&dev->pdev->dev, "H_RDY is not cleared 0x%08X", hcsr); dev_warn(dev->dev, "H_RDY is not cleared 0x%08X", hcsr);
if (intr_enable == false) if (intr_enable == false)
mei_me_hw_reset_release(dev); mei_me_hw_reset_release(dev);
...@@ -279,7 +279,7 @@ static int mei_me_hw_ready_wait(struct mei_device *dev) ...@@ -279,7 +279,7 @@ static int mei_me_hw_ready_wait(struct mei_device *dev)
mei_secs_to_jiffies(MEI_HW_READY_TIMEOUT)); mei_secs_to_jiffies(MEI_HW_READY_TIMEOUT));
mutex_lock(&dev->device_lock); mutex_lock(&dev->device_lock);
if (!dev->recvd_hw_ready) { if (!dev->recvd_hw_ready) {
dev_err(&dev->pdev->dev, "wait hw ready failed\n"); dev_err(dev->dev, "wait hw ready failed\n");
return -ETIME; return -ETIME;
} }
...@@ -293,7 +293,7 @@ static int mei_me_hw_start(struct mei_device *dev) ...@@ -293,7 +293,7 @@ static int mei_me_hw_start(struct mei_device *dev)
if (ret) if (ret)
return ret; return ret;
dev_dbg(&dev->pdev->dev, "hw is ready\n"); dev_dbg(dev->dev, "hw is ready\n");
mei_me_host_set_ready(dev); mei_me_host_set_ready(dev);
return ret; return ret;
...@@ -381,10 +381,10 @@ static int mei_me_write_message(struct mei_device *dev, ...@@ -381,10 +381,10 @@ static int mei_me_write_message(struct mei_device *dev,
int i; int i;
int empty_slots; int empty_slots;
dev_dbg(&dev->pdev->dev, MEI_HDR_FMT, MEI_HDR_PRM(header)); dev_dbg(dev->dev, MEI_HDR_FMT, MEI_HDR_PRM(header));
empty_slots = mei_hbuf_empty_slots(dev); empty_slots = mei_hbuf_empty_slots(dev);
dev_dbg(&dev->pdev->dev, "empty slots = %hu.\n", empty_slots); dev_dbg(dev->dev, "empty slots = %hu.\n", empty_slots);
dw_cnt = mei_data2slots(length); dw_cnt = mei_data2slots(length);
if (empty_slots < 0 || dw_cnt > empty_slots) if (empty_slots < 0 || dw_cnt > empty_slots)
...@@ -434,7 +434,7 @@ static int mei_me_count_full_read_slots(struct mei_device *dev) ...@@ -434,7 +434,7 @@ static int mei_me_count_full_read_slots(struct mei_device *dev)
if (filled_slots > buffer_depth) if (filled_slots > buffer_depth)
return -EOVERFLOW; return -EOVERFLOW;
dev_dbg(&dev->pdev->dev, "filled_slots =%08x\n", filled_slots); dev_dbg(dev->dev, "filled_slots =%08x\n", filled_slots);
return (int)filled_slots; return (int)filled_slots;
} }
...@@ -591,7 +591,7 @@ static bool mei_me_pg_is_enabled(struct mei_device *dev) ...@@ -591,7 +591,7 @@ static bool mei_me_pg_is_enabled(struct mei_device *dev)
return true; return true;
notsupported: notsupported:
dev_dbg(&dev->pdev->dev, "pg: not supported: HGP = %d hbm version %d.%d ?= %d.%d\n", dev_dbg(dev->dev, "pg: not supported: HGP = %d hbm version %d.%d ?= %d.%d\n",
!!(reg & ME_PGIC_HRA), !!(reg & ME_PGIC_HRA),
dev->version.major_version, dev->version.major_version,
dev->version.minor_version, dev->version.minor_version,
...@@ -642,7 +642,7 @@ irqreturn_t mei_me_irq_thread_handler(int irq, void *dev_id) ...@@ -642,7 +642,7 @@ irqreturn_t mei_me_irq_thread_handler(int irq, void *dev_id)
s32 slots; s32 slots;
int rets = 0; int rets = 0;
dev_dbg(&dev->pdev->dev, "function called after ISR to handle the interrupt processing.\n"); dev_dbg(dev->dev, "function called after ISR to handle the interrupt processing.\n");
/* initialize our complete list */ /* initialize our complete list */
mutex_lock(&dev->device_lock); mutex_lock(&dev->device_lock);
mei_io_list_init(&complete_list); mei_io_list_init(&complete_list);
...@@ -654,7 +654,7 @@ irqreturn_t mei_me_irq_thread_handler(int irq, void *dev_id) ...@@ -654,7 +654,7 @@ irqreturn_t mei_me_irq_thread_handler(int irq, void *dev_id)
/* check if ME wants a reset */ /* check if ME wants a reset */
if (!mei_hw_is_ready(dev) && dev->dev_state != MEI_DEV_RESETTING) { if (!mei_hw_is_ready(dev) && dev->dev_state != MEI_DEV_RESETTING) {
dev_warn(&dev->pdev->dev, "FW not ready: resetting.\n"); dev_warn(dev->dev, "FW not ready: resetting.\n");
schedule_work(&dev->reset_work); schedule_work(&dev->reset_work);
goto end; goto end;
} }
...@@ -663,19 +663,19 @@ irqreturn_t mei_me_irq_thread_handler(int irq, void *dev_id) ...@@ -663,19 +663,19 @@ irqreturn_t mei_me_irq_thread_handler(int irq, void *dev_id)
if (!mei_host_is_ready(dev)) { if (!mei_host_is_ready(dev)) {
if (mei_hw_is_ready(dev)) { if (mei_hw_is_ready(dev)) {
mei_me_hw_reset_release(dev); mei_me_hw_reset_release(dev);
dev_dbg(&dev->pdev->dev, "we need to start the dev.\n"); dev_dbg(dev->dev, "we need to start the dev.\n");
dev->recvd_hw_ready = true; dev->recvd_hw_ready = true;
wake_up(&dev->wait_hw_ready); wake_up(&dev->wait_hw_ready);
} else { } else {
dev_dbg(&dev->pdev->dev, "Spurious Interrupt\n"); dev_dbg(dev->dev, "Spurious Interrupt\n");
} }
goto end; goto end;
} }
/* check slots available for reading */ /* check slots available for reading */
slots = mei_count_full_read_slots(dev); slots = mei_count_full_read_slots(dev);
while (slots > 0) { while (slots > 0) {
dev_dbg(&dev->pdev->dev, "slots to read = %08x\n", slots); dev_dbg(dev->dev, "slots to read = %08x\n", slots);
rets = mei_irq_read_handler(dev, &complete_list, &slots); rets = mei_irq_read_handler(dev, &complete_list, &slots);
/* There is a race between ME write and interrupt delivery: /* There is a race between ME write and interrupt delivery:
* Not all data is always available immediately after the * Not all data is always available immediately after the
...@@ -685,7 +685,7 @@ irqreturn_t mei_me_irq_thread_handler(int irq, void *dev_id) ...@@ -685,7 +685,7 @@ irqreturn_t mei_me_irq_thread_handler(int irq, void *dev_id)
break; break;
if (rets && dev->dev_state != MEI_DEV_RESETTING) { if (rets && dev->dev_state != MEI_DEV_RESETTING) {
dev_err(&dev->pdev->dev, "mei_irq_read_handler ret = %d.\n", dev_err(dev->dev, "mei_irq_read_handler ret = %d.\n",
rets); rets);
schedule_work(&dev->reset_work); schedule_work(&dev->reset_work);
goto end; goto end;
...@@ -707,7 +707,7 @@ irqreturn_t mei_me_irq_thread_handler(int irq, void *dev_id) ...@@ -707,7 +707,7 @@ irqreturn_t mei_me_irq_thread_handler(int irq, void *dev_id)
mei_irq_compl_handler(dev, &complete_list); mei_irq_compl_handler(dev, &complete_list);
end: end:
dev_dbg(&dev->pdev->dev, "interrupt thread end ret = %d\n", rets); dev_dbg(dev->dev, "interrupt thread end ret = %d\n", rets);
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
return IRQ_HANDLED; return IRQ_HANDLED;
} }
......
...@@ -155,7 +155,7 @@ static bool mei_txe_aliveness_set(struct mei_device *dev, u32 req) ...@@ -155,7 +155,7 @@ static bool mei_txe_aliveness_set(struct mei_device *dev, u32 req)
struct mei_txe_hw *hw = to_txe_hw(dev); struct mei_txe_hw *hw = to_txe_hw(dev);
bool do_req = hw->aliveness != req; bool do_req = hw->aliveness != req;
dev_dbg(&dev->pdev->dev, "Aliveness current=%d request=%d\n", dev_dbg(dev->dev, "Aliveness current=%d request=%d\n",
hw->aliveness, req); hw->aliveness, req);
if (do_req) { if (do_req) {
dev->pg_event = MEI_PG_EVENT_WAIT; dev->pg_event = MEI_PG_EVENT_WAIT;
...@@ -216,7 +216,7 @@ static int mei_txe_aliveness_poll(struct mei_device *dev, u32 expected) ...@@ -216,7 +216,7 @@ static int mei_txe_aliveness_poll(struct mei_device *dev, u32 expected)
hw->aliveness = mei_txe_aliveness_get(dev); hw->aliveness = mei_txe_aliveness_get(dev);
if (hw->aliveness == expected) { if (hw->aliveness == expected) {
dev->pg_event = MEI_PG_EVENT_IDLE; dev->pg_event = MEI_PG_EVENT_IDLE;
dev_dbg(&dev->pdev->dev, dev_dbg(dev->dev,
"aliveness settled after %d msecs\n", t); "aliveness settled after %d msecs\n", t);
return t; return t;
} }
...@@ -227,7 +227,7 @@ static int mei_txe_aliveness_poll(struct mei_device *dev, u32 expected) ...@@ -227,7 +227,7 @@ static int mei_txe_aliveness_poll(struct mei_device *dev, u32 expected)
} while (t < SEC_ALIVENESS_WAIT_TIMEOUT); } while (t < SEC_ALIVENESS_WAIT_TIMEOUT);
dev->pg_event = MEI_PG_EVENT_IDLE; dev->pg_event = MEI_PG_EVENT_IDLE;
dev_err(&dev->pdev->dev, "aliveness timed out\n"); dev_err(dev->dev, "aliveness timed out\n");
return -ETIME; return -ETIME;
} }
...@@ -261,10 +261,10 @@ static int mei_txe_aliveness_wait(struct mei_device *dev, u32 expected) ...@@ -261,10 +261,10 @@ static int mei_txe_aliveness_wait(struct mei_device *dev, u32 expected)
ret = hw->aliveness == expected ? 0 : -ETIME; ret = hw->aliveness == expected ? 0 : -ETIME;
if (ret) if (ret)
dev_warn(&dev->pdev->dev, "aliveness timed out = %ld aliveness = %d event = %d\n", dev_warn(dev->dev, "aliveness timed out = %ld aliveness = %d event = %d\n",
err, hw->aliveness, dev->pg_event); err, hw->aliveness, dev->pg_event);
else else
dev_dbg(&dev->pdev->dev, "aliveness settled after = %d msec aliveness = %d event = %d\n", dev_dbg(dev->dev, "aliveness settled after = %d msec aliveness = %d event = %d\n",
jiffies_to_msecs(timeout - err), jiffies_to_msecs(timeout - err),
hw->aliveness, dev->pg_event); hw->aliveness, dev->pg_event);
...@@ -425,7 +425,7 @@ static bool mei_txe_pending_interrupts(struct mei_device *dev) ...@@ -425,7 +425,7 @@ static bool mei_txe_pending_interrupts(struct mei_device *dev)
TXE_INTR_OUT_DB)); TXE_INTR_OUT_DB));
if (ret) { if (ret) {
dev_dbg(&dev->pdev->dev, dev_dbg(dev->dev,
"Pending Interrupts InReady=%01d Readiness=%01d, Aliveness=%01d, OutDoor=%01d\n", "Pending Interrupts InReady=%01d Readiness=%01d, Aliveness=%01d, OutDoor=%01d\n",
!!(hw->intr_cause & TXE_INTR_IN_READY), !!(hw->intr_cause & TXE_INTR_IN_READY),
!!(hw->intr_cause & TXE_INTR_READINESS), !!(hw->intr_cause & TXE_INTR_READINESS),
...@@ -565,7 +565,7 @@ static int mei_txe_readiness_wait(struct mei_device *dev) ...@@ -565,7 +565,7 @@ static int mei_txe_readiness_wait(struct mei_device *dev)
msecs_to_jiffies(SEC_RESET_WAIT_TIMEOUT)); msecs_to_jiffies(SEC_RESET_WAIT_TIMEOUT));
mutex_lock(&dev->device_lock); mutex_lock(&dev->device_lock);
if (!dev->recvd_hw_ready) { if (!dev->recvd_hw_ready) {
dev_err(&dev->pdev->dev, "wait for readiness failed\n"); dev_err(dev->dev, "wait for readiness failed\n");
return -ETIME; return -ETIME;
} }
...@@ -592,7 +592,7 @@ static void mei_txe_hw_config(struct mei_device *dev) ...@@ -592,7 +592,7 @@ static void mei_txe_hw_config(struct mei_device *dev)
hw->aliveness = mei_txe_aliveness_get(dev); hw->aliveness = mei_txe_aliveness_get(dev);
hw->readiness = mei_txe_readiness_get(dev); hw->readiness = mei_txe_readiness_get(dev);
dev_dbg(&dev->pdev->dev, "aliveness_resp = 0x%08x, readiness = 0x%08x.\n", dev_dbg(dev->dev, "aliveness_resp = 0x%08x, readiness = 0x%08x.\n",
hw->aliveness, hw->readiness); hw->aliveness, hw->readiness);
} }
...@@ -622,7 +622,7 @@ static int mei_txe_write(struct mei_device *dev, ...@@ -622,7 +622,7 @@ static int mei_txe_write(struct mei_device *dev,
length = header->length; length = header->length;
dev_dbg(&dev->pdev->dev, MEI_HDR_FMT, MEI_HDR_PRM(header)); dev_dbg(dev->dev, MEI_HDR_FMT, MEI_HDR_PRM(header));
dw_cnt = mei_data2slots(length); dw_cnt = mei_data2slots(length);
if (dw_cnt > slots) if (dw_cnt > slots)
...@@ -638,7 +638,7 @@ static int mei_txe_write(struct mei_device *dev, ...@@ -638,7 +638,7 @@ static int mei_txe_write(struct mei_device *dev,
struct mei_fw_status fw_status; struct mei_fw_status fw_status;
mei_fw_status(dev, &fw_status); mei_fw_status(dev, &fw_status);
dev_err(&dev->pdev->dev, "Input is not ready " FW_STS_FMT "\n", dev_err(dev->dev, "Input is not ready " FW_STS_FMT "\n",
FW_STS_PRM(fw_status)); FW_STS_PRM(fw_status));
return -EAGAIN; return -EAGAIN;
} }
...@@ -740,14 +740,13 @@ static int mei_txe_read(struct mei_device *dev, ...@@ -740,14 +740,13 @@ static int mei_txe_read(struct mei_device *dev,
reg_buf = (u32 *)buf; reg_buf = (u32 *)buf;
rem = len & 0x3; rem = len & 0x3;
dev_dbg(&dev->pdev->dev, dev_dbg(dev->dev, "buffer-length = %lu buf[0]0x%08X\n",
"buffer-length = %lu buf[0]0x%08X\n",
len, mei_txe_out_data_read(dev, 0)); len, mei_txe_out_data_read(dev, 0));
for (i = 0; i < len / 4; i++) { for (i = 0; i < len / 4; i++) {
/* skip header: index starts from 1 */ /* skip header: index starts from 1 */
reg = mei_txe_out_data_read(dev, i + 1); reg = mei_txe_out_data_read(dev, i + 1);
dev_dbg(&dev->pdev->dev, "buf[%d] = 0x%08X\n", i, reg); dev_dbg(dev->dev, "buf[%d] = 0x%08X\n", i, reg);
*reg_buf++ = reg; *reg_buf++ = reg;
} }
...@@ -792,8 +791,7 @@ static int mei_txe_hw_reset(struct mei_device *dev, bool intr_enable) ...@@ -792,8 +791,7 @@ static int mei_txe_hw_reset(struct mei_device *dev, bool intr_enable)
*/ */
if (aliveness_req != hw->aliveness) if (aliveness_req != hw->aliveness)
if (mei_txe_aliveness_poll(dev, aliveness_req) < 0) { if (mei_txe_aliveness_poll(dev, aliveness_req) < 0) {
dev_err(&dev->pdev->dev, dev_err(dev->dev, "wait for aliveness settle failed ... bailing out\n");
"wait for aliveness settle failed ... bailing out\n");
return -EIO; return -EIO;
} }
...@@ -803,8 +801,7 @@ static int mei_txe_hw_reset(struct mei_device *dev, bool intr_enable) ...@@ -803,8 +801,7 @@ static int mei_txe_hw_reset(struct mei_device *dev, bool intr_enable)
if (aliveness_req) { if (aliveness_req) {
mei_txe_aliveness_set(dev, 0); mei_txe_aliveness_set(dev, 0);
if (mei_txe_aliveness_poll(dev, 0) < 0) { if (mei_txe_aliveness_poll(dev, 0) < 0) {
dev_err(&dev->pdev->dev, dev_err(dev->dev, "wait for aliveness failed ... bailing out\n");
"wait for aliveness failed ... bailing out\n");
return -EIO; return -EIO;
} }
} }
...@@ -836,7 +833,7 @@ static int mei_txe_hw_start(struct mei_device *dev) ...@@ -836,7 +833,7 @@ static int mei_txe_hw_start(struct mei_device *dev)
ret = mei_txe_readiness_wait(dev); ret = mei_txe_readiness_wait(dev);
if (ret < 0) { if (ret < 0) {
dev_err(&dev->pdev->dev, "wating for readiness failed\n"); dev_err(dev->dev, "wating for readiness failed\n");
return ret; return ret;
} }
...@@ -852,7 +849,7 @@ static int mei_txe_hw_start(struct mei_device *dev) ...@@ -852,7 +849,7 @@ static int mei_txe_hw_start(struct mei_device *dev)
ret = mei_txe_aliveness_set_sync(dev, 1); ret = mei_txe_aliveness_set_sync(dev, 1);
if (ret < 0) { if (ret < 0) {
dev_err(&dev->pdev->dev, "wait for aliveness failed ... bailing out\n"); dev_err(dev->dev, "wait for aliveness failed ... bailing out\n");
return ret; return ret;
} }
...@@ -962,7 +959,7 @@ irqreturn_t mei_txe_irq_thread_handler(int irq, void *dev_id) ...@@ -962,7 +959,7 @@ irqreturn_t mei_txe_irq_thread_handler(int irq, void *dev_id)
s32 slots; s32 slots;
int rets = 0; int rets = 0;
dev_dbg(&dev->pdev->dev, "irq thread: Interrupt Registers HHISR|HISR|SEC=%02X|%04X|%02X\n", dev_dbg(dev->dev, "irq thread: Interrupt Registers HHISR|HISR|SEC=%02X|%04X|%02X\n",
mei_txe_br_reg_read(hw, HHISR_REG), mei_txe_br_reg_read(hw, HHISR_REG),
mei_txe_br_reg_read(hw, HISR_REG), mei_txe_br_reg_read(hw, HISR_REG),
mei_txe_sec_reg_read_silent(hw, SEC_IPC_HOST_INT_STATUS_REG)); mei_txe_sec_reg_read_silent(hw, SEC_IPC_HOST_INT_STATUS_REG));
...@@ -986,17 +983,17 @@ irqreturn_t mei_txe_irq_thread_handler(int irq, void *dev_id) ...@@ -986,17 +983,17 @@ irqreturn_t mei_txe_irq_thread_handler(int irq, void *dev_id)
* or TXE driver resetting the HECI interface. * or TXE driver resetting the HECI interface.
*/ */
if (test_and_clear_bit(TXE_INTR_READINESS_BIT, &hw->intr_cause)) { if (test_and_clear_bit(TXE_INTR_READINESS_BIT, &hw->intr_cause)) {
dev_dbg(&dev->pdev->dev, "Readiness Interrupt was received...\n"); dev_dbg(dev->dev, "Readiness Interrupt was received...\n");
/* Check if SeC is going through reset */ /* Check if SeC is going through reset */
if (mei_txe_readiness_is_sec_rdy(hw->readiness)) { if (mei_txe_readiness_is_sec_rdy(hw->readiness)) {
dev_dbg(&dev->pdev->dev, "we need to start the dev.\n"); dev_dbg(dev->dev, "we need to start the dev.\n");
dev->recvd_hw_ready = true; dev->recvd_hw_ready = true;
} else { } else {
dev->recvd_hw_ready = false; dev->recvd_hw_ready = false;
if (dev->dev_state != MEI_DEV_RESETTING) { if (dev->dev_state != MEI_DEV_RESETTING) {
dev_warn(&dev->pdev->dev, "FW not ready: resetting.\n"); dev_warn(dev->dev, "FW not ready: resetting.\n");
schedule_work(&dev->reset_work); schedule_work(&dev->reset_work);
goto end; goto end;
...@@ -1013,7 +1010,7 @@ irqreturn_t mei_txe_irq_thread_handler(int irq, void *dev_id) ...@@ -1013,7 +1010,7 @@ irqreturn_t mei_txe_irq_thread_handler(int irq, void *dev_id)
if (test_and_clear_bit(TXE_INTR_ALIVENESS_BIT, &hw->intr_cause)) { if (test_and_clear_bit(TXE_INTR_ALIVENESS_BIT, &hw->intr_cause)) {
/* Clear the interrupt cause */ /* Clear the interrupt cause */
dev_dbg(&dev->pdev->dev, dev_dbg(dev->dev,
"Aliveness Interrupt: Status: %d\n", hw->aliveness); "Aliveness Interrupt: Status: %d\n", hw->aliveness);
dev->pg_event = MEI_PG_EVENT_RECEIVED; dev->pg_event = MEI_PG_EVENT_RECEIVED;
if (waitqueue_active(&hw->wait_aliveness_resp)) if (waitqueue_active(&hw->wait_aliveness_resp))
...@@ -1029,7 +1026,7 @@ irqreturn_t mei_txe_irq_thread_handler(int irq, void *dev_id) ...@@ -1029,7 +1026,7 @@ irqreturn_t mei_txe_irq_thread_handler(int irq, void *dev_id)
/* Read from TXE */ /* Read from TXE */
rets = mei_irq_read_handler(dev, &complete_list, &slots); rets = mei_irq_read_handler(dev, &complete_list, &slots);
if (rets && dev->dev_state != MEI_DEV_RESETTING) { if (rets && dev->dev_state != MEI_DEV_RESETTING) {
dev_err(&dev->pdev->dev, dev_err(dev->dev,
"mei_irq_read_handler ret = %d.\n", rets); "mei_irq_read_handler ret = %d.\n", rets);
schedule_work(&dev->reset_work); schedule_work(&dev->reset_work);
...@@ -1047,7 +1044,7 @@ irqreturn_t mei_txe_irq_thread_handler(int irq, void *dev_id) ...@@ -1047,7 +1044,7 @@ irqreturn_t mei_txe_irq_thread_handler(int irq, void *dev_id)
dev->hbuf_is_ready = mei_hbuf_is_ready(dev); dev->hbuf_is_ready = mei_hbuf_is_ready(dev);
rets = mei_irq_write_handler(dev, &complete_list); rets = mei_irq_write_handler(dev, &complete_list);
if (rets && rets != -EMSGSIZE) if (rets && rets != -EMSGSIZE)
dev_err(&dev->pdev->dev, "mei_irq_write_handler ret = %d.\n", dev_err(dev->dev, "mei_irq_write_handler ret = %d.\n",
rets); rets);
dev->hbuf_is_ready = mei_hbuf_is_ready(dev); dev->hbuf_is_ready = mei_hbuf_is_ready(dev);
} }
...@@ -1055,7 +1052,7 @@ irqreturn_t mei_txe_irq_thread_handler(int irq, void *dev_id) ...@@ -1055,7 +1052,7 @@ irqreturn_t mei_txe_irq_thread_handler(int irq, void *dev_id)
mei_irq_compl_handler(dev, &complete_list); mei_irq_compl_handler(dev, &complete_list);
end: end:
dev_dbg(&dev->pdev->dev, "interrupt thread end ret = %d\n", rets); dev_dbg(dev->dev, "interrupt thread end ret = %d\n", rets);
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
...@@ -1171,7 +1168,7 @@ int mei_txe_setup_satt2(struct mei_device *dev, phys_addr_t addr, u32 range) ...@@ -1171,7 +1168,7 @@ int mei_txe_setup_satt2(struct mei_device *dev, phys_addr_t addr, u32 range)
mei_txe_br_reg_write(hw, SATT2_SAP_SIZE_REG, range); mei_txe_br_reg_write(hw, SATT2_SAP_SIZE_REG, range);
mei_txe_br_reg_write(hw, SATT2_BRG_BA_LSB_REG, lo32); mei_txe_br_reg_write(hw, SATT2_BRG_BA_LSB_REG, lo32);
mei_txe_br_reg_write(hw, SATT2_CTRL_REG, ctrl); mei_txe_br_reg_write(hw, SATT2_CTRL_REG, ctrl);
dev_dbg(&dev->pdev->dev, "SATT2: SAP_SIZE_OFFSET=0x%08X, BRG_BA_LSB_OFFSET=0x%08X, CTRL_OFFSET=0x%08X\n", dev_dbg(dev->dev, "SATT2: SAP_SIZE_OFFSET=0x%08X, BRG_BA_LSB_OFFSET=0x%08X, CTRL_OFFSET=0x%08X\n",
range, lo32, ctrl); range, lo32, ctrl);
return 0; return 0;
......
...@@ -90,7 +90,7 @@ int mei_reset(struct mei_device *dev) ...@@ -90,7 +90,7 @@ int mei_reset(struct mei_device *dev)
struct mei_fw_status fw_status; struct mei_fw_status fw_status;
mei_fw_status(dev, &fw_status); mei_fw_status(dev, &fw_status);
dev_warn(&dev->pdev->dev, dev_warn(dev->dev,
"unexpected reset: dev_state = %s " FW_STS_FMT "\n", "unexpected reset: dev_state = %s " FW_STS_FMT "\n",
mei_dev_state_str(state), FW_STS_PRM(fw_status)); mei_dev_state_str(state), FW_STS_PRM(fw_status));
} }
...@@ -108,7 +108,7 @@ int mei_reset(struct mei_device *dev) ...@@ -108,7 +108,7 @@ int mei_reset(struct mei_device *dev)
dev->reset_count++; dev->reset_count++;
if (dev->reset_count > MEI_MAX_CONSEC_RESET) { if (dev->reset_count > MEI_MAX_CONSEC_RESET) {
dev_err(&dev->pdev->dev, "reset: reached maximal consecutive resets: disabling the device\n"); dev_err(dev->dev, "reset: reached maximal consecutive resets: disabling the device\n");
dev->dev_state = MEI_DEV_DISABLED; dev->dev_state = MEI_DEV_DISABLED;
return -ENODEV; return -ENODEV;
} }
...@@ -129,7 +129,7 @@ int mei_reset(struct mei_device *dev) ...@@ -129,7 +129,7 @@ int mei_reset(struct mei_device *dev)
mei_cl_all_wakeup(dev); mei_cl_all_wakeup(dev);
/* remove entry if already in list */ /* remove entry if already in list */
dev_dbg(&dev->pdev->dev, "remove iamthif and wd from the file list.\n"); dev_dbg(dev->dev, "remove iamthif and wd from the file list.\n");
mei_cl_unlink(&dev->wd_cl); mei_cl_unlink(&dev->wd_cl);
mei_cl_unlink(&dev->iamthif_cl); mei_cl_unlink(&dev->iamthif_cl);
mei_amthif_reset_params(dev); mei_amthif_reset_params(dev);
...@@ -141,28 +141,28 @@ int mei_reset(struct mei_device *dev) ...@@ -141,28 +141,28 @@ int mei_reset(struct mei_device *dev)
dev->wd_pending = false; dev->wd_pending = false;
if (ret) { if (ret) {
dev_err(&dev->pdev->dev, "hw_reset failed ret = %d\n", ret); dev_err(dev->dev, "hw_reset failed ret = %d\n", ret);
return ret; return ret;
} }
if (state == MEI_DEV_POWER_DOWN) { if (state == MEI_DEV_POWER_DOWN) {
dev_dbg(&dev->pdev->dev, "powering down: end of reset\n"); dev_dbg(dev->dev, "powering down: end of reset\n");
dev->dev_state = MEI_DEV_DISABLED; dev->dev_state = MEI_DEV_DISABLED;
return 0; return 0;
} }
ret = mei_hw_start(dev); ret = mei_hw_start(dev);
if (ret) { if (ret) {
dev_err(&dev->pdev->dev, "hw_start failed ret = %d\n", ret); dev_err(dev->dev, "hw_start failed ret = %d\n", ret);
return ret; return ret;
} }
dev_dbg(&dev->pdev->dev, "link is established start sending messages.\n"); dev_dbg(dev->dev, "link is established start sending messages.\n");
dev->dev_state = MEI_DEV_INIT_CLIENTS; dev->dev_state = MEI_DEV_INIT_CLIENTS;
ret = mei_hbm_start_req(dev); ret = mei_hbm_start_req(dev);
if (ret) { if (ret) {
dev_err(&dev->pdev->dev, "hbm_start failed ret = %d\n", ret); dev_err(dev->dev, "hbm_start failed ret = %d\n", ret);
dev->dev_state = MEI_DEV_RESETTING; dev->dev_state = MEI_DEV_RESETTING;
return ret; return ret;
} }
...@@ -189,7 +189,7 @@ int mei_start(struct mei_device *dev) ...@@ -189,7 +189,7 @@ int mei_start(struct mei_device *dev)
mei_hw_config(dev); mei_hw_config(dev);
dev_dbg(&dev->pdev->dev, "reset in start the mei device.\n"); dev_dbg(dev->dev, "reset in start the mei device.\n");
dev->reset_count = 0; dev->reset_count = 0;
do { do {
...@@ -197,43 +197,43 @@ int mei_start(struct mei_device *dev) ...@@ -197,43 +197,43 @@ int mei_start(struct mei_device *dev)
ret = mei_reset(dev); ret = mei_reset(dev);
if (ret == -ENODEV || dev->dev_state == MEI_DEV_DISABLED) { if (ret == -ENODEV || dev->dev_state == MEI_DEV_DISABLED) {
dev_err(&dev->pdev->dev, "reset failed ret = %d", ret); dev_err(dev->dev, "reset failed ret = %d", ret);
goto err; goto err;
} }
} while (ret); } while (ret);
/* we cannot start the device w/o hbm start message completed */ /* we cannot start the device w/o hbm start message completed */
if (dev->dev_state == MEI_DEV_DISABLED) { if (dev->dev_state == MEI_DEV_DISABLED) {
dev_err(&dev->pdev->dev, "reset failed"); dev_err(dev->dev, "reset failed");
goto err; goto err;
} }
if (mei_hbm_start_wait(dev)) { if (mei_hbm_start_wait(dev)) {
dev_err(&dev->pdev->dev, "HBM haven't started"); dev_err(dev->dev, "HBM haven't started");
goto err; goto err;
} }
if (!mei_host_is_ready(dev)) { if (!mei_host_is_ready(dev)) {
dev_err(&dev->pdev->dev, "host is not ready.\n"); dev_err(dev->dev, "host is not ready.\n");
goto err; goto err;
} }
if (!mei_hw_is_ready(dev)) { if (!mei_hw_is_ready(dev)) {
dev_err(&dev->pdev->dev, "ME is not ready.\n"); dev_err(dev->dev, "ME is not ready.\n");
goto err; goto err;
} }
if (!mei_hbm_version_is_supported(dev)) { if (!mei_hbm_version_is_supported(dev)) {
dev_dbg(&dev->pdev->dev, "MEI start failed.\n"); dev_dbg(dev->dev, "MEI start failed.\n");
goto err; goto err;
} }
dev_dbg(&dev->pdev->dev, "link layer has been established.\n"); dev_dbg(dev->dev, "link layer has been established.\n");
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
return 0; return 0;
err: err:
dev_err(&dev->pdev->dev, "link layer initialization failed.\n"); dev_err(dev->dev, "link layer initialization failed.\n");
dev->dev_state = MEI_DEV_DISABLED; dev->dev_state = MEI_DEV_DISABLED;
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
return -ENODEV; return -ENODEV;
...@@ -263,7 +263,7 @@ int mei_restart(struct mei_device *dev) ...@@ -263,7 +263,7 @@ int mei_restart(struct mei_device *dev)
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
if (err == -ENODEV || dev->dev_state == MEI_DEV_DISABLED) { if (err == -ENODEV || dev->dev_state == MEI_DEV_DISABLED) {
dev_err(&dev->pdev->dev, "device disabled = %d\n", err); dev_err(dev->dev, "device disabled = %d\n", err);
return -ENODEV; return -ENODEV;
} }
...@@ -289,7 +289,7 @@ static void mei_reset_work(struct work_struct *work) ...@@ -289,7 +289,7 @@ static void mei_reset_work(struct work_struct *work)
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
if (dev->dev_state == MEI_DEV_DISABLED) { if (dev->dev_state == MEI_DEV_DISABLED) {
dev_err(&dev->pdev->dev, "device disabled = %d\n", ret); dev_err(dev->dev, "device disabled = %d\n", ret);
return; return;
} }
...@@ -300,7 +300,7 @@ static void mei_reset_work(struct work_struct *work) ...@@ -300,7 +300,7 @@ static void mei_reset_work(struct work_struct *work)
void mei_stop(struct mei_device *dev) void mei_stop(struct mei_device *dev)
{ {
dev_dbg(&dev->pdev->dev, "stopping the device.\n"); dev_dbg(dev->dev, "stopping the device.\n");
mei_cancel_work(dev); mei_cancel_work(dev);
...@@ -334,7 +334,7 @@ bool mei_write_is_idle(struct mei_device *dev) ...@@ -334,7 +334,7 @@ bool mei_write_is_idle(struct mei_device *dev)
list_empty(&dev->ctrl_wr_list.list) && list_empty(&dev->ctrl_wr_list.list) &&
list_empty(&dev->write_list.list)); list_empty(&dev->write_list.list));
dev_dbg(&dev->pdev->dev, "write pg: is idle[%d] state=%s ctrl=%d write=%d\n", dev_dbg(dev->dev, "write pg: is idle[%d] state=%s ctrl=%d write=%d\n",
idle, idle,
mei_dev_state_str(dev->dev_state), mei_dev_state_str(dev->dev_state),
list_empty(&dev->ctrl_wr_list.list), list_empty(&dev->ctrl_wr_list.list),
......
...@@ -47,7 +47,7 @@ void mei_irq_compl_handler(struct mei_device *dev, struct mei_cl_cb *compl_list) ...@@ -47,7 +47,7 @@ void mei_irq_compl_handler(struct mei_device *dev, struct mei_cl_cb *compl_list)
if (!cl) if (!cl)
continue; continue;
dev_dbg(&dev->pdev->dev, "completing call back.\n"); dev_dbg(dev->dev, "completing call back.\n");
if (cl == &dev->iamthif_cl) if (cl == &dev->iamthif_cl)
mei_amthif_complete(dev, cb); mei_amthif_complete(dev, cb);
else else
...@@ -148,10 +148,10 @@ static int mei_cl_irq_read_msg(struct mei_device *dev, ...@@ -148,10 +148,10 @@ static int mei_cl_irq_read_msg(struct mei_device *dev,
break; break;
} }
dev_dbg(&dev->pdev->dev, "message read\n"); dev_dbg(dev->dev, "message read\n");
if (!buffer) { if (!buffer) {
mei_read_slots(dev, dev->rd_msg_buf, mei_hdr->length); mei_read_slots(dev, dev->rd_msg_buf, mei_hdr->length);
dev_dbg(&dev->pdev->dev, "discarding message " MEI_HDR_FMT "\n", dev_dbg(dev->dev, "discarding message " MEI_HDR_FMT "\n",
MEI_HDR_PRM(mei_hdr)); MEI_HDR_PRM(mei_hdr));
} }
...@@ -333,20 +333,20 @@ int mei_irq_read_handler(struct mei_device *dev, ...@@ -333,20 +333,20 @@ int mei_irq_read_handler(struct mei_device *dev,
if (!dev->rd_msg_hdr) { if (!dev->rd_msg_hdr) {
dev->rd_msg_hdr = mei_read_hdr(dev); dev->rd_msg_hdr = mei_read_hdr(dev);
(*slots)--; (*slots)--;
dev_dbg(&dev->pdev->dev, "slots =%08x.\n", *slots); dev_dbg(dev->dev, "slots =%08x.\n", *slots);
} }
mei_hdr = (struct mei_msg_hdr *) &dev->rd_msg_hdr; mei_hdr = (struct mei_msg_hdr *) &dev->rd_msg_hdr;
dev_dbg(&dev->pdev->dev, MEI_HDR_FMT, MEI_HDR_PRM(mei_hdr)); dev_dbg(dev->dev, MEI_HDR_FMT, MEI_HDR_PRM(mei_hdr));
if (mei_hdr->reserved || !dev->rd_msg_hdr) { if (mei_hdr->reserved || !dev->rd_msg_hdr) {
dev_err(&dev->pdev->dev, "corrupted message header 0x%08X\n", dev_err(dev->dev, "corrupted message header 0x%08X\n",
dev->rd_msg_hdr); dev->rd_msg_hdr);
ret = -EBADMSG; ret = -EBADMSG;
goto end; goto end;
} }
if (mei_slots2data(*slots) < mei_hdr->length) { if (mei_slots2data(*slots) < mei_hdr->length) {
dev_err(&dev->pdev->dev, "less data available than length=%08x.\n", dev_err(dev->dev, "less data available than length=%08x.\n",
*slots); *slots);
/* we can't read the message */ /* we can't read the message */
ret = -ENODATA; ret = -ENODATA;
...@@ -357,7 +357,7 @@ int mei_irq_read_handler(struct mei_device *dev, ...@@ -357,7 +357,7 @@ int mei_irq_read_handler(struct mei_device *dev,
if (mei_hdr->host_addr == 0 && mei_hdr->me_addr == 0) { if (mei_hdr->host_addr == 0 && mei_hdr->me_addr == 0) {
ret = mei_hbm_dispatch(dev, mei_hdr); ret = mei_hbm_dispatch(dev, mei_hdr);
if (ret) { if (ret) {
dev_dbg(&dev->pdev->dev, "mei_hbm_dispatch failed ret = %d\n", dev_dbg(dev->dev, "mei_hbm_dispatch failed ret = %d\n",
ret); ret);
goto end; goto end;
} }
...@@ -374,7 +374,7 @@ int mei_irq_read_handler(struct mei_device *dev, ...@@ -374,7 +374,7 @@ int mei_irq_read_handler(struct mei_device *dev,
/* if no recipient cl was found we assume corrupted header */ /* if no recipient cl was found we assume corrupted header */
if (&cl->link == &dev->file_list) { if (&cl->link == &dev->file_list) {
dev_err(&dev->pdev->dev, "no destination client found 0x%08X\n", dev_err(dev->dev, "no destination client found 0x%08X\n",
dev->rd_msg_hdr); dev->rd_msg_hdr);
ret = -EBADMSG; ret = -EBADMSG;
goto end; goto end;
...@@ -386,14 +386,14 @@ int mei_irq_read_handler(struct mei_device *dev, ...@@ -386,14 +386,14 @@ int mei_irq_read_handler(struct mei_device *dev,
ret = mei_amthif_irq_read_msg(dev, mei_hdr, cmpl_list); ret = mei_amthif_irq_read_msg(dev, mei_hdr, cmpl_list);
if (ret) { if (ret) {
dev_err(&dev->pdev->dev, "mei_amthif_irq_read_msg failed = %d\n", dev_err(dev->dev, "mei_amthif_irq_read_msg failed = %d\n",
ret); ret);
goto end; goto end;
} }
} else { } else {
ret = mei_cl_irq_read_msg(dev, mei_hdr, cmpl_list); ret = mei_cl_irq_read_msg(dev, mei_hdr, cmpl_list);
if (ret) { if (ret) {
dev_err(&dev->pdev->dev, "mei_cl_irq_read_msg failed = %d\n", dev_err(dev->dev, "mei_cl_irq_read_msg failed = %d\n",
ret); ret);
goto end; goto end;
} }
...@@ -406,7 +406,7 @@ int mei_irq_read_handler(struct mei_device *dev, ...@@ -406,7 +406,7 @@ int mei_irq_read_handler(struct mei_device *dev,
if (*slots == -EOVERFLOW) { if (*slots == -EOVERFLOW) {
/* overflow - reset */ /* overflow - reset */
dev_err(&dev->pdev->dev, "resetting due to slots overflow.\n"); dev_err(dev->dev, "resetting due to slots overflow.\n");
/* set the event since message has been read */ /* set the event since message has been read */
ret = -ERANGE; ret = -ERANGE;
goto end; goto end;
...@@ -444,7 +444,7 @@ int mei_irq_write_handler(struct mei_device *dev, struct mei_cl_cb *cmpl_list) ...@@ -444,7 +444,7 @@ int mei_irq_write_handler(struct mei_device *dev, struct mei_cl_cb *cmpl_list)
return -EMSGSIZE; return -EMSGSIZE;
/* complete all waiting for write CB */ /* complete all waiting for write CB */
dev_dbg(&dev->pdev->dev, "complete all waiting for write cb.\n"); dev_dbg(dev->dev, "complete all waiting for write cb.\n");
list = &dev->write_waiting_list; list = &dev->write_waiting_list;
list_for_each_entry_safe(cb, next, &list->list, list) { list_for_each_entry_safe(cb, next, &list->list, list) {
...@@ -486,7 +486,7 @@ int mei_irq_write_handler(struct mei_device *dev, struct mei_cl_cb *cmpl_list) ...@@ -486,7 +486,7 @@ int mei_irq_write_handler(struct mei_device *dev, struct mei_cl_cb *cmpl_list)
} }
/* complete control write list CB */ /* complete control write list CB */
dev_dbg(&dev->pdev->dev, "complete control write list cb.\n"); dev_dbg(dev->dev, "complete control write list cb.\n");
list_for_each_entry_safe(cb, next, &dev->ctrl_wr_list.list, list) { list_for_each_entry_safe(cb, next, &dev->ctrl_wr_list.list, list) {
cl = cb->cl; cl = cb->cl;
if (!cl) { if (!cl) {
...@@ -527,7 +527,7 @@ int mei_irq_write_handler(struct mei_device *dev, struct mei_cl_cb *cmpl_list) ...@@ -527,7 +527,7 @@ int mei_irq_write_handler(struct mei_device *dev, struct mei_cl_cb *cmpl_list)
} }
/* complete write list CB */ /* complete write list CB */
dev_dbg(&dev->pdev->dev, "complete write list cb.\n"); dev_dbg(dev->dev, "complete write list cb.\n");
list_for_each_entry_safe(cb, next, &dev->write_list.list, list) { list_for_each_entry_safe(cb, next, &dev->write_list.list, list) {
cl = cb->cl; cl = cb->cl;
if (cl == NULL) if (cl == NULL)
...@@ -568,7 +568,7 @@ void mei_timer(struct work_struct *work) ...@@ -568,7 +568,7 @@ void mei_timer(struct work_struct *work)
if (dev->init_clients_timer) { if (dev->init_clients_timer) {
if (--dev->init_clients_timer == 0) { if (--dev->init_clients_timer == 0) {
dev_err(&dev->pdev->dev, "timer: init clients timeout hbm_state = %d.\n", dev_err(dev->dev, "timer: init clients timeout hbm_state = %d.\n",
dev->hbm_state); dev->hbm_state);
mei_reset(dev); mei_reset(dev);
goto out; goto out;
...@@ -583,7 +583,7 @@ void mei_timer(struct work_struct *work) ...@@ -583,7 +583,7 @@ void mei_timer(struct work_struct *work)
list_for_each_entry(cl, &dev->file_list, link) { list_for_each_entry(cl, &dev->file_list, link) {
if (cl->timer_count) { if (cl->timer_count) {
if (--cl->timer_count == 0) { if (--cl->timer_count == 0) {
dev_err(&dev->pdev->dev, "timer: connect/disconnect timeout.\n"); dev_err(dev->dev, "timer: connect/disconnect timeout.\n");
mei_reset(dev); mei_reset(dev);
goto out; goto out;
} }
...@@ -595,7 +595,7 @@ void mei_timer(struct work_struct *work) ...@@ -595,7 +595,7 @@ void mei_timer(struct work_struct *work)
if (dev->iamthif_stall_timer) { if (dev->iamthif_stall_timer) {
if (--dev->iamthif_stall_timer == 0) { if (--dev->iamthif_stall_timer == 0) {
dev_err(&dev->pdev->dev, "timer: amthif hanged.\n"); dev_err(dev->dev, "timer: amthif hanged.\n");
mei_reset(dev); mei_reset(dev);
dev->iamthif_msg_buf_size = 0; dev->iamthif_msg_buf_size = 0;
dev->iamthif_msg_buf_index = 0; dev->iamthif_msg_buf_index = 0;
...@@ -617,17 +617,17 @@ void mei_timer(struct work_struct *work) ...@@ -617,17 +617,17 @@ void mei_timer(struct work_struct *work)
timeout = dev->iamthif_timer + timeout = dev->iamthif_timer +
mei_secs_to_jiffies(MEI_IAMTHIF_READ_TIMER); mei_secs_to_jiffies(MEI_IAMTHIF_READ_TIMER);
dev_dbg(&dev->pdev->dev, "dev->iamthif_timer = %ld\n", dev_dbg(dev->dev, "dev->iamthif_timer = %ld\n",
dev->iamthif_timer); dev->iamthif_timer);
dev_dbg(&dev->pdev->dev, "timeout = %ld\n", timeout); dev_dbg(dev->dev, "timeout = %ld\n", timeout);
dev_dbg(&dev->pdev->dev, "jiffies = %ld\n", jiffies); dev_dbg(dev->dev, "jiffies = %ld\n", jiffies);
if (time_after(jiffies, timeout)) { if (time_after(jiffies, timeout)) {
/* /*
* User didn't read the AMTHI data on time (15sec) * User didn't read the AMTHI data on time (15sec)
* freeing AMTHI for other requests * freeing AMTHI for other requests
*/ */
dev_dbg(&dev->pdev->dev, "freeing AMTHI for other requests\n"); dev_dbg(dev->dev, "freeing AMTHI for other requests\n");
mei_io_list_flush(&dev->amthif_rd_complete_list, mei_io_list_flush(&dev->amthif_rd_complete_list,
&dev->iamthif_cl); &dev->iamthif_cl);
......
...@@ -63,7 +63,7 @@ static int mei_open(struct inode *inode, struct file *file) ...@@ -63,7 +63,7 @@ static int mei_open(struct inode *inode, struct file *file)
err = -ENODEV; err = -ENODEV;
if (dev->dev_state != MEI_DEV_ENABLED) { if (dev->dev_state != MEI_DEV_ENABLED) {
dev_dbg(&dev->pdev->dev, "dev_state != MEI_ENABLED dev_state = %s\n", dev_dbg(dev->dev, "dev_state != MEI_ENABLED dev_state = %s\n",
mei_dev_state_str(dev->dev_state)); mei_dev_state_str(dev->dev_state));
goto err_unlock; goto err_unlock;
} }
...@@ -211,7 +211,7 @@ static ssize_t mei_read(struct file *file, char __user *ubuf, ...@@ -211,7 +211,7 @@ static ssize_t mei_read(struct file *file, char __user *ubuf,
err = mei_cl_read_start(cl, length); err = mei_cl_read_start(cl, length);
if (err && err != -EBUSY) { if (err && err != -EBUSY) {
dev_dbg(&dev->pdev->dev, dev_dbg(dev->dev,
"mei start read failure with status = %d\n", err); "mei start read failure with status = %d\n", err);
rets = err; rets = err;
goto out; goto out;
...@@ -254,7 +254,7 @@ static ssize_t mei_read(struct file *file, char __user *ubuf, ...@@ -254,7 +254,7 @@ static ssize_t mei_read(struct file *file, char __user *ubuf,
} }
/* now copy the data to user space */ /* now copy the data to user space */
copy_buffer: copy_buffer:
dev_dbg(&dev->pdev->dev, "buf.size = %d buf.idx= %ld\n", dev_dbg(dev->dev, "buf.size = %d buf.idx= %ld\n",
cb->response_buffer.size, cb->buf_idx); cb->response_buffer.size, cb->buf_idx);
if (length == 0 || ubuf == NULL || *offset > cb->buf_idx) { if (length == 0 || ubuf == NULL || *offset > cb->buf_idx) {
rets = -EMSGSIZE; rets = -EMSGSIZE;
...@@ -266,7 +266,7 @@ static ssize_t mei_read(struct file *file, char __user *ubuf, ...@@ -266,7 +266,7 @@ static ssize_t mei_read(struct file *file, char __user *ubuf,
length = min_t(size_t, length, cb->buf_idx - *offset); length = min_t(size_t, length, cb->buf_idx - *offset);
if (copy_to_user(ubuf, cb->response_buffer.data + *offset, length)) { if (copy_to_user(ubuf, cb->response_buffer.data + *offset, length)) {
dev_dbg(&dev->pdev->dev, "failed to copy data to userland\n"); dev_dbg(dev->dev, "failed to copy data to userland\n");
rets = -EFAULT; rets = -EFAULT;
goto free; goto free;
} }
...@@ -285,7 +285,7 @@ static ssize_t mei_read(struct file *file, char __user *ubuf, ...@@ -285,7 +285,7 @@ static ssize_t mei_read(struct file *file, char __user *ubuf,
cl->reading_state = MEI_IDLE; cl->reading_state = MEI_IDLE;
cl->read_cb = NULL; cl->read_cb = NULL;
out: out:
dev_dbg(&dev->pdev->dev, "end mei read rets= %d\n", rets); dev_dbg(dev->dev, "end mei read rets= %d\n", rets);
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
return rets; return rets;
} }
...@@ -338,7 +338,7 @@ static ssize_t mei_write(struct file *file, const char __user *ubuf, ...@@ -338,7 +338,7 @@ static ssize_t mei_write(struct file *file, const char __user *ubuf,
} }
if (cl->state != MEI_FILE_CONNECTED) { if (cl->state != MEI_FILE_CONNECTED) {
dev_err(&dev->pdev->dev, "host client = %d, is not connected to ME client = %d", dev_err(dev->dev, "host client = %d, is not connected to ME client = %d",
cl->host_client_id, cl->me_client_id); cl->host_client_id, cl->me_client_id);
rets = -ENODEV; rets = -ENODEV;
goto out; goto out;
...@@ -386,7 +386,7 @@ static ssize_t mei_write(struct file *file, const char __user *ubuf, ...@@ -386,7 +386,7 @@ static ssize_t mei_write(struct file *file, const char __user *ubuf,
rets = copy_from_user(write_cb->request_buffer.data, ubuf, length); rets = copy_from_user(write_cb->request_buffer.data, ubuf, length);
if (rets) { if (rets) {
dev_dbg(&dev->pdev->dev, "failed to copy data from userland\n"); dev_dbg(dev->dev, "failed to copy data from userland\n");
rets = -EFAULT; rets = -EFAULT;
goto out; goto out;
} }
...@@ -395,7 +395,7 @@ static ssize_t mei_write(struct file *file, const char __user *ubuf, ...@@ -395,7 +395,7 @@ static ssize_t mei_write(struct file *file, const char __user *ubuf,
rets = mei_amthif_write(dev, write_cb); rets = mei_amthif_write(dev, write_cb);
if (rets) { if (rets) {
dev_err(&dev->pdev->dev, dev_err(dev->dev,
"amthif write failed with status = %d\n", rets); "amthif write failed with status = %d\n", rets);
goto out; goto out;
} }
...@@ -448,7 +448,7 @@ static int mei_ioctl_connect_client(struct file *file, ...@@ -448,7 +448,7 @@ static int mei_ioctl_connect_client(struct file *file,
/* find ME client we're trying to connect to */ /* find ME client we're trying to connect to */
me_cl = mei_me_cl_by_uuid(dev, &data->in_client_uuid); me_cl = mei_me_cl_by_uuid(dev, &data->in_client_uuid);
if (!me_cl || me_cl->props.fixed_address) { if (!me_cl || me_cl->props.fixed_address) {
dev_dbg(&dev->pdev->dev, "Cannot connect to FW Client UUID = %pUl\n", dev_dbg(dev->dev, "Cannot connect to FW Client UUID = %pUl\n",
&data->in_client_uuid); &data->in_client_uuid);
rets = -ENOTTY; rets = -ENOTTY;
goto end; goto end;
...@@ -457,18 +457,18 @@ static int mei_ioctl_connect_client(struct file *file, ...@@ -457,18 +457,18 @@ static int mei_ioctl_connect_client(struct file *file,
cl->me_client_id = me_cl->client_id; cl->me_client_id = me_cl->client_id;
cl->cl_uuid = me_cl->props.protocol_name; cl->cl_uuid = me_cl->props.protocol_name;
dev_dbg(&dev->pdev->dev, "Connect to FW Client ID = %d\n", dev_dbg(dev->dev, "Connect to FW Client ID = %d\n",
cl->me_client_id); cl->me_client_id);
dev_dbg(&dev->pdev->dev, "FW Client - Protocol Version = %d\n", dev_dbg(dev->dev, "FW Client - Protocol Version = %d\n",
me_cl->props.protocol_version); me_cl->props.protocol_version);
dev_dbg(&dev->pdev->dev, "FW Client - Max Msg Len = %d\n", dev_dbg(dev->dev, "FW Client - Max Msg Len = %d\n",
me_cl->props.max_msg_length); me_cl->props.max_msg_length);
/* if we're connecting to amthif client then we will use the /* if we're connecting to amthif client then we will use the
* existing connection * existing connection
*/ */
if (uuid_le_cmp(data->in_client_uuid, mei_amthif_guid) == 0) { if (uuid_le_cmp(data->in_client_uuid, mei_amthif_guid) == 0) {
dev_dbg(&dev->pdev->dev, "FW Client is amthi\n"); dev_dbg(dev->dev, "FW Client is amthi\n");
if (dev->iamthif_cl.state != MEI_FILE_CONNECTED) { if (dev->iamthif_cl.state != MEI_FILE_CONNECTED) {
rets = -ENODEV; rets = -ENODEV;
goto end; goto end;
...@@ -493,7 +493,7 @@ static int mei_ioctl_connect_client(struct file *file, ...@@ -493,7 +493,7 @@ static int mei_ioctl_connect_client(struct file *file,
client = &data->out_client_properties; client = &data->out_client_properties;
client->max_msg_length = me_cl->props.max_msg_length; client->max_msg_length = me_cl->props.max_msg_length;
client->protocol_version = me_cl->props.protocol_version; client->protocol_version = me_cl->props.protocol_version;
dev_dbg(&dev->pdev->dev, "Can connect?\n"); dev_dbg(dev->dev, "Can connect?\n");
rets = mei_cl_connect(cl, file); rets = mei_cl_connect(cl, file);
...@@ -524,7 +524,7 @@ static long mei_ioctl(struct file *file, unsigned int cmd, unsigned long data) ...@@ -524,7 +524,7 @@ static long mei_ioctl(struct file *file, unsigned int cmd, unsigned long data)
dev = cl->dev; dev = cl->dev;
dev_dbg(&dev->pdev->dev, "IOCTL cmd = 0x%x", cmd); dev_dbg(dev->dev, "IOCTL cmd = 0x%x", cmd);
mutex_lock(&dev->device_lock); mutex_lock(&dev->device_lock);
if (dev->dev_state != MEI_DEV_ENABLED) { if (dev->dev_state != MEI_DEV_ENABLED) {
...@@ -534,10 +534,10 @@ static long mei_ioctl(struct file *file, unsigned int cmd, unsigned long data) ...@@ -534,10 +534,10 @@ static long mei_ioctl(struct file *file, unsigned int cmd, unsigned long data)
switch (cmd) { switch (cmd) {
case IOCTL_MEI_CONNECT_CLIENT: case IOCTL_MEI_CONNECT_CLIENT:
dev_dbg(&dev->pdev->dev, ": IOCTL_MEI_CONNECT_CLIENT.\n"); dev_dbg(dev->dev, ": IOCTL_MEI_CONNECT_CLIENT.\n");
if (copy_from_user(&connect_data, (char __user *)data, if (copy_from_user(&connect_data, (char __user *)data,
sizeof(struct mei_connect_client_data))) { sizeof(struct mei_connect_client_data))) {
dev_dbg(&dev->pdev->dev, "failed to copy data from userland\n"); dev_dbg(dev->dev, "failed to copy data from userland\n");
rets = -EFAULT; rets = -EFAULT;
goto out; goto out;
} }
...@@ -549,7 +549,7 @@ static long mei_ioctl(struct file *file, unsigned int cmd, unsigned long data) ...@@ -549,7 +549,7 @@ static long mei_ioctl(struct file *file, unsigned int cmd, unsigned long data)
/* if all is ok, copying the data back to user. */ /* if all is ok, copying the data back to user. */
if (copy_to_user((char __user *)data, &connect_data, if (copy_to_user((char __user *)data, &connect_data,
sizeof(struct mei_connect_client_data))) { sizeof(struct mei_connect_client_data))) {
dev_dbg(&dev->pdev->dev, "failed to copy data to userland\n"); dev_dbg(dev->dev, "failed to copy data to userland\n");
rets = -EFAULT; rets = -EFAULT;
goto out; goto out;
} }
...@@ -557,7 +557,7 @@ static long mei_ioctl(struct file *file, unsigned int cmd, unsigned long data) ...@@ -557,7 +557,7 @@ static long mei_ioctl(struct file *file, unsigned int cmd, unsigned long data)
break; break;
default: default:
dev_err(&dev->pdev->dev, ": unsupported ioctl %d.\n", cmd); dev_err(dev->dev, ": unsupported ioctl %d.\n", cmd);
rets = -ENOIOCTLCMD; rets = -ENOIOCTLCMD;
} }
...@@ -671,7 +671,7 @@ static int mei_minor_get(struct mei_device *dev) ...@@ -671,7 +671,7 @@ static int mei_minor_get(struct mei_device *dev)
if (ret >= 0) if (ret >= 0)
dev->minor = ret; dev->minor = ret;
else if (ret == -ENOSPC) else if (ret == -ENOSPC)
dev_err(&dev->pdev->dev, "too many mei devices\n"); dev_err(dev->dev, "too many mei devices\n");
mutex_unlock(&mei_minor_lock); mutex_unlock(&mei_minor_lock);
return ret; return ret;
......
...@@ -163,7 +163,7 @@ static int mei_nfc_build_bus_name(struct mei_nfc_dev *ndev) ...@@ -163,7 +163,7 @@ static int mei_nfc_build_bus_name(struct mei_nfc_dev *ndev)
return 0; return 0;
default: default:
dev_err(&dev->pdev->dev, "Unknown radio type 0x%x\n", dev_err(dev->dev, "Unknown radio type 0x%x\n",
ndev->radio_type); ndev->radio_type);
return -EINVAL; return -EINVAL;
...@@ -175,14 +175,14 @@ static int mei_nfc_build_bus_name(struct mei_nfc_dev *ndev) ...@@ -175,14 +175,14 @@ static int mei_nfc_build_bus_name(struct mei_nfc_dev *ndev)
ndev->bus_name = "pn544"; ndev->bus_name = "pn544";
return 0; return 0;
default: default:
dev_err(&dev->pdev->dev, "Unknown radio type 0x%x\n", dev_err(dev->dev, "Unknown radio type 0x%x\n",
ndev->radio_type); ndev->radio_type);
return -EINVAL; return -EINVAL;
} }
default: default:
dev_err(&dev->pdev->dev, "Unknown vendor ID 0x%x\n", dev_err(dev->dev, "Unknown vendor ID 0x%x\n",
ndev->vendor_id); ndev->vendor_id);
return -EINVAL; return -EINVAL;
...@@ -231,21 +231,21 @@ static int mei_nfc_connect(struct mei_nfc_dev *ndev) ...@@ -231,21 +231,21 @@ static int mei_nfc_connect(struct mei_nfc_dev *ndev)
ret = __mei_cl_send(cl, (u8 *)cmd, connect_length); ret = __mei_cl_send(cl, (u8 *)cmd, connect_length);
if (ret < 0) { if (ret < 0) {
dev_err(&dev->pdev->dev, "Could not send connect cmd\n"); dev_err(dev->dev, "Could not send connect cmd\n");
goto err; goto err;
} }
bytes_recv = __mei_cl_recv(cl, (u8 *)reply, connect_resp_length); bytes_recv = __mei_cl_recv(cl, (u8 *)reply, connect_resp_length);
if (bytes_recv < 0) { if (bytes_recv < 0) {
dev_err(&dev->pdev->dev, "Could not read connect response\n"); dev_err(dev->dev, "Could not read connect response\n");
ret = bytes_recv; ret = bytes_recv;
goto err; goto err;
} }
dev_info(&dev->pdev->dev, "IVN 0x%x Vendor ID 0x%x\n", dev_info(dev->dev, "IVN 0x%x Vendor ID 0x%x\n",
connect_resp->fw_ivn, connect_resp->vendor_id); connect_resp->fw_ivn, connect_resp->vendor_id);
dev_info(&dev->pdev->dev, "ME FW %d.%d.%d.%d\n", dev_info(dev->dev, "ME FW %d.%d.%d.%d\n",
connect_resp->me_major, connect_resp->me_minor, connect_resp->me_major, connect_resp->me_minor,
connect_resp->me_hotfix, connect_resp->me_build); connect_resp->me_hotfix, connect_resp->me_build);
...@@ -279,7 +279,7 @@ static int mei_nfc_if_version(struct mei_nfc_dev *ndev) ...@@ -279,7 +279,7 @@ static int mei_nfc_if_version(struct mei_nfc_dev *ndev)
ret = __mei_cl_send(cl, (u8 *)&cmd, sizeof(struct mei_nfc_cmd)); ret = __mei_cl_send(cl, (u8 *)&cmd, sizeof(struct mei_nfc_cmd));
if (ret < 0) { if (ret < 0) {
dev_err(&dev->pdev->dev, "Could not send IF version cmd\n"); dev_err(dev->dev, "Could not send IF version cmd\n");
return ret; return ret;
} }
...@@ -293,7 +293,7 @@ static int mei_nfc_if_version(struct mei_nfc_dev *ndev) ...@@ -293,7 +293,7 @@ static int mei_nfc_if_version(struct mei_nfc_dev *ndev)
bytes_recv = __mei_cl_recv(cl, (u8 *)reply, if_version_length); bytes_recv = __mei_cl_recv(cl, (u8 *)reply, if_version_length);
if (bytes_recv < 0 || bytes_recv < sizeof(struct mei_nfc_reply)) { if (bytes_recv < 0 || bytes_recv < sizeof(struct mei_nfc_reply)) {
dev_err(&dev->pdev->dev, "Could not read IF version\n"); dev_err(dev->dev, "Could not read IF version\n");
ret = -EIO; ret = -EIO;
goto err; goto err;
} }
...@@ -319,7 +319,7 @@ static int mei_nfc_enable(struct mei_cl_device *cldev) ...@@ -319,7 +319,7 @@ static int mei_nfc_enable(struct mei_cl_device *cldev)
ret = mei_nfc_connect(ndev); ret = mei_nfc_connect(ndev);
if (ret < 0) { if (ret < 0) {
dev_err(&dev->pdev->dev, "Could not connect to NFC"); dev_err(dev->dev, "Could not connect to NFC");
return ret; return ret;
} }
...@@ -361,7 +361,7 @@ static int mei_nfc_send(struct mei_cl_device *cldev, u8 *buf, size_t length) ...@@ -361,7 +361,7 @@ static int mei_nfc_send(struct mei_cl_device *cldev, u8 *buf, size_t length)
if (!wait_event_interruptible_timeout(ndev->send_wq, if (!wait_event_interruptible_timeout(ndev->send_wq,
ndev->recv_req_id == ndev->req_id, HZ)) { ndev->recv_req_id == ndev->req_id, HZ)) {
dev_err(&dev->pdev->dev, "NFC MEI command timeout\n"); dev_err(dev->dev, "NFC MEI command timeout\n");
err = -ETIME; err = -ETIME;
} else { } else {
ndev->req_id++; ndev->req_id++;
...@@ -418,8 +418,7 @@ static void mei_nfc_init(struct work_struct *work) ...@@ -418,8 +418,7 @@ static void mei_nfc_init(struct work_struct *work)
if (mei_cl_connect(cl_info, NULL) < 0) { if (mei_cl_connect(cl_info, NULL) < 0) {
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
dev_err(&dev->pdev->dev, dev_err(dev->dev, "Could not connect to the NFC INFO ME client");
"Could not connect to the NFC INFO ME client");
goto err; goto err;
} }
...@@ -427,21 +426,19 @@ static void mei_nfc_init(struct work_struct *work) ...@@ -427,21 +426,19 @@ static void mei_nfc_init(struct work_struct *work)
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
if (mei_nfc_if_version(ndev) < 0) { if (mei_nfc_if_version(ndev) < 0) {
dev_err(&dev->pdev->dev, "Could not get the NFC interface version"); dev_err(dev->dev, "Could not get the NFC interface version");
goto err; goto err;
} }
dev_info(&dev->pdev->dev, dev_info(dev->dev, "NFC MEI VERSION: IVN 0x%x Vendor ID 0x%x Type 0x%x\n",
"NFC MEI VERSION: IVN 0x%x Vendor ID 0x%x Type 0x%x\n",
ndev->fw_ivn, ndev->vendor_id, ndev->radio_type); ndev->fw_ivn, ndev->vendor_id, ndev->radio_type);
mutex_lock(&dev->device_lock); mutex_lock(&dev->device_lock);
if (mei_cl_disconnect(cl_info) < 0) { if (mei_cl_disconnect(cl_info) < 0) {
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
dev_err(&dev->pdev->dev, dev_err(dev->dev, "Could not disconnect the NFC INFO ME client");
"Could not disconnect the NFC INFO ME client");
goto err; goto err;
} }
...@@ -449,15 +446,13 @@ static void mei_nfc_init(struct work_struct *work) ...@@ -449,15 +446,13 @@ static void mei_nfc_init(struct work_struct *work)
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
if (mei_nfc_build_bus_name(ndev) < 0) { if (mei_nfc_build_bus_name(ndev) < 0) {
dev_err(&dev->pdev->dev, dev_err(dev->dev, "Could not build the bus ID name\n");
"Could not build the bus ID name\n");
return; return;
} }
cldev = mei_cl_add_device(dev, mei_nfc_guid, ndev->bus_name, &nfc_ops); cldev = mei_cl_add_device(dev, mei_nfc_guid, ndev->bus_name, &nfc_ops);
if (!cldev) { if (!cldev) {
dev_err(&dev->pdev->dev, dev_err(dev->dev, "Could not add the NFC device to the MEI bus\n");
"Could not add the NFC device to the MEI bus\n");
goto err; goto err;
} }
...@@ -500,7 +495,7 @@ int mei_nfc_host_init(struct mei_device *dev) ...@@ -500,7 +495,7 @@ int mei_nfc_host_init(struct mei_device *dev)
/* check for valid client id */ /* check for valid client id */
me_cl = mei_me_cl_by_uuid(dev, &mei_nfc_info_guid); me_cl = mei_me_cl_by_uuid(dev, &mei_nfc_info_guid);
if (!me_cl) { if (!me_cl) {
dev_info(&dev->pdev->dev, "nfc: failed to find the client\n"); dev_info(dev->dev, "nfc: failed to find the client\n");
ret = -ENOTTY; ret = -ENOTTY;
goto err; goto err;
} }
...@@ -518,7 +513,7 @@ int mei_nfc_host_init(struct mei_device *dev) ...@@ -518,7 +513,7 @@ int mei_nfc_host_init(struct mei_device *dev)
/* check for valid client id */ /* check for valid client id */
me_cl = mei_me_cl_by_uuid(dev, &mei_nfc_guid); me_cl = mei_me_cl_by_uuid(dev, &mei_nfc_guid);
if (!me_cl) { if (!me_cl) {
dev_info(&dev->pdev->dev, "nfc: failed to find the client\n"); dev_info(dev->dev, "nfc: failed to find the client\n");
ret = -ENOTTY; ret = -ENOTTY;
goto err; goto err;
} }
......
...@@ -451,7 +451,7 @@ static inline void mei_me_set_pm_domain(struct mei_device *dev) ...@@ -451,7 +451,7 @@ static inline void mei_me_set_pm_domain(struct mei_device *dev)
static inline void mei_me_unset_pm_domain(struct mei_device *dev) static inline void mei_me_unset_pm_domain(struct mei_device *dev)
{ {
/* stop using pm callbacks if any */ /* stop using pm callbacks if any */
dev->pdev->dev.pm_domain = NULL; dev->dev->pm_domain = NULL;
} }
#endif /* CONFIG_PM_RUNTIME */ #endif /* CONFIG_PM_RUNTIME */
......
...@@ -399,7 +399,7 @@ static inline void mei_txe_set_pm_domain(struct mei_device *dev) ...@@ -399,7 +399,7 @@ static inline void mei_txe_set_pm_domain(struct mei_device *dev)
static inline void mei_txe_unset_pm_domain(struct mei_device *dev) static inline void mei_txe_unset_pm_domain(struct mei_device *dev)
{ {
/* stop using pm callbacks if any */ /* stop using pm callbacks if any */
dev->pdev->dev.pm_domain = NULL; dev->dev->pm_domain = NULL;
} }
#endif /* CONFIG_PM_RUNTIME */ #endif /* CONFIG_PM_RUNTIME */
......
...@@ -42,7 +42,7 @@ const uuid_le mei_wd_guid = UUID_LE(0x05B79A6F, 0x4628, 0x4D7F, 0x89, ...@@ -42,7 +42,7 @@ const uuid_le mei_wd_guid = UUID_LE(0x05B79A6F, 0x4628, 0x4D7F, 0x89,
static void mei_wd_set_start_timeout(struct mei_device *dev, u16 timeout) static void mei_wd_set_start_timeout(struct mei_device *dev, u16 timeout)
{ {
dev_dbg(&dev->pdev->dev, "wd: set timeout=%d.\n", timeout); dev_dbg(dev->dev, "wd: set timeout=%d.\n", timeout);
memcpy(dev->wd_data, mei_start_wd_params, MEI_WD_HDR_SIZE); memcpy(dev->wd_data, mei_start_wd_params, MEI_WD_HDR_SIZE);
memcpy(dev->wd_data + MEI_WD_HDR_SIZE, &timeout, sizeof(u16)); memcpy(dev->wd_data + MEI_WD_HDR_SIZE, &timeout, sizeof(u16));
} }
...@@ -71,7 +71,7 @@ int mei_wd_host_init(struct mei_device *dev) ...@@ -71,7 +71,7 @@ int mei_wd_host_init(struct mei_device *dev)
/* check for valid client id */ /* check for valid client id */
me_cl = mei_me_cl_by_uuid(dev, &mei_wd_guid); me_cl = mei_me_cl_by_uuid(dev, &mei_wd_guid);
if (!me_cl) { if (!me_cl) {
dev_info(&dev->pdev->dev, "wd: failed to find the client\n"); dev_info(dev->dev, "wd: failed to find the client\n");
return -ENOTTY; return -ENOTTY;
} }
...@@ -81,14 +81,14 @@ int mei_wd_host_init(struct mei_device *dev) ...@@ -81,14 +81,14 @@ int mei_wd_host_init(struct mei_device *dev)
ret = mei_cl_link(cl, MEI_WD_HOST_CLIENT_ID); ret = mei_cl_link(cl, MEI_WD_HOST_CLIENT_ID);
if (ret < 0) { if (ret < 0) {
dev_info(&dev->pdev->dev, "wd: failed link client\n"); dev_info(dev->dev, "wd: failed link client\n");
return ret; return ret;
} }
ret = mei_cl_connect(cl, NULL); ret = mei_cl_connect(cl, NULL);
if (ret) { if (ret) {
dev_err(&dev->pdev->dev, "wd: failed to connect = %d\n", ret); dev_err(dev->dev, "wd: failed to connect = %d\n", ret);
mei_cl_unlink(cl); mei_cl_unlink(cl);
return ret; return ret;
} }
...@@ -128,19 +128,19 @@ int mei_wd_send(struct mei_device *dev) ...@@ -128,19 +128,19 @@ int mei_wd_send(struct mei_device *dev)
else if (!memcmp(dev->wd_data, mei_stop_wd_params, MEI_WD_HDR_SIZE)) else if (!memcmp(dev->wd_data, mei_stop_wd_params, MEI_WD_HDR_SIZE))
hdr.length = MEI_WD_STOP_MSG_SIZE; hdr.length = MEI_WD_STOP_MSG_SIZE;
else { else {
dev_err(&dev->pdev->dev, "wd: invalid message is to be sent, aborting\n"); dev_err(dev->dev, "wd: invalid message is to be sent, aborting\n");
return -EINVAL; return -EINVAL;
} }
ret = mei_write_message(dev, &hdr, dev->wd_data); ret = mei_write_message(dev, &hdr, dev->wd_data);
if (ret) { if (ret) {
dev_err(&dev->pdev->dev, "wd: write message failed\n"); dev_err(dev->dev, "wd: write message failed\n");
return ret; return ret;
} }
ret = mei_cl_flow_ctrl_reduce(cl); ret = mei_cl_flow_ctrl_reduce(cl);
if (ret) { if (ret) {
dev_err(&dev->pdev->dev, "wd: flow_ctrl_reduce failed.\n"); dev_err(dev->dev, "wd: flow_ctrl_reduce failed.\n");
return ret; return ret;
} }
...@@ -193,11 +193,10 @@ int mei_wd_stop(struct mei_device *dev) ...@@ -193,11 +193,10 @@ int mei_wd_stop(struct mei_device *dev)
if (dev->wd_state != MEI_WD_IDLE) { if (dev->wd_state != MEI_WD_IDLE) {
/* timeout */ /* timeout */
ret = -ETIME; ret = -ETIME;
dev_warn(&dev->pdev->dev, dev_warn(dev->dev, "wd: stop failed to complete ret=%d\n", ret);
"wd: stop failed to complete ret=%d.\n", ret);
goto err; goto err;
} }
dev_dbg(&dev->pdev->dev, "wd: stop completed after %u msec\n", dev_dbg(dev->dev, "wd: stop completed after %u msec\n",
MEI_WD_STOP_TIMEOUT - jiffies_to_msecs(ret)); MEI_WD_STOP_TIMEOUT - jiffies_to_msecs(ret));
return 0; return 0;
err: err:
...@@ -223,15 +222,13 @@ static int mei_wd_ops_start(struct watchdog_device *wd_dev) ...@@ -223,15 +222,13 @@ static int mei_wd_ops_start(struct watchdog_device *wd_dev)
mutex_lock(&dev->device_lock); mutex_lock(&dev->device_lock);
if (dev->dev_state != MEI_DEV_ENABLED) { if (dev->dev_state != MEI_DEV_ENABLED) {
dev_dbg(&dev->pdev->dev, dev_dbg(dev->dev, "wd: dev_state != MEI_DEV_ENABLED dev_state = %s\n",
"wd: dev_state != MEI_DEV_ENABLED dev_state = %s\n",
mei_dev_state_str(dev->dev_state)); mei_dev_state_str(dev->dev_state));
goto end_unlock; goto end_unlock;
} }
if (dev->wd_cl.state != MEI_FILE_CONNECTED) { if (dev->wd_cl.state != MEI_FILE_CONNECTED) {
dev_dbg(&dev->pdev->dev, dev_dbg(dev->dev, "MEI Driver is not connected to Watchdog Client\n");
"MEI Driver is not connected to Watchdog Client\n");
goto end_unlock; goto end_unlock;
} }
...@@ -284,7 +281,7 @@ static int mei_wd_ops_ping(struct watchdog_device *wd_dev) ...@@ -284,7 +281,7 @@ static int mei_wd_ops_ping(struct watchdog_device *wd_dev)
mutex_lock(&dev->device_lock); mutex_lock(&dev->device_lock);
if (dev->wd_cl.state != MEI_FILE_CONNECTED) { if (dev->wd_cl.state != MEI_FILE_CONNECTED) {
dev_err(&dev->pdev->dev, "wd: not connected.\n"); dev_err(dev->dev, "wd: not connected.\n");
ret = -ENODEV; ret = -ENODEV;
goto end; goto end;
} }
...@@ -297,7 +294,7 @@ static int mei_wd_ops_ping(struct watchdog_device *wd_dev) ...@@ -297,7 +294,7 @@ static int mei_wd_ops_ping(struct watchdog_device *wd_dev)
/* Check if we can send the ping to HW*/ /* Check if we can send the ping to HW*/
if (ret && mei_hbuf_acquire(dev)) { if (ret && mei_hbuf_acquire(dev)) {
dev_dbg(&dev->pdev->dev, "wd: sending ping\n"); dev_dbg(dev->dev, "wd: sending ping\n");
ret = mei_wd_send(dev); ret = mei_wd_send(dev);
if (ret) if (ret)
...@@ -380,13 +377,12 @@ int mei_watchdog_register(struct mei_device *dev) ...@@ -380,13 +377,12 @@ int mei_watchdog_register(struct mei_device *dev)
ret = watchdog_register_device(&amt_wd_dev); ret = watchdog_register_device(&amt_wd_dev);
mutex_lock(&dev->device_lock); mutex_lock(&dev->device_lock);
if (ret) { if (ret) {
dev_err(&dev->pdev->dev, "wd: unable to register watchdog device = %d.\n", dev_err(dev->dev, "wd: unable to register watchdog device = %d.\n",
ret); ret);
return ret; return ret;
} }
dev_dbg(&dev->pdev->dev, dev_dbg(dev->dev, "wd: successfully register watchdog interface.\n");
"wd: successfully register watchdog interface.\n");
watchdog_set_drvdata(&amt_wd_dev, dev); watchdog_set_drvdata(&amt_wd_dev, dev);
return 0; return 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册