2020-03-06 07:28:22 +03:00
|
|
|
// 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>
|
|
|
|
|
2020-07-07 02:10:10 +03:00
|
|
|
#include "ipa_gsi.h"
|
2020-03-06 07:28:22 +03:00
|
|
|
#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;
|
|
|
|
}
|