| // SPDX-License-Identifier: GPL-2.0 | 
 |  | 
 | /* Copyright (c) 2012-2018, The Linux Foundation. All rights reserved. | 
 |  * Copyright (C) 2019-2020 Linaro Ltd. | 
 |  */ | 
 |  | 
 | #include <linux/types.h> | 
 |  | 
 | #include "ipa_gsi.h" | 
 | #include "gsi_trans.h" | 
 | #include "ipa.h" | 
 | #include "ipa_endpoint.h" | 
 | #include "ipa_data.h" | 
 |  | 
 | void ipa_gsi_trans_complete(struct gsi_trans *trans) | 
 | { | 
 | 	struct ipa *ipa = container_of(trans->gsi, struct ipa, gsi); | 
 |  | 
 | 	ipa_endpoint_trans_complete(ipa->channel_map[trans->channel_id], trans); | 
 | } | 
 |  | 
 | void ipa_gsi_trans_release(struct gsi_trans *trans) | 
 | { | 
 | 	struct ipa *ipa = container_of(trans->gsi, struct ipa, gsi); | 
 |  | 
 | 	ipa_endpoint_trans_release(ipa->channel_map[trans->channel_id], trans); | 
 | } | 
 |  | 
 | void ipa_gsi_channel_tx_queued(struct gsi *gsi, u32 channel_id, u32 count, | 
 | 			       u32 byte_count) | 
 | { | 
 | 	struct ipa *ipa = container_of(gsi, struct ipa, gsi); | 
 | 	struct ipa_endpoint *endpoint; | 
 |  | 
 | 	endpoint = ipa->channel_map[channel_id]; | 
 | 	if (endpoint->netdev) | 
 | 		netdev_sent_queue(endpoint->netdev, byte_count); | 
 | } | 
 |  | 
 | void ipa_gsi_channel_tx_completed(struct gsi *gsi, u32 channel_id, u32 count, | 
 | 				  u32 byte_count) | 
 | { | 
 | 	struct ipa *ipa = container_of(gsi, struct ipa, gsi); | 
 | 	struct ipa_endpoint *endpoint; | 
 |  | 
 | 	endpoint = ipa->channel_map[channel_id]; | 
 | 	if (endpoint->netdev) | 
 | 		netdev_completed_queue(endpoint->netdev, count, byte_count); | 
 | } | 
 |  | 
 | /* Indicate whether an endpoint config data entry is "empty" */ | 
 | bool ipa_gsi_endpoint_data_empty(const struct ipa_gsi_endpoint_data *data) | 
 | { | 
 | 	return data->ee_id == GSI_EE_AP && !data->channel.tlv_count; | 
 | } |