Lines Matching +full:ipa +full:- +full:ap +full:- +full:to +full:- +full:modem
1 /* SPDX-License-Identifier: GPL-2.0 */
3 /* Copyright (c) 2015-2018, The Linux Foundation. All rights reserved.
4 * Copyright (C) 2018-2022 Linaro Ltd.
41 * A channel ring consists of TRE entries filled by the AP and passed
42 * to the hardware for processing. For a channel ring, the ring index
43 * identifies the next unused entry to be filled by the AP. In this
44 * case the initial value is assumed by hardware to be 0.
47 * and passed to the AP. For event rings, the ring index identifies
48 * the next ring entry that is not known to have been filled by the
55 * but taken from a fixed-size pool. The number of elements required for
58 * If sufficient TREs are available to reserve for a transaction,
59 * allocation from these pools is guaranteed to succeed. Furthermore,
85 struct gsi_trans **map; /* TRE -> transaction map */
98 GSI_CHANNEL_STATE_FLOW_CONTROLLED = 0x5, /* IPA v4.2-v4.9 */
102 /* We only care about channels between IPA and AP */
106 bool command; /* AP command TX channel or not */
141 struct device *dev; /* Same as IPA device */
149 u32 modem_channel_bitmap; /* modem channels to allocate */
161 * gsi_setup() - Set up the GSI subsystem
162 * @gsi: Address of GSI structure embedded in an IPA structure
172 * gsi_teardown() - Tear down GSI subsystem
173 * @gsi: GSI address previously passed to a successful gsi_setup() call
178 * gsi_channel_tre_max() - Channel maximum number of in-flight TREs
180 * @channel_id: Channel whose limit is to be returned
187 * gsi_channel_start() - Start an allocated GSI channel
189 * @channel_id: Channel to start
196 * gsi_channel_stop() - Stop a started GSI channel
198 * @channel_id: Channel to stop
205 * gsi_modem_channel_flow_control() - Set channel flow control state (IPA v4.2+)
207 * @channel_id: Modem TX channel to control
208 * @enable: Whether to enable flow control (i.e., prevent flow)
214 * gsi_channel_reset() - Reset an allocated GSI channel
216 * @channel_id: Channel to be reset
217 * @doorbell: Whether to (possibly) enable the doorbell engine
228 * gsi_suspend() - Prepare the GSI subsystem for suspend
234 * gsi_resume() - Resume the GSI subsystem following suspend
240 * gsi_channel_suspend() - Suspend a GSI channel
242 * @channel_id: Channel to suspend
244 * For IPA v4.0+, suspend is implemented by stopping the channel.
249 * gsi_channel_resume() - Resume a suspended GSI channel
251 * @channel_id: Channel to resume
253 * For IPA v4.0+, the stopped channel is started again.
258 * gsi_init() - Initialize the GSI subsystem
259 * @gsi: Address of GSI structure embedded in an IPA structure
260 * @pdev: IPA platform device
261 * @version: IPA hardware version (implies GSI version)
268 * that can be done before the GSI hardware is ready to use.
275 * gsi_exit() - Exit the GSI subsystem
276 * @gsi: GSI address previously passed to a successful gsi_init() call