ymfpci.c
上传用户:lgb322
上传日期:2013-02-24
资源大小:30529k
文件大小:73k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. /*
  2.  *  Copyright 1999 Jaroslav Kysela <perex@suse.cz>
  3.  *  Copyright 2000 Alan Cox <alan@redhat.com>
  4.  *
  5.  *  Yamaha YMF7xx driver.
  6.  *
  7.  *  This code is a result of high-speed collision
  8.  *  between ymfpci.c of ALSA and cs46xx.c of Linux.
  9.  *  -- Pete Zaitcev <zaitcev@yahoo.com>; 2000/09/18
  10.  *
  11.  *   This program is free software; you can redistribute it and/or modify
  12.  *   it under the terms of the GNU General Public License as published by
  13.  *   the Free Software Foundation; either version 2 of the License, or
  14.  *   (at your option) any later version.
  15.  *
  16.  *   This program is distributed in the hope that it will be useful,
  17.  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
  18.  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  19.  *   GNU General Public License for more details.
  20.  *
  21.  *   You should have received a copy of the GNU General Public License
  22.  *   along with this program; if not, write to the Free Software
  23.  *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  24.  *
  25.  * TODO:
  26.  *  - Use P44Slot for 44.1 playback (beware of idle buzzing in P44Slot).
  27.  *  - 96KHz playback for DVD - use pitch of 2.0.
  28.  *  - Retain DMA buffer on close, do not wait the end of frame.
  29.  *  - Resolve XXX tagged questions.
  30.  *  - Cannot play 5133Hz.
  31.  *  - 2001/01/07 Consider if we can remove voice_lock, like so:
  32.  *     : Allocate/deallocate voices in open/close under semafore.
  33.  *     : We access voices in interrupt, that only for pcms that open.
  34.  *    voice_lock around playback_prepare closes interrupts for insane duration.
  35.  *  - Revisit the way voice_alloc is done - too confusing, overcomplicated.
  36.  *    Should support various channel types, however.
  37.  *  - Remove prog_dmabuf from read/write, leave it in open.
  38.  *  - 2001/01/07 Replace the OPL3 part of CONFIG_SOUND_YMFPCI_LEGACY code with
  39.  *    native synthesizer through a playback slot.
  40.  *  - Use new 2.3.x cache coherent PCI DMA routines instead of virt_to_bus.
  41.  *  - Make the thing big endian compatible. ALSA has it done.
  42.  *  - 2001/11/29 ac97_save_state
  43.  */
  44. #include <linux/config.h>
  45. #include <linux/module.h>
  46. #include <linux/init.h>
  47. #include <linux/ioport.h>
  48. #include <linux/delay.h>
  49. #include <linux/pci.h>
  50. #include <linux/slab.h>
  51. #include <linux/poll.h>
  52. #include <linux/soundcard.h>
  53. #include <linux/ac97_codec.h>
  54. #include <linux/sound.h>
  55. #include <asm/io.h>
  56. #include <asm/dma.h>
  57. #include <asm/uaccess.h>
  58. #ifdef CONFIG_SOUND_YMFPCI_LEGACY
  59. # include "sound_config.h"
  60. # include "mpu401.h"
  61. #endif
  62. #include "ymfpci.h"
  63. /*
  64.  * I do not believe in debug levels as I never can guess what
  65.  * part of the code is going to be problematic in the future.
  66.  * Don't forget to run your klogd with -c 8.
  67.  *
  68.  * Example (do not remove):
  69.  * #define YMFDBG(fmt, arg...)  do{ printk(KERN_DEBUG fmt, ##arg); }while(0)
  70.  */
  71. #define YMFDBGW(fmt, arg...)  /* */ /* write counts */
  72. #define YMFDBGI(fmt, arg...)  /* */ /* interrupts */
  73. #define YMFDBGX(fmt, arg...)  /* */ /* ioctl */
  74. static int ymf_playback_trigger(ymfpci_t *unit, struct ymf_pcm *ypcm, int cmd);
  75. static void ymf_capture_trigger(ymfpci_t *unit, struct ymf_pcm *ypcm, int cmd);
  76. static void ymfpci_voice_free(ymfpci_t *unit, ymfpci_voice_t *pvoice);
  77. static int ymf_capture_alloc(struct ymf_unit *unit, int *pbank);
  78. static int ymf_playback_prepare(struct ymf_state *state);
  79. static int ymf_capture_prepare(struct ymf_state *state);
  80. static struct ymf_state *ymf_state_alloc(ymfpci_t *unit);
  81. static void ymfpci_aclink_reset(struct pci_dev * pci);
  82. static void ymfpci_disable_dsp(ymfpci_t *unit);
  83. static void ymfpci_download_image(ymfpci_t *codec);
  84. static void ymf_memload(ymfpci_t *unit);
  85. static LIST_HEAD(ymf_devs);
  86. /*
  87.  *  constants
  88.  */
  89. static struct pci_device_id ymf_id_tbl[] __devinitdata = {
  90. #define DEV(v, d, data) 
  91.   { PCI_VENDOR_ID_##v, PCI_DEVICE_ID_##v##_##d, PCI_ANY_ID, PCI_ANY_ID, 0, 0, (unsigned long)data }
  92. DEV (YAMAHA, 724,  "YMF724"),
  93. DEV (YAMAHA, 724F, "YMF724F"),
  94. DEV (YAMAHA, 740,  "YMF740"),
  95. DEV (YAMAHA, 740C, "YMF740C"),
  96. DEV (YAMAHA, 744,  "YMF744"),
  97. DEV (YAMAHA, 754,  "YMF754"),
  98. #undef DEV
  99. { }
  100. };
  101. MODULE_DEVICE_TABLE(pci, ymf_id_tbl);
  102. /*
  103.  *  common I/O routines
  104.  */
  105. static inline u8 ymfpci_readb(ymfpci_t *codec, u32 offset)
  106. {
  107. return readb(codec->reg_area_virt + offset);
  108. }
  109. static inline void ymfpci_writeb(ymfpci_t *codec, u32 offset, u8 val)
  110. {
  111. writeb(val, codec->reg_area_virt + offset);
  112. }
  113. static inline u16 ymfpci_readw(ymfpci_t *codec, u32 offset)
  114. {
  115. return readw(codec->reg_area_virt + offset);
  116. }
  117. static inline void ymfpci_writew(ymfpci_t *codec, u32 offset, u16 val)
  118. {
  119. writew(val, codec->reg_area_virt + offset);
  120. }
  121. static inline u32 ymfpci_readl(ymfpci_t *codec, u32 offset)
  122. {
  123. return readl(codec->reg_area_virt + offset);
  124. }
  125. static inline void ymfpci_writel(ymfpci_t *codec, u32 offset, u32 val)
  126. {
  127. writel(val, codec->reg_area_virt + offset);
  128. }
  129. static int ymfpci_codec_ready(ymfpci_t *codec, int secondary, int sched)
  130. {
  131. signed long end_time;
  132. u32 reg = secondary ? YDSXGR_SECSTATUSADR : YDSXGR_PRISTATUSADR;
  133. end_time = jiffies + 3 * (HZ / 4);
  134. do {
  135. if ((ymfpci_readw(codec, reg) & 0x8000) == 0)
  136. return 0;
  137. if (sched) {
  138. set_current_state(TASK_UNINTERRUPTIBLE);
  139. schedule_timeout(1);
  140. }
  141. } while (end_time - (signed long)jiffies >= 0);
  142. printk(KERN_ERR "ymfpci_codec_ready: codec %i is not ready [0x%x]n",
  143.     secondary, ymfpci_readw(codec, reg));
  144. return -EBUSY;
  145. }
  146. static void ymfpci_codec_write(struct ac97_codec *dev, u8 reg, u16 val)
  147. {
  148. ymfpci_t *codec = dev->private_data;
  149. u32 cmd;
  150. /* XXX Do make use of dev->id */
  151. ymfpci_codec_ready(codec, 0, 0);
  152. cmd = ((YDSXG_AC97WRITECMD | reg) << 16) | val;
  153. ymfpci_writel(codec, YDSXGR_AC97CMDDATA, cmd);
  154. }
  155. static u16 ymfpci_codec_read(struct ac97_codec *dev, u8 reg)
  156. {
  157. ymfpci_t *unit = dev->private_data;
  158. int i;
  159. if (ymfpci_codec_ready(unit, 0, 0))
  160. return ~0;
  161. ymfpci_writew(unit, YDSXGR_AC97CMDADR, YDSXG_AC97READCMD | reg);
  162. if (ymfpci_codec_ready(unit, 0, 0))
  163. return ~0;
  164. if (unit->pci->device == PCI_DEVICE_ID_YAMAHA_744 && unit->rev < 2) {
  165. for (i = 0; i < 600; i++)
  166. ymfpci_readw(unit, YDSXGR_PRISTATUSDATA);
  167. }
  168. return ymfpci_readw(unit, YDSXGR_PRISTATUSDATA);
  169. }
  170. /*
  171.  *  Misc routines
  172.  */
  173. /*
  174.  * Calculate the actual sampling rate relatetively to the base clock (48kHz).
  175.  */
  176. static u32 ymfpci_calc_delta(u32 rate)
  177. {
  178. switch (rate) {
  179. case 8000: return 0x02aaab00;
  180. case 11025: return 0x03accd00;
  181. case 16000: return 0x05555500;
  182. case 22050: return 0x07599a00;
  183. case 32000: return 0x0aaaab00;
  184. case 44100: return 0x0eb33300;
  185. default: return ((rate << 16) / 48000) << 12;
  186. }
  187. }
  188. static u32 def_rate[8] = {
  189. 100, 2000, 8000, 11025, 16000, 22050, 32000, 48000
  190. };
  191. static u32 ymfpci_calc_lpfK(u32 rate)
  192. {
  193. u32 i;
  194. static u32 val[8] = {
  195. 0x00570000, 0x06AA0000, 0x18B20000, 0x20930000,
  196. 0x2B9A0000, 0x35A10000, 0x3EAA0000, 0x40000000
  197. };
  198. if (rate == 44100)
  199. return 0x40000000; /* FIXME: What's the right value? */
  200. for (i = 0; i < 8; i++)
  201. if (rate <= def_rate[i])
  202. return val[i];
  203. return val[0];
  204. }
  205. static u32 ymfpci_calc_lpfQ(u32 rate)
  206. {
  207. u32 i;
  208. static u32 val[8] = {
  209. 0x35280000, 0x34A70000, 0x32020000, 0x31770000,
  210. 0x31390000, 0x31C90000, 0x33D00000, 0x40000000
  211. };
  212. if (rate == 44100)
  213. return 0x370A0000;
  214. for (i = 0; i < 8; i++)
  215. if (rate <= def_rate[i])
  216. return val[i];
  217. return val[0];
  218. }
  219. static u32 ymf_calc_lend(u32 rate)
  220. {
  221. return (rate * YMF_SAMPF) / 48000;
  222. }
  223. /*
  224.  * We ever allow only a few formats, but let's be generic, for smaller surprise.
  225.  */
  226. static int ymf_pcm_format_width(int format)
  227. {
  228. static int mask16 = AFMT_S16_LE|AFMT_S16_BE|AFMT_U16_LE|AFMT_U16_BE;
  229. if ((format & (format-1)) != 0) {
  230. printk(KERN_ERR "ymfpci: format 0x%x is not a power of 2n", format);
  231. return 8;
  232. }
  233. if (format == AFMT_IMA_ADPCM) return 4;
  234. if ((format & mask16) != 0) return 16;
  235. return 8;
  236. }
  237. static void ymf_pcm_update_shift(struct ymf_pcm_format *f)
  238. {
  239. f->shift = 0;
  240. if (f->voices == 2)
  241. f->shift++;
  242. if (ymf_pcm_format_width(f->format) == 16)
  243. f->shift++;
  244. }
  245. /* Are you sure 32K is not too much? See if mpg123 skips on loaded systems. */
  246. #define DMABUF_DEFAULTORDER (15-PAGE_SHIFT)
  247. #define DMABUF_MINORDER 1
  248. /* allocate DMA buffer, playback and recording buffer should be allocated seperately */
  249. static int alloc_dmabuf(struct ymf_dmabuf *dmabuf)
  250. {
  251. void *rawbuf = NULL;
  252. int order;
  253. struct page * map,  * mapend;
  254. /* alloc as big a chunk as we can */
  255. for (order = DMABUF_DEFAULTORDER; order >= DMABUF_MINORDER; order--)
  256. if((rawbuf = (void *)__get_free_pages(GFP_KERNEL|GFP_DMA, order)))
  257. break;
  258. if (!rawbuf)
  259. return -ENOMEM;
  260. #if 0
  261. printk(KERN_DEBUG "ymfpci: allocated %ld (order = %d) bytes at %pn",
  262.        PAGE_SIZE << order, order, rawbuf);
  263. #endif
  264. dmabuf->ready  = dmabuf->mapped = 0;
  265. dmabuf->rawbuf = rawbuf;
  266. dmabuf->buforder = order;
  267. /* now mark the pages as reserved; otherwise remap_page_range doesn't do what we want */
  268. mapend = virt_to_page(rawbuf + (PAGE_SIZE << order) - 1);
  269. for (map = virt_to_page(rawbuf); map <= mapend; map++)
  270. set_bit(PG_reserved, &map->flags);
  271. return 0;
  272. }
  273. /* free DMA buffer */
  274. static void dealloc_dmabuf(struct ymf_dmabuf *dmabuf)
  275. {
  276. struct page *map, *mapend;
  277. if (dmabuf->rawbuf) {
  278. /* undo marking the pages as reserved */
  279. mapend = virt_to_page(dmabuf->rawbuf + (PAGE_SIZE << dmabuf->buforder) - 1);
  280. for (map = virt_to_page(dmabuf->rawbuf); map <= mapend; map++)
  281. clear_bit(PG_reserved, &map->flags);
  282. free_pages((unsigned long)dmabuf->rawbuf,dmabuf->buforder);
  283. }
  284. dmabuf->rawbuf = NULL;
  285. dmabuf->mapped = dmabuf->ready = 0;
  286. }
  287. static int prog_dmabuf(struct ymf_state *state, int rec)
  288. {
  289. struct ymf_dmabuf *dmabuf;
  290. int w_16;
  291. unsigned bufsize;
  292. unsigned long flags;
  293. int redzone, redfrags;
  294. int ret;
  295. w_16 = ymf_pcm_format_width(state->format.format) == 16;
  296. dmabuf = rec ? &state->rpcm.dmabuf : &state->wpcm.dmabuf;
  297. spin_lock_irqsave(&state->unit->reg_lock, flags);
  298. dmabuf->hwptr = dmabuf->swptr = 0;
  299. dmabuf->total_bytes = 0;
  300. dmabuf->count = 0;
  301. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  302. /* allocate DMA buffer if not allocated yet */
  303. if (!dmabuf->rawbuf)
  304. if ((ret = alloc_dmabuf(dmabuf)))
  305. return ret;
  306. /*
  307.  * Create fake fragment sizes and numbers for OSS ioctls.
  308.  * Import what Doom might have set with SNDCTL_DSP_SETFRAGMENT.
  309.  */
  310. bufsize = PAGE_SIZE << dmabuf->buforder;
  311. /* By default we give 4 big buffers. */
  312. dmabuf->fragshift = (dmabuf->buforder + PAGE_SHIFT - 2);
  313. if (dmabuf->ossfragshift > 3 &&
  314.     dmabuf->ossfragshift < dmabuf->fragshift) {
  315. /* If OSS set smaller fragments, give more smaller buffers. */
  316. dmabuf->fragshift = dmabuf->ossfragshift;
  317. }
  318. dmabuf->fragsize = 1 << dmabuf->fragshift;
  319. dmabuf->numfrag = bufsize >> dmabuf->fragshift;
  320. dmabuf->dmasize = dmabuf->numfrag << dmabuf->fragshift;
  321. if (dmabuf->ossmaxfrags >= 2) {
  322. redzone = ymf_calc_lend(state->format.rate);
  323. redzone <<= state->format.shift;
  324. redzone *= 3;
  325. redfrags = (redzone + dmabuf->fragsize-1) >> dmabuf->fragshift;
  326. if (dmabuf->ossmaxfrags + redfrags < dmabuf->numfrag) {
  327. dmabuf->numfrag = dmabuf->ossmaxfrags + redfrags;
  328. dmabuf->dmasize = dmabuf->numfrag << dmabuf->fragshift;
  329. }
  330. }
  331. memset(dmabuf->rawbuf, w_16 ? 0 : 0x80, dmabuf->dmasize);
  332. /*
  333.  * Now set up the ring 
  334.  */
  335. /* XXX   ret = rec? cap_pre(): pbk_pre();  */
  336. spin_lock_irqsave(&state->unit->voice_lock, flags);
  337. if (rec) {
  338. if ((ret = ymf_capture_prepare(state)) != 0) {
  339. spin_unlock_irqrestore(&state->unit->voice_lock, flags);
  340. return ret;
  341. }
  342. } else {
  343. if ((ret = ymf_playback_prepare(state)) != 0) {
  344. spin_unlock_irqrestore(&state->unit->voice_lock, flags);
  345. return ret;
  346. }
  347. }
  348. spin_unlock_irqrestore(&state->unit->voice_lock, flags);
  349. /* set the ready flag for the dma buffer (this comment is not stupid) */
  350. dmabuf->ready = 1;
  351. #if 0
  352. printk(KERN_DEBUG "prog_dmabuf: rate %d format 0x%x,"
  353.     " numfrag %d fragsize %d dmasize %dn",
  354.        state->format.rate, state->format.format, dmabuf->numfrag,
  355.        dmabuf->fragsize, dmabuf->dmasize);
  356. #endif
  357. return 0;
  358. }
  359. static void ymf_start_dac(struct ymf_state *state)
  360. {
  361. ymf_playback_trigger(state->unit, &state->wpcm, 1);
  362. }
  363. // static void ymf_start_adc(struct ymf_state *state)
  364. // {
  365. //  ymf_capture_trigger(state->unit, &state->rpcm, 1);
  366. // }
  367. /*
  368.  * Wait until output is drained.
  369.  * This does not kill the hardware for the sake of ioctls.
  370.  */
  371. static void ymf_wait_dac(struct ymf_state *state)
  372. {
  373. struct ymf_unit *unit = state->unit;
  374. struct ymf_pcm *ypcm = &state->wpcm;
  375. DECLARE_WAITQUEUE(waita, current);
  376. unsigned long flags;
  377. add_wait_queue(&ypcm->dmabuf.wait, &waita);
  378. spin_lock_irqsave(&unit->reg_lock, flags);
  379. if (ypcm->dmabuf.count != 0 && !ypcm->running) {
  380. ymf_playback_trigger(unit, ypcm, 1);
  381. }
  382. #if 0
  383. if (file->f_flags & O_NONBLOCK) {
  384. /*
  385.  * XXX Our  mistake is to attach DMA buffer to state
  386.  * rather than to some per-device structure.
  387.  * Cannot skip waiting, can only make it shorter.
  388.  */
  389. }
  390. #endif
  391. set_current_state(TASK_UNINTERRUPTIBLE);
  392. while (ypcm->running) {
  393. spin_unlock_irqrestore(&unit->reg_lock, flags);
  394. schedule();
  395. spin_lock_irqsave(&unit->reg_lock, flags);
  396. set_current_state(TASK_UNINTERRUPTIBLE);
  397. }
  398. spin_unlock_irqrestore(&unit->reg_lock, flags);
  399. set_current_state(TASK_RUNNING);
  400. remove_wait_queue(&ypcm->dmabuf.wait, &waita);
  401. /*
  402.  * This function may take up to 4 seconds to reach this point
  403.  * (32K circular buffer, 8000 Hz). User notices.
  404.  */
  405. }
  406. /* Can just stop, without wait. Or can we? */
  407. static void ymf_stop_adc(struct ymf_state *state)
  408. {
  409. struct ymf_unit *unit = state->unit;
  410. unsigned long flags;
  411. spin_lock_irqsave(&unit->reg_lock, flags);
  412. ymf_capture_trigger(unit, &state->rpcm, 0);
  413. spin_unlock_irqrestore(&unit->reg_lock, flags);
  414. }
  415. /*
  416.  *  Hardware start management
  417.  */
  418. static void ymfpci_hw_start(ymfpci_t *unit)
  419. {
  420. unsigned long flags;
  421. spin_lock_irqsave(&unit->reg_lock, flags);
  422. if (unit->start_count++ == 0) {
  423. ymfpci_writel(unit, YDSXGR_MODE,
  424.     ymfpci_readl(unit, YDSXGR_MODE) | 3);
  425. unit->active_bank = ymfpci_readl(unit, YDSXGR_CTRLSELECT) & 1;
  426. }
  427. spin_unlock_irqrestore(&unit->reg_lock, flags);
  428. }
  429. static void ymfpci_hw_stop(ymfpci_t *unit)
  430. {
  431. unsigned long flags;
  432. long timeout = 1000;
  433. spin_lock_irqsave(&unit->reg_lock, flags);
  434. if (--unit->start_count == 0) {
  435. ymfpci_writel(unit, YDSXGR_MODE,
  436.     ymfpci_readl(unit, YDSXGR_MODE) & ~3);
  437. while (timeout-- > 0) {
  438. if ((ymfpci_readl(unit, YDSXGR_STATUS) & 2) == 0)
  439. break;
  440. }
  441. }
  442. spin_unlock_irqrestore(&unit->reg_lock, flags);
  443. }
  444. /*
  445.  *  Playback voice management
  446.  */
  447. static int voice_alloc(ymfpci_t *codec, ymfpci_voice_type_t type, int pair, ymfpci_voice_t *rvoice[])
  448. {
  449. ymfpci_voice_t *voice, *voice2;
  450. int idx;
  451. for (idx = 0; idx < YDSXG_PLAYBACK_VOICES; idx += pair ? 2 : 1) {
  452. voice = &codec->voices[idx];
  453. voice2 = pair ? &codec->voices[idx+1] : NULL;
  454. if (voice->use || (voice2 && voice2->use))
  455. continue;
  456. voice->use = 1;
  457. if (voice2)
  458. voice2->use = 1;
  459. switch (type) {
  460. case YMFPCI_PCM:
  461. voice->pcm = 1;
  462. if (voice2)
  463. voice2->pcm = 1;
  464. break;
  465. case YMFPCI_SYNTH:
  466. voice->synth = 1;
  467. break;
  468. case YMFPCI_MIDI:
  469. voice->midi = 1;
  470. break;
  471. }
  472. ymfpci_hw_start(codec);
  473. rvoice[0] = voice;
  474. if (voice2) {
  475. ymfpci_hw_start(codec);
  476. rvoice[1] = voice2;
  477. }
  478. return 0;
  479. }
  480. return -EBUSY; /* Your audio channel is open by someone else. */
  481. }
  482. static void ymfpci_voice_free(ymfpci_t *unit, ymfpci_voice_t *pvoice)
  483. {
  484. ymfpci_hw_stop(unit);
  485. pvoice->use = pvoice->pcm = pvoice->synth = pvoice->midi = 0;
  486. pvoice->ypcm = NULL;
  487. }
  488. /*
  489.  */
  490. static void ymf_pcm_interrupt(ymfpci_t *codec, ymfpci_voice_t *voice)
  491. {
  492. struct ymf_pcm *ypcm;
  493. int redzone;
  494. int pos, delta, swptr;
  495. int played, distance;
  496. struct ymf_state *state;
  497. struct ymf_dmabuf *dmabuf;
  498. char silence;
  499. if ((ypcm = voice->ypcm) == NULL) {
  500. return;
  501. }
  502. if ((state = ypcm->state) == NULL) {
  503. ypcm->running = 0; // lock it
  504. return;
  505. }
  506. dmabuf = &ypcm->dmabuf;
  507. spin_lock(&codec->reg_lock);
  508. if (ypcm->running) {
  509. YMFDBGI("ymfpci: %d, intr bank %d count %d start 0x%x:%xn",
  510.    voice->number, codec->active_bank, dmabuf->count,
  511.    voice->bank[0].start, voice->bank[1].start);
  512. silence = (ymf_pcm_format_width(state->format.format) == 16) ?
  513.     0 : 0x80;
  514. /* We need actual left-hand-side redzone size here. */
  515. redzone = ymf_calc_lend(state->format.rate);
  516. redzone <<= (state->format.shift + 1);
  517. swptr = dmabuf->swptr;
  518. pos = voice->bank[codec->active_bank].start;
  519. pos <<= state->format.shift;
  520. if (pos < 0 || pos >= dmabuf->dmasize) { /* ucode bug */
  521. printk(KERN_ERR "ymfpci%d: runaway voice %d: hwptr %d=>%d dmasize %dn",
  522.     codec->dev_audio, voice->number,
  523.     dmabuf->hwptr, pos, dmabuf->dmasize);
  524. pos = 0;
  525. }
  526. if (pos < dmabuf->hwptr) {
  527. delta = dmabuf->dmasize - dmabuf->hwptr;
  528. memset(dmabuf->rawbuf + dmabuf->hwptr, silence, delta);
  529. delta += pos;
  530. memset(dmabuf->rawbuf, silence, pos);
  531. } else {
  532. delta = pos - dmabuf->hwptr;
  533. memset(dmabuf->rawbuf + dmabuf->hwptr, silence, delta);
  534. }
  535. dmabuf->hwptr = pos;
  536. if (dmabuf->count == 0) {
  537. printk(KERN_ERR "ymfpci%d: %d: strain: hwptr %dn",
  538.     codec->dev_audio, voice->number, dmabuf->hwptr);
  539. ymf_playback_trigger(codec, ypcm, 0);
  540. }
  541. if (swptr <= pos) {
  542. distance = pos - swptr;
  543. } else {
  544. distance = dmabuf->dmasize - (swptr - pos);
  545. }
  546. if (distance < redzone) {
  547. /*
  548.  * hwptr inside redzone => DMA ran out of samples.
  549.  */
  550. if (delta < dmabuf->count) {
  551. /*
  552.  * Lost interrupt or other screwage.
  553.  */
  554. printk(KERN_ERR "ymfpci%d: %d: lost: delta %d"
  555.     " hwptr %d swptr %d distance %d count %dn",
  556.     codec->dev_audio, voice->number, delta,
  557.     dmabuf->hwptr, swptr, distance, dmabuf->count);
  558. } else {
  559. /*
  560.  * Normal end of DMA.
  561.  */
  562. YMFDBGI("ymfpci%d: %d: done: delta %d"
  563.     " hwptr %d swptr %d distance %d count %dn",
  564.     codec->dev_audio, voice->number, delta,
  565.     dmabuf->hwptr, swptr, distance, dmabuf->count);
  566. }
  567. played = dmabuf->count;
  568. if (ypcm->running) {
  569. ymf_playback_trigger(codec, ypcm, 0);
  570. }
  571. } else {
  572. /*
  573.  * hwptr is chipping away towards a remote swptr.
  574.  * Calculate other distance and apply it to count.
  575.  */
  576. if (swptr >= pos) {
  577. distance = swptr - pos;
  578. } else {
  579. distance = dmabuf->dmasize - (pos - swptr);
  580. }
  581. if (distance < dmabuf->count) {
  582. played = dmabuf->count - distance;
  583. } else {
  584. played = 0;
  585. }
  586. }
  587. dmabuf->total_bytes += played;
  588. dmabuf->count -= played;
  589. if (dmabuf->count < dmabuf->dmasize / 2) {
  590. wake_up(&dmabuf->wait);
  591. }
  592. }
  593. spin_unlock(&codec->reg_lock);
  594. }
  595. static void ymf_cap_interrupt(ymfpci_t *unit, struct ymf_capture *cap)
  596. {
  597. struct ymf_pcm *ypcm;
  598. int redzone;
  599. struct ymf_state *state;
  600. struct ymf_dmabuf *dmabuf;
  601. int pos, delta;
  602. int cnt;
  603. if ((ypcm = cap->ypcm) == NULL) {
  604. return;
  605. }
  606. if ((state = ypcm->state) == NULL) {
  607. ypcm->running = 0; // lock it
  608. return;
  609. }
  610. dmabuf = &ypcm->dmabuf;
  611. spin_lock(&unit->reg_lock);
  612. if (ypcm->running) {
  613. redzone = ymf_calc_lend(state->format.rate);
  614. redzone <<= (state->format.shift + 1);
  615. pos = cap->bank[unit->active_bank].start;
  616. // pos <<= state->format.shift;
  617. if (pos < 0 || pos >= dmabuf->dmasize) { /* ucode bug */
  618. printk(KERN_ERR "ymfpci%d: runaway capture %d: hwptr %d=>%d dmasize %dn",
  619.     unit->dev_audio, ypcm->capture_bank_number,
  620.     dmabuf->hwptr, pos, dmabuf->dmasize);
  621. pos = 0;
  622. }
  623. if (pos < dmabuf->hwptr) {
  624. delta = dmabuf->dmasize - dmabuf->hwptr;
  625. delta += pos;
  626. } else {
  627. delta = pos - dmabuf->hwptr;
  628. }
  629. dmabuf->hwptr = pos;
  630. cnt = dmabuf->count;
  631. cnt += delta;
  632. if (cnt + redzone > dmabuf->dmasize) {
  633. /* Overflow - bump swptr */
  634. dmabuf->count = dmabuf->dmasize - redzone;
  635. dmabuf->swptr = dmabuf->hwptr + redzone;
  636. if (dmabuf->swptr >= dmabuf->dmasize) {
  637. dmabuf->swptr -= dmabuf->dmasize;
  638. }
  639. } else {
  640. dmabuf->count = cnt;
  641. }
  642. dmabuf->total_bytes += delta;
  643. if (dmabuf->count) { /* && is_sleeping  XXX */
  644. wake_up(&dmabuf->wait);
  645. }
  646. }
  647. spin_unlock(&unit->reg_lock);
  648. }
  649. static int ymf_playback_trigger(ymfpci_t *codec, struct ymf_pcm *ypcm, int cmd)
  650. {
  651. if (ypcm->voices[0] == NULL) {
  652. return -EINVAL;
  653. }
  654. if (cmd != 0) {
  655. codec->ctrl_playback[ypcm->voices[0]->number + 1] = virt_to_bus(ypcm->voices[0]->bank);
  656. if (ypcm->voices[1] != NULL)
  657. codec->ctrl_playback[ypcm->voices[1]->number + 1] = virt_to_bus(ypcm->voices[1]->bank);
  658. ypcm->running = 1;
  659. } else {
  660. codec->ctrl_playback[ypcm->voices[0]->number + 1] = 0;
  661. if (ypcm->voices[1] != NULL)
  662. codec->ctrl_playback[ypcm->voices[1]->number + 1] = 0;
  663. ypcm->running = 0;
  664. }
  665. return 0;
  666. }
  667. static void ymf_capture_trigger(ymfpci_t *codec, struct ymf_pcm *ypcm, int cmd)
  668. {
  669. u32 tmp;
  670. if (cmd != 0) {
  671. tmp = ymfpci_readl(codec, YDSXGR_MAPOFREC) | (1 << ypcm->capture_bank_number);
  672. ymfpci_writel(codec, YDSXGR_MAPOFREC, tmp);
  673. ypcm->running = 1;
  674. } else {
  675. tmp = ymfpci_readl(codec, YDSXGR_MAPOFREC) & ~(1 << ypcm->capture_bank_number);
  676. ymfpci_writel(codec, YDSXGR_MAPOFREC, tmp);
  677. ypcm->running = 0;
  678. }
  679. }
  680. static int ymfpci_pcm_voice_alloc(struct ymf_pcm *ypcm, int voices)
  681. {
  682. struct ymf_unit *unit;
  683. int err;
  684. unit = ypcm->state->unit;
  685. if (ypcm->voices[1] != NULL && voices < 2) {
  686. ymfpci_voice_free(unit, ypcm->voices[1]);
  687. ypcm->voices[1] = NULL;
  688. }
  689. if (voices == 1 && ypcm->voices[0] != NULL)
  690. return 0; /* already allocated */
  691. if (voices == 2 && ypcm->voices[0] != NULL && ypcm->voices[1] != NULL)
  692. return 0; /* already allocated */
  693. if (voices > 1) {
  694. if (ypcm->voices[0] != NULL && ypcm->voices[1] == NULL) {
  695. ymfpci_voice_free(unit, ypcm->voices[0]);
  696. ypcm->voices[0] = NULL;
  697. }
  698. if ((err = voice_alloc(unit, YMFPCI_PCM, 1, ypcm->voices)) < 0)
  699. return err;
  700. ypcm->voices[0]->ypcm = ypcm;
  701. ypcm->voices[1]->ypcm = ypcm;
  702. } else {
  703. if ((err = voice_alloc(unit, YMFPCI_PCM, 0, ypcm->voices)) < 0)
  704. return err;
  705. ypcm->voices[0]->ypcm = ypcm;
  706. }
  707. return 0;
  708. }
  709. static void ymf_pcm_init_voice(ymfpci_voice_t *voice, int stereo,
  710.     int rate, int w_16, unsigned long addr, unsigned int end, int spdif)
  711. {
  712. u32 format;
  713. u32 delta = ymfpci_calc_delta(rate);
  714. u32 lpfQ = ymfpci_calc_lpfQ(rate);
  715. u32 lpfK = ymfpci_calc_lpfK(rate);
  716. ymfpci_playback_bank_t *bank;
  717. int nbank;
  718. format = (stereo ? 0x00010000 : 0) | (w_16 ? 0 : 0x80000000);
  719. if (stereo)
  720. end >>= 1;
  721. if (w_16)
  722. end >>= 1;
  723. for (nbank = 0; nbank < 2; nbank++) {
  724. bank = &voice->bank[nbank];
  725. bank->format = format;
  726. bank->loop_default = 0; /* 0-loops forever, otherwise count */
  727. bank->base = addr;
  728. bank->loop_start = 0;
  729. bank->loop_end = end;
  730. bank->loop_frac = 0;
  731. bank->eg_gain_end = 0x40000000;
  732. bank->lpfQ = lpfQ;
  733. bank->status = 0;
  734. bank->num_of_frames = 0;
  735. bank->loop_count = 0;
  736. bank->start = 0;
  737. bank->start_frac = 0;
  738. bank->delta =
  739. bank->delta_end = delta;
  740. bank->lpfK =
  741. bank->lpfK_end = lpfK;
  742. bank->eg_gain = 0x40000000;
  743. bank->lpfD1 =
  744. bank->lpfD2 = 0;
  745. bank->left_gain = 
  746. bank->right_gain =
  747. bank->left_gain_end =
  748. bank->right_gain_end =
  749. bank->eff1_gain =
  750. bank->eff2_gain =
  751. bank->eff3_gain =
  752. bank->eff1_gain_end =
  753. bank->eff2_gain_end =
  754. bank->eff3_gain_end = 0;
  755. if (!stereo) {
  756. if (!spdif) {
  757. bank->left_gain = 
  758. bank->right_gain =
  759. bank->left_gain_end =
  760. bank->right_gain_end = 0x40000000;
  761. } else {
  762. bank->eff2_gain =
  763. bank->eff2_gain_end =
  764. bank->eff3_gain =
  765. bank->eff3_gain_end = 0x40000000;
  766. }
  767. } else {
  768. if (!spdif) {
  769. if ((voice->number & 1) == 0) {
  770. bank->left_gain =
  771. bank->left_gain_end = 0x40000000;
  772. } else {
  773. bank->format |= 1;
  774. bank->right_gain =
  775. bank->right_gain_end = 0x40000000;
  776. }
  777. } else {
  778. if ((voice->number & 1) == 0) {
  779. bank->eff2_gain =
  780. bank->eff2_gain_end = 0x40000000;
  781. } else {
  782. bank->format |= 1;
  783. bank->eff3_gain =
  784. bank->eff3_gain_end = 0x40000000;
  785. }
  786. }
  787. }
  788. }
  789. }
  790. /*
  791.  * XXX Capture channel allocation is entirely fake at the moment.
  792.  * We use only one channel and mark it busy as required.
  793.  */
  794. static int ymf_capture_alloc(struct ymf_unit *unit, int *pbank)
  795. {
  796. struct ymf_capture *cap;
  797. int cbank;
  798. cbank = 1; /* Only ADC slot is used for now. */
  799. cap = &unit->capture[cbank];
  800. if (cap->use)
  801. return -EBUSY;
  802. cap->use = 1;
  803. *pbank = cbank;
  804. return 0;
  805. }
  806. static int ymf_playback_prepare(struct ymf_state *state)
  807. {
  808. struct ymf_pcm *ypcm = &state->wpcm;
  809. int err, nvoice;
  810. if ((err = ymfpci_pcm_voice_alloc(ypcm, state->format.voices)) < 0) {
  811. /* Somebody started 32 mpg123's in parallel? */
  812. printk(KERN_INFO "ymfpci%d: cannot allocate voicen",
  813.     state->unit->dev_audio);
  814. return err;
  815. }
  816. for (nvoice = 0; nvoice < state->format.voices; nvoice++) {
  817. ymf_pcm_init_voice(ypcm->voices[nvoice],
  818.     state->format.voices == 2, state->format.rate,
  819.     ymf_pcm_format_width(state->format.format) == 16,
  820.     virt_to_bus(ypcm->dmabuf.rawbuf), ypcm->dmabuf.dmasize,
  821.     ypcm->spdif);
  822. }
  823. return 0;
  824. }
  825. static int ymf_capture_prepare(struct ymf_state *state)
  826. {
  827. ymfpci_t *unit = state->unit;
  828. struct ymf_pcm *ypcm = &state->rpcm;
  829. ymfpci_capture_bank_t * bank;
  830. /* XXX This is confusing, gotta rename one of them banks... */
  831. int nbank; /* flip-flop bank */
  832. int cbank; /* input [super-]bank */
  833. struct ymf_capture *cap;
  834. u32 rate, format;
  835. if (ypcm->capture_bank_number == -1) {
  836. if (ymf_capture_alloc(unit, &cbank) != 0)
  837. return -EBUSY;
  838. ypcm->capture_bank_number = cbank;
  839. cap = &unit->capture[cbank];
  840. cap->bank = unit->bank_capture[cbank][0];
  841. cap->ypcm = ypcm;
  842. ymfpci_hw_start(unit);
  843. }
  844. // ypcm->frag_size = snd_pcm_lib_transfer_fragment(substream);
  845. // frag_size is replaced with nonfragged byte-aligned rolling buffer
  846. rate = ((48000 * 4096) / state->format.rate) - 1;
  847. format = 0;
  848. if (state->format.voices == 2)
  849. format |= 2;
  850. if (ymf_pcm_format_width(state->format.format) == 8)
  851. format |= 1;
  852. switch (ypcm->capture_bank_number) {
  853. case 0:
  854. ymfpci_writel(unit, YDSXGR_RECFORMAT, format);
  855. ymfpci_writel(unit, YDSXGR_RECSLOTSR, rate);
  856. break;
  857. case 1:
  858. ymfpci_writel(unit, YDSXGR_ADCFORMAT, format);
  859. ymfpci_writel(unit, YDSXGR_ADCSLOTSR, rate);
  860. break;
  861. }
  862. for (nbank = 0; nbank < 2; nbank++) {
  863. bank = unit->bank_capture[ypcm->capture_bank_number][nbank];
  864. bank->base = virt_to_bus(ypcm->dmabuf.rawbuf);
  865. // bank->loop_end = ypcm->dmabuf.dmasize >> state->format.shift;
  866. bank->loop_end = ypcm->dmabuf.dmasize;
  867. bank->start = 0;
  868. bank->num_of_loops = 0;
  869. }
  870. #if 0 /* s/pdif */
  871. if (state->digital.dig_valid)
  872. /*state->digital.type == SND_PCM_DIG_AES_IEC958*/
  873. ymfpci_writew(codec, YDSXGR_SPDIFOUTSTATUS,
  874.     state->digital.dig_status[0] | (state->digital.dig_status[1] << 8));
  875. #endif
  876. return 0;
  877. }
  878. void ymf_interrupt(int irq, void *dev_id, struct pt_regs *regs)
  879. {
  880. ymfpci_t *codec = dev_id;
  881. u32 status, nvoice, mode;
  882. struct ymf_voice *voice;
  883. struct ymf_capture *cap;
  884. status = ymfpci_readl(codec, YDSXGR_STATUS);
  885. if (status & 0x80000000) {
  886. codec->active_bank = ymfpci_readl(codec, YDSXGR_CTRLSELECT) & 1;
  887. spin_lock(&codec->voice_lock);
  888. for (nvoice = 0; nvoice < YDSXG_PLAYBACK_VOICES; nvoice++) {
  889. voice = &codec->voices[nvoice];
  890. if (voice->use)
  891. ymf_pcm_interrupt(codec, voice);
  892. }
  893. for (nvoice = 0; nvoice < YDSXG_CAPTURE_VOICES; nvoice++) {
  894. cap = &codec->capture[nvoice];
  895. if (cap->use)
  896. ymf_cap_interrupt(codec, cap);
  897. }
  898. spin_unlock(&codec->voice_lock);
  899. spin_lock(&codec->reg_lock);
  900. ymfpci_writel(codec, YDSXGR_STATUS, 0x80000000);
  901. mode = ymfpci_readl(codec, YDSXGR_MODE) | 2;
  902. ymfpci_writel(codec, YDSXGR_MODE, mode);
  903. spin_unlock(&codec->reg_lock);
  904. }
  905. status = ymfpci_readl(codec, YDSXGR_INTFLAG);
  906. if (status & 1) {
  907. /* timer handler */
  908. ymfpci_writel(codec, YDSXGR_INTFLAG, ~0);
  909. }
  910. }
  911. static void ymf_pcm_free_substream(struct ymf_pcm *ypcm)
  912. {
  913. unsigned long flags;
  914. struct ymf_unit *unit;
  915. unit = ypcm->state->unit;
  916. if (ypcm->type == PLAYBACK_VOICE) {
  917. spin_lock_irqsave(&unit->voice_lock, flags);
  918. if (ypcm->voices[1])
  919. ymfpci_voice_free(unit, ypcm->voices[1]);
  920. if (ypcm->voices[0])
  921. ymfpci_voice_free(unit, ypcm->voices[0]);
  922. spin_unlock_irqrestore(&unit->voice_lock, flags);
  923. } else {
  924. if (ypcm->capture_bank_number != -1) {
  925. unit->capture[ypcm->capture_bank_number].use = 0;
  926. ypcm->capture_bank_number = -1;
  927. ymfpci_hw_stop(unit);
  928. }
  929. }
  930. }
  931. static struct ymf_state *ymf_state_alloc(ymfpci_t *unit)
  932. {
  933. struct ymf_pcm *ypcm;
  934. struct ymf_state *state;
  935. if ((state = kmalloc(sizeof(struct ymf_state), GFP_KERNEL)) == NULL) {
  936. goto out0;
  937. }
  938. memset(state, 0, sizeof(struct ymf_state));
  939. ypcm = &state->wpcm;
  940. ypcm->state = state;
  941. ypcm->type = PLAYBACK_VOICE;
  942. ypcm->capture_bank_number = -1;
  943. init_waitqueue_head(&ypcm->dmabuf.wait);
  944. ypcm = &state->rpcm;
  945. ypcm->state = state;
  946. ypcm->type = CAPTURE_AC97;
  947. ypcm->capture_bank_number = -1;
  948. init_waitqueue_head(&ypcm->dmabuf.wait);
  949. state->unit = unit;
  950. state->format.format = AFMT_U8;
  951. state->format.rate = 8000;
  952. state->format.voices = 1;
  953. ymf_pcm_update_shift(&state->format);
  954. return state;
  955. out0:
  956. return NULL;
  957. }
  958. /* AES/IEC958 channel status bits */
  959. #define SND_PCM_AES0_PROFESSIONAL (1<<0) /* 0 = consumer, 1 = professional */
  960. #define SND_PCM_AES0_NONAUDIO (1<<1) /* 0 = audio, 1 = non-audio */
  961. #define SND_PCM_AES0_PRO_EMPHASIS (7<<2) /* mask - emphasis */
  962. #define SND_PCM_AES0_PRO_EMPHASIS_NOTID (0<<2) /* emphasis not indicated */
  963. #define SND_PCM_AES0_PRO_EMPHASIS_NONE (1<<2) /* none emphasis */
  964. #define SND_PCM_AES0_PRO_EMPHASIS_5015 (3<<2) /* 50/15us emphasis */
  965. #define SND_PCM_AES0_PRO_EMPHASIS_CCITT (7<<2) /* CCITT J.17 emphasis */
  966. #define SND_PCM_AES0_PRO_FREQ_UNLOCKED (1<<5) /* source sample frequency: 0 = locked, 1 = unlocked */
  967. #define SND_PCM_AES0_PRO_FS (3<<6) /* mask - sample frequency */
  968. #define SND_PCM_AES0_PRO_FS_NOTID (0<<6) /* fs not indicated */
  969. #define SND_PCM_AES0_PRO_FS_44100 (1<<6) /* 44.1kHz */
  970. #define SND_PCM_AES0_PRO_FS_48000 (2<<6) /* 48kHz */
  971. #define SND_PCM_AES0_PRO_FS_32000 (3<<6) /* 32kHz */
  972. #define SND_PCM_AES0_CON_NOT_COPYRIGHT (1<<2) /* 0 = copyright, 1 = not copyright */
  973. #define SND_PCM_AES0_CON_EMPHASIS (7<<3) /* mask - emphasis */
  974. #define SND_PCM_AES0_CON_EMPHASIS_NONE (0<<3) /* none emphasis */
  975. #define SND_PCM_AES0_CON_EMPHASIS_5015 (1<<3) /* 50/15us emphasis */
  976. #define SND_PCM_AES0_CON_MODE (3<<6) /* mask - mode */
  977. #define SND_PCM_AES1_PRO_MODE (15<<0) /* mask - channel mode */
  978. #define SND_PCM_AES1_PRO_MODE_NOTID (0<<0) /* not indicated */
  979. #define SND_PCM_AES1_PRO_MODE_STEREOPHONIC (2<<0) /* stereophonic - ch A is left */
  980. #define SND_PCM_AES1_PRO_MODE_SINGLE (4<<0) /* single channel */
  981. #define SND_PCM_AES1_PRO_MODE_TWO (8<<0) /* two channels */
  982. #define SND_PCM_AES1_PRO_MODE_PRIMARY (12<<0) /* primary/secondary */
  983. #define SND_PCM_AES1_PRO_MODE_BYTE3 (15<<0) /* vector to byte 3 */
  984. #define SND_PCM_AES1_PRO_USERBITS (15<<4) /* mask - user bits */
  985. #define SND_PCM_AES1_PRO_USERBITS_NOTID (0<<4) /* not indicated */
  986. #define SND_PCM_AES1_PRO_USERBITS_192 (8<<4) /* 192-bit structure */
  987. #define SND_PCM_AES1_PRO_USERBITS_UDEF (12<<4) /* user defined application */
  988. #define SND_PCM_AES1_CON_CATEGORY 0x7f
  989. #define SND_PCM_AES1_CON_GENERAL 0x00
  990. #define SND_PCM_AES1_CON_EXPERIMENTAL 0x40
  991. #define SND_PCM_AES1_CON_SOLIDMEM_MASK 0x0f
  992. #define SND_PCM_AES1_CON_SOLIDMEM_ID 0x08
  993. #define SND_PCM_AES1_CON_BROADCAST1_MASK 0x07
  994. #define SND_PCM_AES1_CON_BROADCAST1_ID 0x04
  995. #define SND_PCM_AES1_CON_DIGDIGCONV_MASK 0x07
  996. #define SND_PCM_AES1_CON_DIGDIGCONV_ID 0x02
  997. #define SND_PCM_AES1_CON_ADC_COPYRIGHT_MASK 0x1f
  998. #define SND_PCM_AES1_CON_ADC_COPYRIGHT_ID 0x06
  999. #define SND_PCM_AES1_CON_ADC_MASK 0x1f
  1000. #define SND_PCM_AES1_CON_ADC_ID 0x16
  1001. #define SND_PCM_AES1_CON_BROADCAST2_MASK 0x0f
  1002. #define SND_PCM_AES1_CON_BROADCAST2_ID 0x0e
  1003. #define SND_PCM_AES1_CON_LASEROPT_MASK 0x07
  1004. #define SND_PCM_AES1_CON_LASEROPT_ID 0x01
  1005. #define SND_PCM_AES1_CON_MUSICAL_MASK 0x07
  1006. #define SND_PCM_AES1_CON_MUSICAL_ID 0x05
  1007. #define SND_PCM_AES1_CON_MAGNETIC_MASK 0x07
  1008. #define SND_PCM_AES1_CON_MAGNETIC_ID 0x03
  1009. #define SND_PCM_AES1_CON_IEC908_CD (SND_PCM_AES1_CON_LASEROPT_ID|0x00)
  1010. #define SND_PCM_AES1_CON_NON_IEC908_CD (SND_PCM_AES1_CON_LASEROPT_ID|0x08)
  1011. #define SND_PCM_AES1_CON_PCM_CODER (SND_PCM_AES1_CON_DIGDIGCONV_ID|0x00)
  1012. #define SND_PCM_AES1_CON_SAMPLER (SND_PCM_AES1_CON_DIGDIGCONV_ID|0x20)
  1013. #define SND_PCM_AES1_CON_MIXER (SND_PCM_AES1_CON_DIGDIGCONV_ID|0x10)
  1014. #define SND_PCM_AES1_CON_RATE_CONVERTER (SND_PCM_AES1_CON_DIGDIGCONV_ID|0x18)
  1015. #define SND_PCM_AES1_CON_SYNTHESIZER (SND_PCM_AES1_CON_MUSICAL_ID|0x00)
  1016. #define SND_PCM_AES1_CON_MICROPHONE (SND_PCM_AES1_CON_MUSICAL_ID|0x08)
  1017. #define SND_PCM_AES1_CON_DAT (SND_PCM_AES1_CON_MAGNETIC_ID|0x00)
  1018. #define SND_PCM_AES1_CON_VCR (SND_PCM_AES1_CON_MAGNETIC_ID|0x08)
  1019. #define SND_PCM_AES1_CON_ORIGINAL (1<<7) /* this bits depends on the category code */
  1020. #define SND_PCM_AES2_PRO_SBITS (7<<0) /* mask - sample bits */
  1021. #define SND_PCM_AES2_PRO_SBITS_20 (2<<0) /* 20-bit - coordination */
  1022. #define SND_PCM_AES2_PRO_SBITS_24 (4<<0) /* 24-bit - main audio */
  1023. #define SND_PCM_AES2_PRO_SBITS_UDEF (6<<0) /* user defined application */
  1024. #define SND_PCM_AES2_PRO_WORDLEN (7<<3) /* mask - source word length */
  1025. #define SND_PCM_AES2_PRO_WORDLEN_NOTID (0<<3) /* not indicated */
  1026. #define SND_PCM_AES2_PRO_WORDLEN_22_18 (2<<3) /* 22-bit or 18-bit */
  1027. #define SND_PCM_AES2_PRO_WORDLEN_23_19 (4<<3) /* 23-bit or 19-bit */
  1028. #define SND_PCM_AES2_PRO_WORDLEN_24_20 (5<<3) /* 24-bit or 20-bit */
  1029. #define SND_PCM_AES2_PRO_WORDLEN_20_16 (6<<3) /* 20-bit or 16-bit */
  1030. #define SND_PCM_AES2_CON_SOURCE (15<<0) /* mask - source number */
  1031. #define SND_PCM_AES2_CON_SOURCE_UNSPEC (0<<0) /* unspecified */
  1032. #define SND_PCM_AES2_CON_CHANNEL (15<<4) /* mask - channel number */
  1033. #define SND_PCM_AES2_CON_CHANNEL_UNSPEC (0<<4) /* unspecified */
  1034. #define SND_PCM_AES3_CON_FS (15<<0) /* mask - sample frequency */
  1035. #define SND_PCM_AES3_CON_FS_44100 (0<<0) /* 44.1kHz */
  1036. #define SND_PCM_AES3_CON_FS_48000 (2<<0) /* 48kHz */
  1037. #define SND_PCM_AES3_CON_FS_32000 (3<<0) /* 32kHz */
  1038. #define SND_PCM_AES3_CON_CLOCK (3<<4) /* mask - clock accuracy */
  1039. #define SND_PCM_AES3_CON_CLOCK_1000PPM (0<<4) /* 1000 ppm */
  1040. #define SND_PCM_AES3_CON_CLOCK_50PPM (1<<4) /* 50 ppm */
  1041. #define SND_PCM_AES3_CON_CLOCK_VARIABLE (2<<4) /* variable pitch */
  1042. /*
  1043.  * User interface
  1044.  */
  1045. /*
  1046.  * in this loop, dmabuf.count signifies the amount of data that is
  1047.  * waiting to be copied to the user's buffer.  it is filled by the dma
  1048.  * machine and drained by this loop.
  1049.  */
  1050. static ssize_t
  1051. ymf_read(struct file *file, char *buffer, size_t count, loff_t *ppos)
  1052. {
  1053. struct ymf_state *state = (struct ymf_state *)file->private_data;
  1054. struct ymf_dmabuf *dmabuf = &state->rpcm.dmabuf;
  1055. struct ymf_unit *unit = state->unit;
  1056. DECLARE_WAITQUEUE(waita, current);
  1057. ssize_t ret;
  1058. unsigned long flags;
  1059. unsigned int swptr;
  1060. int cnt; /* This many to go in this revolution */
  1061. if (ppos != &file->f_pos)
  1062. return -ESPIPE;
  1063. if (dmabuf->mapped)
  1064. return -ENXIO;
  1065. if (!dmabuf->ready && (ret = prog_dmabuf(state, 1)))
  1066. return ret;
  1067. ret = 0;
  1068. add_wait_queue(&dmabuf->wait, &waita);
  1069. set_current_state(TASK_INTERRUPTIBLE);
  1070. while (count > 0) {
  1071. spin_lock_irqsave(&unit->reg_lock, flags);
  1072. if (unit->suspended) {
  1073. spin_unlock_irqrestore(&unit->reg_lock, flags);
  1074. schedule();
  1075. set_current_state(TASK_INTERRUPTIBLE);
  1076. if (signal_pending(current)) {
  1077. if (!ret) ret = -EAGAIN;
  1078. break;
  1079. }
  1080. continue;
  1081. }
  1082. swptr = dmabuf->swptr;
  1083. cnt = dmabuf->dmasize - swptr;
  1084. if (dmabuf->count < cnt)
  1085. cnt = dmabuf->count;
  1086. spin_unlock_irqrestore(&unit->reg_lock, flags);
  1087. if (cnt > count)
  1088. cnt = count;
  1089. if (cnt <= 0) {
  1090. unsigned long tmo;
  1091. /* buffer is empty, start the dma machine and wait for data to be
  1092.    recorded */
  1093. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1094. if (!state->rpcm.running) {
  1095. ymf_capture_trigger(state->unit, &state->rpcm, 1);
  1096. }
  1097. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1098. if (file->f_flags & O_NONBLOCK) {
  1099. if (!ret) ret = -EAGAIN;
  1100. break;
  1101. }
  1102. /* This isnt strictly right for the 810  but it'll do */
  1103. tmo = (dmabuf->dmasize * HZ) / (state->format.rate * 2);
  1104. tmo >>= state->format.shift;
  1105. /* There are two situations when sleep_on_timeout returns, one is when
  1106.    the interrupt is serviced correctly and the process is waked up by
  1107.    ISR ON TIME. Another is when timeout is expired, which means that
  1108.    either interrupt is NOT serviced correctly (pending interrupt) or it
  1109.    is TOO LATE for the process to be scheduled to run (scheduler latency)
  1110.    which results in a (potential) buffer overrun. And worse, there is
  1111.    NOTHING we can do to prevent it. */
  1112. tmo = schedule_timeout(tmo);
  1113. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1114. set_current_state(TASK_INTERRUPTIBLE);
  1115. if (tmo == 0 && dmabuf->count == 0) {
  1116. printk(KERN_ERR "ymfpci%d: recording schedule timeout, "
  1117.     "dmasz %u fragsz %u count %i hwptr %u swptr %un",
  1118.     state->unit->dev_audio,
  1119.     dmabuf->dmasize, dmabuf->fragsize, dmabuf->count,
  1120.     dmabuf->hwptr, dmabuf->swptr);
  1121. }
  1122. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1123. if (signal_pending(current)) {
  1124. if (!ret) ret = -ERESTARTSYS;
  1125. break;
  1126. }
  1127. continue;
  1128. }
  1129. if (copy_to_user(buffer, dmabuf->rawbuf + swptr, cnt)) {
  1130. if (!ret) ret = -EFAULT;
  1131. break;
  1132. }
  1133. swptr = (swptr + cnt) % dmabuf->dmasize;
  1134. spin_lock_irqsave(&unit->reg_lock, flags);
  1135. if (unit->suspended) {
  1136. spin_unlock_irqrestore(&unit->reg_lock, flags);
  1137. continue;
  1138. }
  1139. dmabuf->swptr = swptr;
  1140. dmabuf->count -= cnt;
  1141. // spin_unlock_irqrestore(&unit->reg_lock, flags);
  1142. count -= cnt;
  1143. buffer += cnt;
  1144. ret += cnt;
  1145. // spin_lock_irqsave(&unit->reg_lock, flags);
  1146. if (!state->rpcm.running) {
  1147. ymf_capture_trigger(unit, &state->rpcm, 1);
  1148. }
  1149. spin_unlock_irqrestore(&unit->reg_lock, flags);
  1150. }
  1151. set_current_state(TASK_RUNNING);
  1152. remove_wait_queue(&dmabuf->wait, &waita);
  1153. return ret;
  1154. }
  1155. static ssize_t
  1156. ymf_write(struct file *file, const char *buffer, size_t count, loff_t *ppos)
  1157. {
  1158. struct ymf_state *state = (struct ymf_state *)file->private_data;
  1159. struct ymf_dmabuf *dmabuf = &state->wpcm.dmabuf;
  1160. struct ymf_unit *unit = state->unit;
  1161. DECLARE_WAITQUEUE(waita, current);
  1162. ssize_t ret;
  1163. unsigned long flags;
  1164. unsigned int swptr;
  1165. int cnt; /* This many to go in this revolution */
  1166. int redzone;
  1167. int delay;
  1168. YMFDBGW("ymf_write: count %dn", count);
  1169. if (ppos != &file->f_pos)
  1170. return -ESPIPE;
  1171. if (dmabuf->mapped)
  1172. return -ENXIO;
  1173. if (!dmabuf->ready && (ret = prog_dmabuf(state, 0)))
  1174. return ret;
  1175. ret = 0;
  1176. /*
  1177.  * Alan's cs46xx works without a red zone - marvel of ingenuity.
  1178.  * We are not so brilliant... Red zone does two things:
  1179.  *  1. allows for safe start after a pause as we have no way
  1180.  *     to know what the actual, relentlessly advancing, hwptr is.
  1181.  *  2. makes computations in ymf_pcm_interrupt simpler.
  1182.  */
  1183. redzone = ymf_calc_lend(state->format.rate) << state->format.shift;
  1184. redzone *= 3; /* 2 redzone + 1 possible uncertainty reserve. */
  1185. add_wait_queue(&dmabuf->wait, &waita);
  1186. set_current_state(TASK_INTERRUPTIBLE);
  1187. while (count > 0) {
  1188. spin_lock_irqsave(&unit->reg_lock, flags);
  1189. if (unit->suspended) {
  1190. spin_unlock_irqrestore(&unit->reg_lock, flags);
  1191. schedule();
  1192. set_current_state(TASK_INTERRUPTIBLE);
  1193. if (signal_pending(current)) {
  1194. if (!ret) ret = -EAGAIN;
  1195. break;
  1196. }
  1197. continue;
  1198. }
  1199. if (dmabuf->count < 0) {
  1200. printk(KERN_ERR
  1201.    "ymf_write: count %d, was legal in cs46xxn",
  1202.     dmabuf->count);
  1203. dmabuf->count = 0;
  1204. }
  1205. if (dmabuf->count == 0) {
  1206. swptr = dmabuf->hwptr;
  1207. if (state->wpcm.running) {
  1208. /*
  1209.  * Add uncertainty reserve.
  1210.  */
  1211. cnt = ymf_calc_lend(state->format.rate);
  1212. cnt <<= state->format.shift;
  1213. if ((swptr += cnt) >= dmabuf->dmasize) {
  1214. swptr -= dmabuf->dmasize;
  1215. }
  1216. }
  1217. dmabuf->swptr = swptr;
  1218. } else {
  1219. /*
  1220.  * XXX This is not right if dmabuf->count is small -
  1221.  * about 2*x frame size or less. We cannot count on
  1222.  * on appending and not causing an artefact.
  1223.  * Should use a variation of the count==0 case above.
  1224.  */
  1225. swptr = dmabuf->swptr;
  1226. }
  1227. cnt = dmabuf->dmasize - swptr;
  1228. if (dmabuf->count + cnt > dmabuf->dmasize - redzone)
  1229. cnt = (dmabuf->dmasize - redzone) - dmabuf->count;
  1230. spin_unlock_irqrestore(&unit->reg_lock, flags);
  1231. if (cnt > count)
  1232. cnt = count;
  1233. if (cnt <= 0) {
  1234. YMFDBGW("ymf_write: full, count %d swptr %dn",
  1235.    dmabuf->count, dmabuf->swptr);
  1236. /*
  1237.  * buffer is full, start the dma machine and
  1238.  * wait for data to be played
  1239.  */
  1240. spin_lock_irqsave(&unit->reg_lock, flags);
  1241. if (!state->wpcm.running) {
  1242. ymf_playback_trigger(unit, &state->wpcm, 1);
  1243. }
  1244. spin_unlock_irqrestore(&unit->reg_lock, flags);
  1245. if (file->f_flags & O_NONBLOCK) {
  1246. if (!ret) ret = -EAGAIN;
  1247. break;
  1248. }
  1249. schedule();
  1250. set_current_state(TASK_INTERRUPTIBLE);
  1251. if (signal_pending(current)) {
  1252. if (!ret) ret = -ERESTARTSYS;
  1253. break;
  1254. }
  1255. continue;
  1256. }
  1257. if (copy_from_user(dmabuf->rawbuf + swptr, buffer, cnt)) {
  1258. if (!ret) ret = -EFAULT;
  1259. break;
  1260. }
  1261. if ((swptr += cnt) >= dmabuf->dmasize) {
  1262. swptr -= dmabuf->dmasize;
  1263. }
  1264. spin_lock_irqsave(&unit->reg_lock, flags);
  1265. if (unit->suspended) {
  1266. spin_unlock_irqrestore(&unit->reg_lock, flags);
  1267. continue;
  1268. }
  1269. dmabuf->swptr = swptr;
  1270. dmabuf->count += cnt;
  1271. /*
  1272.  * Start here is a bad idea - may cause startup click
  1273.  * in /bin/play when dmabuf is not full yet.
  1274.  * However, some broken applications do not make
  1275.  * any use of SNDCTL_DSP_SYNC (Doom is the worst).
  1276.  * One frame is about 5.3ms, Doom write size is 46ms.
  1277.  */
  1278. delay = state->format.rate / 20; /* 50ms */
  1279. delay <<= state->format.shift;
  1280. if (dmabuf->count >= delay && !state->wpcm.running) {
  1281. ymf_playback_trigger(unit, &state->wpcm, 1);
  1282. }
  1283. spin_unlock_irqrestore(&unit->reg_lock, flags);
  1284. count -= cnt;
  1285. buffer += cnt;
  1286. ret += cnt;
  1287. }
  1288. set_current_state(TASK_RUNNING);
  1289. remove_wait_queue(&dmabuf->wait, &waita);
  1290. YMFDBGW("ymf_write: ret %d dmabuf.count %dn", ret, dmabuf->count);
  1291. return ret;
  1292. }
  1293. static unsigned int ymf_poll(struct file *file, struct poll_table_struct *wait)
  1294. {
  1295. struct ymf_state *state = (struct ymf_state *)file->private_data;
  1296. struct ymf_dmabuf *dmabuf;
  1297. int redzone;
  1298. unsigned long flags;
  1299. unsigned int mask = 0;
  1300. if (file->f_mode & FMODE_WRITE)
  1301. poll_wait(file, &state->wpcm.dmabuf.wait, wait);
  1302. if (file->f_mode & FMODE_READ)
  1303. poll_wait(file, &state->rpcm.dmabuf.wait, wait);
  1304. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1305. if (file->f_mode & FMODE_READ) {
  1306. dmabuf = &state->rpcm.dmabuf;
  1307. if (dmabuf->count >= (signed)dmabuf->fragsize)
  1308. mask |= POLLIN | POLLRDNORM;
  1309. }
  1310. if (file->f_mode & FMODE_WRITE) {
  1311. redzone = ymf_calc_lend(state->format.rate);
  1312. redzone <<= state->format.shift;
  1313. redzone *= 3;
  1314. dmabuf = &state->wpcm.dmabuf;
  1315. if (dmabuf->mapped) {
  1316. if (dmabuf->count >= (signed)dmabuf->fragsize)
  1317. mask |= POLLOUT | POLLWRNORM;
  1318. } else {
  1319. /*
  1320.  * Don't select unless a full fragment is available.
  1321.  * Otherwise artsd does GETOSPACE, sees 0, and loops.
  1322.  */
  1323. if (dmabuf->count + redzone + dmabuf->fragsize
  1324.      <= dmabuf->dmasize)
  1325. mask |= POLLOUT | POLLWRNORM;
  1326. }
  1327. }
  1328. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1329. return mask;
  1330. }
  1331. static int ymf_mmap(struct file *file, struct vm_area_struct *vma)
  1332. {
  1333. struct ymf_state *state = (struct ymf_state *)file->private_data;
  1334. struct ymf_dmabuf *dmabuf = &state->wpcm.dmabuf;
  1335. int ret;
  1336. unsigned long size;
  1337. if (vma->vm_flags & VM_WRITE) {
  1338. if ((ret = prog_dmabuf(state, 0)) != 0)
  1339. return ret;
  1340. } else if (vma->vm_flags & VM_READ) {
  1341. if ((ret = prog_dmabuf(state, 1)) != 0)
  1342. return ret;
  1343. } else 
  1344. return -EINVAL;
  1345. if (vma->vm_pgoff != 0)
  1346. return -EINVAL;
  1347. size = vma->vm_end - vma->vm_start;
  1348. if (size > (PAGE_SIZE << dmabuf->buforder))
  1349. return -EINVAL;
  1350. if (remap_page_range(vma->vm_start, virt_to_phys(dmabuf->rawbuf),
  1351.      size, vma->vm_page_prot))
  1352. return -EAGAIN;
  1353. dmabuf->mapped = 1;
  1354. /* P3 */ printk(KERN_INFO "ymfpci: using memory mapped sound, untested!n");
  1355. return 0;
  1356. }
  1357. static int ymf_ioctl(struct inode *inode, struct file *file,
  1358.     unsigned int cmd, unsigned long arg)
  1359. {
  1360. struct ymf_state *state = (struct ymf_state *)file->private_data;
  1361. struct ymf_dmabuf *dmabuf;
  1362. unsigned long flags;
  1363. audio_buf_info abinfo;
  1364. count_info cinfo;
  1365. int redzone;
  1366. int val;
  1367. switch (cmd) {
  1368. case OSS_GETVERSION:
  1369. YMFDBGX("ymf_ioctl: cmd 0x%x(GETVER) arg 0x%lxn", cmd, arg);
  1370. return put_user(SOUND_VERSION, (int *)arg);
  1371. case SNDCTL_DSP_RESET:
  1372. YMFDBGX("ymf_ioctl: cmd 0x%x(RESET)n", cmd);
  1373. if (file->f_mode & FMODE_WRITE) {
  1374. ymf_wait_dac(state);
  1375. dmabuf = &state->wpcm.dmabuf;
  1376. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1377. dmabuf->ready = 0;
  1378. dmabuf->swptr = dmabuf->hwptr;
  1379. dmabuf->count = dmabuf->total_bytes = 0;
  1380. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1381. }
  1382. if (file->f_mode & FMODE_READ) {
  1383. ymf_stop_adc(state);
  1384. dmabuf = &state->rpcm.dmabuf;
  1385. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1386. dmabuf->ready = 0;
  1387. dmabuf->swptr = dmabuf->hwptr;
  1388. dmabuf->count = dmabuf->total_bytes = 0;
  1389. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1390. }
  1391. return 0;
  1392. case SNDCTL_DSP_SYNC:
  1393. YMFDBGX("ymf_ioctl: cmd 0x%x(SYNC)n", cmd);
  1394. if (file->f_mode & FMODE_WRITE) {
  1395. dmabuf = &state->wpcm.dmabuf;
  1396. if (file->f_flags & O_NONBLOCK) {
  1397. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1398. if (dmabuf->count != 0 && !state->wpcm.running) {
  1399. ymf_start_dac(state);
  1400. }
  1401. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1402. } else {
  1403. ymf_wait_dac(state);
  1404. }
  1405. }
  1406. /* XXX What does this do for reading? dmabuf->count=0; ? */
  1407. return 0;
  1408. case SNDCTL_DSP_SPEED: /* set smaple rate */
  1409. if (get_user(val, (int *)arg))
  1410. return -EFAULT;
  1411. YMFDBGX("ymf_ioctl: cmd 0x%x(SPEED) sp %dn", cmd, val);
  1412. if (val >= 8000 && val <= 48000) {
  1413. if (file->f_mode & FMODE_WRITE) {
  1414. ymf_wait_dac(state);
  1415. dmabuf = &state->wpcm.dmabuf;
  1416. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1417. dmabuf->ready = 0;
  1418. state->format.rate = val;
  1419. ymf_pcm_update_shift(&state->format);
  1420. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1421. }
  1422. if (file->f_mode & FMODE_READ) {
  1423. ymf_stop_adc(state);
  1424. dmabuf = &state->rpcm.dmabuf;
  1425. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1426. dmabuf->ready = 0;
  1427. state->format.rate = val;
  1428. ymf_pcm_update_shift(&state->format);
  1429. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1430. }
  1431. }
  1432. return put_user(state->format.rate, (int *)arg);
  1433. /*
  1434.  * OSS manual does not mention SNDCTL_DSP_STEREO at all.
  1435.  * All channels are mono and if you want stereo, you
  1436.  * play into two channels with SNDCTL_DSP_CHANNELS.
  1437.  * However, mpg123 calls it. I wonder, why Michael Hipp used it.
  1438.  */
  1439. case SNDCTL_DSP_STEREO: /* set stereo or mono channel */
  1440. if (get_user(val, (int *)arg))
  1441. return -EFAULT;
  1442. YMFDBGX("ymf_ioctl: cmd 0x%x(STEREO) st %dn", cmd, val);
  1443. if (file->f_mode & FMODE_WRITE) {
  1444. ymf_wait_dac(state); 
  1445. dmabuf = &state->wpcm.dmabuf;
  1446. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1447. dmabuf->ready = 0;
  1448. state->format.voices = val ? 2 : 1;
  1449. ymf_pcm_update_shift(&state->format);
  1450. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1451. }
  1452. if (file->f_mode & FMODE_READ) {
  1453. ymf_stop_adc(state);
  1454. dmabuf = &state->rpcm.dmabuf;
  1455. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1456. dmabuf->ready = 0;
  1457. state->format.voices = val ? 2 : 1;
  1458. ymf_pcm_update_shift(&state->format);
  1459. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1460. }
  1461. return 0;
  1462. case SNDCTL_DSP_GETBLKSIZE:
  1463. YMFDBGX("ymf_ioctl: cmd 0x%x(GETBLK)n", cmd);
  1464. if (file->f_mode & FMODE_WRITE) {
  1465. if ((val = prog_dmabuf(state, 0)))
  1466. return val;
  1467. val = state->wpcm.dmabuf.fragsize;
  1468. YMFDBGX("ymf_ioctl: GETBLK w %dn", val);
  1469. return put_user(val, (int *)arg);
  1470. }
  1471. if (file->f_mode & FMODE_READ) {
  1472. if ((val = prog_dmabuf(state, 1)))
  1473. return val;
  1474. val = state->rpcm.dmabuf.fragsize;
  1475. YMFDBGX("ymf_ioctl: GETBLK r %dn", val);
  1476. return put_user(val, (int *)arg);
  1477. }
  1478. return -EINVAL;
  1479. case SNDCTL_DSP_GETFMTS: /* Returns a mask of supported sample format*/
  1480. YMFDBGX("ymf_ioctl: cmd 0x%x(GETFMTS)n", cmd);
  1481. return put_user(AFMT_S16_LE|AFMT_U8, (int *)arg);
  1482. case SNDCTL_DSP_SETFMT: /* Select sample format */
  1483. if (get_user(val, (int *)arg))
  1484. return -EFAULT;
  1485. YMFDBGX("ymf_ioctl: cmd 0x%x(SETFMT) fmt %dn", cmd, val);
  1486. if (val == AFMT_S16_LE || val == AFMT_U8) {
  1487. if (file->f_mode & FMODE_WRITE) {
  1488. ymf_wait_dac(state);
  1489. dmabuf = &state->wpcm.dmabuf;
  1490. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1491. dmabuf->ready = 0;
  1492. state->format.format = val;
  1493. ymf_pcm_update_shift(&state->format);
  1494. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1495. }
  1496. if (file->f_mode & FMODE_READ) {
  1497. ymf_stop_adc(state);
  1498. dmabuf = &state->rpcm.dmabuf;
  1499. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1500. dmabuf->ready = 0;
  1501. state->format.format = val;
  1502. ymf_pcm_update_shift(&state->format);
  1503. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1504. }
  1505. }
  1506. return put_user(state->format.format, (int *)arg);
  1507. case SNDCTL_DSP_CHANNELS:
  1508. if (get_user(val, (int *)arg))
  1509. return -EFAULT;
  1510. YMFDBGX("ymf_ioctl: cmd 0x%x(CHAN) ch %dn", cmd, val);
  1511. if (val != 0) {
  1512. if (file->f_mode & FMODE_WRITE) {
  1513. ymf_wait_dac(state);
  1514. if (val == 1 || val == 2) {
  1515. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1516. dmabuf = &state->wpcm.dmabuf;
  1517. dmabuf->ready = 0;
  1518. state->format.voices = val;
  1519. ymf_pcm_update_shift(&state->format);
  1520. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1521. }
  1522. }
  1523. if (file->f_mode & FMODE_READ) {
  1524. ymf_stop_adc(state);
  1525. if (val == 1 || val == 2) {
  1526. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1527. dmabuf = &state->rpcm.dmabuf;
  1528. dmabuf->ready = 0;
  1529. state->format.voices = val;
  1530. ymf_pcm_update_shift(&state->format);
  1531. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1532. }
  1533. }
  1534. }
  1535. return put_user(state->format.voices, (int *)arg);
  1536. case SNDCTL_DSP_POST:
  1537. YMFDBGX("ymf_ioctl: cmd 0x%x(POST)n", cmd);
  1538. /*
  1539.  * Quoting OSS PG:
  1540.  *    The ioctl SNDCTL_DSP_POST is a lightweight version of
  1541.  *    SNDCTL_DSP_SYNC. It just tells to the driver that there
  1542.  *    is likely to be a pause in the output. This makes it
  1543.  *    possible for the device to handle the pause more
  1544.  *    intelligently. This ioctl doesn't block the application.
  1545.  *
  1546.  * The paragraph above is a clumsy way to say "flush ioctl".
  1547.  * This ioctl is used by mpg123.
  1548.  */
  1549. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1550. if (state->wpcm.dmabuf.count != 0 && !state->wpcm.running) {
  1551. ymf_start_dac(state);
  1552. }
  1553. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1554. return 0;
  1555. case SNDCTL_DSP_SETFRAGMENT:
  1556. if (get_user(val, (int *)arg))
  1557. return -EFAULT;
  1558. YMFDBGX("ymf_ioctl: cmd 0x%x(SETFRAG) fr 0x%04x:%04x(%d:%d)n",
  1559.     cmd,
  1560.     (val >> 16) & 0xFFFF, val & 0xFFFF,
  1561.     (val >> 16) & 0xFFFF, val & 0xFFFF);
  1562. dmabuf = &state->wpcm.dmabuf;
  1563. dmabuf->ossfragshift = val & 0xffff;
  1564. dmabuf->ossmaxfrags = (val >> 16) & 0xffff;
  1565. if (dmabuf->ossfragshift < 4)
  1566. dmabuf->ossfragshift = 4;
  1567. if (dmabuf->ossfragshift > 15)
  1568. dmabuf->ossfragshift = 15;
  1569. return 0;
  1570. case SNDCTL_DSP_GETOSPACE:
  1571. YMFDBGX("ymf_ioctl: cmd 0x%x(GETOSPACE)n", cmd);
  1572. if (!(file->f_mode & FMODE_WRITE))
  1573. return -EINVAL;
  1574. dmabuf = &state->wpcm.dmabuf;
  1575. if (!dmabuf->ready && (val = prog_dmabuf(state, 0)) != 0)
  1576. return val;
  1577. redzone = ymf_calc_lend(state->format.rate);
  1578. redzone <<= state->format.shift;
  1579. redzone *= 3;
  1580. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1581. abinfo.fragsize = dmabuf->fragsize;
  1582. abinfo.bytes = dmabuf->dmasize - dmabuf->count - redzone;
  1583. abinfo.fragstotal = dmabuf->numfrag;
  1584. abinfo.fragments = abinfo.bytes >> dmabuf->fragshift;
  1585. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1586. return copy_to_user((void *)arg, &abinfo, sizeof(abinfo)) ? -EFAULT : 0;
  1587. case SNDCTL_DSP_GETISPACE:
  1588. YMFDBGX("ymf_ioctl: cmd 0x%x(GETISPACE)n", cmd);
  1589. if (!(file->f_mode & FMODE_READ))
  1590. return -EINVAL;
  1591. dmabuf = &state->rpcm.dmabuf;
  1592. if (!dmabuf->ready && (val = prog_dmabuf(state, 1)) != 0)
  1593. return val;
  1594. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1595. abinfo.fragsize = dmabuf->fragsize;
  1596. abinfo.bytes = dmabuf->count;
  1597. abinfo.fragstotal = dmabuf->numfrag;
  1598. abinfo.fragments = abinfo.bytes >> dmabuf->fragshift;
  1599. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1600. return copy_to_user((void *)arg, &abinfo, sizeof(abinfo)) ? -EFAULT : 0;
  1601. case SNDCTL_DSP_NONBLOCK:
  1602. YMFDBGX("ymf_ioctl: cmd 0x%x(NONBLOCK)n", cmd);
  1603. file->f_flags |= O_NONBLOCK;
  1604. return 0;
  1605. case SNDCTL_DSP_GETCAPS:
  1606. YMFDBGX("ymf_ioctl: cmd 0x%x(GETCAPS)n", cmd);
  1607. /* return put_user(DSP_CAP_REALTIME|DSP_CAP_TRIGGER|DSP_CAP_MMAP,
  1608.     (int *)arg); */
  1609. return put_user(0, (int *)arg);
  1610. case SNDCTL_DSP_GETIPTR:
  1611. YMFDBGX("ymf_ioctl: cmd 0x%x(GETIPTR)n", cmd);
  1612. if (!(file->f_mode & FMODE_READ))
  1613. return -EINVAL;
  1614. dmabuf = &state->rpcm.dmabuf;
  1615. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1616. cinfo.bytes = dmabuf->total_bytes;
  1617. cinfo.blocks = dmabuf->count >> dmabuf->fragshift;
  1618. cinfo.ptr = dmabuf->hwptr;
  1619. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1620. YMFDBGX("ymf_ioctl: GETIPTR ptr %d bytes %dn",
  1621.     cinfo.ptr, cinfo.bytes);
  1622. return copy_to_user((void *)arg, &cinfo, sizeof(cinfo)) ? -EFAULT : 0;
  1623. case SNDCTL_DSP_GETOPTR:
  1624. YMFDBGX("ymf_ioctl: cmd 0x%x(GETOPTR)n", cmd);
  1625. if (!(file->f_mode & FMODE_WRITE))
  1626. return -EINVAL;
  1627. dmabuf = &state->wpcm.dmabuf;
  1628. spin_lock_irqsave(&state->unit->reg_lock, flags);
  1629. cinfo.bytes = dmabuf->total_bytes;
  1630. cinfo.blocks = dmabuf->count >> dmabuf->fragshift;
  1631. cinfo.ptr = dmabuf->hwptr;
  1632. spin_unlock_irqrestore(&state->unit->reg_lock, flags);
  1633. YMFDBGX("ymf_ioctl: GETOPTR ptr %d bytes %dn",
  1634.     cinfo.ptr, cinfo.bytes);
  1635. return copy_to_user((void *)arg, &cinfo, sizeof(cinfo)) ? -EFAULT : 0;
  1636. case SNDCTL_DSP_SETDUPLEX: /* XXX TODO */
  1637. YMFDBGX("ymf_ioctl: cmd 0x%x(SETDUPLEX)n", cmd);
  1638. return -EINVAL;
  1639. case SOUND_PCM_READ_RATE:
  1640. YMFDBGX("ymf_ioctl: cmd 0x%x(READ_RATE)n", cmd);
  1641. return put_user(state->format.rate, (int *)arg);
  1642. case SOUND_PCM_READ_CHANNELS:
  1643. YMFDBGX("ymf_ioctl: cmd 0x%x(READ_CH)n", cmd);
  1644. return put_user(state->format.voices, (int *)arg);
  1645. case SOUND_PCM_READ_BITS:
  1646. YMFDBGX("ymf_ioctl: cmd 0x%x(READ_BITS)n", cmd);
  1647. return put_user(AFMT_S16_LE, (int *)arg);
  1648. case SNDCTL_DSP_MAPINBUF:
  1649. case SNDCTL_DSP_MAPOUTBUF:
  1650. case SNDCTL_DSP_SETSYNCRO:
  1651. case SOUND_PCM_WRITE_FILTER:
  1652. case SOUND_PCM_READ_FILTER:
  1653. YMFDBGX("ymf_ioctl: cmd 0x%x unsupportedn", cmd);
  1654. return -ENOTTY;
  1655. default:
  1656. /*
  1657.  * Some programs mix up audio devices and ioctls
  1658.  * or perhaps they expect "universal" ioctls,
  1659.  * for instance we get SNDCTL_TMR_CONTINUE here.
  1660.  */
  1661. YMFDBGX("ymf_ioctl: cmd 0x%x unknownn", cmd);
  1662. break;
  1663. }
  1664. return -ENOTTY;
  1665. }
  1666. /*
  1667.  * open(2)
  1668.  * We use upper part of the minor to distinguish between soundcards.
  1669.  * Channels are opened with a clone open.
  1670.  */
  1671. static int ymf_open(struct inode *inode, struct file *file)
  1672. {
  1673. struct list_head *list;
  1674. ymfpci_t *unit = NULL;
  1675. int minor;
  1676. struct ymf_state *state;
  1677. int err;
  1678. minor = MINOR(inode->i_rdev);
  1679. if ((minor & 0x0F) == 3) { /* /dev/dspN */
  1680. ;
  1681. } else {
  1682. return -ENXIO;
  1683. }
  1684. unit = NULL; /* gcc warns */
  1685. list_for_each(list, &ymf_devs) {
  1686. unit = list_entry(list, ymfpci_t, ymf_devs);
  1687. if (((unit->dev_audio ^ minor) & ~0x0F) == 0)
  1688. break;
  1689. }
  1690. if (list == &ymf_devs)
  1691. return -ENODEV;
  1692. down(&unit->open_sem);
  1693. if ((state = ymf_state_alloc(unit)) == NULL) {
  1694. up(&unit->open_sem);
  1695. return -ENOMEM;
  1696. }
  1697. list_add_tail(&state->chain, &unit->states);
  1698. file->private_data = state;
  1699. /*
  1700.  * ymf_read and ymf_write that we borrowed from cs46xx
  1701.  * allocate buffers with prog_dmabuf(). We call prog_dmabuf
  1702.  * here so that in case of DMA memory exhaustion open
  1703.  * fails rather than write.
  1704.  *
  1705.  * XXX prog_dmabuf allocates voice. Should allocate explicitly, above.
  1706.  */
  1707. if (file->f_mode & FMODE_WRITE) {
  1708. if (!state->wpcm.dmabuf.ready) {
  1709. if ((err = prog_dmabuf(state, 0)) != 0) {
  1710. goto out_nodma;
  1711. }
  1712. }
  1713. }
  1714. if (file->f_mode & FMODE_READ) {
  1715. if (!state->rpcm.dmabuf.ready) {
  1716. if ((err = prog_dmabuf(state, 1)) != 0) {
  1717. goto out_nodma;
  1718. }
  1719. }
  1720. }
  1721. #if 0 /* test if interrupts work */
  1722. ymfpci_writew(unit, YDSXGR_TIMERCOUNT, 0xfffe); /* ~ 680ms */
  1723. ymfpci_writeb(unit, YDSXGR_TIMERCTRL,
  1724.     (YDSXGR_TIMERCTRL_TEN|YDSXGR_TIMERCTRL_TIEN));
  1725. #endif
  1726. up(&unit->open_sem);
  1727. return 0;
  1728. out_nodma:
  1729. /*
  1730.  * XXX Broken custom: "goto out_xxx" in other place is
  1731.  * a nestable exception, but here it is not nestable due to semaphore.
  1732.  * XXX Doubtful technique of self-describing objects....
  1733.  */
  1734. dealloc_dmabuf(&state->wpcm.dmabuf);
  1735. dealloc_dmabuf(&state->rpcm.dmabuf);
  1736. ymf_pcm_free_substream(&state->wpcm);
  1737. ymf_pcm_free_substream(&state->rpcm);
  1738. list_del(&state->chain);
  1739. kfree(state);
  1740. up(&unit->open_sem);
  1741. return err;
  1742. }
  1743. static int ymf_release(struct inode *inode, struct file *file)
  1744. {
  1745. struct ymf_state *state = (struct ymf_state *)file->private_data;
  1746. ymfpci_t *unit = state->unit;
  1747. #if 0 /* test if interrupts work */
  1748. ymfpci_writeb(unit, YDSXGR_TIMERCTRL, 0);
  1749. #endif
  1750. down(&unit->open_sem);
  1751. /*
  1752.  * XXX Solve the case of O_NONBLOCK close - don't deallocate here.
  1753.  * Deallocate when unloading the driver and we can wait.
  1754.  */
  1755. ymf_wait_dac(state);
  1756. ymf_stop_adc(state); /* fortunately, it's immediate */
  1757. dealloc_dmabuf(&state->wpcm.dmabuf);
  1758. dealloc_dmabuf(&state->rpcm.dmabuf);
  1759. ymf_pcm_free_substream(&state->wpcm);
  1760. ymf_pcm_free_substream(&state->rpcm);
  1761. list_del(&state->chain);
  1762. file->private_data = NULL; /* Can you tell I programmed Solaris */
  1763. kfree(state);
  1764. up(&unit->open_sem);
  1765. return 0;
  1766. }
  1767. /*
  1768.  * Mixer operations are based on cs46xx.
  1769.  */
  1770. static int ymf_open_mixdev(struct inode *inode, struct file *file)
  1771. {
  1772. int minor = MINOR(inode->i_rdev);
  1773. struct list_head *list;
  1774. ymfpci_t *unit;
  1775. int i;
  1776. list_for_each(list, &ymf_devs) {
  1777. unit = list_entry(list, ymfpci_t, ymf_devs);
  1778. for (i = 0; i < NR_AC97; i++) {
  1779. if (unit->ac97_codec[i] != NULL &&
  1780.     unit->ac97_codec[i]->dev_mixer == minor) {
  1781. goto match;
  1782. }
  1783. }
  1784. }
  1785. return -ENODEV;
  1786.  match:
  1787. file->private_data = unit->ac97_codec[i];
  1788. return 0;
  1789. }
  1790. static int ymf_ioctl_mixdev(struct inode *inode, struct file *file,
  1791.     unsigned int cmd, unsigned long arg)
  1792. {
  1793. struct ac97_codec *codec = (struct ac97_codec *)file->private_data;
  1794. return codec->mixer_ioctl(codec, cmd, arg);
  1795. }
  1796. static int ymf_release_mixdev(struct inode *inode, struct file *file)
  1797. {
  1798. return 0;
  1799. }
  1800. static /*const*/ struct file_operations ymf_fops = {
  1801. owner: THIS_MODULE,
  1802. llseek: no_llseek,
  1803. read: ymf_read,
  1804. write: ymf_write,
  1805. poll: ymf_poll,
  1806. ioctl: ymf_ioctl,
  1807. mmap: ymf_mmap,
  1808. open: ymf_open,
  1809. release: ymf_release,
  1810. };
  1811. static /*const*/ struct file_operations ymf_mixer_fops = {
  1812. owner: THIS_MODULE,
  1813. llseek: no_llseek,
  1814. ioctl: ymf_ioctl_mixdev,
  1815. open: ymf_open_mixdev,
  1816. release: ymf_release_mixdev,
  1817. };
  1818. /*
  1819.  */
  1820. static int ymf_suspend(struct pci_dev *pcidev, u32 unused)
  1821. {
  1822. struct ymf_unit *unit = pci_get_drvdata(pcidev);
  1823. unsigned long flags;
  1824. struct ymf_dmabuf *dmabuf;
  1825. struct list_head *p;
  1826. struct ymf_state *state;
  1827. struct ac97_codec *codec;
  1828. int i;
  1829. spin_lock_irqsave(&unit->reg_lock, flags);
  1830. unit->suspended = 1;
  1831. /*
  1832.  * XXX Talk to Kai to remove ac97_save_state before it's too late!
  1833.  * Other drivers call ac97_reset, which does not have
  1834.  * a save counterpart. Current ac97_save_state is empty.
  1835.  */
  1836. for (i = 0; i < NR_AC97; i++) {
  1837. if ((codec = unit->ac97_codec[i]) != NULL)
  1838. ac97_save_state(codec);
  1839. }
  1840. list_for_each(p, &unit->states) {
  1841. state = list_entry(p, struct ymf_state, chain);
  1842. dmabuf = &state->wpcm.dmabuf;
  1843. dmabuf->hwptr = dmabuf->swptr = 0;
  1844. dmabuf->total_bytes = 0;
  1845. dmabuf->count = 0;
  1846. dmabuf = &state->rpcm.dmabuf;
  1847. dmabuf->hwptr = dmabuf->swptr = 0;
  1848. dmabuf->total_bytes = 0;
  1849. dmabuf->count = 0;
  1850. }
  1851. ymfpci_writel(unit, YDSXGR_NATIVEDACOUTVOL, 0);
  1852. ymfpci_disable_dsp(unit);
  1853. spin_unlock_irqrestore(&unit->reg_lock, flags);
  1854. return 0;
  1855. }
  1856. static int ymf_resume(struct pci_dev *pcidev)
  1857. {
  1858. struct ymf_unit *unit = pci_get_drvdata(pcidev);
  1859. unsigned long flags;
  1860. struct list_head *p;
  1861. struct ymf_state *state;
  1862. struct ac97_codec *codec;
  1863. int i;
  1864. ymfpci_aclink_reset(unit->pci);
  1865. ymfpci_codec_ready(unit, 0, 1); /* prints diag if not ready. */
  1866. #ifdef CONFIG_SOUND_YMFPCI_LEGACY
  1867. /* XXX At this time the legacy registers are probably deprogrammed. */
  1868. #endif
  1869. ymfpci_download_image(unit);
  1870. ymf_memload(unit);
  1871. spin_lock_irqsave(&unit->reg_lock, flags);
  1872. if (unit->start_count) {
  1873. ymfpci_writel(unit, YDSXGR_MODE, 3);
  1874. unit->active_bank = ymfpci_readl(unit, YDSXGR_CTRLSELECT) & 1;
  1875. }
  1876. for (i = 0; i < NR_AC97; i++) {
  1877. if ((codec = unit->ac97_codec[i]) != NULL)
  1878. ac97_restore_state(codec);
  1879. }
  1880. unit->suspended = 0;
  1881. list_for_each(p, &unit->states) {
  1882. state = list_entry(p, struct ymf_state, chain);
  1883. wake_up(&state->wpcm.dmabuf.wait);
  1884. wake_up(&state->rpcm.dmabuf.wait);
  1885. }
  1886. spin_unlock_irqrestore(&unit->reg_lock, flags);
  1887. return 0;
  1888. }
  1889. /*
  1890.  *  initialization routines
  1891.  */
  1892. #ifdef CONFIG_SOUND_YMFPCI_LEGACY
  1893. static int ymfpci_setup_legacy(ymfpci_t *unit, struct pci_dev *pcidev)
  1894. {
  1895. int v;
  1896. int mpuio = -1, oplio = -1;
  1897. switch (unit->iomidi) {
  1898. case 0x330:
  1899. mpuio = 0;
  1900. break;
  1901. case 0x300:
  1902. mpuio = 1;
  1903. break;
  1904. case 0x332:
  1905. mpuio = 2;
  1906. break;
  1907. case 0x334:
  1908. mpuio = 3;
  1909. break;
  1910. default: ;
  1911. }
  1912. switch (unit->iosynth) {
  1913. case 0x388:
  1914. oplio = 0;
  1915. break;
  1916. case 0x398:
  1917. oplio = 1;
  1918. break;
  1919. case 0x3a0:
  1920. oplio = 2;
  1921. break;
  1922. case 0x3a8:
  1923. oplio = 3;
  1924. break;
  1925. default: ;
  1926. }
  1927. if (mpuio >= 0 || oplio >= 0) {
  1928. /* 0x0020: 1 - 10 bits of I/O address decoded, 0 - 16 bits. */
  1929. v = 0x001e;
  1930. pci_write_config_word(pcidev, PCIR_LEGCTRL, v);
  1931. switch (pcidev->device) {
  1932. case PCI_DEVICE_ID_YAMAHA_724:
  1933. case PCI_DEVICE_ID_YAMAHA_740:
  1934. case PCI_DEVICE_ID_YAMAHA_724F:
  1935. case PCI_DEVICE_ID_YAMAHA_740C:
  1936. v = 0x8800;
  1937. if (mpuio >= 0) { v |= mpuio<<4; }
  1938. if (oplio >= 0) { v |= oplio; }
  1939. pci_write_config_word(pcidev, PCIR_ELEGCTRL, v);
  1940. break;
  1941. case PCI_DEVICE_ID_YAMAHA_744:
  1942. case PCI_DEVICE_ID_YAMAHA_754:
  1943. v = 0x8800;
  1944. pci_write_config_word(pcidev, PCIR_ELEGCTRL, v);
  1945. if (oplio >= 0) {
  1946. pci_write_config_word(pcidev, PCIR_OPLADR, unit->iosynth);
  1947. }
  1948. if (mpuio >= 0) {
  1949. pci_write_config_word(pcidev, PCIR_MPUADR, unit->iomidi);
  1950. }
  1951. break;
  1952. default:
  1953. printk(KERN_ERR "ymfpci: Unknown device ID: 0x%xn",
  1954.     pcidev->device);
  1955. return -EINVAL;
  1956. }
  1957. }
  1958. return 0;
  1959. }
  1960. #endif /* CONFIG_SOUND_YMFPCI_LEGACY */
  1961. static void ymfpci_aclink_reset(struct pci_dev * pci)
  1962. {
  1963. u8 cmd;
  1964. /*
  1965.  * In the 744, 754 only 0x01 exists, 0x02 is undefined.
  1966.  * It does not seem to hurt to trip both regardless of revision.
  1967.  */
  1968. pci_read_config_byte(pci, PCIR_DSXGCTRL, &cmd);
  1969. pci_write_config_byte(pci, PCIR_DSXGCTRL, cmd & 0xfc);
  1970. pci_write_config_byte(pci, PCIR_DSXGCTRL, cmd | 0x03);
  1971. pci_write_config_byte(pci, PCIR_DSXGCTRL, cmd & 0xfc);
  1972. pci_write_config_word(pci, PCIR_DSXPWRCTRL1, 0);
  1973. pci_write_config_word(pci, PCIR_DSXPWRCTRL2, 0);
  1974. }
  1975. static void ymfpci_enable_dsp(ymfpci_t *codec)
  1976. {
  1977. ymfpci_writel(codec, YDSXGR_CONFIG, 0x00000001);
  1978. }
  1979. static void ymfpci_disable_dsp(ymfpci_t *codec)
  1980. {
  1981. u32 val;
  1982. int timeout = 1000;
  1983. val = ymfpci_readl(codec, YDSXGR_CONFIG);
  1984. if (val)
  1985. ymfpci_writel(codec, YDSXGR_CONFIG, 0x00000000);
  1986. while (timeout-- > 0) {
  1987. val = ymfpci_readl(codec, YDSXGR_STATUS);
  1988. if ((val & 0x00000002) == 0)
  1989. break;
  1990. }
  1991. }
  1992. #include "ymfpci_image.h"
  1993. static void ymfpci_download_image(ymfpci_t *codec)
  1994. {
  1995. int i, ver_1e;
  1996. u16 ctrl;
  1997. ymfpci_writel(codec, YDSXGR_NATIVEDACOUTVOL, 0x00000000);
  1998. ymfpci_disable_dsp(codec);
  1999. ymfpci_writel(codec, YDSXGR_MODE, 0x00010000);
  2000. ymfpci_writel(codec, YDSXGR_MODE, 0x00000000);
  2001. ymfpci_writel(codec, YDSXGR_MAPOFREC, 0x00000000);
  2002. ymfpci_writel(codec, YDSXGR_MAPOFEFFECT, 0x00000000);
  2003. ymfpci_writel(codec, YDSXGR_PLAYCTRLBASE, 0x00000000);
  2004. ymfpci_writel(codec, YDSXGR_RECCTRLBASE, 0x00000000);
  2005. ymfpci_writel(codec, YDSXGR_EFFCTRLBASE, 0x00000000);
  2006. ctrl = ymfpci_readw(codec, YDSXGR_GLOBALCTRL);
  2007. ymfpci_writew(codec, YDSXGR_GLOBALCTRL, ctrl & ~0x0007);
  2008. /* setup DSP instruction code */
  2009. for (i = 0; i < YDSXG_DSPLENGTH / 4; i++)
  2010. ymfpci_writel(codec, YDSXGR_DSPINSTRAM + (i << 2), DspInst[i]);
  2011. switch (codec->pci->device) {
  2012. case PCI_DEVICE_ID_YAMAHA_724F:
  2013. case PCI_DEVICE_ID_YAMAHA_740C:
  2014. case PCI_DEVICE_ID_YAMAHA_744:
  2015. case PCI_DEVICE_ID_YAMAHA_754:
  2016. ver_1e = 1;
  2017. break;
  2018. default:
  2019. ver_1e = 0;
  2020. }
  2021. if (ver_1e) {
  2022. /* setup control instruction code */
  2023. for (i = 0; i < YDSXG_CTRLLENGTH / 4; i++)
  2024. ymfpci_writel(codec, YDSXGR_CTRLINSTRAM + (i << 2), CntrlInst1E[i]);
  2025. } else {
  2026. for (i = 0; i < YDSXG_CTRLLENGTH / 4; i++)
  2027. ymfpci_writel(codec, YDSXGR_CTRLINSTRAM + (i << 2), CntrlInst[i]);
  2028. }
  2029. ymfpci_enable_dsp(codec);
  2030. /* 0.02s sounds not too bad, we may do schedule_timeout() later. */
  2031. mdelay(20); /* seems we need some delay after downloading image.. */
  2032. }
  2033. static int ymfpci_memalloc(ymfpci_t *codec)
  2034. {
  2035. long size, playback_ctrl_size;
  2036. int voice, bank;
  2037. u8 *ptr;
  2038. playback_ctrl_size = 4 + 4 * YDSXG_PLAYBACK_VOICES;
  2039. codec->bank_size_playback = ymfpci_readl(codec, YDSXGR_PLAYCTRLSIZE) << 2;
  2040. codec->bank_size_capture = ymfpci_readl(codec, YDSXGR_RECCTRLSIZE) << 2;
  2041. codec->bank_size_effect = ymfpci_readl(codec, YDSXGR_EFFCTRLSIZE) << 2;
  2042. codec->work_size = YDSXG_DEFAULT_WORK_SIZE;
  2043. size = ((playback_ctrl_size + 0x00ff) & ~0x00ff) +
  2044.     ((codec->bank_size_playback * 2 * YDSXG_PLAYBACK_VOICES + 0xff) & ~0xff) +
  2045.     ((codec->bank_size_capture * 2 * YDSXG_CAPTURE_VOICES + 0xff) & ~0xff) +
  2046.     ((codec->bank_size_effect * 2 * YDSXG_EFFECT_VOICES + 0xff) & ~0xff) +
  2047.     codec->work_size;
  2048. ptr = (u8 *)kmalloc(size + 0x00ff, GFP_KERNEL);
  2049. if (ptr == NULL)
  2050. return -ENOMEM;
  2051. codec->work_ptr = ptr;
  2052. ptr += 0x00ff;
  2053. (long)ptr &= ~0x00ff;
  2054. /*
  2055.  * Hardware requires only ptr[playback_ctrl_size] zeroed,
  2056.  * but in our judgement it is a wrong kind of savings, so clear it all.
  2057.  */
  2058. memset(ptr, 0, size);
  2059. codec->bank_base_playback = ptr;
  2060. codec->ctrl_playback = (u32 *)ptr;
  2061. codec->ctrl_playback[0] = YDSXG_PLAYBACK_VOICES;
  2062. ptr += (playback_ctrl_size + 0x00ff) & ~0x00ff;
  2063. for (voice = 0; voice < YDSXG_PLAYBACK_VOICES; voice++) {
  2064. for (bank = 0; bank < 2; bank++) {
  2065. codec->bank_playback[voice][bank] = (ymfpci_playback_bank_t *)ptr;
  2066. ptr += codec->bank_size_playback;
  2067. }
  2068. codec->voices[voice].number = voice;
  2069. codec->voices[voice].bank = codec->bank_playback[voice][0];
  2070. }
  2071. ptr += (codec->bank_size_playback + 0x00ff) & ~0x00ff;
  2072. codec->bank_base_capture = ptr;
  2073. for (voice = 0; voice < YDSXG_CAPTURE_VOICES; voice++)
  2074. for (bank = 0; bank < 2; bank++) {
  2075. codec->bank_capture[voice][bank] = (ymfpci_capture_bank_t *)ptr;
  2076. ptr += codec->bank_size_capture;
  2077. }
  2078. ptr += (codec->bank_size_capture + 0x00ff) & ~0x00ff;
  2079. codec->bank_base_effect = ptr;
  2080. for (voice = 0; voice < YDSXG_EFFECT_VOICES; voice++)
  2081. for (bank = 0; bank < 2; bank++) {
  2082. codec->bank_effect[voice][bank] = (ymfpci_effect_bank_t *)ptr;
  2083. ptr += codec->bank_size_effect;
  2084. }
  2085. ptr += (codec->bank_size_effect + 0x00ff) & ~0x00ff;
  2086. codec->work_base = ptr;
  2087. return 0;
  2088. }
  2089. static void ymfpci_memfree(ymfpci_t *codec)
  2090. {
  2091. ymfpci_writel(codec, YDSXGR_PLAYCTRLBASE, 0);
  2092. ymfpci_writel(codec, YDSXGR_RECCTRLBASE, 0);
  2093. ymfpci_writel(codec, YDSXGR_EFFCTRLBASE, 0);
  2094. ymfpci_writel(codec, YDSXGR_WORKBASE, 0);
  2095. ymfpci_writel(codec, YDSXGR_WORKSIZE, 0);
  2096. kfree(codec->work_ptr);
  2097. }
  2098. static void ymf_memload(ymfpci_t *unit)
  2099. {
  2100. ymfpci_writel(unit, YDSXGR_PLAYCTRLBASE, virt_to_bus(unit->bank_base_playback));
  2101. ymfpci_writel(unit, YDSXGR_RECCTRLBASE, virt_to_bus(unit->bank_base_capture));
  2102. ymfpci_writel(unit, YDSXGR_EFFCTRLBASE, virt_to_bus(unit->bank_base_effect));
  2103. ymfpci_writel(unit, YDSXGR_WORKBASE, virt_to_bus(unit->work_base));
  2104. ymfpci_writel(unit, YDSXGR_WORKSIZE, unit->work_size >> 2);
  2105. /* S/PDIF output initialization */
  2106. ymfpci_writew(unit, YDSXGR_SPDIFOUTCTRL, 0);
  2107. ymfpci_writew(unit, YDSXGR_SPDIFOUTSTATUS,
  2108. SND_PCM_AES0_CON_EMPHASIS_NONE |
  2109. (SND_PCM_AES1_CON_ORIGINAL << 8) |
  2110. (SND_PCM_AES1_CON_PCM_CODER << 8));
  2111. /* S/PDIF input initialization */
  2112. ymfpci_writew(unit, YDSXGR_SPDIFINCTRL, 0);
  2113. /* move this volume setup to mixer */
  2114. ymfpci_writel(unit, YDSXGR_NATIVEDACOUTVOL, 0x3fff3fff);
  2115. ymfpci_writel(unit, YDSXGR_BUF441OUTVOL, 0);
  2116. ymfpci_writel(unit, YDSXGR_NATIVEADCINVOL, 0x3fff3fff);
  2117. ymfpci_writel(unit, YDSXGR_NATIVEDACINVOL, 0x3fff3fff);
  2118. }
  2119. static int ymf_ac97_init(ymfpci_t *unit, int num_ac97)
  2120. {
  2121. struct ac97_codec *codec;
  2122. u16 eid;
  2123. if ((codec = kmalloc(sizeof(struct ac97_codec), GFP_KERNEL)) == NULL)
  2124. return -ENOMEM;
  2125. memset(codec, 0, sizeof(struct ac97_codec));
  2126. /* initialize some basic codec information, other fields will be filled
  2127.    in ac97_probe_codec */
  2128. codec->private_data = unit;
  2129. codec->id = num_ac97;
  2130. codec->codec_read = ymfpci_codec_read;
  2131. codec->codec_write = ymfpci_codec_write;
  2132. if (ac97_probe_codec(codec) == 0) {
  2133. printk(KERN_ERR "ymfpci: ac97_probe_codec failedn");
  2134. goto out_kfree;
  2135. }
  2136. eid = ymfpci_codec_read(codec, AC97_EXTENDED_ID);
  2137. if (eid==0xFFFFFF) {
  2138. printk(KERN_WARNING "ymfpci: no codec attached ?n");
  2139. goto out_kfree;
  2140. }
  2141. unit->ac97_features = eid;
  2142. if ((codec->dev_mixer = register_sound_mixer(&ymf_mixer_fops, -1)) < 0) {
  2143. printk(KERN_ERR "ymfpci: couldn't register mixer!n");
  2144. goto out_kfree;
  2145. }
  2146. unit->ac97_codec[num_ac97] = codec;
  2147. return 0;
  2148.  out_kfree:
  2149. kfree(codec);
  2150. return -ENODEV;
  2151. }
  2152. #ifdef CONFIG_SOUND_YMFPCI_LEGACY
  2153. # ifdef MODULE
  2154. static int mpu_io     = 0;
  2155. static int synth_io   = 0;
  2156. MODULE_PARM(mpu_io, "i");
  2157. MODULE_PARM(synth_io, "i");
  2158. # else
  2159. static int mpu_io     = 0x330;
  2160. static int synth_io   = 0x388;
  2161. # endif
  2162. static int assigned;
  2163. #endif /* CONFIG_SOUND_YMFPCI_LEGACY */
  2164. static int __devinit ymf_probe_one(struct pci_dev *pcidev, const struct pci_device_id *ent)
  2165. {
  2166. u16 ctrl;
  2167. unsigned long base;
  2168. ymfpci_t *codec;
  2169. int err;
  2170. if ((err = pci_enable_device(pcidev)) != 0) {
  2171. printk(KERN_ERR "ymfpci: pci_enable_device failedn");
  2172. return err;
  2173. }
  2174. base = pci_resource_start(pcidev, 0);
  2175. if ((codec = kmalloc(sizeof(ymfpci_t), GFP_KERNEL)) == NULL) {
  2176. printk(KERN_ERR "ymfpci: no coren");
  2177. return -ENOMEM;
  2178. }
  2179. memset(codec, 0, sizeof(*codec));
  2180. spin_lock_init(&codec->reg_lock);
  2181. spin_lock_init(&codec->voice_lock);
  2182. init_MUTEX(&codec->open_sem);
  2183. INIT_LIST_HEAD(&codec->states);
  2184. codec->pci = pcidev;
  2185. pci_read_config_byte(pcidev, PCI_REVISION_ID, &codec->rev);
  2186. if (request_mem_region(base, 0x8000, "ymfpci") == NULL) {
  2187. printk(KERN_ERR "ymfpci: unable to request mem regionn");
  2188. goto out_free;
  2189. }
  2190. if ((codec->reg_area_virt = ioremap(base, 0x8000)) == NULL) {
  2191. printk(KERN_ERR "ymfpci: unable to map registersn");
  2192. goto out_release_region;
  2193. }
  2194. pci_set_master(pcidev);
  2195. printk(KERN_INFO "ymfpci: %s at 0x%lx IRQ %dn",
  2196.     (char *)ent->driver_data, base, pcidev->irq);
  2197. ymfpci_aclink_reset(pcidev);
  2198. if (ymfpci_codec_ready(codec, 0, 1) < 0)
  2199. goto out_unmap;
  2200. #ifdef CONFIG_SOUND_YMFPCI_LEGACY
  2201. if (assigned == 0) {
  2202. codec->iomidi = mpu_io;
  2203. codec->iosynth = synth_io;
  2204. if (ymfpci_setup_legacy(codec, pcidev) < 0)
  2205. goto out_unmap;
  2206. assigned = 1;
  2207. }
  2208. #endif
  2209. ymfpci_download_image(codec);
  2210. if (ymfpci_memalloc(codec) < 0)
  2211. goto out_disable_dsp;
  2212. ymf_memload(codec);
  2213. if (request_irq(pcidev->irq, ymf_interrupt, SA_SHIRQ, "ymfpci", codec) != 0) {
  2214. printk(KERN_ERR "ymfpci: unable to request IRQ %dn",
  2215.     pcidev->irq);
  2216. goto out_memfree;
  2217. }
  2218. /* register /dev/dsp */
  2219. if ((codec->dev_audio = register_sound_dsp(&ymf_fops, -1)) < 0) {
  2220. printk(KERN_ERR "ymfpci: unable to register dspn");
  2221. goto out_free_irq;
  2222. }
  2223. /*
  2224.  * Poke just the primary for the moment.
  2225.  */
  2226. if ((err = ymf_ac97_init(codec, 0)) != 0)
  2227. goto out_unregister_sound_dsp;
  2228. #ifdef CONFIG_SOUND_YMFPCI_LEGACY
  2229. codec->opl3_data.name = "ymfpci";
  2230. codec->mpu_data.name  = "ymfpci";
  2231. codec->opl3_data.io_base = codec->iosynth;
  2232. codec->opl3_data.irq     = -1;
  2233. codec->mpu_data.io_base  = codec->iomidi;
  2234. codec->mpu_data.irq      = -1; /* XXX Make it ours. */
  2235. if (codec->iomidi) {
  2236. if (!probe_uart401(&codec->mpu_data, THIS_MODULE)) {
  2237. codec->iomidi = 0; /* XXX kludge */
  2238. }
  2239. }
  2240. #endif /* CONFIG_SOUND_YMFPCI_LEGACY */
  2241. /* put it into driver list */
  2242. list_add_tail(&codec->ymf_devs, &ymf_devs);
  2243. pci_set_drvdata(pcidev, codec);
  2244. return 0;
  2245.  out_unregister_sound_dsp:
  2246. unregister_sound_dsp(codec->dev_audio);
  2247.  out_free_irq:
  2248. free_irq(pcidev->irq, codec);
  2249.  out_memfree:
  2250. ymfpci_memfree(codec);
  2251.  out_disable_dsp:
  2252. ymfpci_disable_dsp(codec);
  2253. ctrl = ymfpci_readw(codec, YDSXGR_GLOBALCTRL);
  2254. ymfpci_writew(codec, YDSXGR_GLOBALCTRL, ctrl & ~0x0007);
  2255. ymfpci_writel(codec, YDSXGR_STATUS, ~0);
  2256.  out_unmap:
  2257. iounmap(codec->reg_area_virt);
  2258.  out_release_region:
  2259. release_mem_region(pci_resource_start(pcidev, 0), 0x8000);
  2260.  out_free:
  2261. kfree(codec);
  2262. return -ENODEV;
  2263. }
  2264. static void __devexit ymf_remove_one(struct pci_dev *pcidev)
  2265. {
  2266. __u16 ctrl;
  2267. ymfpci_t *codec = pci_get_drvdata(pcidev);
  2268. /* remove from list of devices */
  2269. list_del(&codec->ymf_devs);
  2270. unregister_sound_mixer(codec->ac97_codec[0]->dev_mixer);
  2271. kfree(codec->ac97_codec[0]);
  2272. unregister_sound_dsp(codec->dev_audio);
  2273. free_irq(pcidev->irq, codec);
  2274. ymfpci_memfree(codec);
  2275. ymfpci_writel(codec, YDSXGR_STATUS, ~0);
  2276. ymfpci_disable_dsp(codec);
  2277. ctrl = ymfpci_readw(codec, YDSXGR_GLOBALCTRL);
  2278. ymfpci_writew(codec, YDSXGR_GLOBALCTRL, ctrl & ~0x0007);
  2279. iounmap(codec->reg_area_virt);
  2280. release_mem_region(pci_resource_start(pcidev, 0), 0x8000);
  2281. #ifdef CONFIG_SOUND_YMFPCI_LEGACY
  2282. if (codec->iomidi) {
  2283. unload_uart401(&codec->mpu_data);
  2284. }
  2285. #endif /* CONFIG_SOUND_YMFPCI_LEGACY */
  2286. kfree(codec);
  2287. }
  2288. MODULE_AUTHOR("Jaroslav Kysela");
  2289. MODULE_DESCRIPTION("Yamaha YMF7xx PCI Audio");
  2290. MODULE_LICENSE("GPL");
  2291. static struct pci_driver ymfpci_driver = {
  2292. name: "ymfpci",
  2293. id_table: ymf_id_tbl,
  2294. probe: ymf_probe_one,
  2295. remove:         __devexit_p(ymf_remove_one),
  2296. suspend: ymf_suspend,
  2297. resume: ymf_resume
  2298. };
  2299. static int __init ymf_init_module(void)
  2300. {
  2301. return pci_module_init(&ymfpci_driver);
  2302. }
  2303. static void __exit ymf_cleanup_module (void)
  2304. {
  2305. pci_unregister_driver(&ymfpci_driver);
  2306. }
  2307. module_init(ymf_init_module);
  2308. module_exit(ymf_cleanup_module);