/linux/include/linux/ |
A D | mailbox_controller.h | 12 struct mbox_chan; 47 int (*send_data)(struct mbox_chan *chan, void *data); 48 int (*flush)(struct mbox_chan *chan, unsigned long timeout); 49 int (*startup)(struct mbox_chan *chan); 50 void (*shutdown)(struct mbox_chan *chan); 51 bool (*last_tx_done)(struct mbox_chan *chan); 52 bool (*peek_data)(struct mbox_chan *chan); 77 struct mbox_chan *chans; 82 struct mbox_chan *(*of_xlate)(struct mbox_controller *mbox, 117 struct mbox_chan { struct [all …]
|
A D | mailbox_client.h | 13 struct mbox_chan; 40 struct mbox_chan *mbox_request_channel_byname(struct mbox_client *cl, 42 struct mbox_chan *mbox_request_channel(struct mbox_client *cl, int index); 43 int mbox_send_message(struct mbox_chan *chan, void *mssg); 44 int mbox_flush(struct mbox_chan *chan, unsigned long timeout); 45 void mbox_client_txdone(struct mbox_chan *chan, int r); /* atomic */ 46 bool mbox_client_peek_data(struct mbox_chan *chan); /* atomic */ 47 void mbox_free_channel(struct mbox_chan *chan); /* may sleep */
|
A D | omap-mailbox.h | 17 struct mbox_chan; 20 struct mbox_chan *omap_mbox_request_channel(struct mbox_client *cl, 23 void omap_mbox_enable_irq(struct mbox_chan *chan, omap_mbox_irq_t irq); 24 void omap_mbox_disable_irq(struct mbox_chan *chan, omap_mbox_irq_t irq);
|
/linux/drivers/mailbox/ |
A D | arm_mhuv2.c | 270 struct mbox_chan *chan) in mhuv2_doorbell_rx_shutdown() 288 struct mbox_chan *chan) in mhuv2_doorbell_last_tx_done() 325 struct mbox_chan *chan) in mhuv2_data_transfer_rx_startup() 339 struct mbox_chan *chan) in mhuv2_data_transfer_rx_shutdown() 348 struct mbox_chan *chan) in mhuv2_data_transfer_read_data() 385 struct mbox_chan *chan) in mhuv2_data_transfer_tx_startup() 398 struct mbox_chan *chan) in mhuv2_data_transfer_tx_shutdown() 408 struct mbox_chan *chan) in mhuv2_data_transfer_last_tx_done() 542 struct mbox_chan *chan; in mhuv2_sender_interrupt() 622 struct mbox_chan *chan; in get_irq_chan_comb_rx() [all …]
|
A D | mailbox-altera.c | 49 struct mbox_chan *chan; 117 static void altera_mbox_rx_data(struct mbox_chan *chan) in altera_mbox_rx_data() 143 struct mbox_chan *chan = (struct mbox_chan *)p; in altera_mbox_tx_interrupt() 154 struct mbox_chan *chan = (struct mbox_chan *)p; in altera_mbox_rx_interrupt() 160 static int altera_mbox_startup_sender(struct mbox_chan *chan) in altera_mbox_startup_sender() 179 static int altera_mbox_startup_receiver(struct mbox_chan *chan) in altera_mbox_startup_receiver() 233 static bool altera_mbox_last_tx_done(struct mbox_chan *chan) in altera_mbox_last_tx_done() 241 static bool altera_mbox_peek_data(struct mbox_chan *chan) in altera_mbox_peek_data() 248 static int altera_mbox_startup(struct mbox_chan *chan) in altera_mbox_startup() 264 static void altera_mbox_shutdown(struct mbox_chan *chan) in altera_mbox_shutdown() [all …]
|
A D | mailbox-sti.c | 119 static void sti_mbox_enable_channel(struct mbox_chan *chan) in sti_mbox_enable_channel() 134 static void sti_mbox_disable_channel(struct mbox_chan *chan) in sti_mbox_disable_channel() 149 static void sti_mbox_clear_irq(struct mbox_chan *chan) in sti_mbox_clear_irq() 164 struct mbox_chan *chan = NULL; in sti_mbox_irq_to_channel() 195 struct mbox_chan *chan; in sti_mbox_thread_handler() 218 struct mbox_chan *chan; in sti_mbox_irq_handler() 251 static bool sti_mbox_tx_is_ready(struct mbox_chan *chan) in sti_mbox_tx_is_ready() 292 static int sti_mbox_startup_chan(struct mbox_chan *chan) in sti_mbox_startup_chan() 300 static void sti_mbox_shutdown_chan(struct mbox_chan *chan) in sti_mbox_shutdown_chan() 327 struct mbox_chan *chan = NULL; in sti_mbox_xlate() [all …]
|
A D | mailbox.c | 26 static int add_to_rbuf(struct mbox_chan *chan, void *mssg) in add_to_rbuf() 53 static void msg_submit(struct mbox_chan *chan) in msg_submit() 93 static void tx_tick(struct mbox_chan *chan, int r) in tx_tick() 125 struct mbox_chan *chan = &mbox->chans[i]; in txdone_hrtimer() 170 void mbox_chan_txdone(struct mbox_chan *chan, int r) in mbox_chan_txdone() 191 void mbox_client_txdone(struct mbox_chan *chan, int r) in mbox_client_txdone() 217 bool mbox_client_peek_data(struct mbox_chan *chan) in mbox_client_peek_data() 336 struct mbox_chan *chan; in mbox_request_channel() 438 void mbox_free_channel(struct mbox_chan *chan) in mbox_free_channel() 460 static struct mbox_chan * [all …]
|
A D | arm_mhu_db.c | 59 static inline struct mbox_chan * 76 static void mhu_db_mbox_clear_irq(struct mbox_chan *chan) in mhu_db_mbox_clear_irq() 94 static struct mbox_chan * 99 struct mbox_chan *chan = NULL; in mhu_db_mbox_irq_to_channel() 126 struct mbox_chan *chan; in mhu_db_mbox_rx_handler() 138 static bool mhu_db_last_tx_done(struct mbox_chan *chan) in mhu_db_last_tx_done() 149 static int mhu_db_send_data(struct mbox_chan *chan, void *data) in mhu_db_send_data() 160 static int mhu_db_startup(struct mbox_chan *chan) in mhu_db_startup() 166 static void mhu_db_shutdown(struct mbox_chan *chan) in mhu_db_shutdown() 192 struct mbox_chan *chan; in mhu_db_mbox_xlate() [all …]
|
A D | sun6i-msgbox.c | 53 static bool sun6i_msgbox_last_tx_done(struct mbox_chan *chan); 54 static bool sun6i_msgbox_peek_data(struct mbox_chan *chan); 56 static inline int channel_number(struct mbox_chan *chan) in channel_number() 61 static inline struct sun6i_msgbox *to_sun6i_msgbox(struct mbox_chan *chan) in to_sun6i_msgbox() 80 struct mbox_chan *chan = &mbox->controller.chans[n]; in sun6i_msgbox_irq() 99 static int sun6i_msgbox_send_data(struct mbox_chan *chan, void *data) in sun6i_msgbox_send_data() 115 static int sun6i_msgbox_startup(struct mbox_chan *chan) in sun6i_msgbox_startup() 139 static void sun6i_msgbox_shutdown(struct mbox_chan *chan) in sun6i_msgbox_shutdown() 162 static bool sun6i_msgbox_last_tx_done(struct mbox_chan *chan) in sun6i_msgbox_last_tx_done() 179 static bool sun6i_msgbox_peek_data(struct mbox_chan *chan) in sun6i_msgbox_peek_data() [all …]
|
A D | bcm2835-mailbox.c | 61 static struct bcm2835_mbox *bcm2835_link_mbox(struct mbox_chan *link) in bcm2835_link_mbox() 70 struct mbox_chan *link = &mbox->controller.chans[0]; in bcm2835_mbox_irq() 80 static int bcm2835_send_data(struct mbox_chan *link, void *data) in bcm2835_send_data() 92 static int bcm2835_startup(struct mbox_chan *link) in bcm2835_startup() 102 static void bcm2835_shutdown(struct mbox_chan *link) in bcm2835_shutdown() 109 static bool bcm2835_last_tx_done(struct mbox_chan *link) in bcm2835_last_tx_done() 127 static struct mbox_chan *bcm2835_mbox_index_xlate(struct mbox_controller *mbox, in bcm2835_mbox_index_xlate()
|
A D | hi3660-mailbox.c | 76 struct mbox_chan chan[MBOX_CHAN_MAX]; 86 static int hi3660_mbox_check_state(struct mbox_chan *chan) in hi3660_mbox_check_state() 113 static int hi3660_mbox_unlock(struct mbox_chan *chan) in hi3660_mbox_unlock() 134 static int hi3660_mbox_acquire_channel(struct mbox_chan *chan) in hi3660_mbox_acquire_channel() 160 static int hi3660_mbox_startup(struct mbox_chan *chan) in hi3660_mbox_startup() 175 static int hi3660_mbox_send_data(struct mbox_chan *chan, void *msg) in hi3660_mbox_send_data() 212 static struct mbox_chan *hi3660_mbox_xlate(struct mbox_controller *controller, in hi3660_mbox_xlate() 242 struct mbox_chan *chan; in hi3660_mbox_probe()
|
A D | arm_mhu.c | 36 struct mbox_chan chan[MHU_CHANS]; 42 struct mbox_chan *chan = p; in mhu_rx_interrupt() 57 static bool mhu_last_tx_done(struct mbox_chan *chan) in mhu_last_tx_done() 65 static int mhu_send_data(struct mbox_chan *chan, void *data) in mhu_send_data() 75 static int mhu_startup(struct mbox_chan *chan) in mhu_startup() 95 static void mhu_shutdown(struct mbox_chan *chan) in mhu_shutdown()
|
A D | platform_mhu.c | 42 struct mbox_chan chan[MHU_CHANS]; 48 struct mbox_chan *chan = p; in platform_mhu_rx_interrupt() 63 static bool platform_mhu_last_tx_done(struct mbox_chan *chan) in platform_mhu_last_tx_done() 71 static int platform_mhu_send_data(struct mbox_chan *chan, void *data) in platform_mhu_send_data() 81 static int platform_mhu_startup(struct mbox_chan *chan) in platform_mhu_startup() 101 static void platform_mhu_shutdown(struct mbox_chan *chan) in platform_mhu_shutdown()
|
A D | armada-37xx-rwtm-mailbox.c | 43 static void a37xx_mbox_receive(struct mbox_chan *chan) in a37xx_mbox_receive() 58 struct mbox_chan *chan = data; in a37xx_mbox_irq_handler() 77 static int a37xx_mbox_send_data(struct mbox_chan *chan, void *data) in a37xx_mbox_send_data() 103 static int a37xx_mbox_startup(struct mbox_chan *chan) in a37xx_mbox_startup() 124 static void a37xx_mbox_shutdown(struct mbox_chan *chan) in a37xx_mbox_shutdown() 146 struct mbox_chan *chans; in armada_37xx_mbox_probe()
|
A D | mailbox-mpfs.c | 67 struct mbox_chan chans[1]; 81 static int mpfs_mbox_send_data(struct mbox_chan *chan, void *data) in mpfs_mbox_send_data() 129 static void mpfs_mbox_rx_data(struct mbox_chan *chan) in mpfs_mbox_rx_data() 154 struct mbox_chan *chan = data; in mpfs_mbox_inbox_isr() 165 static int mpfs_mbox_startup(struct mbox_chan *chan) in mpfs_mbox_startup() 180 static void mpfs_mbox_shutdown(struct mbox_chan *chan) in mpfs_mbox_shutdown()
|
A D | hi6220-mailbox.c | 85 struct mbox_chan *chan; 109 static bool hi6220_mbox_last_tx_done(struct mbox_chan *chan) in hi6220_mbox_last_tx_done() 122 static int hi6220_mbox_send_data(struct mbox_chan *chan, void *msg) in hi6220_mbox_send_data() 152 struct mbox_chan *chan; in hi6220_mbox_interrupt() 193 static int hi6220_mbox_startup(struct mbox_chan *chan) in hi6220_mbox_startup() 205 static void hi6220_mbox_shutdown(struct mbox_chan *chan) in hi6220_mbox_shutdown() 222 static struct mbox_chan *hi6220_mbox_xlate(struct mbox_controller *controller, in hi6220_mbox_xlate() 227 struct mbox_chan *chan; in hi6220_mbox_xlate()
|
A D | ti-msgmgr.c | 114 struct mbox_chan *chan; 141 struct mbox_chan *chans; 204 struct mbox_chan *chan = p; in ti_msgmgr_queue_rx_interrupt() 285 static bool ti_msgmgr_queue_peek_data(struct mbox_chan *chan) in ti_msgmgr_queue_peek_data() 312 static bool ti_msgmgr_last_tx_done(struct mbox_chan *chan) in ti_msgmgr_last_tx_done() 346 static int ti_msgmgr_send_data(struct mbox_chan *chan, void *data) in ti_msgmgr_send_data() 410 struct mbox_chan *chan) in ti_msgmgr_queue_rx_irq_req() 453 static int ti_msgmgr_queue_startup(struct mbox_chan *chan) in ti_msgmgr_queue_startup() 499 static void ti_msgmgr_queue_shutdown(struct mbox_chan *chan) in ti_msgmgr_queue_shutdown() 587 struct mbox_chan *chan) in ti_msgmgr_queue_setup() [all …]
|
A D | mailbox-xgene-slimpro.c | 45 struct mbox_chan *chan; 65 struct mbox_chan chans[MBOX_CNT]; 118 static int slimpro_mbox_send_data(struct mbox_chan *chan, void *msg) in slimpro_mbox_send_data() 126 static int slimpro_mbox_startup(struct mbox_chan *chan) in slimpro_mbox_startup() 151 static void slimpro_mbox_shutdown(struct mbox_chan *chan) in slimpro_mbox_shutdown()
|
A D | sprd-mailbox.c | 70 struct mbox_chan chan[SPRD_MBOX_CHAN_MAX]; 106 struct mbox_chan *chan; in do_outbox_isr() 157 struct mbox_chan *chan; in sprd_mbox_inbox_isr() 196 static int sprd_mbox_send_data(struct mbox_chan *chan, void *msg) in sprd_mbox_send_data() 215 static int sprd_mbox_flush(struct mbox_chan *chan, unsigned long timeout) in sprd_mbox_flush() 237 static int sprd_mbox_startup(struct mbox_chan *chan) in sprd_mbox_startup() 270 static void sprd_mbox_shutdown(struct mbox_chan *chan) in sprd_mbox_shutdown()
|
/linux/drivers/soc/qcom/ |
A D | smp2p.c | 154 struct mbox_chan *mbox_chan; member 165 if (smp2p->mbox_chan) { in qcom_smp2p_kick() 166 mbox_send_message(smp2p->mbox_chan, NULL); in qcom_smp2p_kick() 167 mbox_client_txdone(smp2p->mbox_chan, 0); in qcom_smp2p_kick() 556 smp2p->mbox_chan = mbox_request_channel(&smp2p->mbox_client, 0); in qcom_smp2p_probe() 557 if (IS_ERR(smp2p->mbox_chan)) { in qcom_smp2p_probe() 558 if (PTR_ERR(smp2p->mbox_chan) != -ENODEV) in qcom_smp2p_probe() 559 return PTR_ERR(smp2p->mbox_chan); in qcom_smp2p_probe() 561 smp2p->mbox_chan = NULL; in qcom_smp2p_probe() 650 mbox_free_channel(smp2p->mbox_chan); in qcom_smp2p_probe() [all …]
|
A D | qcom_aoss.c | 74 struct mbox_chan *mbox_chan; member 89 mbox_send_message(qmp->mbox_chan, NULL); in qmp_kick() 90 mbox_client_txdone(qmp->mbox_chan, 0); in qmp_kick() 493 qmp->mbox_chan = mbox_request_channel(&qmp->mbox_client, 0); in qmp_probe() 494 if (IS_ERR(qmp->mbox_chan)) { in qmp_probe() 496 return PTR_ERR(qmp->mbox_chan); in qmp_probe() 526 mbox_free_channel(qmp->mbox_chan); in qmp_probe() 539 mbox_free_channel(qmp->mbox_chan); in qmp_remove()
|
/linux/drivers/remoteproc/ |
A D | st_remoteproc.c | 51 struct mbox_chan *mbox_chan[ST_RPROC_MAX_VRING * MBOX_MAX]; member 86 ret = mbox_send_message(ddata->mbox_chan[vqid * MBOX_MAX + MBOX_TX], in st_rproc_kick() 345 struct mbox_chan *chan; in st_rproc_probe() 405 ddata->mbox_chan[ST_RPROC_VQ0 * MBOX_MAX + MBOX_RX] = chan; in st_rproc_probe() 413 ddata->mbox_chan[ST_RPROC_VQ0 * MBOX_MAX + MBOX_TX] = chan; in st_rproc_probe() 421 ddata->mbox_chan[ST_RPROC_VQ1 * MBOX_MAX + MBOX_RX] = chan; in st_rproc_probe() 429 ddata->mbox_chan[ST_RPROC_VQ1 * MBOX_MAX + MBOX_TX] = chan; in st_rproc_probe() 440 mbox_free_channel(ddata->mbox_chan[i]); in st_rproc_probe() 459 mbox_free_channel(ddata->mbox_chan[i]); in st_rproc_remove()
|
/linux/drivers/i2c/busses/ |
A D | i2c-xgene-slimpro.c | 105 struct mbox_chan *mbox_chan; member 228 rc = mbox_send_message(ctx->mbox_chan, msg); in slimpro_i2c_send_msg() 236 mbox_chan_txdone(ctx->mbox_chan, 0); in slimpro_i2c_send_msg() 464 ctx->mbox_chan = mbox_request_channel(cl, MAILBOX_I2C_INDEX); in xgene_slimpro_i2c_probe() 465 if (IS_ERR(ctx->mbox_chan)) { in xgene_slimpro_i2c_probe() 467 return PTR_ERR(ctx->mbox_chan); in xgene_slimpro_i2c_probe() 494 ctx->mbox_chan = pcc_chan->mchan; in xgene_slimpro_i2c_probe() 496 if (!ctx->mbox_chan->mbox->txdone_irq) { in xgene_slimpro_i2c_probe() 553 mbox_free_channel(ctx->mbox_chan); in xgene_slimpro_i2c_probe() 567 mbox_free_channel(ctx->mbox_chan); in xgene_slimpro_i2c_remove()
|
/linux/include/linux/firmware/imx/ |
A D | dsp.h | 20 struct mbox_chan *ch; 58 struct mbox_chan *imx_dsp_request_channel(struct imx_dsp_ipc *ipc, int idx); 69 struct mbox_chan *imx_dsp_request_channel(struct imx_dsp_ipc *ipc, int idx) in imx_dsp_request_channel()
|
/linux/drivers/hwmon/ |
A D | xgene-hwmon.c | 95 struct mbox_chan *mbox_chan; member 161 rc = mbox_send_message(ctx->mbox_chan, msg); in xgene_hwmon_pcc_rd() 184 mbox_chan_txdone(ctx->mbox_chan, 0); in xgene_hwmon_pcc_rd() 198 rc = mbox_send_message(ctx->mbox_chan, msg); in xgene_hwmon_rd() 648 ctx->mbox_chan = mbox_request_channel(cl, 0); in xgene_hwmon_probe() 649 if (IS_ERR(ctx->mbox_chan)) { in xgene_hwmon_probe() 684 ctx->mbox_chan = pcc_chan->mchan; in xgene_hwmon_probe() 686 if (!ctx->mbox_chan->mbox->txdone_irq) { in xgene_hwmon_probe() 749 mbox_free_channel(ctx->mbox_chan); in xgene_hwmon_probe() 765 mbox_free_channel(ctx->mbox_chan); in xgene_hwmon_remove()
|