1 // SPDX-License-Identifier: GPL-2.0-only
3 * Copyright (c) 2019-2020, The Linux Foundation. All rights reserved.
4 * Copyright (c) 2023, Linaro Ltd
6 #include <linux/auxiliary_bus.h>
7 #include <linux/module.h>
8 #include <linux/of_device.h>
9 #include <linux/mutex.h>
10 #include <linux/property.h>
11 #include <linux/soc/qcom/pdr.h>
12 #include <linux/soc/qcom/pmic_glink.h>
15 #define UCSI_BUF_SIZE 48
17 #define MSG_TYPE_REQ_RESP 1
18 #define UCSI_BUF_SIZE 48
20 #define UC_NOTIFY_RECEIVER_UCSI 0x0
21 #define UC_UCSI_READ_BUF_REQ 0x11
22 #define UC_UCSI_WRITE_BUF_REQ 0x12
23 #define UC_UCSI_USBC_NOTIFY_IND 0x13
25 struct ucsi_read_buf_req_msg {
26 struct pmic_glink_hdr hdr;
29 struct ucsi_read_buf_resp_msg {
30 struct pmic_glink_hdr hdr;
31 u8 buf[UCSI_BUF_SIZE];
35 struct ucsi_write_buf_req_msg {
36 struct pmic_glink_hdr hdr;
37 u8 buf[UCSI_BUF_SIZE];
41 struct ucsi_write_buf_resp_msg {
42 struct pmic_glink_hdr hdr;
46 struct ucsi_notify_ind_msg {
47 struct pmic_glink_hdr hdr;
53 struct pmic_glink_ucsi {
56 struct pmic_glink_client *client;
59 struct completion read_ack;
60 struct completion write_ack;
61 struct completion sync_ack;
63 struct mutex lock; /* protects concurrent access to PMIC Glink interface */
67 struct work_struct notify_work;
68 struct work_struct register_work;
70 u8 read_buf[UCSI_BUF_SIZE];
73 static int pmic_glink_ucsi_read(struct ucsi *__ucsi, unsigned int offset,
74 void *val, size_t val_len)
76 struct pmic_glink_ucsi *ucsi = ucsi_get_drvdata(__ucsi);
77 struct ucsi_read_buf_req_msg req = {};
81 req.hdr.owner = PMIC_GLINK_OWNER_USBC;
82 req.hdr.type = MSG_TYPE_REQ_RESP;
83 req.hdr.opcode = UC_UCSI_READ_BUF_REQ;
85 mutex_lock(&ucsi->lock);
86 memset(ucsi->read_buf, 0, sizeof(ucsi->read_buf));
87 reinit_completion(&ucsi->read_ack);
89 ret = pmic_glink_send(ucsi->client, &req, sizeof(req));
91 dev_err(ucsi->dev, "failed to send UCSI read request: %d\n", ret);
95 left = wait_for_completion_timeout(&ucsi->read_ack, 5 * HZ);
97 dev_err(ucsi->dev, "timeout waiting for UCSI read response\n");
102 memcpy(val, &ucsi->read_buf[offset], val_len);
106 mutex_unlock(&ucsi->lock);
111 static int pmic_glink_ucsi_locked_write(struct pmic_glink_ucsi *ucsi, unsigned int offset,
112 const void *val, size_t val_len)
114 struct ucsi_write_buf_req_msg req = {};
118 req.hdr.owner = PMIC_GLINK_OWNER_USBC;
119 req.hdr.type = MSG_TYPE_REQ_RESP;
120 req.hdr.opcode = UC_UCSI_WRITE_BUF_REQ;
121 memcpy(&req.buf[offset], val, val_len);
123 reinit_completion(&ucsi->write_ack);
125 ret = pmic_glink_send(ucsi->client, &req, sizeof(req));
127 dev_err(ucsi->dev, "failed to send UCSI write request: %d\n", ret);
131 left = wait_for_completion_timeout(&ucsi->write_ack, 5 * HZ);
133 dev_err(ucsi->dev, "timeout waiting for UCSI write response\n");
140 static int pmic_glink_ucsi_async_write(struct ucsi *__ucsi, unsigned int offset,
141 const void *val, size_t val_len)
143 struct pmic_glink_ucsi *ucsi = ucsi_get_drvdata(__ucsi);
146 mutex_lock(&ucsi->lock);
147 ret = pmic_glink_ucsi_locked_write(ucsi, offset, val, val_len);
148 mutex_unlock(&ucsi->lock);
153 static int pmic_glink_ucsi_sync_write(struct ucsi *__ucsi, unsigned int offset,
154 const void *val, size_t val_len)
156 struct pmic_glink_ucsi *ucsi = ucsi_get_drvdata(__ucsi);
160 /* TOFIX: Downstream forces recipient to CON when UCSI_GET_ALTERNATE_MODES command */
162 mutex_lock(&ucsi->lock);
164 reinit_completion(&ucsi->sync_ack);
165 ucsi->sync_pending = true;
166 ret = pmic_glink_ucsi_locked_write(ucsi, offset, val, val_len);
167 mutex_unlock(&ucsi->lock);
169 left = wait_for_completion_timeout(&ucsi->sync_ack, 5 * HZ);
171 dev_err(ucsi->dev, "timeout waiting for UCSI sync write response\n");
173 } else if (ucsi->sync_val) {
174 dev_err(ucsi->dev, "sync write returned: %d\n", ucsi->sync_val);
177 ucsi->sync_pending = false;
182 static const struct ucsi_operations pmic_glink_ucsi_ops = {
183 .read = pmic_glink_ucsi_read,
184 .sync_write = pmic_glink_ucsi_sync_write,
185 .async_write = pmic_glink_ucsi_async_write
188 static void pmic_glink_ucsi_read_ack(struct pmic_glink_ucsi *ucsi, const void *data, int len)
190 const struct ucsi_read_buf_resp_msg *resp = data;
195 memcpy(ucsi->read_buf, resp->buf, UCSI_BUF_SIZE);
196 complete(&ucsi->read_ack);
199 static void pmic_glink_ucsi_write_ack(struct pmic_glink_ucsi *ucsi, const void *data, int len)
201 const struct ucsi_write_buf_resp_msg *resp = data;
206 ucsi->sync_val = resp->ret_code;
207 complete(&ucsi->write_ack);
210 static void pmic_glink_ucsi_notify(struct work_struct *work)
212 struct pmic_glink_ucsi *ucsi = container_of(work, struct pmic_glink_ucsi, notify_work);
213 unsigned int con_num;
217 ret = pmic_glink_ucsi_read(ucsi->ucsi, UCSI_CCI, &cci, sizeof(cci));
219 dev_err(ucsi->dev, "failed to read CCI on notification\n");
223 con_num = UCSI_CCI_CONNECTOR(cci);
225 ucsi_connector_change(ucsi->ucsi, con_num);
227 if (ucsi->sync_pending && cci & UCSI_CCI_BUSY) {
228 ucsi->sync_val = -EBUSY;
229 complete(&ucsi->sync_ack);
230 } else if (ucsi->sync_pending &&
231 (cci & (UCSI_CCI_ACK_COMPLETE | UCSI_CCI_COMMAND_COMPLETE))) {
232 complete(&ucsi->sync_ack);
236 static void pmic_glink_ucsi_register(struct work_struct *work)
238 struct pmic_glink_ucsi *ucsi = container_of(work, struct pmic_glink_ucsi, register_work);
240 ucsi_register(ucsi->ucsi);
243 static void pmic_glink_ucsi_callback(const void *data, size_t len, void *priv)
245 struct pmic_glink_ucsi *ucsi = priv;
246 const struct pmic_glink_hdr *hdr = data;
248 switch (le32_to_cpu(hdr->opcode)) {
249 case UC_UCSI_READ_BUF_REQ:
250 pmic_glink_ucsi_read_ack(ucsi, data, len);
252 case UC_UCSI_WRITE_BUF_REQ:
253 pmic_glink_ucsi_write_ack(ucsi, data, len);
255 case UC_UCSI_USBC_NOTIFY_IND:
256 schedule_work(&ucsi->notify_work);
261 static void pmic_glink_ucsi_pdr_notify(void *priv, int state)
263 struct pmic_glink_ucsi *ucsi = priv;
265 if (state == SERVREG_SERVICE_STATE_UP)
266 schedule_work(&ucsi->register_work);
267 else if (state == SERVREG_SERVICE_STATE_DOWN)
268 ucsi_unregister(ucsi->ucsi);
271 static void pmic_glink_ucsi_destroy(void *data)
273 struct pmic_glink_ucsi *ucsi = data;
275 /* Protect to make sure we're not in a middle of a transaction from a glink callback */
276 mutex_lock(&ucsi->lock);
277 ucsi_destroy(ucsi->ucsi);
278 mutex_unlock(&ucsi->lock);
281 static int pmic_glink_ucsi_probe(struct auxiliary_device *adev,
282 const struct auxiliary_device_id *id)
284 struct pmic_glink_ucsi *ucsi;
285 struct device *dev = &adev->dev;
288 ucsi = devm_kzalloc(dev, sizeof(*ucsi), GFP_KERNEL);
293 dev_set_drvdata(dev, ucsi);
295 INIT_WORK(&ucsi->notify_work, pmic_glink_ucsi_notify);
296 INIT_WORK(&ucsi->register_work, pmic_glink_ucsi_register);
297 init_completion(&ucsi->read_ack);
298 init_completion(&ucsi->write_ack);
299 init_completion(&ucsi->sync_ack);
300 mutex_init(&ucsi->lock);
302 ucsi->ucsi = ucsi_create(dev, &pmic_glink_ucsi_ops);
303 if (IS_ERR(ucsi->ucsi))
304 return PTR_ERR(ucsi->ucsi);
306 /* Make sure we destroy *after* pmic_glink unregister */
307 ret = devm_add_action_or_reset(dev, pmic_glink_ucsi_destroy, ucsi);
311 ucsi_set_drvdata(ucsi->ucsi, ucsi);
313 ucsi->client = devm_pmic_glink_register_client(dev,
314 PMIC_GLINK_OWNER_USBC,
315 pmic_glink_ucsi_callback,
316 pmic_glink_ucsi_pdr_notify,
318 return PTR_ERR_OR_ZERO(ucsi->client);
321 static void pmic_glink_ucsi_remove(struct auxiliary_device *adev)
323 struct pmic_glink_ucsi *ucsi = dev_get_drvdata(&adev->dev);
325 /* Unregister first to stop having read & writes */
326 ucsi_unregister(ucsi->ucsi);
329 static const struct auxiliary_device_id pmic_glink_ucsi_id_table[] = {
330 { .name = "pmic_glink.ucsi", },
333 MODULE_DEVICE_TABLE(auxiliary, pmic_glink_ucsi_id_table);
335 static struct auxiliary_driver pmic_glink_ucsi_driver = {
336 .name = "pmic_glink_ucsi",
337 .probe = pmic_glink_ucsi_probe,
338 .remove = pmic_glink_ucsi_remove,
339 .id_table = pmic_glink_ucsi_id_table,
342 module_auxiliary_driver(pmic_glink_ucsi_driver);
344 MODULE_DESCRIPTION("Qualcomm PMIC GLINK UCSI driver");
345 MODULE_LICENSE("GPL");