Lines Matching +full:rx +full:- +full:shared

1 /* SPDX-License-Identifier: GPL-2.0-only */
36 HSI_ARB_RR, /* Round-robin arbitration */
58 * struct hsi_channel - channel resource used by the hsi clients
68 * struct hsi_config - Configuration for RX/TX HSI modules
74 * @flow: RX flow type (SYNCHRONIZED or PIPELINE)
84 unsigned int flow; /* RX only */
90 * struct hsi_board_info - HSI client board info
95 * @rx_cfg: HSI RX configuration
97 * @archdata: Architecture-dependent device data
121 * struct hsi_client - HSI client attached to an HSI port
124 * @rx_cfg: HSI RX configuration
140 dev_set_drvdata(&cl->device, data); in hsi_client_set_drvdata()
145 return dev_get_drvdata(&cl->device); in hsi_client_drvdata()
153 * struct hsi_client_driver - Driver associated to an HSI client
167 driver_unregister(&drv->driver); in hsi_unregister_client_driver()
171 * struct hsi_msg - HSI message descriptor
180 * @channel: Channel were to TX/RX the message
181 * @ttype: Transfer type (TX if set, RX otherwise)
205 * struct hsi_port - HSI port device
208 * @rx_cfg: Current RX path configuration
210 * @shared: Set when port can be shared by different clients
226 unsigned int shared:1; member
240 #define hsi_get_port(cl) to_hsi_port((cl)->device.parent)
248 return cl->pclaimed; in hsi_port_claimed()
253 dev_set_drvdata(&port->device, data); in hsi_port_set_drvdata()
258 return dev_get_drvdata(&port->device); in hsi_port_drvdata()
262 * struct hsi_controller - HSI controller device
302 dev_set_drvdata(&hsi->device, data); in hsi_controller_set_drvdata()
307 return dev_get_drvdata(&hsi->device); in hsi_controller_drvdata()
313 return (num < hsi->num_ports) ? hsi->port[num] : NULL; in hsi_find_port_num()
324 * hsi_id - Get HSI controller ID associated to a client
331 return to_hsi_controller(cl->device.parent->parent)->id; in hsi_id()
335 * hsi_port_id - Gets the port number a client is attached to
342 return to_hsi_port(cl->device.parent)->num; in hsi_port_id()
346 * hsi_setup - Configure the client's port
352 * Return -errno on failure, 0 on success
357 return -EACCES; in hsi_setup()
358 return hsi_get_port(cl)->setup(cl); in hsi_setup()
362 * hsi_flush - Flush all pending transactions on the client's port
368 * Return -errno on failure, 0 on success
373 return -EACCES; in hsi_flush()
374 return hsi_get_port(cl)->flush(cl); in hsi_flush()
378 * hsi_async_read - Submit a read transfer
382 * Return -errno on failure, 0 on success
386 msg->ttype = HSI_MSG_READ; in hsi_async_read()
391 * hsi_async_write - Submit a write transfer
395 * Return -errno on failure, 0 on success
399 msg->ttype = HSI_MSG_WRITE; in hsi_async_write()
404 * hsi_start_tx - Signal the port that the client wants to start a TX
407 * Return -errno on failure, 0 on success
412 return -EACCES; in hsi_start_tx()
413 return hsi_get_port(cl)->start_tx(cl); in hsi_start_tx()
417 * hsi_stop_tx - Signal the port that the client no longer wants to transmit
420 * Return -errno on failure, 0 on success
425 return -EACCES; in hsi_stop_tx()
426 return hsi_get_port(cl)->stop_tx(cl); in hsi_stop_tx()