162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Driver for Digigram VX soundcards
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * DSP commands
662306a36Sopenharmony_ci *
762306a36Sopenharmony_ci * Copyright (c) 2002 by Takashi Iwai <tiwai@suse.de>
862306a36Sopenharmony_ci */
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci#include <sound/core.h>
1162306a36Sopenharmony_ci#include <sound/pcm.h>
1262306a36Sopenharmony_ci#include <sound/vx_core.h>
1362306a36Sopenharmony_ci#include "vx_cmd.h"
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ci/*
1662306a36Sopenharmony_ci * Array of DSP commands
1762306a36Sopenharmony_ci */
1862306a36Sopenharmony_cistatic const struct vx_cmd_info vx_dsp_cmds[] = {
1962306a36Sopenharmony_ci[CMD_VERSION] =			{ 0x010000, 2, RMH_SSIZE_FIXED, 1 },
2062306a36Sopenharmony_ci[CMD_SUPPORTED] =		{ 0x020000, 1, RMH_SSIZE_FIXED, 2 },
2162306a36Sopenharmony_ci[CMD_TEST_IT] =			{ 0x040000, 1, RMH_SSIZE_FIXED, 1 },
2262306a36Sopenharmony_ci[CMD_SEND_IRQA] =		{ 0x070001, 1, RMH_SSIZE_FIXED, 0 },
2362306a36Sopenharmony_ci[CMD_IBL] =			{ 0x080000, 1, RMH_SSIZE_FIXED, 4 },
2462306a36Sopenharmony_ci[CMD_ASYNC] =			{ 0x0A0000, 1, RMH_SSIZE_ARG, 0 },
2562306a36Sopenharmony_ci[CMD_RES_PIPE] =		{ 0x400000, 1, RMH_SSIZE_FIXED, 0 },
2662306a36Sopenharmony_ci[CMD_FREE_PIPE] =		{ 0x410000, 1, RMH_SSIZE_FIXED, 0 },
2762306a36Sopenharmony_ci[CMD_CONF_PIPE] =		{ 0x42A101, 2, RMH_SSIZE_FIXED, 0 },
2862306a36Sopenharmony_ci[CMD_ABORT_CONF_PIPE] =		{ 0x42A100, 2, RMH_SSIZE_FIXED, 0 },
2962306a36Sopenharmony_ci[CMD_PARAM_OUTPUT_PIPE] =	{ 0x43A000, 2, RMH_SSIZE_FIXED, 0 },
3062306a36Sopenharmony_ci[CMD_STOP_PIPE] =		{ 0x470004, 1, RMH_SSIZE_FIXED, 0 },
3162306a36Sopenharmony_ci[CMD_PIPE_STATE] =		{ 0x480000, 1, RMH_SSIZE_FIXED, 1 },
3262306a36Sopenharmony_ci[CMD_PIPE_SPL_COUNT] =		{ 0x49A000, 2, RMH_SSIZE_FIXED, 2 },
3362306a36Sopenharmony_ci[CMD_CAN_START_PIPE] =		{ 0x4b0000, 1, RMH_SSIZE_FIXED, 1 },
3462306a36Sopenharmony_ci[CMD_SIZE_HBUFFER] =		{ 0x4C0000, 1, RMH_SSIZE_FIXED, 1 },
3562306a36Sopenharmony_ci[CMD_START_STREAM] =		{ 0x80A000, 2, RMH_SSIZE_FIXED, 0 },
3662306a36Sopenharmony_ci[CMD_START_ONE_STREAM] =	{ 0x800000, 1, RMH_SSIZE_FIXED, 0 },
3762306a36Sopenharmony_ci[CMD_PAUSE_STREAM] =		{ 0x81A000, 2, RMH_SSIZE_FIXED, 0 },
3862306a36Sopenharmony_ci[CMD_PAUSE_ONE_STREAM] =	{ 0x810000, 1, RMH_SSIZE_FIXED, 0 },
3962306a36Sopenharmony_ci[CMD_STREAM_OUT_LEVEL_ADJUST] =	{ 0x828000, 2, RMH_SSIZE_FIXED, 0 },
4062306a36Sopenharmony_ci[CMD_STOP_STREAM] =		{ 0x830000, 1, RMH_SSIZE_FIXED, 0 },
4162306a36Sopenharmony_ci[CMD_FORMAT_STREAM_OUT] =	{ 0x868000, 1, RMH_SSIZE_FIXED, 0 },
4262306a36Sopenharmony_ci[CMD_FORMAT_STREAM_IN] =	{ 0x878800, 1, RMH_SSIZE_FIXED, 0 },
4362306a36Sopenharmony_ci[CMD_GET_STREAM_STATE] =	{ 0x890001, 2, RMH_SSIZE_FIXED, 1 },
4462306a36Sopenharmony_ci[CMD_DROP_BYTES_AWAY] =		{ 0x8A8000, 2, RMH_SSIZE_FIXED, 0 },
4562306a36Sopenharmony_ci[CMD_GET_REMAINING_BYTES] =	{ 0x8D0800, 1, RMH_SSIZE_FIXED, 2 },
4662306a36Sopenharmony_ci[CMD_CONNECT_AUDIO] =		{ 0xC10000, 1, RMH_SSIZE_FIXED, 0 },
4762306a36Sopenharmony_ci[CMD_AUDIO_LEVEL_ADJUST] =	{ 0xC2A000, 3, RMH_SSIZE_FIXED, 0 },
4862306a36Sopenharmony_ci[CMD_AUDIO_VU_PIC_METER] =	{ 0xC3A003, 2, RMH_SSIZE_FIXED, 1 },
4962306a36Sopenharmony_ci[CMD_GET_AUDIO_LEVELS] =	{ 0xC4A000, 2, RMH_SSIZE_FIXED, 0 },
5062306a36Sopenharmony_ci[CMD_GET_NOTIFY_EVENT] =	{ 0x4D0000, 1, RMH_SSIZE_ARG, 0 },
5162306a36Sopenharmony_ci[CMD_INFO_NOTIFIED] =		{ 0x0B0000, 1, RMH_SSIZE_FIXED, 2 },
5262306a36Sopenharmony_ci[CMD_ACCESS_IO_FCT] =		{ 0x098000, 1, RMH_SSIZE_ARG, 0 },
5362306a36Sopenharmony_ci[CMD_STATUS_R_BUFFERS] =	{ 0x440000, 1, RMH_SSIZE_ARG, 0 },
5462306a36Sopenharmony_ci[CMD_UPDATE_R_BUFFERS] =	{ 0x848000, 4, RMH_SSIZE_FIXED, 0 },
5562306a36Sopenharmony_ci[CMD_LOAD_EFFECT_CONTEXT] =	{ 0x0c8000, 3, RMH_SSIZE_FIXED, 1 },
5662306a36Sopenharmony_ci[CMD_EFFECT_ONE_PIPE] =		{ 0x458000, 0, RMH_SSIZE_FIXED, 0 },
5762306a36Sopenharmony_ci[CMD_MODIFY_CLOCK] =		{ 0x0d0000, 1, RMH_SSIZE_FIXED, 0 },
5862306a36Sopenharmony_ci[CMD_STREAM1_OUT_SET_N_LEVELS] ={ 0x858000, 3, RMH_SSIZE_FIXED, 0 },
5962306a36Sopenharmony_ci[CMD_PURGE_STREAM_DCMDS] =	{ 0x8b8000, 3, RMH_SSIZE_FIXED, 0 },
6062306a36Sopenharmony_ci[CMD_NOTIFY_PIPE_TIME] =	{ 0x4e0000, 1, RMH_SSIZE_FIXED, 0 },
6162306a36Sopenharmony_ci[CMD_LOAD_EFFECT_CONTEXT_PACKET] = { 0x0c8000, 1, RMH_SSIZE_FIXED, 0 },
6262306a36Sopenharmony_ci[CMD_RELIC_R_BUFFER] =		{ 0x8e0800, 1, RMH_SSIZE_FIXED, 1 },
6362306a36Sopenharmony_ci[CMD_RESYNC_AUDIO_INPUTS] =	{ 0x0e0000, 1, RMH_SSIZE_FIXED, 0 },
6462306a36Sopenharmony_ci[CMD_NOTIFY_STREAM_TIME] =	{ 0x8f0000, 1, RMH_SSIZE_FIXED, 0 },
6562306a36Sopenharmony_ci[CMD_STREAM_SAMPLE_COUNT] =	{ 0x900000, 1, RMH_SSIZE_FIXED, 2 },
6662306a36Sopenharmony_ci[CMD_CONFIG_TIME_CODE] =	{ 0x050000, 2, RMH_SSIZE_FIXED, 0 },
6762306a36Sopenharmony_ci[CMD_GET_TIME_CODE] =		{ 0x060000, 1, RMH_SSIZE_FIXED, 5 },
6862306a36Sopenharmony_ci[CMD_MANAGE_SIGNAL] =		{ 0x0f0000, 1, RMH_SSIZE_FIXED, 0 },
6962306a36Sopenharmony_ci[CMD_PARAMETER_STREAM_OUT] =	{ 0x91A000, 3, RMH_SSIZE_FIXED, 0 },
7062306a36Sopenharmony_ci[CMD_READ_BOARD_FREQ] =		{ 0x030000, 1, RMH_SSIZE_FIXED, 2 },
7162306a36Sopenharmony_ci[CMD_GET_STREAM_LEVELS] =	{ 0x8c0000, 1, RMH_SSIZE_FIXED, 3 },
7262306a36Sopenharmony_ci[CMD_PURGE_PIPE_DCMDS] =	{ 0x4f8000, 3, RMH_SSIZE_FIXED, 0 },
7362306a36Sopenharmony_ci// [CMD_SET_STREAM_OUT_EFFECTS] =	{ 0x888000, 34, RMH_SSIZE_FIXED, 0 },
7462306a36Sopenharmony_ci// [CMD_GET_STREAM_OUT_EFFECTS] =	{ 0x928000, 2, RMH_SSIZE_FIXED, 32 },
7562306a36Sopenharmony_ci[CMD_CONNECT_MONITORING] =	{ 0xC00000, 1, RMH_SSIZE_FIXED, 0 },
7662306a36Sopenharmony_ci[CMD_STREAM2_OUT_SET_N_LEVELS] = { 0x938000, 3, RMH_SSIZE_FIXED, 0 },
7762306a36Sopenharmony_ci[CMD_CANCEL_R_BUFFERS] =	{ 0x948000, 4, RMH_SSIZE_FIXED, 0 },
7862306a36Sopenharmony_ci[CMD_NOTIFY_END_OF_BUFFER] =	{ 0x950000, 1, RMH_SSIZE_FIXED, 0 },
7962306a36Sopenharmony_ci[CMD_GET_STREAM_VU_METER] =	{ 0x95A000, 2, RMH_SSIZE_ARG, 0 },
8062306a36Sopenharmony_ci};
8162306a36Sopenharmony_ci
8262306a36Sopenharmony_ci/**
8362306a36Sopenharmony_ci * vx_init_rmh - initialize the RMH instance
8462306a36Sopenharmony_ci * @rmh: the rmh pointer to be initialized
8562306a36Sopenharmony_ci * @cmd: the rmh command to be set
8662306a36Sopenharmony_ci */
8762306a36Sopenharmony_civoid vx_init_rmh(struct vx_rmh *rmh, unsigned int cmd)
8862306a36Sopenharmony_ci{
8962306a36Sopenharmony_ci	if (snd_BUG_ON(cmd >= CMD_LAST_INDEX))
9062306a36Sopenharmony_ci		return;
9162306a36Sopenharmony_ci	rmh->LgCmd = vx_dsp_cmds[cmd].length;
9262306a36Sopenharmony_ci	rmh->LgStat = vx_dsp_cmds[cmd].st_length;
9362306a36Sopenharmony_ci	rmh->DspStat = vx_dsp_cmds[cmd].st_type;
9462306a36Sopenharmony_ci	rmh->Cmd[0] = vx_dsp_cmds[cmd].opcode;
9562306a36Sopenharmony_ci}
9662306a36Sopenharmony_ci
97