1*1da177e4SLinus Torvalds /* 2*1da177e4SLinus Torvalds * Driver for Digigram VX soundcards 3*1da177e4SLinus Torvalds * 4*1da177e4SLinus Torvalds * DSP commands 5*1da177e4SLinus Torvalds * 6*1da177e4SLinus Torvalds * Copyright (c) 2002 by Takashi Iwai <tiwai@suse.de> 7*1da177e4SLinus Torvalds * 8*1da177e4SLinus Torvalds * This program is free software; you can redistribute it and/or modify 9*1da177e4SLinus Torvalds * it under the terms of the GNU General Public License as published by 10*1da177e4SLinus Torvalds * the Free Software Foundation; either version 2 of the License, or 11*1da177e4SLinus Torvalds * (at your option) any later version. 12*1da177e4SLinus Torvalds * 13*1da177e4SLinus Torvalds * This program is distributed in the hope that it will be useful, 14*1da177e4SLinus Torvalds * but WITHOUT ANY WARRANTY; without even the implied warranty of 15*1da177e4SLinus Torvalds * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16*1da177e4SLinus Torvalds * GNU General Public License for more details. 17*1da177e4SLinus Torvalds * 18*1da177e4SLinus Torvalds * You should have received a copy of the GNU General Public License 19*1da177e4SLinus Torvalds * along with this program; if not, write to the Free Software 20*1da177e4SLinus Torvalds * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 21*1da177e4SLinus Torvalds */ 22*1da177e4SLinus Torvalds 23*1da177e4SLinus Torvalds #include <sound/driver.h> 24*1da177e4SLinus Torvalds #include <sound/core.h> 25*1da177e4SLinus Torvalds #include <sound/pcm.h> 26*1da177e4SLinus Torvalds #include <sound/vx_core.h> 27*1da177e4SLinus Torvalds #include "vx_cmd.h" 28*1da177e4SLinus Torvalds 29*1da177e4SLinus Torvalds /* 30*1da177e4SLinus Torvalds * Array of DSP commands 31*1da177e4SLinus Torvalds */ 32*1da177e4SLinus Torvalds static struct vx_cmd_info vx_dsp_cmds[] = { 33*1da177e4SLinus Torvalds [CMD_VERSION] = { 0x010000, 2, RMH_SSIZE_FIXED, 1 }, 34*1da177e4SLinus Torvalds [CMD_SUPPORTED] = { 0x020000, 1, RMH_SSIZE_FIXED, 2 }, 35*1da177e4SLinus Torvalds [CMD_TEST_IT] = { 0x040000, 1, RMH_SSIZE_FIXED, 1 }, 36*1da177e4SLinus Torvalds [CMD_SEND_IRQA] = { 0x070001, 1, RMH_SSIZE_FIXED, 0 }, 37*1da177e4SLinus Torvalds [CMD_IBL] = { 0x080000, 1, RMH_SSIZE_FIXED, 4 }, 38*1da177e4SLinus Torvalds [CMD_ASYNC] = { 0x0A0000, 1, RMH_SSIZE_ARG, 0 }, 39*1da177e4SLinus Torvalds [CMD_RES_PIPE] = { 0x400000, 1, RMH_SSIZE_FIXED, 0 }, 40*1da177e4SLinus Torvalds [CMD_FREE_PIPE] = { 0x410000, 1, RMH_SSIZE_FIXED, 0 }, 41*1da177e4SLinus Torvalds [CMD_CONF_PIPE] = { 0x42A101, 2, RMH_SSIZE_FIXED, 0 }, 42*1da177e4SLinus Torvalds [CMD_ABORT_CONF_PIPE] = { 0x42A100, 2, RMH_SSIZE_FIXED, 0 }, 43*1da177e4SLinus Torvalds [CMD_PARAM_OUTPUT_PIPE] = { 0x43A000, 2, RMH_SSIZE_FIXED, 0 }, 44*1da177e4SLinus Torvalds [CMD_STOP_PIPE] = { 0x470004, 1, RMH_SSIZE_FIXED, 0 }, 45*1da177e4SLinus Torvalds [CMD_PIPE_STATE] = { 0x480000, 1, RMH_SSIZE_FIXED, 1 }, 46*1da177e4SLinus Torvalds [CMD_PIPE_SPL_COUNT] = { 0x49A000, 2, RMH_SSIZE_FIXED, 2 }, 47*1da177e4SLinus Torvalds [CMD_CAN_START_PIPE] = { 0x4b0000, 1, RMH_SSIZE_FIXED, 1 }, 48*1da177e4SLinus Torvalds [CMD_SIZE_HBUFFER] = { 0x4C0000, 1, RMH_SSIZE_FIXED, 1 }, 49*1da177e4SLinus Torvalds [CMD_START_STREAM] = { 0x80A000, 2, RMH_SSIZE_FIXED, 0 }, 50*1da177e4SLinus Torvalds [CMD_START_ONE_STREAM] = { 0x800000, 1, RMH_SSIZE_FIXED, 0 }, 51*1da177e4SLinus Torvalds [CMD_PAUSE_STREAM] = { 0x81A000, 2, RMH_SSIZE_FIXED, 0 }, 52*1da177e4SLinus Torvalds [CMD_PAUSE_ONE_STREAM] = { 0x810000, 1, RMH_SSIZE_FIXED, 0 }, 53*1da177e4SLinus Torvalds [CMD_STREAM_OUT_LEVEL_ADJUST] = { 0x828000, 2, RMH_SSIZE_FIXED, 0 }, 54*1da177e4SLinus Torvalds [CMD_STOP_STREAM] = { 0x830000, 1, RMH_SSIZE_FIXED, 0 }, 55*1da177e4SLinus Torvalds [CMD_FORMAT_STREAM_OUT] = { 0x868000, 1, RMH_SSIZE_FIXED, 0 }, 56*1da177e4SLinus Torvalds [CMD_FORMAT_STREAM_IN] = { 0x878800, 1, RMH_SSIZE_FIXED, 0 }, 57*1da177e4SLinus Torvalds [CMD_GET_STREAM_STATE] = { 0x890001, 2, RMH_SSIZE_FIXED, 1 }, 58*1da177e4SLinus Torvalds [CMD_DROP_BYTES_AWAY] = { 0x8A8000, 2, RMH_SSIZE_FIXED, 0 }, 59*1da177e4SLinus Torvalds [CMD_GET_REMAINING_BYTES] = { 0x8D0800, 1, RMH_SSIZE_FIXED, 2 }, 60*1da177e4SLinus Torvalds [CMD_CONNECT_AUDIO] = { 0xC10000, 1, RMH_SSIZE_FIXED, 0 }, 61*1da177e4SLinus Torvalds [CMD_AUDIO_LEVEL_ADJUST] = { 0xC2A000, 3, RMH_SSIZE_FIXED, 0 }, 62*1da177e4SLinus Torvalds [CMD_AUDIO_VU_PIC_METER] = { 0xC3A003, 2, RMH_SSIZE_FIXED, 1 }, 63*1da177e4SLinus Torvalds [CMD_GET_AUDIO_LEVELS] = { 0xC4A000, 2, RMH_SSIZE_FIXED, 0 }, 64*1da177e4SLinus Torvalds [CMD_GET_NOTIFY_EVENT] = { 0x4D0000, 1, RMH_SSIZE_ARG, 0 }, 65*1da177e4SLinus Torvalds [CMD_INFO_NOTIFIED] = { 0x0B0000, 1, RMH_SSIZE_FIXED, 2 }, 66*1da177e4SLinus Torvalds [CMD_ACCESS_IO_FCT] = { 0x098000, 1, RMH_SSIZE_ARG, 0 }, 67*1da177e4SLinus Torvalds [CMD_STATUS_R_BUFFERS] = { 0x440000, 1, RMH_SSIZE_ARG, 0 }, 68*1da177e4SLinus Torvalds [CMD_UPDATE_R_BUFFERS] = { 0x848000, 4, RMH_SSIZE_FIXED, 0 }, 69*1da177e4SLinus Torvalds [CMD_LOAD_EFFECT_CONTEXT] = { 0x0c8000, 3, RMH_SSIZE_FIXED, 1 }, 70*1da177e4SLinus Torvalds [CMD_EFFECT_ONE_PIPE] = { 0x458000, 0, RMH_SSIZE_FIXED, 0 }, 71*1da177e4SLinus Torvalds [CMD_MODIFY_CLOCK] = { 0x0d0000, 1, RMH_SSIZE_FIXED, 0 }, 72*1da177e4SLinus Torvalds [CMD_STREAM1_OUT_SET_N_LEVELS] ={ 0x858000, 3, RMH_SSIZE_FIXED, 0 }, 73*1da177e4SLinus Torvalds [CMD_PURGE_STREAM_DCMDS] = { 0x8b8000, 3, RMH_SSIZE_FIXED, 0 }, 74*1da177e4SLinus Torvalds [CMD_NOTIFY_PIPE_TIME] = { 0x4e0000, 1, RMH_SSIZE_FIXED, 0 }, 75*1da177e4SLinus Torvalds [CMD_LOAD_EFFECT_CONTEXT_PACKET] = { 0x0c8000, 1, RMH_SSIZE_FIXED, 0 }, 76*1da177e4SLinus Torvalds [CMD_RELIC_R_BUFFER] = { 0x8e0800, 1, RMH_SSIZE_FIXED, 1 }, 77*1da177e4SLinus Torvalds [CMD_RESYNC_AUDIO_INPUTS] = { 0x0e0000, 1, RMH_SSIZE_FIXED, 0 }, 78*1da177e4SLinus Torvalds [CMD_NOTIFY_STREAM_TIME] = { 0x8f0000, 1, RMH_SSIZE_FIXED, 0 }, 79*1da177e4SLinus Torvalds [CMD_STREAM_SAMPLE_COUNT] = { 0x900000, 1, RMH_SSIZE_FIXED, 2 }, 80*1da177e4SLinus Torvalds [CMD_CONFIG_TIME_CODE] = { 0x050000, 2, RMH_SSIZE_FIXED, 0 }, 81*1da177e4SLinus Torvalds [CMD_GET_TIME_CODE] = { 0x060000, 1, RMH_SSIZE_FIXED, 5 }, 82*1da177e4SLinus Torvalds [CMD_MANAGE_SIGNAL] = { 0x0f0000, 1, RMH_SSIZE_FIXED, 0 }, 83*1da177e4SLinus Torvalds [CMD_PARAMETER_STREAM_OUT] = { 0x91A000, 3, RMH_SSIZE_FIXED, 0 }, 84*1da177e4SLinus Torvalds [CMD_READ_BOARD_FREQ] = { 0x030000, 1, RMH_SSIZE_FIXED, 2 }, 85*1da177e4SLinus Torvalds [CMD_GET_STREAM_LEVELS] = { 0x8c0000, 1, RMH_SSIZE_FIXED, 3 }, 86*1da177e4SLinus Torvalds [CMD_PURGE_PIPE_DCMDS] = { 0x4f8000, 3, RMH_SSIZE_FIXED, 0 }, 87*1da177e4SLinus Torvalds // [CMD_SET_STREAM_OUT_EFFECTS] = { 0x888000, 34, RMH_SSIZE_FIXED, 0 }, 88*1da177e4SLinus Torvalds // [CMD_GET_STREAM_OUT_EFFECTS] = { 0x928000, 2, RMH_SSIZE_FIXED, 32 }, 89*1da177e4SLinus Torvalds [CMD_CONNECT_MONITORING] = { 0xC00000, 1, RMH_SSIZE_FIXED, 0 }, 90*1da177e4SLinus Torvalds [CMD_STREAM2_OUT_SET_N_LEVELS] = { 0x938000, 3, RMH_SSIZE_FIXED, 0 }, 91*1da177e4SLinus Torvalds [CMD_CANCEL_R_BUFFERS] = { 0x948000, 4, RMH_SSIZE_FIXED, 0 }, 92*1da177e4SLinus Torvalds [CMD_NOTIFY_END_OF_BUFFER] = { 0x950000, 1, RMH_SSIZE_FIXED, 0 }, 93*1da177e4SLinus Torvalds [CMD_GET_STREAM_VU_METER] = { 0x95A000, 2, RMH_SSIZE_ARG, 0 }, 94*1da177e4SLinus Torvalds }; 95*1da177e4SLinus Torvalds 96*1da177e4SLinus Torvalds /** 97*1da177e4SLinus Torvalds * vx_init_rmh - initialize the RMH instance 98*1da177e4SLinus Torvalds * @rmh: the rmh pointer to be initialized 99*1da177e4SLinus Torvalds * @cmd: the rmh command to be set 100*1da177e4SLinus Torvalds */ 101*1da177e4SLinus Torvalds void vx_init_rmh(struct vx_rmh *rmh, unsigned int cmd) 102*1da177e4SLinus Torvalds { 103*1da177e4SLinus Torvalds snd_assert(cmd < CMD_LAST_INDEX, return); 104*1da177e4SLinus Torvalds rmh->LgCmd = vx_dsp_cmds[cmd].length; 105*1da177e4SLinus Torvalds rmh->LgStat = vx_dsp_cmds[cmd].st_length; 106*1da177e4SLinus Torvalds rmh->DspStat = vx_dsp_cmds[cmd].st_type; 107*1da177e4SLinus Torvalds rmh->Cmd[0] = vx_dsp_cmds[cmd].opcode; 108*1da177e4SLinus Torvalds } 109*1da177e4SLinus Torvalds 110