Lines Matching refs:cl

32 	struct mei_cl *cl;  in mei_irq_compl_handler()  local
35 cl = cb->cl; in mei_irq_compl_handler()
39 mei_cl_complete(cl, cb); in mei_irq_compl_handler()
52 static inline int mei_cl_hbm_equal(struct mei_cl *cl, in mei_cl_hbm_equal() argument
55 return mei_cl_host_addr(cl) == mei_hdr->host_addr && in mei_cl_hbm_equal()
56 mei_cl_me_id(cl) == mei_hdr->me_addr; in mei_cl_hbm_equal()
87 static int mei_cl_irq_read_msg(struct mei_cl *cl, in mei_cl_irq_read_msg() argument
91 struct mei_device *dev = cl->dev; in mei_cl_irq_read_msg()
96 cb = list_first_entry_or_null(&cl->rd_pending, struct mei_cl_cb, list); in mei_cl_irq_read_msg()
98 if (!mei_cl_is_fixed_address(cl)) { in mei_cl_irq_read_msg()
99 cl_err(dev, cl, "pending read cb not found\n"); in mei_cl_irq_read_msg()
102 cb = mei_cl_alloc_cb(cl, mei_cl_mtu(cl), MEI_FOP_READ, cl->fp); in mei_cl_irq_read_msg()
105 list_add_tail(&cb->list, &cl->rd_pending); in mei_cl_irq_read_msg()
108 if (!mei_cl_is_connected(cl)) { in mei_cl_irq_read_msg()
109 cl_dbg(dev, cl, "not connected\n"); in mei_cl_irq_read_msg()
119 cl_err(dev, cl, "message is too big len %d idx %zu\n", in mei_cl_irq_read_msg()
126 cl_dbg(dev, cl, "message overflow. size %zu len %d idx %zu\n", in mei_cl_irq_read_msg()
141 cl_dbg(dev, cl, "completed read length = %zu\n", cb->buf_idx); in mei_cl_irq_read_msg()
166 static int mei_cl_irq_disconnect_rsp(struct mei_cl *cl, struct mei_cl_cb *cb, in mei_cl_irq_disconnect_rsp() argument
169 struct mei_device *dev = cl->dev; in mei_cl_irq_disconnect_rsp()
182 ret = mei_hbm_cl_disconnect_rsp(dev, cl); in mei_cl_irq_disconnect_rsp()
198 static int mei_cl_irq_read(struct mei_cl *cl, struct mei_cl_cb *cb, in mei_cl_irq_read() argument
201 struct mei_device *dev = cl->dev; in mei_cl_irq_read()
206 if (!list_empty(&cl->rd_pending)) in mei_cl_irq_read()
217 ret = mei_hbm_cl_flow_control_req(dev, cl); in mei_cl_irq_read()
219 cl->status = ret; in mei_cl_irq_read()
225 list_move_tail(&cb->list, &cl->rd_pending); in mei_cl_irq_read()
268 struct mei_cl *cl; in mei_irq_read_handler() local
313 list_for_each_entry(cl, &dev->file_list, link) { in mei_irq_read_handler()
314 if (mei_cl_hbm_equal(cl, mei_hdr)) { in mei_irq_read_handler()
315 cl_dbg(dev, cl, "got a message\n"); in mei_irq_read_handler()
321 if (&cl->link == &dev->file_list) { in mei_irq_read_handler()
339 ret = mei_cl_irq_read_msg(cl, mei_hdr, cmpl_list); in mei_irq_read_handler()
371 struct mei_cl *cl; in mei_irq_write_handler() local
391 cl = cb->cl; in mei_irq_write_handler()
393 cl->status = 0; in mei_irq_write_handler()
394 cl_dbg(dev, cl, "MEI WRITE COMPLETE\n"); in mei_irq_write_handler()
395 cl->writing_state = MEI_WRITE_COMPLETE; in mei_irq_write_handler()
402 cl = cb->cl; in mei_irq_write_handler()
406 ret = mei_cl_irq_disconnect(cl, cb, cmpl_list); in mei_irq_write_handler()
413 ret = mei_cl_irq_read(cl, cb, cmpl_list); in mei_irq_write_handler()
420 ret = mei_cl_irq_connect(cl, cb, cmpl_list); in mei_irq_write_handler()
427 ret = mei_cl_irq_disconnect_rsp(cl, cb, cmpl_list); in mei_irq_write_handler()
434 ret = mei_cl_irq_notify(cl, cb, cmpl_list); in mei_irq_write_handler()
446 cl = cb->cl; in mei_irq_write_handler()
447 ret = mei_cl_irq_write(cl, cb, cmpl_list); in mei_irq_write_handler()
461 static void mei_connect_timeout(struct mei_cl *cl) in mei_connect_timeout() argument
463 struct mei_device *dev = cl->dev; in mei_connect_timeout()
465 if (cl->state == MEI_FILE_CONNECTING) { in mei_connect_timeout()
467 cl->state = MEI_FILE_DISCONNECT_REQUIRED; in mei_connect_timeout()
468 wake_up(&cl->wait); in mei_connect_timeout()
496 struct mei_cl *cl; in mei_timer() local
522 list_for_each_entry(cl, &dev->file_list, link) { in mei_timer()
523 if (cl->timer_count) { in mei_timer()
524 if (--cl->timer_count == 0) { in mei_timer()
526 mei_connect_timeout(cl); in mei_timer()