Orange Pi5 kernel

Deprecated Linux kernel 5.10.110 for OrangePi 5/5B/5+ boards

3 Commits   0 Branches   0 Tags
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  1) // SPDX-License-Identifier: GPL-2.0-or-later
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  2) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  3)  * Driver for Digigram VX soundcards
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  4)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  5)  * DSP commands
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  6)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  7)  * Copyright (c) 2002 by Takashi Iwai <tiwai@suse.de>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  8)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  9) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) #include <sound/core.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) #include <sound/pcm.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) #include <sound/vx_core.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) #include "vx_cmd.h"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16)  * Array of DSP commands
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) static const struct vx_cmd_info vx_dsp_cmds[] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) [CMD_VERSION] =			{ 0x010000, 2, RMH_SSIZE_FIXED, 1 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) [CMD_SUPPORTED] =		{ 0x020000, 1, RMH_SSIZE_FIXED, 2 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) [CMD_TEST_IT] =			{ 0x040000, 1, RMH_SSIZE_FIXED, 1 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) [CMD_SEND_IRQA] =		{ 0x070001, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) [CMD_IBL] =			{ 0x080000, 1, RMH_SSIZE_FIXED, 4 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) [CMD_ASYNC] =			{ 0x0A0000, 1, RMH_SSIZE_ARG, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) [CMD_RES_PIPE] =		{ 0x400000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) [CMD_FREE_PIPE] =		{ 0x410000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) [CMD_CONF_PIPE] =		{ 0x42A101, 2, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) [CMD_ABORT_CONF_PIPE] =		{ 0x42A100, 2, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) [CMD_PARAM_OUTPUT_PIPE] =	{ 0x43A000, 2, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) [CMD_STOP_PIPE] =		{ 0x470004, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) [CMD_PIPE_STATE] =		{ 0x480000, 1, RMH_SSIZE_FIXED, 1 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) [CMD_PIPE_SPL_COUNT] =		{ 0x49A000, 2, RMH_SSIZE_FIXED, 2 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) [CMD_CAN_START_PIPE] =		{ 0x4b0000, 1, RMH_SSIZE_FIXED, 1 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) [CMD_SIZE_HBUFFER] =		{ 0x4C0000, 1, RMH_SSIZE_FIXED, 1 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) [CMD_START_STREAM] =		{ 0x80A000, 2, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) [CMD_START_ONE_STREAM] =	{ 0x800000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) [CMD_PAUSE_STREAM] =		{ 0x81A000, 2, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38) [CMD_PAUSE_ONE_STREAM] =	{ 0x810000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) [CMD_STREAM_OUT_LEVEL_ADJUST] =	{ 0x828000, 2, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) [CMD_STOP_STREAM] =		{ 0x830000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) [CMD_FORMAT_STREAM_OUT] =	{ 0x868000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42) [CMD_FORMAT_STREAM_IN] =	{ 0x878800, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) [CMD_GET_STREAM_STATE] =	{ 0x890001, 2, RMH_SSIZE_FIXED, 1 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) [CMD_DROP_BYTES_AWAY] =		{ 0x8A8000, 2, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45) [CMD_GET_REMAINING_BYTES] =	{ 0x8D0800, 1, RMH_SSIZE_FIXED, 2 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) [CMD_CONNECT_AUDIO] =		{ 0xC10000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47) [CMD_AUDIO_LEVEL_ADJUST] =	{ 0xC2A000, 3, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48) [CMD_AUDIO_VU_PIC_METER] =	{ 0xC3A003, 2, RMH_SSIZE_FIXED, 1 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) [CMD_GET_AUDIO_LEVELS] =	{ 0xC4A000, 2, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50) [CMD_GET_NOTIFY_EVENT] =	{ 0x4D0000, 1, RMH_SSIZE_ARG, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) [CMD_INFO_NOTIFIED] =		{ 0x0B0000, 1, RMH_SSIZE_FIXED, 2 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) [CMD_ACCESS_IO_FCT] =		{ 0x098000, 1, RMH_SSIZE_ARG, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) [CMD_STATUS_R_BUFFERS] =	{ 0x440000, 1, RMH_SSIZE_ARG, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 54) [CMD_UPDATE_R_BUFFERS] =	{ 0x848000, 4, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 55) [CMD_LOAD_EFFECT_CONTEXT] =	{ 0x0c8000, 3, RMH_SSIZE_FIXED, 1 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 56) [CMD_EFFECT_ONE_PIPE] =		{ 0x458000, 0, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 57) [CMD_MODIFY_CLOCK] =		{ 0x0d0000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 58) [CMD_STREAM1_OUT_SET_N_LEVELS] ={ 0x858000, 3, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 59) [CMD_PURGE_STREAM_DCMDS] =	{ 0x8b8000, 3, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 60) [CMD_NOTIFY_PIPE_TIME] =	{ 0x4e0000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 61) [CMD_LOAD_EFFECT_CONTEXT_PACKET] = { 0x0c8000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 62) [CMD_RELIC_R_BUFFER] =		{ 0x8e0800, 1, RMH_SSIZE_FIXED, 1 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 63) [CMD_RESYNC_AUDIO_INPUTS] =	{ 0x0e0000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 64) [CMD_NOTIFY_STREAM_TIME] =	{ 0x8f0000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 65) [CMD_STREAM_SAMPLE_COUNT] =	{ 0x900000, 1, RMH_SSIZE_FIXED, 2 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 66) [CMD_CONFIG_TIME_CODE] =	{ 0x050000, 2, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 67) [CMD_GET_TIME_CODE] =		{ 0x060000, 1, RMH_SSIZE_FIXED, 5 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 68) [CMD_MANAGE_SIGNAL] =		{ 0x0f0000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 69) [CMD_PARAMETER_STREAM_OUT] =	{ 0x91A000, 3, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 70) [CMD_READ_BOARD_FREQ] =		{ 0x030000, 1, RMH_SSIZE_FIXED, 2 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 71) [CMD_GET_STREAM_LEVELS] =	{ 0x8c0000, 1, RMH_SSIZE_FIXED, 3 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 72) [CMD_PURGE_PIPE_DCMDS] =	{ 0x4f8000, 3, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 73) // [CMD_SET_STREAM_OUT_EFFECTS] =	{ 0x888000, 34, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 74) // [CMD_GET_STREAM_OUT_EFFECTS] =	{ 0x928000, 2, RMH_SSIZE_FIXED, 32 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 75) [CMD_CONNECT_MONITORING] =	{ 0xC00000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 76) [CMD_STREAM2_OUT_SET_N_LEVELS] = { 0x938000, 3, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 77) [CMD_CANCEL_R_BUFFERS] =	{ 0x948000, 4, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 78) [CMD_NOTIFY_END_OF_BUFFER] =	{ 0x950000, 1, RMH_SSIZE_FIXED, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 79) [CMD_GET_STREAM_VU_METER] =	{ 0x95A000, 2, RMH_SSIZE_ARG, 0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 80) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 81) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 82) /**
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 83)  * vx_init_rmh - initialize the RMH instance
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 84)  * @rmh: the rmh pointer to be initialized
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 85)  * @cmd: the rmh command to be set
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 86)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 87) void vx_init_rmh(struct vx_rmh *rmh, unsigned int cmd)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 88) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 89) 	if (snd_BUG_ON(cmd >= CMD_LAST_INDEX))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 90) 		return;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 91) 	rmh->LgCmd = vx_dsp_cmds[cmd].length;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 92) 	rmh->LgStat = vx_dsp_cmds[cmd].st_length;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 93) 	rmh->DspStat = vx_dsp_cmds[cmd].st_type;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 94) 	rmh->Cmd[0] = vx_dsp_cmds[cmd].opcode;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 95) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 96)