18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * Driver for Digigram VX soundcards 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * DSP commands 68c2ecf20Sopenharmony_ci * 78c2ecf20Sopenharmony_ci * Copyright (c) 2002 by Takashi Iwai <tiwai@suse.de> 88c2ecf20Sopenharmony_ci */ 98c2ecf20Sopenharmony_ci 108c2ecf20Sopenharmony_ci#include <sound/core.h> 118c2ecf20Sopenharmony_ci#include <sound/pcm.h> 128c2ecf20Sopenharmony_ci#include <sound/vx_core.h> 138c2ecf20Sopenharmony_ci#include "vx_cmd.h" 148c2ecf20Sopenharmony_ci 158c2ecf20Sopenharmony_ci/* 168c2ecf20Sopenharmony_ci * Array of DSP commands 178c2ecf20Sopenharmony_ci */ 188c2ecf20Sopenharmony_cistatic const struct vx_cmd_info vx_dsp_cmds[] = { 198c2ecf20Sopenharmony_ci[CMD_VERSION] = { 0x010000, 2, RMH_SSIZE_FIXED, 1 }, 208c2ecf20Sopenharmony_ci[CMD_SUPPORTED] = { 0x020000, 1, RMH_SSIZE_FIXED, 2 }, 218c2ecf20Sopenharmony_ci[CMD_TEST_IT] = { 0x040000, 1, RMH_SSIZE_FIXED, 1 }, 228c2ecf20Sopenharmony_ci[CMD_SEND_IRQA] = { 0x070001, 1, RMH_SSIZE_FIXED, 0 }, 238c2ecf20Sopenharmony_ci[CMD_IBL] = { 0x080000, 1, RMH_SSIZE_FIXED, 4 }, 248c2ecf20Sopenharmony_ci[CMD_ASYNC] = { 0x0A0000, 1, RMH_SSIZE_ARG, 0 }, 258c2ecf20Sopenharmony_ci[CMD_RES_PIPE] = { 0x400000, 1, RMH_SSIZE_FIXED, 0 }, 268c2ecf20Sopenharmony_ci[CMD_FREE_PIPE] = { 0x410000, 1, RMH_SSIZE_FIXED, 0 }, 278c2ecf20Sopenharmony_ci[CMD_CONF_PIPE] = { 0x42A101, 2, RMH_SSIZE_FIXED, 0 }, 288c2ecf20Sopenharmony_ci[CMD_ABORT_CONF_PIPE] = { 0x42A100, 2, RMH_SSIZE_FIXED, 0 }, 298c2ecf20Sopenharmony_ci[CMD_PARAM_OUTPUT_PIPE] = { 0x43A000, 2, RMH_SSIZE_FIXED, 0 }, 308c2ecf20Sopenharmony_ci[CMD_STOP_PIPE] = { 0x470004, 1, RMH_SSIZE_FIXED, 0 }, 318c2ecf20Sopenharmony_ci[CMD_PIPE_STATE] = { 0x480000, 1, RMH_SSIZE_FIXED, 1 }, 328c2ecf20Sopenharmony_ci[CMD_PIPE_SPL_COUNT] = { 0x49A000, 2, RMH_SSIZE_FIXED, 2 }, 338c2ecf20Sopenharmony_ci[CMD_CAN_START_PIPE] = { 0x4b0000, 1, RMH_SSIZE_FIXED, 1 }, 348c2ecf20Sopenharmony_ci[CMD_SIZE_HBUFFER] = { 0x4C0000, 1, RMH_SSIZE_FIXED, 1 }, 358c2ecf20Sopenharmony_ci[CMD_START_STREAM] = { 0x80A000, 2, RMH_SSIZE_FIXED, 0 }, 368c2ecf20Sopenharmony_ci[CMD_START_ONE_STREAM] = { 0x800000, 1, RMH_SSIZE_FIXED, 0 }, 378c2ecf20Sopenharmony_ci[CMD_PAUSE_STREAM] = { 0x81A000, 2, RMH_SSIZE_FIXED, 0 }, 388c2ecf20Sopenharmony_ci[CMD_PAUSE_ONE_STREAM] = { 0x810000, 1, RMH_SSIZE_FIXED, 0 }, 398c2ecf20Sopenharmony_ci[CMD_STREAM_OUT_LEVEL_ADJUST] = { 0x828000, 2, RMH_SSIZE_FIXED, 0 }, 408c2ecf20Sopenharmony_ci[CMD_STOP_STREAM] = { 0x830000, 1, RMH_SSIZE_FIXED, 0 }, 418c2ecf20Sopenharmony_ci[CMD_FORMAT_STREAM_OUT] = { 0x868000, 1, RMH_SSIZE_FIXED, 0 }, 428c2ecf20Sopenharmony_ci[CMD_FORMAT_STREAM_IN] = { 0x878800, 1, RMH_SSIZE_FIXED, 0 }, 438c2ecf20Sopenharmony_ci[CMD_GET_STREAM_STATE] = { 0x890001, 2, RMH_SSIZE_FIXED, 1 }, 448c2ecf20Sopenharmony_ci[CMD_DROP_BYTES_AWAY] = { 0x8A8000, 2, RMH_SSIZE_FIXED, 0 }, 458c2ecf20Sopenharmony_ci[CMD_GET_REMAINING_BYTES] = { 0x8D0800, 1, RMH_SSIZE_FIXED, 2 }, 468c2ecf20Sopenharmony_ci[CMD_CONNECT_AUDIO] = { 0xC10000, 1, RMH_SSIZE_FIXED, 0 }, 478c2ecf20Sopenharmony_ci[CMD_AUDIO_LEVEL_ADJUST] = { 0xC2A000, 3, RMH_SSIZE_FIXED, 0 }, 488c2ecf20Sopenharmony_ci[CMD_AUDIO_VU_PIC_METER] = { 0xC3A003, 2, RMH_SSIZE_FIXED, 1 }, 498c2ecf20Sopenharmony_ci[CMD_GET_AUDIO_LEVELS] = { 0xC4A000, 2, RMH_SSIZE_FIXED, 0 }, 508c2ecf20Sopenharmony_ci[CMD_GET_NOTIFY_EVENT] = { 0x4D0000, 1, RMH_SSIZE_ARG, 0 }, 518c2ecf20Sopenharmony_ci[CMD_INFO_NOTIFIED] = { 0x0B0000, 1, RMH_SSIZE_FIXED, 2 }, 528c2ecf20Sopenharmony_ci[CMD_ACCESS_IO_FCT] = { 0x098000, 1, RMH_SSIZE_ARG, 0 }, 538c2ecf20Sopenharmony_ci[CMD_STATUS_R_BUFFERS] = { 0x440000, 1, RMH_SSIZE_ARG, 0 }, 548c2ecf20Sopenharmony_ci[CMD_UPDATE_R_BUFFERS] = { 0x848000, 4, RMH_SSIZE_FIXED, 0 }, 558c2ecf20Sopenharmony_ci[CMD_LOAD_EFFECT_CONTEXT] = { 0x0c8000, 3, RMH_SSIZE_FIXED, 1 }, 568c2ecf20Sopenharmony_ci[CMD_EFFECT_ONE_PIPE] = { 0x458000, 0, RMH_SSIZE_FIXED, 0 }, 578c2ecf20Sopenharmony_ci[CMD_MODIFY_CLOCK] = { 0x0d0000, 1, RMH_SSIZE_FIXED, 0 }, 588c2ecf20Sopenharmony_ci[CMD_STREAM1_OUT_SET_N_LEVELS] ={ 0x858000, 3, RMH_SSIZE_FIXED, 0 }, 598c2ecf20Sopenharmony_ci[CMD_PURGE_STREAM_DCMDS] = { 0x8b8000, 3, RMH_SSIZE_FIXED, 0 }, 608c2ecf20Sopenharmony_ci[CMD_NOTIFY_PIPE_TIME] = { 0x4e0000, 1, RMH_SSIZE_FIXED, 0 }, 618c2ecf20Sopenharmony_ci[CMD_LOAD_EFFECT_CONTEXT_PACKET] = { 0x0c8000, 1, RMH_SSIZE_FIXED, 0 }, 628c2ecf20Sopenharmony_ci[CMD_RELIC_R_BUFFER] = { 0x8e0800, 1, RMH_SSIZE_FIXED, 1 }, 638c2ecf20Sopenharmony_ci[CMD_RESYNC_AUDIO_INPUTS] = { 0x0e0000, 1, RMH_SSIZE_FIXED, 0 }, 648c2ecf20Sopenharmony_ci[CMD_NOTIFY_STREAM_TIME] = { 0x8f0000, 1, RMH_SSIZE_FIXED, 0 }, 658c2ecf20Sopenharmony_ci[CMD_STREAM_SAMPLE_COUNT] = { 0x900000, 1, RMH_SSIZE_FIXED, 2 }, 668c2ecf20Sopenharmony_ci[CMD_CONFIG_TIME_CODE] = { 0x050000, 2, RMH_SSIZE_FIXED, 0 }, 678c2ecf20Sopenharmony_ci[CMD_GET_TIME_CODE] = { 0x060000, 1, RMH_SSIZE_FIXED, 5 }, 688c2ecf20Sopenharmony_ci[CMD_MANAGE_SIGNAL] = { 0x0f0000, 1, RMH_SSIZE_FIXED, 0 }, 698c2ecf20Sopenharmony_ci[CMD_PARAMETER_STREAM_OUT] = { 0x91A000, 3, RMH_SSIZE_FIXED, 0 }, 708c2ecf20Sopenharmony_ci[CMD_READ_BOARD_FREQ] = { 0x030000, 1, RMH_SSIZE_FIXED, 2 }, 718c2ecf20Sopenharmony_ci[CMD_GET_STREAM_LEVELS] = { 0x8c0000, 1, RMH_SSIZE_FIXED, 3 }, 728c2ecf20Sopenharmony_ci[CMD_PURGE_PIPE_DCMDS] = { 0x4f8000, 3, RMH_SSIZE_FIXED, 0 }, 738c2ecf20Sopenharmony_ci// [CMD_SET_STREAM_OUT_EFFECTS] = { 0x888000, 34, RMH_SSIZE_FIXED, 0 }, 748c2ecf20Sopenharmony_ci// [CMD_GET_STREAM_OUT_EFFECTS] = { 0x928000, 2, RMH_SSIZE_FIXED, 32 }, 758c2ecf20Sopenharmony_ci[CMD_CONNECT_MONITORING] = { 0xC00000, 1, RMH_SSIZE_FIXED, 0 }, 768c2ecf20Sopenharmony_ci[CMD_STREAM2_OUT_SET_N_LEVELS] = { 0x938000, 3, RMH_SSIZE_FIXED, 0 }, 778c2ecf20Sopenharmony_ci[CMD_CANCEL_R_BUFFERS] = { 0x948000, 4, RMH_SSIZE_FIXED, 0 }, 788c2ecf20Sopenharmony_ci[CMD_NOTIFY_END_OF_BUFFER] = { 0x950000, 1, RMH_SSIZE_FIXED, 0 }, 798c2ecf20Sopenharmony_ci[CMD_GET_STREAM_VU_METER] = { 0x95A000, 2, RMH_SSIZE_ARG, 0 }, 808c2ecf20Sopenharmony_ci}; 818c2ecf20Sopenharmony_ci 828c2ecf20Sopenharmony_ci/** 838c2ecf20Sopenharmony_ci * vx_init_rmh - initialize the RMH instance 848c2ecf20Sopenharmony_ci * @rmh: the rmh pointer to be initialized 858c2ecf20Sopenharmony_ci * @cmd: the rmh command to be set 868c2ecf20Sopenharmony_ci */ 878c2ecf20Sopenharmony_civoid vx_init_rmh(struct vx_rmh *rmh, unsigned int cmd) 888c2ecf20Sopenharmony_ci{ 898c2ecf20Sopenharmony_ci if (snd_BUG_ON(cmd >= CMD_LAST_INDEX)) 908c2ecf20Sopenharmony_ci return; 918c2ecf20Sopenharmony_ci rmh->LgCmd = vx_dsp_cmds[cmd].length; 928c2ecf20Sopenharmony_ci rmh->LgStat = vx_dsp_cmds[cmd].st_length; 938c2ecf20Sopenharmony_ci rmh->DspStat = vx_dsp_cmds[cmd].st_type; 948c2ecf20Sopenharmony_ci rmh->Cmd[0] = vx_dsp_cmds[cmd].opcode; 958c2ecf20Sopenharmony_ci} 968c2ecf20Sopenharmony_ci 97