{
void *tlv_buf;
int tlv_len;
- int ret;
if (!req->pending)
return;
struct qmi_msg *msg;
char *buf;
int len, msg_len;
- int i;
while (1) {
buf = ustream_get_read_buf(us, &len);
{
int len = qmi_complete_request_message(msg);
uint16_t tid;
- int ret;
- int i;
memset(req, 0, sizeof(*req));
req->ret = -1;
return req.req.ret;
client_id = req.cid;
+ } else {
+ qmi->service_keep_cid |= (1 << idx);
}
qmi->service_data[idx].connected = true;
qmi_request_wait(qmi, &req);
}
+int qmi_service_release_client_id(struct qmi_dev *qmi, QmiService svc)
+{
+ int idx = qmi_get_service_idx(svc);
+ qmi->service_release_cid |= 1 << idx;
+ return 0;
+}
+
static void qmi_close_all_services(struct qmi_dev *qmi)
{
uint32_t connected = qmi->service_connected;
int idx;
+ qmi->service_keep_cid &= ~qmi->service_release_cid;
for (idx = 0; connected; idx++, connected >>= 1) {
if (!(connected & 1))
continue;
void qmi_device_close(struct qmi_dev *qmi)
{
struct qmi_request *req;
- int idx;
qmi_close_all_services(qmi);
ustream_free(&qmi->sf.stream);