/* * ALSA driver for Echoaudio soundcards. * Copyright (C) 2003-2004 Giuliano Pochini <pochini@shiny.it> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; version 2 of the License. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #define ECHOGALS_FAMILY #define ECHOCARD_LAYLA20 #define ECHOCARD_NAME "Layla20" #define ECHOCARD_HAS_MONITOR #define ECHOCARD_HAS_ASIC #define ECHOCARD_HAS_INPUT_GAIN #define ECHOCARD_HAS_OUTPUT_NOMINAL_LEVEL #define ECHOCARD_HAS_SUPER_INTERLEAVE #define ECHOCARD_HAS_DIGITAL_IO #define ECHOCARD_HAS_EXTERNAL_CLOCK #define ECHOCARD_HAS_ADAT false #define ECHOCARD_HAS_OUTPUT_CLOCK_SWITCH #define ECHOCARD_HAS_MIDI /* Pipe indexes */ #define PX_ANALOG_OUT 0 /* 10 */ #define PX_DIGITAL_OUT 10 /* 2 */ #define PX_ANALOG_IN 12 /* 8 */ #define PX_DIGITAL_IN 20 /* 2 */ #define PX_NUM 22 /* Bus indexes */ #define BX_ANALOG_OUT 0 /* 10 */ #define BX_DIGITAL_OUT 10 /* 2 */ #define BX_ANALOG_IN 12 /* 8 */ #define BX_DIGITAL_IN 20 /* 2 */ #define BX_NUM 22 #include <linux/delay.h> #include <linux/init.h> #include <linux/interrupt.h> #include <linux/pci.h> #include <linux/module.h> #include <linux/firmware.h> #include <linux/slab.h> #include <linux/io.h> #include <sound/core.h> #include <sound/info.h> #include <sound/control.h> #include <sound/tlv.h> #include <sound/pcm.h> #include <sound/pcm_params.h> #include <sound/asoundef.h> #include <sound/initval.h> #include <sound/rawmidi.h> #include <linux/atomic.h> #include "echoaudio.h" MODULE_FIRMWARE("ea/layla20_dsp.fw"); MODULE_FIRMWARE("ea/layla20_asic.fw"); #define FW_LAYLA20_DSP 0 #define FW_LAYLA20_ASIC 1 static const struct firmware card_fw[] = { {0, "layla20_dsp.fw"}, {0, "layla20_asic.fw"} }; static const struct pci_device_id snd_echo_ids[] = { {0x1057, 0x1801, 0xECC0, 0x0030, 0, 0, 0}, /* DSP 56301 Layla20 rev.0 */ {0x1057, 0x1801, 0xECC0, 0x0031, 0, 0, 0}, /* DSP 56301 Layla20 rev.1 */ {0,} }; static struct snd_pcm_hardware pcm_hardware_skel = { .info = SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | SNDRV_PCM_INFO_BLOCK_TRANSFER | SNDRV_PCM_INFO_MMAP_VALID | SNDRV_PCM_INFO_PAUSE | SNDRV_PCM_INFO_SYNC_START, .formats = SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S24_3LE | SNDRV_PCM_FMTBIT_S32_LE | SNDRV_PCM_FMTBIT_S32_BE, .rates = SNDRV_PCM_RATE_8000_48000 | SNDRV_PCM_RATE_CONTINUOUS, .rate_min = 8000, .rate_max = 50000, .channels_min = 1, .channels_max = 10, .buffer_bytes_max = 262144, .period_bytes_min = 32, .period_bytes_max = 131072, .periods_min = 2, .periods_max = 220, /* One page (4k) contains 512 instructions. I don't know if the hw supports lists longer than this. In this case periods_max=220 is a safe limit to make sure the list never exceeds 512 instructions. */ }; #include "layla20_dsp.c" #include "echoaudio_dsp.c" #include "echoaudio.c" #include "midi.c" 0'>include</a></div><div class='content'><div class='cgit-panel'><b>diff options</b><form method='get'><input type='hidden' name='id' value='c1b0789271b13dd7561f78370122c3183cd74ab0'/><table><tr><td colspan='2'/></tr><tr><td class='label'>context:</td><td class='ctrl'><select name='context' onchange='this.form.submit();'><option value='1'>1</option><option value='2'>2</option><option value='3' selected='selected'>3</option><option value='4'>4</option><option value='5'>5</option><option value='6'>6</option><option value='7'>7</option><option value='8'>8</option><option value='9'>9</option><option value='10'>10</option><option value='15'>15</option><option value='20'>20</option><option value='25'>25</option><option value='30'>30</option><option value='35'>35</option><option value='40'>40</option></select></td></tr><tr><td class='label'>space:</td><td class='ctrl'><select name='ignorews' onchange='this.form.submit();'><option value='0' selected='selected'>include</option><option value='1'>ignore</option></select></td></tr><tr><td class='label'>mode:</td><td class='ctrl'><select name='dt' onchange='this.form.submit();'><option value='0' selected='selected'>unified</option><option value='1'>ssdiff</option><option value='2'>stat only</option></select></td></tr><tr><td/><td class='ctrl'><noscript><input type='submit' value='reload'/></noscript></td></tr></table></form></div><table summary='commit info' class='commit-info'> <tr><th>author</th><td>Mark Brown <broonie@kernel.org></td><td class='right'>2016-12-12 12:17:19 +0000</td></tr> <tr><th>committer</th><td>Mark Brown <broonie@kernel.org></td><td class='right'>2016-12-12 12:17:19 +0000</td></tr> <tr><th>commit</th><td colspan='2' class='oid'><a href='/cgit.cgi/linux/net-next.git/commit/tools/perf/arch/xtensa/include?id=c1b0789271b13dd7561f78370122c3183cd74ab0'>c1b0789271b13dd7561f78370122c3183cd74ab0</a> (<a href='/cgit.cgi/linux/net-next.git/patch/tools/perf/arch/xtensa/include?id=c1b0789271b13dd7561f78370122c3183cd74ab0'>patch</a>)</td></tr> <tr><th>tree</th><td colspan='2' class='oid'><a href='/cgit.cgi/linux/net-next.git/tree/?id=c1b0789271b13dd7561f78370122c3183cd74ab0'>f4eda3db7bd1b059de81cd4bec7fbb871661dbe2</a> /<a href='/cgit.cgi/linux/net-next.git/tree/tools/perf/arch/xtensa/include?id=c1b0789271b13dd7561f78370122c3183cd74ab0'>tools/perf/arch/xtensa/include</a></td></tr> <tr><th>parent</th><td colspan='2' class='oid'><a href='/cgit.cgi/linux/net-next.git/commit/tools/perf/arch/xtensa/include?id=69973b830859bc6529a7a0468ba0d80ee5117826'>69973b830859bc6529a7a0468ba0d80ee5117826</a> (<a href='/cgit.cgi/linux/net-next.git/diff/tools/perf/arch/xtensa/include?id=c1b0789271b13dd7561f78370122c3183cd74ab0&id2=69973b830859bc6529a7a0468ba0d80ee5117826'>diff</a>)</td></tr><tr><th>parent</th><td colspan='2' class='oid'><a href='/cgit.cgi/linux/net-next.git/commit/tools/perf/arch/xtensa/include?id=618c808968852609d2d9f0e5cfc351a4807ef8d0'>618c808968852609d2d9f0e5cfc351a4807ef8d0</a> (<a href='/cgit.cgi/linux/net-next.git/diff/tools/perf/arch/xtensa/include?id=c1b0789271b13dd7561f78370122c3183cd74ab0&id2=618c808968852609d2d9f0e5cfc351a4807ef8d0'>diff</a>)</td></tr></table> <div class='commit-subject'>Merge remote-tracking branch 'regulator/fix/axp20x' into regulator-linus</div><div class='commit-msg'></div><div class='diffstat-header'><a href='/cgit.cgi/linux/net-next.git/diff/?id=c1b0789271b13dd7561f78370122c3183cd74ab0'>Diffstat</a> (limited to 'tools/perf/arch/xtensa/include')</div><table summary='diffstat' class='diffstat'>