aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/drivers/net/ethernet/intel/ice/ice_ethtool.c
diff options
context:
space:
mode:
authorAlex Elder <elder@linaro.org>2020-03-05 22:28:23 -0600
committerDavid S. Miller <davem@davemloft.net>2020-03-08 22:07:10 -0700
commit9dd441e4ed5755c2a74c206bd9bc50a431b1689b (patch)
tree687681876d6de6d6490dbc4fc39718a30c8be6a7 /drivers/net/ethernet/intel/ice/ice_ethtool.c
parentsoc: qcom: ipa: IPA interface to GSI (diff)
downloadwireguard-linux-9dd441e4ed5755c2a74c206bd9bc50a431b1689b.tar.xz
wireguard-linux-9dd441e4ed5755c2a74c206bd9bc50a431b1689b.zip
soc: qcom: ipa: GSI transactions
This patch implements GSI transactions. A GSI transaction is a structure that represents a single request (consisting of one or more TREs) sent to the GSI hardware. The last TRE in a transaction includes a flag requesting that the GSI interrupt the AP to notify that it has completed. TREs are executed and completed strictly in order. For this reason, the completion of a single TRE implies that all previous TREs (in particular all of those "earlier" in a transaction) have completed. Whenever there is a need to send a request (a set of TREs) to the IPA, a GSI transaction is allocated, specifying the number of TREs that will be required. Details of the request (e.g. transfer offsets and length) are represented by in a Linux scatterlist array that is incorporated in the transaction structure. Once all commands (TREs) are added to a transaction it is committed. When the hardware signals that the request has completed, a callback function allows for cleanup or followup activity to be performed before the transaction is freed. Signed-off-by: Alex Elder <elder@linaro.org> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/intel/ice/ice_ethtool.c')
0 files changed, 0 insertions, 0 deletions