162306a36Sopenharmony_ci// SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause)
262306a36Sopenharmony_ci//
362306a36Sopenharmony_ci// This file is provided under a dual BSD/GPLv2 license.  When using or
462306a36Sopenharmony_ci// redistributing this file, you may do so under either license.
562306a36Sopenharmony_ci//
662306a36Sopenharmony_ci// Copyright(c) 2021 Advanced Micro Devices, Inc. All rights reserved.
762306a36Sopenharmony_ci//
862306a36Sopenharmony_ci// Authors: Vishnuvardhanrao Ravuapati <vishnuvardhanrao.ravulapati@amd.com>
962306a36Sopenharmony_ci//	    V Sujith Kumar Reddy <Vsujithkumar.Reddy@amd.com>
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci/*This file support Host TRACE Logger driver callback for SOF FW */
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci#include "acp.h"
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ci#define ACP_LOGGER_STREAM	8
1662306a36Sopenharmony_ci#define NUM_PAGES		16
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ciint acp_sof_trace_release(struct snd_sof_dev *sdev)
1962306a36Sopenharmony_ci{
2062306a36Sopenharmony_ci	struct acp_dsp_stream *stream;
2162306a36Sopenharmony_ci	struct acp_dev_data *adata;
2262306a36Sopenharmony_ci	int ret;
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_ci	adata = sdev->pdata->hw_pdata;
2562306a36Sopenharmony_ci	stream = adata->dtrace_stream;
2662306a36Sopenharmony_ci	ret = acp_dsp_stream_put(sdev, stream);
2762306a36Sopenharmony_ci	if (ret < 0) {
2862306a36Sopenharmony_ci		dev_err(sdev->dev, "Failed to release trace stream\n");
2962306a36Sopenharmony_ci		return ret;
3062306a36Sopenharmony_ci	}
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci	adata->dtrace_stream = NULL;
3362306a36Sopenharmony_ci	return 0;
3462306a36Sopenharmony_ci}
3562306a36Sopenharmony_ciEXPORT_SYMBOL_NS(acp_sof_trace_release, SND_SOC_SOF_AMD_COMMON);
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ciint acp_sof_trace_init(struct snd_sof_dev *sdev, struct snd_dma_buffer *dmab,
3862306a36Sopenharmony_ci		       struct sof_ipc_dma_trace_params_ext *dtrace_params)
3962306a36Sopenharmony_ci{
4062306a36Sopenharmony_ci	struct acp_dsp_stream *stream;
4162306a36Sopenharmony_ci	struct acp_dev_data *adata;
4262306a36Sopenharmony_ci	int ret;
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_ci	adata = sdev->pdata->hw_pdata;
4562306a36Sopenharmony_ci	stream = acp_dsp_stream_get(sdev, ACP_LOGGER_STREAM);
4662306a36Sopenharmony_ci	if (!stream)
4762306a36Sopenharmony_ci		return -ENODEV;
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_ci	stream->dmab = dmab;
5062306a36Sopenharmony_ci	stream->num_pages = NUM_PAGES;
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_ci	ret = acp_dsp_stream_config(sdev, stream);
5362306a36Sopenharmony_ci	if (ret < 0) {
5462306a36Sopenharmony_ci		acp_dsp_stream_put(sdev, stream);
5562306a36Sopenharmony_ci		return ret;
5662306a36Sopenharmony_ci	}
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_ci	adata->dtrace_stream = stream;
5962306a36Sopenharmony_ci	dtrace_params->stream_tag = stream->stream_tag;
6062306a36Sopenharmony_ci	dtrace_params->buffer.phy_addr = stream->reg_offset;
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_ci	return 0;
6362306a36Sopenharmony_ci}
6462306a36Sopenharmony_ciEXPORT_SYMBOL_NS(acp_sof_trace_init, SND_SOC_SOF_AMD_COMMON);
65