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

嵌入式Linux

开发平台:

Unix_Linux

  1. /****************************************************************************/
  2. /*
  3.  *      esssolo1.c  --  ESS Technology Solo1 (ES1946) audio driver.
  4.  *
  5.  *      Copyright (C) 1998-2001  Thomas Sailer (t.sailer@alumni.ethz.ch)
  6.  *
  7.  *      This program is free software; you can redistribute it and/or modify
  8.  *      it under the terms of the GNU General Public License as published by
  9.  *      the Free Software Foundation; either version 2 of the License, or
  10.  *      (at your option) any later version.
  11.  *
  12.  *      This program is distributed in the hope that it will be useful,
  13.  *      but WITHOUT ANY WARRANTY; without even the implied warranty of
  14.  *      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  15.  *      GNU General Public License for more details.
  16.  *
  17.  *      You should have received a copy of the GNU General Public License
  18.  *      along with this program; if not, write to the Free Software
  19.  *      Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  20.  *
  21.  * Module command line parameters:
  22.  *   none so far
  23.  *
  24.  *  Supported devices:
  25.  *  /dev/dsp    standard /dev/dsp device, (mostly) OSS compatible
  26.  *  /dev/mixer  standard /dev/mixer device, (mostly) OSS compatible
  27.  *  /dev/midi   simple MIDI UART interface, no ioctl
  28.  *
  29.  *  Revision history
  30.  *    10.11.1998   0.1   Initial release (without any hardware)
  31.  *    22.03.1999   0.2   cinfo.blocks should be reset after GETxPTR ioctl.
  32.  *                       reported by Johan Maes <joma@telindus.be>
  33.  *                       return EAGAIN instead of EBUSY when O_NONBLOCK
  34.  *                       read/write cannot be executed
  35.  *    07.04.1999   0.3   implemented the following ioctl's: SOUND_PCM_READ_RATE, 
  36.  *                       SOUND_PCM_READ_CHANNELS, SOUND_PCM_READ_BITS; 
  37.  *                       Alpha fixes reported by Peter Jones <pjones@redhat.com>
  38.  *    15.06.1999   0.4   Fix bad allocation bug.
  39.  *                       Thanks to Deti Fliegl <fliegl@in.tum.de>
  40.  *    28.06.1999   0.5   Add pci_set_master
  41.  *    12.08.1999   0.6   Fix MIDI UART crashing the driver
  42.  *                       Changed mixer semantics from OSS documented
  43.  *                       behaviour to OSS "code behaviour".
  44.  *                       Recording might actually work now.
  45.  *                       The real DDMA controller address register is at PCI config
  46.  *                       0x60, while the register at 0x18 is used as a placeholder
  47.  *                       register for BIOS address allocation. This register
  48.  *                       is supposed to be copied into 0x60, according
  49.  *                       to the Solo1 datasheet. When I do that, I can access
  50.  *                       the DDMA registers except the mask bit, which
  51.  *                       is stuck at 1. When I copy the contents of 0x18 +0x10
  52.  *                       to the DDMA base register, everything seems to work.
  53.  *                       The fun part is that the Windows Solo1 driver doesn't
  54.  *                       seem to do these tricks.
  55.  *                       Bugs remaining: plops and clicks when starting/stopping playback
  56.  *    31.08.1999   0.7   add spin_lock_init
  57.  *                       replaced current->state = x with set_current_state(x)
  58.  *    03.09.1999   0.8   change read semantics for MIDI to match
  59.  *                       OSS more closely; remove possible wakeup race
  60.  *    07.10.1999   0.9   Fix initialization; complain if sequencer writes time out
  61.  *                       Revised resource grabbing for the FM synthesizer
  62.  *    28.10.1999   0.10  More waitqueue races fixed
  63.  *    09.12.1999   0.11  Work around stupid Alpha port issue (virt_to_bus(kmalloc(GFP_DMA)) > 16M)
  64.  *                       Disabling recording on Alpha
  65.  *    12.01.2000   0.12  Prevent some ioctl's from returning bad count values on underrun/overrun;
  66.  *                       Tim Janik's BSE (Bedevilled Sound Engine) found this
  67.  *                       Integrated (aka redid 8-)) APM support patch by Zach Brown
  68.  *    07.02.2000   0.13  Use pci_alloc_consistent and pci_register_driver
  69.  *    19.02.2000   0.14  Use pci_dma_supported to determine if recording should be disabled
  70.  *    13.03.2000   0.15  Reintroduce initialization of a couple of PCI config space registers
  71.  *    21.11.2000   0.16  Initialize dma buffers in poll, otherwise poll may return a bogus mask
  72.  *    12.12.2000   0.17  More dma buffer initializations, patch from
  73.  *                       Tjeerd Mulder <tjeerd.mulder@fujitsu-siemens.com>
  74.  *    31.01.2001   0.18  Register/Unregister gameport, original patch from
  75.  *                       Nathaniel Daw <daw@cs.cmu.edu>
  76.  *                       Fix SETTRIGGER non OSS API conformity
  77.  *    10.03.2001         provide abs function, prevent picking up a bogus kernel macro
  78.  *                       for abs. Bug report by Andrew Morton <andrewm@uow.edu.au>
  79.  *    15.05.2001         pci_enable_device moved, return values in probe cleaned
  80.  *                       up. Marcus Meissner <mm@caldera.de>
  81.  *    22.05.2001   0.19  more cleanups, changed PM to PCI 2.4 style, got rid
  82.  *                       of global list of devices, using pci device data.
  83.  *                       Marcus Meissner <mm@caldera.de>
  84.  */
  85. /*****************************************************************************/
  86.       
  87. #include <linux/version.h>
  88. #include <linux/module.h>
  89. #include <linux/string.h>
  90. #include <linux/ioport.h>
  91. #include <linux/sched.h>
  92. #include <linux/delay.h>
  93. #include <linux/sound.h>
  94. #include <linux/slab.h>
  95. #include <linux/soundcard.h>
  96. #include <linux/pci.h>
  97. #include <linux/bitops.h>
  98. #include <asm/io.h>
  99. #include <asm/dma.h>
  100. #include <linux/init.h>
  101. #include <linux/poll.h>
  102. #include <linux/spinlock.h>
  103. #include <linux/smp_lock.h>
  104. #include <linux/wrapper.h>
  105. #include <asm/uaccess.h>
  106. #include <asm/hardirq.h>
  107. #include <linux/gameport.h>
  108. #include "dm.h"
  109. /* --------------------------------------------------------------------- */
  110. #undef OSS_DOCUMENTED_MIXER_SEMANTICS
  111. /* --------------------------------------------------------------------- */
  112. #ifndef PCI_VENDOR_ID_ESS
  113. #define PCI_VENDOR_ID_ESS         0x125d
  114. #endif
  115. #ifndef PCI_DEVICE_ID_ESS_SOLO1
  116. #define PCI_DEVICE_ID_ESS_SOLO1   0x1969
  117. #endif
  118. #define SOLO1_MAGIC  ((PCI_VENDOR_ID_ESS<<16)|PCI_DEVICE_ID_ESS_SOLO1)
  119. #define DDMABASE_OFFSET           0    /* chip bug workaround kludge */
  120. #define DDMABASE_EXTENT           16
  121. #define IOBASE_EXTENT             16
  122. #define SBBASE_EXTENT             16
  123. #define VCBASE_EXTENT             (DDMABASE_EXTENT+DDMABASE_OFFSET)
  124. #define MPUBASE_EXTENT            4
  125. #define GPBASE_EXTENT             4
  126. #define GAMEPORT_EXTENT   4
  127. #define FMSYNTH_EXTENT            4
  128. /* MIDI buffer sizes */
  129. #define MIDIINBUF  256
  130. #define MIDIOUTBUF 256
  131. #define FMODE_MIDI_SHIFT 3
  132. #define FMODE_MIDI_READ  (FMODE_READ << FMODE_MIDI_SHIFT)
  133. #define FMODE_MIDI_WRITE (FMODE_WRITE << FMODE_MIDI_SHIFT)
  134. #define FMODE_DMFM 0x10
  135. static struct pci_driver solo1_driver;
  136. /* --------------------------------------------------------------------- */
  137. struct solo1_state {
  138. /* magic */
  139. unsigned int magic;
  140. /* the corresponding pci_dev structure */
  141. struct pci_dev *dev;
  142. /* soundcore stuff */
  143. int dev_audio;
  144. int dev_mixer;
  145. int dev_midi;
  146. int dev_dmfm;
  147. /* hardware resources */
  148. unsigned long iobase, sbbase, vcbase, ddmabase, mpubase; /* long for SPARC */
  149. unsigned int irq;
  150. /* mixer registers */
  151. struct {
  152. unsigned short vol[10];
  153. unsigned int recsrc;
  154. unsigned int modcnt;
  155. unsigned short micpreamp;
  156. } mix;
  157. /* wave stuff */
  158. unsigned fmt;
  159. unsigned channels;
  160. unsigned rate;
  161. unsigned char clkdiv;
  162. unsigned ena;
  163. spinlock_t lock;
  164. struct semaphore open_sem;
  165. mode_t open_mode;
  166. wait_queue_head_t open_wait;
  167. struct dmabuf {
  168. void *rawbuf;
  169. dma_addr_t dmaaddr;
  170. unsigned buforder;
  171. unsigned numfrag;
  172. unsigned fragshift;
  173. unsigned hwptr, swptr;
  174. unsigned total_bytes;
  175. int count;
  176. unsigned error; /* over/underrun */
  177. wait_queue_head_t wait;
  178. /* redundant, but makes calculations easier */
  179. unsigned fragsize;
  180. unsigned dmasize;
  181. unsigned fragsamples;
  182. /* OSS stuff */
  183. unsigned mapped:1;
  184. unsigned ready:1;
  185. unsigned endcleared:1;
  186. unsigned enabled:1;
  187. unsigned ossfragshift;
  188. int ossmaxfrags;
  189. unsigned subdivision;
  190. } dma_dac, dma_adc;
  191. /* midi stuff */
  192. struct {
  193. unsigned ird, iwr, icnt;
  194. unsigned ord, owr, ocnt;
  195. wait_queue_head_t iwait;
  196. wait_queue_head_t owait;
  197. struct timer_list timer;
  198. unsigned char ibuf[MIDIINBUF];
  199. unsigned char obuf[MIDIOUTBUF];
  200. } midi;
  201. struct gameport gameport;
  202. };
  203. /* --------------------------------------------------------------------- */
  204. static inline void write_seq(struct solo1_state *s, unsigned char data)
  205. {
  206.         int i;
  207. unsigned long flags;
  208. /* the __cli stunt is to send the data within the command window */
  209.         for (i = 0; i < 0xffff; i++) {
  210. __save_flags(flags);
  211. __cli();
  212.                 if (!(inb(s->sbbase+0xc) & 0x80)) {
  213.                         outb(data, s->sbbase+0xc);
  214. __restore_flags(flags);
  215.                         return;
  216.                 }
  217. __restore_flags(flags);
  218. }
  219. printk(KERN_ERR "esssolo1: write_seq timeoutn");
  220. outb(data, s->sbbase+0xc);
  221. }
  222. static inline int read_seq(struct solo1_state *s, unsigned char *data)
  223. {
  224.         int i;
  225.         if (!data)
  226.                 return 0;
  227.         for (i = 0; i < 0xffff; i++)
  228.                 if (inb(s->sbbase+0xe) & 0x80) {
  229.                         *data = inb(s->sbbase+0xa);
  230.                         return 1;
  231.                 }
  232. printk(KERN_ERR "esssolo1: read_seq timeoutn");
  233.         return 0;
  234. }
  235. static int inline reset_ctrl(struct solo1_state *s)
  236. {
  237.         int i;
  238.         outb(3, s->sbbase+6); /* clear sequencer and FIFO */
  239.         udelay(10);
  240.         outb(0, s->sbbase+6);
  241.         for (i = 0; i < 0xffff; i++)
  242.                 if (inb(s->sbbase+0xe) & 0x80)
  243.                         if (inb(s->sbbase+0xa) == 0xaa) {
  244. write_seq(s, 0xc6); /* enter enhanced mode */
  245.                                 return 1;
  246. }
  247.         return 0;
  248. }
  249. static void write_ctrl(struct solo1_state *s, unsigned char reg, unsigned char data)
  250. {
  251. write_seq(s, reg);
  252. write_seq(s, data);
  253. }
  254. #if 0 /* unused */
  255. static unsigned char read_ctrl(struct solo1_state *s, unsigned char reg)
  256. {
  257.         unsigned char r;
  258. write_seq(s, 0xc0);
  259. write_seq(s, reg);
  260. read_seq(s, &r);
  261. return r;
  262. }
  263. #endif /* unused */
  264. static void write_mixer(struct solo1_state *s, unsigned char reg, unsigned char data)
  265. {
  266. outb(reg, s->sbbase+4);
  267. outb(data, s->sbbase+5);
  268. }
  269. static unsigned char read_mixer(struct solo1_state *s, unsigned char reg)
  270. {
  271. outb(reg, s->sbbase+4);
  272. return inb(s->sbbase+5);
  273. }
  274. /* --------------------------------------------------------------------- */
  275. static inline unsigned ld2(unsigned int x)
  276. {
  277. unsigned r = 0;
  278. if (x >= 0x10000) {
  279. x >>= 16;
  280. r += 16;
  281. }
  282. if (x >= 0x100) {
  283. x >>= 8;
  284. r += 8;
  285. }
  286. if (x >= 0x10) {
  287. x >>= 4;
  288. r += 4;
  289. }
  290. if (x >= 4) {
  291. x >>= 2;
  292. r += 2;
  293. }
  294. if (x >= 2)
  295. r++;
  296. return r;
  297. }
  298. /* --------------------------------------------------------------------- */
  299. static inline void stop_dac(struct solo1_state *s)
  300. {
  301. unsigned long flags;
  302. spin_lock_irqsave(&s->lock, flags);
  303. s->ena &= ~FMODE_WRITE;
  304. write_mixer(s, 0x78, 0x10);
  305. spin_unlock_irqrestore(&s->lock, flags);
  306. }
  307. static void start_dac(struct solo1_state *s)
  308. {
  309. unsigned long flags;
  310. spin_lock_irqsave(&s->lock, flags);
  311. if (!(s->ena & FMODE_WRITE) && (s->dma_dac.mapped || s->dma_dac.count > 0) && s->dma_dac.ready) {
  312. s->ena |= FMODE_WRITE;
  313. write_mixer(s, 0x78, 0x12);
  314. udelay(10);
  315. write_mixer(s, 0x78, 0x13);
  316. }
  317. spin_unlock_irqrestore(&s->lock, flags);
  318. }
  319. static inline void stop_adc(struct solo1_state *s)
  320. {
  321. unsigned long flags;
  322. spin_lock_irqsave(&s->lock, flags);
  323. s->ena &= ~FMODE_READ;
  324. write_ctrl(s, 0xb8, 0xe);
  325. spin_unlock_irqrestore(&s->lock, flags);
  326. }
  327. static void start_adc(struct solo1_state *s)
  328. {
  329. unsigned long flags;
  330. spin_lock_irqsave(&s->lock, flags);
  331. if (!(s->ena & FMODE_READ) && (s->dma_adc.mapped || s->dma_adc.count < (signed)(s->dma_adc.dmasize - 2*s->dma_adc.fragsize))
  332.     && s->dma_adc.ready) {
  333. s->ena |= FMODE_READ;
  334. write_ctrl(s, 0xb8, 0xf);
  335. #if 0
  336. printk(KERN_DEBUG "solo1: DMAbuffer: 0x%08lxn", (long)s->dma_adc.rawbuf);
  337. printk(KERN_DEBUG "solo1: DMA: mask: 0x%02x cnt: 0x%04x addr: 0x%08x  stat: 0x%02xn", 
  338.        inb(s->ddmabase+0xf), inw(s->ddmabase+4), inl(s->ddmabase), inb(s->ddmabase+8));
  339. #endif
  340.                 outb(0, s->ddmabase+0xd); /* master reset */
  341. outb(1, s->ddmabase+0xf);  /* mask */
  342. outb(0x54/*0x14*/, s->ddmabase+0xb);  /* DMA_MODE_READ | DMA_MODE_AUTOINIT */
  343. outl(virt_to_bus(s->dma_adc.rawbuf), s->ddmabase);
  344. outw(s->dma_adc.dmasize-1, s->ddmabase+4);
  345. outb(0, s->ddmabase+0xf);
  346. }
  347. spin_unlock_irqrestore(&s->lock, flags);
  348. #if 0
  349. printk(KERN_DEBUG "solo1: start DMA: reg B8: 0x%02x  SBstat: 0x%02xn"
  350.        KERN_DEBUG "solo1: DMA: stat: 0x%02x  cnt: 0x%04x  mask: 0x%02xn", 
  351.        read_ctrl(s, 0xb8), inb(s->sbbase+0xc), 
  352.        inb(s->ddmabase+8), inw(s->ddmabase+4), inb(s->ddmabase+0xf));
  353. printk(KERN_DEBUG "solo1: A1: 0x%02x  A2: 0x%02x  A4: 0x%02x  A5: 0x%02x  A8: 0x%02xn"  
  354.        KERN_DEBUG "solo1: B1: 0x%02x  B2: 0x%02x  B4: 0x%02x  B7: 0x%02x  B8: 0x%02x  B9: 0x%02xn",
  355.        read_ctrl(s, 0xa1), read_ctrl(s, 0xa2), read_ctrl(s, 0xa4), read_ctrl(s, 0xa5), read_ctrl(s, 0xa8), 
  356.        read_ctrl(s, 0xb1), read_ctrl(s, 0xb2), read_ctrl(s, 0xb4), read_ctrl(s, 0xb7), read_ctrl(s, 0xb8), 
  357.        read_ctrl(s, 0xb9));
  358. #endif
  359. }
  360. /* --------------------------------------------------------------------- */
  361. #define DMABUF_DEFAULTORDER (15-PAGE_SHIFT)
  362. #define DMABUF_MINORDER 1
  363. static inline void dealloc_dmabuf(struct solo1_state *s, struct dmabuf *db)
  364. {
  365. struct page *page, *pend;
  366. if (db->rawbuf) {
  367. /* undo marking the pages as reserved */
  368. pend = virt_to_page(db->rawbuf + (PAGE_SIZE << db->buforder) - 1);
  369. for (page = virt_to_page(db->rawbuf); page <= pend; page++)
  370. mem_map_unreserve(page);
  371. pci_free_consistent(s->dev, PAGE_SIZE << db->buforder, db->rawbuf, db->dmaaddr);
  372. }
  373. db->rawbuf = NULL;
  374. db->mapped = db->ready = 0;
  375. }
  376. static int prog_dmabuf(struct solo1_state *s, struct dmabuf *db)
  377. {
  378. int order;
  379. unsigned bytespersec;
  380. unsigned bufs, sample_shift = 0;
  381. struct page *page, *pend;
  382. db->hwptr = db->swptr = db->total_bytes = db->count = db->error = db->endcleared = 0;
  383. if (!db->rawbuf) {
  384. db->ready = db->mapped = 0;
  385.                 for (order = DMABUF_DEFAULTORDER; order >= DMABUF_MINORDER; order--)
  386. if ((db->rawbuf = pci_alloc_consistent(s->dev, PAGE_SIZE << order, &db->dmaaddr)))
  387. break;
  388. if (!db->rawbuf)
  389. return -ENOMEM;
  390. db->buforder = order;
  391. /* now mark the pages as reserved; otherwise remap_page_range doesn't do what we want */
  392. pend = virt_to_page(db->rawbuf + (PAGE_SIZE << db->buforder) - 1);
  393. for (page = virt_to_page(db->rawbuf); page <= pend; page++)
  394. mem_map_reserve(page);
  395. }
  396. if (s->fmt & (AFMT_S16_LE | AFMT_U16_LE))
  397. sample_shift++;
  398. if (s->channels > 1)
  399. sample_shift++;
  400. bytespersec = s->rate << sample_shift;
  401. bufs = PAGE_SIZE << db->buforder;
  402. if (db->ossfragshift) {
  403. if ((1000 << db->ossfragshift) < bytespersec)
  404. db->fragshift = ld2(bytespersec/1000);
  405. else
  406. db->fragshift = db->ossfragshift;
  407. } else {
  408. db->fragshift = ld2(bytespersec/100/(db->subdivision ? db->subdivision : 1));
  409. if (db->fragshift < 3)
  410. db->fragshift = 3;
  411. }
  412. db->numfrag = bufs >> db->fragshift;
  413. while (db->numfrag < 4 && db->fragshift > 3) {
  414. db->fragshift--;
  415. db->numfrag = bufs >> db->fragshift;
  416. }
  417. db->fragsize = 1 << db->fragshift;
  418. if (db->ossmaxfrags >= 4 && db->ossmaxfrags < db->numfrag)
  419. db->numfrag = db->ossmaxfrags;
  420. db->fragsamples = db->fragsize >> sample_shift;
  421. db->dmasize = db->numfrag << db->fragshift;
  422. db->enabled = 1;
  423. return 0;
  424. }
  425. static inline int prog_dmabuf_adc(struct solo1_state *s)
  426. {
  427. unsigned long va;
  428. int c;
  429. stop_adc(s);
  430. /* check if PCI implementation supports 24bit busmaster DMA */
  431. if (s->dev->dma_mask > 0xffffff)
  432. return -EIO;
  433. if ((c = prog_dmabuf(s, &s->dma_adc)))
  434. return c;
  435. va = s->dma_adc.dmaaddr;
  436. if ((va & ~((1<<24)-1)))
  437. panic("solo1: buffer above 16M boundary");
  438. outb(0, s->ddmabase+0xd);  /* clear */
  439. outb(1, s->ddmabase+0xf); /* mask */
  440. /*outb(0, s->ddmabase+8);*/  /* enable (enable is active low!) */
  441. outb(0x54, s->ddmabase+0xb);  /* DMA_MODE_READ | DMA_MODE_AUTOINIT */
  442. outl(va, s->ddmabase);
  443. outw(s->dma_adc.dmasize-1, s->ddmabase+4);
  444. c = - s->dma_adc.fragsamples;
  445. write_ctrl(s, 0xa4, c);
  446. write_ctrl(s, 0xa5, c >> 8);
  447. outb(0, s->ddmabase+0xf);
  448. s->dma_adc.ready = 1;
  449. return 0;
  450. }
  451. static inline int prog_dmabuf_dac(struct solo1_state *s)
  452. {
  453. unsigned long va;
  454. int c;
  455. stop_dac(s);
  456. if ((c = prog_dmabuf(s, &s->dma_dac)))
  457. return c;
  458. memset(s->dma_dac.rawbuf, (s->fmt & (AFMT_U8 | AFMT_U16_LE)) ? 0 : 0x80, s->dma_dac.dmasize); /* almost correct for U16 */
  459. va = s->dma_dac.dmaaddr;
  460. if ((va ^ (va + s->dma_dac.dmasize - 1)) & ~((1<<20)-1))
  461. panic("solo1: buffer crosses 1M boundary");
  462. outl(va, s->iobase);
  463. /* warning: s->dma_dac.dmasize & 0xffff must not be zero! i.e. this limits us to a 32k buffer */
  464. outw(s->dma_dac.dmasize, s->iobase+4);
  465. c = - s->dma_dac.fragsamples;
  466. write_mixer(s, 0x74, c);
  467. write_mixer(s, 0x76, c >> 8);
  468. outb(0xa, s->iobase+6);
  469. s->dma_dac.ready = 1;
  470. return 0;
  471. }
  472. static inline void clear_advance(void *buf, unsigned bsize, unsigned bptr, unsigned len, unsigned char c)
  473. {
  474. if (bptr + len > bsize) {
  475. unsigned x = bsize - bptr;
  476. memset(((char *)buf) + bptr, c, x);
  477. bptr = 0;
  478. len -= x;
  479. }
  480. memset(((char *)buf) + bptr, c, len);
  481. }
  482. /* call with spinlock held! */
  483. static void solo1_update_ptr(struct solo1_state *s)
  484. {
  485. int diff;
  486. unsigned hwptr;
  487. /* update ADC pointer */
  488. if (s->ena & FMODE_READ) {
  489. hwptr = (s->dma_adc.dmasize - 1 - inw(s->ddmabase+4)) % s->dma_adc.dmasize;
  490.                 diff = (s->dma_adc.dmasize + hwptr - s->dma_adc.hwptr) % s->dma_adc.dmasize;
  491.                 s->dma_adc.hwptr = hwptr;
  492. s->dma_adc.total_bytes += diff;
  493. s->dma_adc.count += diff;
  494. #if 0
  495. printk(KERN_DEBUG "solo1: rd: hwptr %u swptr %u dmasize %u count %un",
  496.        s->dma_adc.hwptr, s->dma_adc.swptr, s->dma_adc.dmasize, s->dma_adc.count);
  497. #endif
  498. if (s->dma_adc.mapped) {
  499. if (s->dma_adc.count >= (signed)s->dma_adc.fragsize)
  500. wake_up(&s->dma_adc.wait);
  501. } else {
  502. if (s->dma_adc.count > (signed)(s->dma_adc.dmasize - ((3 * s->dma_adc.fragsize) >> 1))) {
  503. s->ena &= ~FMODE_READ;
  504. write_ctrl(s, 0xb8, 0xe);
  505. s->dma_adc.error++;
  506. }
  507. if (s->dma_adc.count > 0)
  508. wake_up(&s->dma_adc.wait);
  509. }
  510. }
  511. /* update DAC pointer */
  512. if (s->ena & FMODE_WRITE) {
  513.                 hwptr = (s->dma_dac.dmasize - inw(s->iobase+4)) % s->dma_dac.dmasize;
  514.                 diff = (s->dma_dac.dmasize + hwptr - s->dma_dac.hwptr) % s->dma_dac.dmasize;
  515.                 s->dma_dac.hwptr = hwptr;
  516. s->dma_dac.total_bytes += diff;
  517. #if 0
  518. printk(KERN_DEBUG "solo1: wr: hwptr %u swptr %u dmasize %u count %un",
  519.        s->dma_dac.hwptr, s->dma_dac.swptr, s->dma_dac.dmasize, s->dma_dac.count);
  520. #endif
  521. if (s->dma_dac.mapped) {
  522. s->dma_dac.count += diff;
  523. if (s->dma_dac.count >= (signed)s->dma_dac.fragsize)
  524. wake_up(&s->dma_dac.wait);
  525. } else {
  526. s->dma_dac.count -= diff;
  527. if (s->dma_dac.count <= 0) {
  528. s->ena &= ~FMODE_WRITE;
  529. write_mixer(s, 0x78, 0x12);
  530. s->dma_dac.error++;
  531. } else if (s->dma_dac.count <= (signed)s->dma_dac.fragsize && !s->dma_dac.endcleared) {
  532. clear_advance(s->dma_dac.rawbuf, s->dma_dac.dmasize, s->dma_dac.swptr,
  533.       s->dma_dac.fragsize, (s->fmt & (AFMT_U8 | AFMT_U16_LE)) ? 0 : 0x80);
  534. s->dma_dac.endcleared = 1;
  535. }
  536. if (s->dma_dac.count < (signed)s->dma_dac.dmasize)
  537. wake_up(&s->dma_dac.wait);
  538. }
  539. }
  540. }
  541. /* --------------------------------------------------------------------- */
  542. static void prog_codec(struct solo1_state *s)
  543. {
  544. unsigned long flags;
  545. int fdiv, filter;
  546. unsigned char c;
  547. reset_ctrl(s);
  548. write_seq(s, 0xd3);
  549. /* program sampling rates */
  550. filter = s->rate * 9 / 20; /* Set filter roll-off to 90% of rate/2 */
  551. fdiv = 256 - 7160000 / (filter * 82);
  552. spin_lock_irqsave(&s->lock, flags);
  553. write_ctrl(s, 0xa1, s->clkdiv);
  554. write_ctrl(s, 0xa2, fdiv);
  555. write_mixer(s, 0x70, s->clkdiv);
  556. write_mixer(s, 0x72, fdiv);
  557. /* program ADC parameters */
  558. write_ctrl(s, 0xb8, 0xe);
  559. write_ctrl(s, 0xb9, /*0x1*/0);
  560. write_ctrl(s, 0xa8, (s->channels > 1) ? 0x11 : 0x12);
  561. c = 0xd0;
  562. if (s->fmt & (AFMT_S16_LE | AFMT_U16_LE))
  563. c |= 0x04;
  564. if (s->fmt & (AFMT_S16_LE | AFMT_S8))
  565. c |= 0x20;
  566. if (s->channels > 1)
  567. c ^= 0x48;
  568. write_ctrl(s, 0xb7, (c & 0x70) | 1);
  569. write_ctrl(s, 0xb7, c);
  570. write_ctrl(s, 0xb1, 0x50);
  571. write_ctrl(s, 0xb2, 0x50);
  572. /* program DAC parameters */
  573. c = 0x40;
  574. if (s->fmt & (AFMT_S16_LE | AFMT_U16_LE))
  575. c |= 1;
  576. if (s->fmt & (AFMT_S16_LE | AFMT_S8))
  577. c |= 4;
  578. if (s->channels > 1)
  579. c |= 2;
  580. write_mixer(s, 0x7a, c);
  581. write_mixer(s, 0x78, 0x10);
  582. s->ena = 0;
  583. spin_unlock_irqrestore(&s->lock, flags);
  584. }
  585. /* --------------------------------------------------------------------- */
  586. static const char invalid_magic[] = KERN_CRIT "solo1: invalid magic valuen";
  587. #define VALIDATE_STATE(s)                         
  588. ({                                                
  589. if (!(s) || (s)->magic != SOLO1_MAGIC) { 
  590. printk(invalid_magic);            
  591. return -ENXIO;                    
  592. }                                         
  593. })
  594. /* --------------------------------------------------------------------- */
  595. static int mixer_ioctl(struct solo1_state *s, unsigned int cmd, unsigned long arg)
  596. {
  597. static const unsigned int mixer_src[8] = {
  598. SOUND_MASK_MIC, SOUND_MASK_MIC, SOUND_MASK_CD, SOUND_MASK_VOLUME,
  599. SOUND_MASK_MIC, 0, SOUND_MASK_LINE, 0
  600. };
  601. static const unsigned char mixtable1[SOUND_MIXER_NRDEVICES] = {
  602. [SOUND_MIXER_PCM]     = 1,   /* voice */
  603. [SOUND_MIXER_SYNTH]   = 2,   /* FM */
  604. [SOUND_MIXER_CD]      = 3,   /* CD */
  605. [SOUND_MIXER_LINE]    = 4,   /* Line */
  606. [SOUND_MIXER_LINE1]   = 5,   /* AUX */
  607. [SOUND_MIXER_MIC]     = 6,   /* Mic */
  608. [SOUND_MIXER_LINE2]   = 7,   /* Mono in */
  609. [SOUND_MIXER_SPEAKER] = 8,   /* Speaker */
  610. [SOUND_MIXER_RECLEV]  = 9,   /* Recording level */
  611. [SOUND_MIXER_VOLUME]  = 10   /* Master Volume */
  612. };
  613. static const unsigned char mixreg[] = {
  614. 0x7c,   /* voice */
  615. 0x36,   /* FM */
  616. 0x38,   /* CD */
  617. 0x3e,   /* Line */
  618. 0x3a,   /* AUX */
  619. 0x1a,   /* Mic */
  620. 0x6d    /* Mono in */
  621. };
  622. unsigned char l, r, rl, rr, vidx;
  623. int i, val;
  624. VALIDATE_STATE(s);
  625. if (cmd == SOUND_MIXER_PRIVATE1) {
  626. /* enable/disable/query mixer preamp */
  627. if (get_user(val, (int *)arg))
  628. return -EFAULT;
  629. if (val != -1) {
  630. val = val ? 0xff : 0xf7;
  631. write_mixer(s, 0x7d, (read_mixer(s, 0x7d) | 0x08) & val);
  632. }
  633. val = (read_mixer(s, 0x7d) & 0x08) ? 1 : 0;
  634. return put_user(val, (int *)arg);
  635. }
  636. if (cmd == SOUND_MIXER_PRIVATE2) {
  637. /* enable/disable/query spatializer */
  638. if (get_user(val, (int *)arg))
  639. return -EFAULT;
  640. if (val != -1) {
  641. val &= 0x3f;
  642. write_mixer(s, 0x52, val);
  643. write_mixer(s, 0x50, val ? 0x08 : 0);
  644. }
  645. return put_user(read_mixer(s, 0x52), (int *)arg);
  646. }
  647.         if (cmd == SOUND_MIXER_INFO) {
  648. mixer_info info;
  649. strncpy(info.id, "Solo1", sizeof(info.id));
  650. strncpy(info.name, "ESS Solo1", sizeof(info.name));
  651. info.modify_counter = s->mix.modcnt;
  652. if (copy_to_user((void *)arg, &info, sizeof(info)))
  653. return -EFAULT;
  654. return 0;
  655. }
  656. if (cmd == SOUND_OLD_MIXER_INFO) {
  657. _old_mixer_info info;
  658. strncpy(info.id, "Solo1", sizeof(info.id));
  659. strncpy(info.name, "ESS Solo1", sizeof(info.name));
  660. if (copy_to_user((void *)arg, &info, sizeof(info)))
  661. return -EFAULT;
  662. return 0;
  663. }
  664. if (cmd == OSS_GETVERSION)
  665. return put_user(SOUND_VERSION, (int *)arg);
  666. if (_IOC_TYPE(cmd) != 'M' || _SIOC_SIZE(cmd) != sizeof(int))
  667.                 return -EINVAL;
  668.         if (_SIOC_DIR(cmd) == _SIOC_READ) {
  669.                 switch (_IOC_NR(cmd)) {
  670.                 case SOUND_MIXER_RECSRC: /* Arg contains a bit for each recording source */
  671. return put_user(mixer_src[read_mixer(s, 0x1c) & 7], (int *)arg);
  672.                 case SOUND_MIXER_DEVMASK: /* Arg contains a bit for each supported device */
  673. return put_user(SOUND_MASK_PCM | SOUND_MASK_SYNTH | SOUND_MASK_CD |
  674. SOUND_MASK_LINE | SOUND_MASK_LINE1 | SOUND_MASK_MIC |
  675. SOUND_MASK_VOLUME | SOUND_MASK_LINE2 | SOUND_MASK_RECLEV |
  676. SOUND_MASK_SPEAKER, (int *)arg);
  677.                 case SOUND_MIXER_RECMASK: /* Arg contains a bit for each supported recording source */
  678. return put_user(SOUND_MASK_LINE | SOUND_MASK_MIC | SOUND_MASK_CD | SOUND_MASK_VOLUME, (int *)arg);
  679.                 case SOUND_MIXER_STEREODEVS: /* Mixer channels supporting stereo */
  680. return put_user(SOUND_MASK_PCM | SOUND_MASK_SYNTH | SOUND_MASK_CD |
  681. SOUND_MASK_LINE | SOUND_MASK_LINE1 | SOUND_MASK_MIC |
  682. SOUND_MASK_VOLUME | SOUND_MASK_LINE2 | SOUND_MASK_RECLEV, (int *)arg);
  683.                 case SOUND_MIXER_CAPS:
  684. return put_user(SOUND_CAP_EXCL_INPUT, (int *)arg);
  685. default:
  686. i = _IOC_NR(cmd);
  687.                         if (i >= SOUND_MIXER_NRDEVICES || !(vidx = mixtable1[i]))
  688.                                 return -EINVAL;
  689. return put_user(s->mix.vol[vidx-1], (int *)arg);
  690. }
  691. }
  692.         if (_SIOC_DIR(cmd) != (_SIOC_READ|_SIOC_WRITE)) 
  693. return -EINVAL;
  694. s->mix.modcnt++;
  695. switch (_IOC_NR(cmd)) {
  696. case SOUND_MIXER_RECSRC: /* Arg contains a bit for each recording source */
  697. #if 0
  698.         {
  699. static const unsigned char regs[] = {
  700. 0x1c, 0x1a, 0x36, 0x38, 0x3a, 0x3c, 0x3e, 0x60, 0x62, 0x6d, 0x7c
  701. };
  702. int i;
  703. for (i = 0; i < sizeof(regs); i++)
  704. printk(KERN_DEBUG "solo1: mixer reg 0x%02x: 0x%02xn",
  705.        regs[i], read_mixer(s, regs[i]));
  706. printk(KERN_DEBUG "solo1: ctrl reg 0x%02x: 0x%02xn",
  707.        0xb4, read_ctrl(s, 0xb4));
  708. }
  709. #endif
  710.         if (get_user(val, (int *)arg))
  711. return -EFAULT;
  712.                 i = hweight32(val);
  713.                 if (i == 0)
  714.                         return 0;
  715.                 else if (i > 1) 
  716.                         val &= ~mixer_src[read_mixer(s, 0x1c) & 7];
  717. for (i = 0; i < 8; i++) {
  718. if (mixer_src[i] & val)
  719. break;
  720. }
  721. if (i > 7)
  722. return 0;
  723. write_mixer(s, 0x1c, i);
  724. return 0;
  725. case SOUND_MIXER_VOLUME:
  726. if (get_user(val, (int *)arg))
  727. return -EFAULT;
  728. l = val & 0xff;
  729. if (l > 100)
  730. l = 100;
  731. r = (val >> 8) & 0xff;
  732. if (r > 100)
  733. r = 100;
  734. if (l < 6) {
  735. rl = 0x40;
  736. l = 0;
  737. } else {
  738. rl = (l * 2 - 11) / 3;
  739. l = (rl * 3 + 11) / 2;
  740. }
  741. if (r < 6) {
  742. rr = 0x40;
  743. r = 0;
  744. } else {
  745. rr = (r * 2 - 11) / 3;
  746. r = (rr * 3 + 11) / 2;
  747. }
  748. write_mixer(s, 0x60, rl);
  749. write_mixer(s, 0x62, rr);
  750. #ifdef OSS_DOCUMENTED_MIXER_SEMANTICS
  751.                 s->mix.vol[9] = ((unsigned int)r << 8) | l;
  752. #else
  753.                 s->mix.vol[9] = val;
  754. #endif
  755. return put_user(s->mix.vol[9], (int *)arg);
  756. case SOUND_MIXER_SPEAKER:
  757. if (get_user(val, (int *)arg))
  758. return -EFAULT;
  759. l = val & 0xff;
  760. if (l > 100)
  761. l = 100;
  762. else if (l < 2)
  763. l = 2;
  764. rl = (l - 2) / 14;
  765. l = rl * 14 + 2;
  766. write_mixer(s, 0x3c, rl);
  767. #ifdef OSS_DOCUMENTED_MIXER_SEMANTICS
  768.                 s->mix.vol[7] = l * 0x101;
  769. #else
  770.                 s->mix.vol[7] = val;
  771. #endif
  772. return put_user(s->mix.vol[7], (int *)arg);
  773. case SOUND_MIXER_RECLEV:
  774. if (get_user(val, (int *)arg))
  775. return -EFAULT;
  776. l = (val << 1) & 0x1fe;
  777. if (l > 200)
  778. l = 200;
  779. else if (l < 5)
  780. l = 5;
  781. r = (val >> 7) & 0x1fe;
  782. if (r > 200)
  783. r = 200;
  784. else if (r < 5)
  785. r = 5;
  786. rl = (l - 5) / 13;
  787. rr = (r - 5) / 13;
  788. r = (rl * 13 + 5) / 2;
  789. l = (rr * 13 + 5) / 2;
  790. write_ctrl(s, 0xb4, (rl << 4) | rr);
  791. #ifdef OSS_DOCUMENTED_MIXER_SEMANTICS
  792.                 s->mix.vol[8] = ((unsigned int)r << 8) | l;
  793. #else
  794.                 s->mix.vol[8] = val;
  795. #endif
  796. return put_user(s->mix.vol[8], (int *)arg);
  797. default:
  798. i = _IOC_NR(cmd);
  799. if (i >= SOUND_MIXER_NRDEVICES || !(vidx = mixtable1[i]))
  800. return -EINVAL;
  801. if (get_user(val, (int *)arg))
  802. return -EFAULT;
  803. l = (val << 1) & 0x1fe;
  804. if (l > 200)
  805. l = 200;
  806. else if (l < 5)
  807. l = 5;
  808. r = (val >> 7) & 0x1fe;
  809. if (r > 200)
  810. r = 200;
  811. else if (r < 5)
  812. r = 5;
  813. rl = (l - 5) / 13;
  814. rr = (r - 5) / 13;
  815. r = (rl * 13 + 5) / 2;
  816. l = (rr * 13 + 5) / 2;
  817. write_mixer(s, mixreg[vidx-1], (rl << 4) | rr);
  818. #ifdef OSS_DOCUMENTED_MIXER_SEMANTICS
  819.                 s->mix.vol[vidx-1] = ((unsigned int)r << 8) | l;
  820. #else
  821.                 s->mix.vol[vidx-1] = val;
  822. #endif
  823. return put_user(s->mix.vol[vidx-1], (int *)arg);
  824. }
  825. }
  826. /* --------------------------------------------------------------------- */
  827. static int solo1_open_mixdev(struct inode *inode, struct file *file)
  828. {
  829. int minor = MINOR(inode->i_rdev);
  830. struct solo1_state *s = NULL;
  831. struct pci_dev *pci_dev;
  832. pci_for_each_dev(pci_dev) {
  833. struct pci_driver *drvr;
  834. drvr = pci_dev_driver (pci_dev);
  835. if (drvr != &solo1_driver)
  836. continue;
  837. s = (struct solo1_state*)pci_get_drvdata(pci_dev);
  838. if (!s)
  839. continue;
  840. if (s->dev_mixer == minor)
  841. break;
  842. }
  843. if (!s)
  844. return -ENODEV;
  845.         VALIDATE_STATE(s);
  846. file->private_data = s;
  847. return 0;
  848. }
  849. static int solo1_release_mixdev(struct inode *inode, struct file *file)
  850. {
  851. struct solo1_state *s = (struct solo1_state *)file->private_data;
  852. VALIDATE_STATE(s);
  853. return 0;
  854. }
  855. static int solo1_ioctl_mixdev(struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg)
  856. {
  857. return mixer_ioctl((struct solo1_state *)file->private_data, cmd, arg);
  858. }
  859. static /*const*/ struct file_operations solo1_mixer_fops = {
  860. owner: THIS_MODULE,
  861. llseek: no_llseek,
  862. ioctl: solo1_ioctl_mixdev,
  863. open: solo1_open_mixdev,
  864. release: solo1_release_mixdev,
  865. };
  866. /* --------------------------------------------------------------------- */
  867. static int drain_dac(struct solo1_state *s, int nonblock)
  868. {
  869. DECLARE_WAITQUEUE(wait, current);
  870. unsigned long flags;
  871. int count;
  872. unsigned tmo;
  873. if (s->dma_dac.mapped)
  874. return 0;
  875.         add_wait_queue(&s->dma_dac.wait, &wait);
  876.         for (;;) {
  877. set_current_state(TASK_INTERRUPTIBLE);
  878.                 spin_lock_irqsave(&s->lock, flags);
  879. count = s->dma_dac.count;
  880.                 spin_unlock_irqrestore(&s->lock, flags);
  881. if (count <= 0)
  882. break;
  883. if (signal_pending(current))
  884.                         break;
  885.                 if (nonblock) {
  886.                         remove_wait_queue(&s->dma_dac.wait, &wait);
  887.                         set_current_state(TASK_RUNNING);
  888.                         return -EBUSY;
  889.                 }
  890. tmo = 3 * HZ * (count + s->dma_dac.fragsize) / 2 / s->rate;
  891. if (s->fmt & (AFMT_S16_LE | AFMT_U16_LE))
  892. tmo >>= 1;
  893. if (s->channels > 1)
  894. tmo >>= 1;
  895.                 if (!schedule_timeout(tmo + 1))
  896.                         printk(KERN_DEBUG "solo1: dma timed out??n");
  897.         }
  898.         remove_wait_queue(&s->dma_dac.wait, &wait);
  899.         set_current_state(TASK_RUNNING);
  900.         if (signal_pending(current))
  901.                 return -ERESTARTSYS;
  902.         return 0;
  903. }
  904. /* --------------------------------------------------------------------- */
  905. static ssize_t solo1_read(struct file *file, char *buffer, size_t count, loff_t *ppos)
  906. {
  907. struct solo1_state *s = (struct solo1_state *)file->private_data;
  908. DECLARE_WAITQUEUE(wait, current);
  909. ssize_t ret;
  910. unsigned long flags;
  911. unsigned swptr;
  912. int cnt;
  913. VALIDATE_STATE(s);
  914. if (ppos != &file->f_pos)
  915. return -ESPIPE;
  916. if (s->dma_adc.mapped)
  917. return -ENXIO;
  918. if (!s->dma_adc.ready && (ret = prog_dmabuf_adc(s)))
  919. return ret;
  920. if (!access_ok(VERIFY_WRITE, buffer, count))
  921. return -EFAULT;
  922. ret = 0;
  923. add_wait_queue(&s->dma_adc.wait, &wait);
  924. while (count > 0) {
  925. spin_lock_irqsave(&s->lock, flags);
  926. swptr = s->dma_adc.swptr;
  927. cnt = s->dma_adc.dmasize-swptr;
  928. if (s->dma_adc.count < cnt)
  929. cnt = s->dma_adc.count;
  930. if (cnt <= 0)
  931. __set_current_state(TASK_INTERRUPTIBLE);
  932. spin_unlock_irqrestore(&s->lock, flags);
  933. if (cnt > count)
  934. cnt = count;
  935. #ifdef DEBUGREC
  936. printk(KERN_DEBUG "solo1_read: reg B8: 0x%02x  DMAstat: 0x%02x  DMAcnt: 0x%04x  SBstat: 0x%02x  cnt: %un", 
  937.        read_ctrl(s, 0xb8), inb(s->ddmabase+8), inw(s->ddmabase+4), inb(s->sbbase+0xc), cnt);
  938. #endif
  939. if (cnt <= 0) {
  940. if (s->dma_adc.enabled)
  941. start_adc(s);
  942. #ifdef DEBUGREC
  943. printk(KERN_DEBUG "solo1_read: regs: A1: 0x%02x  A2: 0x%02x  A4: 0x%02x  A5: 0x%02x  A8: 0x%02xn"
  944.        KERN_DEBUG "solo1_read: regs: B1: 0x%02x  B2: 0x%02x  B7: 0x%02x  B8: 0x%02x  B9: 0x%02xn"
  945.        KERN_DEBUG "solo1_read: DMA: addr: 0x%08x cnt: 0x%04x stat: 0x%02x mask: 0x%02xn"  
  946.        KERN_DEBUG "solo1_read: SBstat: 0x%02x  cnt: %un",
  947.        read_ctrl(s, 0xa1), read_ctrl(s, 0xa2), read_ctrl(s, 0xa4), read_ctrl(s, 0xa5), read_ctrl(s, 0xa8), 
  948.        read_ctrl(s, 0xb1), read_ctrl(s, 0xb2), read_ctrl(s, 0xb7), read_ctrl(s, 0xb8), read_ctrl(s, 0xb9), 
  949.        inl(s->ddmabase), inw(s->ddmabase+4), inb(s->ddmabase+8), inb(s->ddmabase+15), inb(s->sbbase+0xc), cnt);
  950. #endif
  951. if (inb(s->ddmabase+15) & 1)
  952. printk(KERN_ERR "solo1: cannot start recording, DDMA mask bit stuck at 1n");
  953. if (file->f_flags & O_NONBLOCK) {
  954. if (!ret)
  955. ret = -EAGAIN;
  956. break;
  957. }
  958. schedule();
  959. #ifdef DEBUGREC
  960. printk(KERN_DEBUG "solo1_read: regs: A1: 0x%02x  A2: 0x%02x  A4: 0x%02x  A5: 0x%02x  A8: 0x%02xn"
  961.        KERN_DEBUG "solo1_read: regs: B1: 0x%02x  B2: 0x%02x  B7: 0x%02x  B8: 0x%02x  B9: 0x%02xn"
  962.        KERN_DEBUG "solo1_read: DMA: addr: 0x%08x cnt: 0x%04x stat: 0x%02x mask: 0x%02xn"  
  963.        KERN_DEBUG "solo1_read: SBstat: 0x%02x  cnt: %un",
  964.        read_ctrl(s, 0xa1), read_ctrl(s, 0xa2), read_ctrl(s, 0xa4), read_ctrl(s, 0xa5), read_ctrl(s, 0xa8), 
  965.        read_ctrl(s, 0xb1), read_ctrl(s, 0xb2), read_ctrl(s, 0xb7), read_ctrl(s, 0xb8), read_ctrl(s, 0xb9), 
  966.        inl(s->ddmabase), inw(s->ddmabase+4), inb(s->ddmabase+8), inb(s->ddmabase+15), inb(s->sbbase+0xc), cnt);
  967. #endif
  968. if (signal_pending(current)) {
  969. if (!ret)
  970. ret = -ERESTARTSYS;
  971. break;
  972. }
  973. continue;
  974. }
  975. if (copy_to_user(buffer, s->dma_adc.rawbuf + swptr, cnt)) {
  976. if (!ret)
  977. ret = -EFAULT;
  978. break;
  979. }
  980. swptr = (swptr + cnt) % s->dma_adc.dmasize;
  981. spin_lock_irqsave(&s->lock, flags);
  982. s->dma_adc.swptr = swptr;
  983. s->dma_adc.count -= cnt;
  984. spin_unlock_irqrestore(&s->lock, flags);
  985. count -= cnt;
  986. buffer += cnt;
  987. ret += cnt;
  988. if (s->dma_adc.enabled)
  989. start_adc(s);
  990. #ifdef DEBUGREC
  991. printk(KERN_DEBUG "solo1_read: reg B8: 0x%02x  DMAstat: 0x%02x  DMAcnt: 0x%04x  SBstat: 0x%02xn", 
  992.        read_ctrl(s, 0xb8), inb(s->ddmabase+8), inw(s->ddmabase+4), inb(s->sbbase+0xc));
  993. #endif
  994. }
  995. remove_wait_queue(&s->dma_adc.wait, &wait);
  996. set_current_state(TASK_RUNNING);
  997. return ret;
  998. }
  999. static ssize_t solo1_write(struct file *file, const char *buffer, size_t count, loff_t *ppos)
  1000. {
  1001. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1002. DECLARE_WAITQUEUE(wait, current);
  1003. ssize_t ret;
  1004. unsigned long flags;
  1005. unsigned swptr;
  1006. int cnt;
  1007. VALIDATE_STATE(s);
  1008. if (ppos != &file->f_pos)
  1009. return -ESPIPE;
  1010. if (s->dma_dac.mapped)
  1011. return -ENXIO;
  1012. if (!s->dma_dac.ready && (ret = prog_dmabuf_dac(s)))
  1013. return ret;
  1014. if (!access_ok(VERIFY_READ, buffer, count))
  1015. return -EFAULT;
  1016. #if 0
  1017. printk(KERN_DEBUG "solo1_write: reg 70: 0x%02x  71: 0x%02x  72: 0x%02x  74: 0x%02x  76: 0x%02x  78: 0x%02x  7A: 0x%02xn"
  1018.        KERN_DEBUG "solo1_write: DMA: addr: 0x%08x  cnt: 0x%04x  stat: 0x%02x  SBstat: 0x%02xn", 
  1019.        read_mixer(s, 0x70), read_mixer(s, 0x71), read_mixer(s, 0x72), read_mixer(s, 0x74), read_mixer(s, 0x76),
  1020.        read_mixer(s, 0x78), read_mixer(s, 0x7a), inl(s->iobase), inw(s->iobase+4), inb(s->iobase+6), inb(s->sbbase+0xc));
  1021. printk(KERN_DEBUG "solo1_write: reg 78: 0x%02x  reg 7A: 0x%02x  DMAcnt: 0x%04x  DMAstat: 0x%02x  SBstat: 0x%02xn", 
  1022.        read_mixer(s, 0x78), read_mixer(s, 0x7a), inw(s->iobase+4), inb(s->iobase+6), inb(s->sbbase+0xc));
  1023. #endif
  1024. ret = 0;
  1025. add_wait_queue(&s->dma_dac.wait, &wait);
  1026. while (count > 0) {
  1027. spin_lock_irqsave(&s->lock, flags);
  1028. if (s->dma_dac.count < 0) {
  1029. s->dma_dac.count = 0;
  1030. s->dma_dac.swptr = s->dma_dac.hwptr;
  1031. }
  1032. swptr = s->dma_dac.swptr;
  1033. cnt = s->dma_dac.dmasize-swptr;
  1034. if (s->dma_dac.count + cnt > s->dma_dac.dmasize)
  1035. cnt = s->dma_dac.dmasize - s->dma_dac.count;
  1036. if (cnt <= 0)
  1037. __set_current_state(TASK_INTERRUPTIBLE);
  1038. spin_unlock_irqrestore(&s->lock, flags);
  1039. if (cnt > count)
  1040. cnt = count;
  1041. if (cnt <= 0) {
  1042. if (s->dma_dac.enabled)
  1043. start_dac(s);
  1044. if (file->f_flags & O_NONBLOCK) {
  1045. if (!ret)
  1046. ret = -EAGAIN;
  1047. break;
  1048. }
  1049. schedule();
  1050. if (signal_pending(current)) {
  1051. if (!ret)
  1052. ret = -ERESTARTSYS;
  1053. break;
  1054. }
  1055. continue;
  1056. }
  1057. if (copy_from_user(s->dma_dac.rawbuf + swptr, buffer, cnt)) {
  1058. if (!ret)
  1059. ret = -EFAULT;
  1060. break;
  1061. }
  1062. swptr = (swptr + cnt) % s->dma_dac.dmasize;
  1063. spin_lock_irqsave(&s->lock, flags);
  1064. s->dma_dac.swptr = swptr;
  1065. s->dma_dac.count += cnt;
  1066. s->dma_dac.endcleared = 0;
  1067. spin_unlock_irqrestore(&s->lock, flags);
  1068. count -= cnt;
  1069. buffer += cnt;
  1070. ret += cnt;
  1071. if (s->dma_dac.enabled)
  1072. start_dac(s);
  1073. }
  1074. remove_wait_queue(&s->dma_dac.wait, &wait);
  1075. set_current_state(TASK_RUNNING);
  1076. return ret;
  1077. }
  1078. /* No kernel lock - we have our own spinlock */
  1079. static unsigned int solo1_poll(struct file *file, struct poll_table_struct *wait)
  1080. {
  1081. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1082. unsigned long flags;
  1083. unsigned int mask = 0;
  1084. VALIDATE_STATE(s);
  1085. if (file->f_mode & FMODE_WRITE) {
  1086. if (!s->dma_dac.ready && prog_dmabuf_dac(s))
  1087. return 0;
  1088. poll_wait(file, &s->dma_dac.wait, wait);
  1089. }
  1090. if (file->f_mode & FMODE_READ) {
  1091. if (!s->dma_adc.ready && prog_dmabuf_adc(s))
  1092. return 0;
  1093. poll_wait(file, &s->dma_adc.wait, wait);
  1094. }
  1095. spin_lock_irqsave(&s->lock, flags);
  1096. solo1_update_ptr(s);
  1097. if (file->f_mode & FMODE_READ) {
  1098. if (s->dma_adc.mapped) {
  1099. if (s->dma_adc.count >= (signed)s->dma_adc.fragsize)
  1100. mask |= POLLIN | POLLRDNORM;
  1101. } else {
  1102. if (s->dma_adc.count > 0)
  1103. mask |= POLLIN | POLLRDNORM;
  1104. }
  1105. }
  1106. if (file->f_mode & FMODE_WRITE) {
  1107. if (s->dma_dac.mapped) {
  1108. if (s->dma_dac.count >= (signed)s->dma_dac.fragsize) 
  1109. mask |= POLLOUT | POLLWRNORM;
  1110. } else {
  1111. if ((signed)s->dma_dac.dmasize > s->dma_dac.count)
  1112. mask |= POLLOUT | POLLWRNORM;
  1113. }
  1114. }
  1115. spin_unlock_irqrestore(&s->lock, flags);
  1116. return mask;
  1117. }
  1118. static int solo1_mmap(struct file *file, struct vm_area_struct *vma)
  1119. {
  1120. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1121. struct dmabuf *db;
  1122. int ret = -EINVAL;
  1123. unsigned long size;
  1124. VALIDATE_STATE(s);
  1125. lock_kernel();
  1126. if (vma->vm_flags & VM_WRITE) {
  1127. if ((ret = prog_dmabuf_dac(s)) != 0)
  1128. goto out;
  1129. db = &s->dma_dac;
  1130. } else if (vma->vm_flags & VM_READ) {
  1131. if ((ret = prog_dmabuf_adc(s)) != 0)
  1132. goto out;
  1133. db = &s->dma_adc;
  1134. } else 
  1135. goto out;
  1136. ret = -EINVAL;
  1137. if (vma->vm_pgoff != 0)
  1138. goto out;
  1139. size = vma->vm_end - vma->vm_start;
  1140. if (size > (PAGE_SIZE << db->buforder))
  1141. goto out;
  1142. ret = -EAGAIN;
  1143. if (remap_page_range(vma->vm_start, virt_to_phys(db->rawbuf), size, vma->vm_page_prot))
  1144. goto out;
  1145. db->mapped = 1;
  1146. ret = 0;
  1147. out:
  1148. unlock_kernel();
  1149. return ret;
  1150. }
  1151. static int solo1_ioctl(struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg)
  1152. {
  1153. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1154. unsigned long flags;
  1155.         audio_buf_info abinfo;
  1156.         count_info cinfo;
  1157. int val, mapped, ret, count;
  1158.         int div1, div2;
  1159.         unsigned rate1, rate2;
  1160. VALIDATE_STATE(s);
  1161.         mapped = ((file->f_mode & FMODE_WRITE) && s->dma_dac.mapped) ||
  1162. ((file->f_mode & FMODE_READ) && s->dma_adc.mapped);
  1163. switch (cmd) {
  1164. case OSS_GETVERSION:
  1165. return put_user(SOUND_VERSION, (int *)arg);
  1166. case SNDCTL_DSP_SYNC:
  1167. if (file->f_mode & FMODE_WRITE)
  1168. return drain_dac(s, 0/*file->f_flags & O_NONBLOCK*/);
  1169. return 0;
  1170. case SNDCTL_DSP_SETDUPLEX:
  1171. return 0;
  1172. case SNDCTL_DSP_GETCAPS:
  1173. return put_user(DSP_CAP_DUPLEX | DSP_CAP_REALTIME | DSP_CAP_TRIGGER | DSP_CAP_MMAP, (int *)arg);
  1174.         case SNDCTL_DSP_RESET:
  1175. if (file->f_mode & FMODE_WRITE) {
  1176. stop_dac(s);
  1177. synchronize_irq();
  1178. s->dma_dac.swptr = s->dma_dac.hwptr = s->dma_dac.count = s->dma_dac.total_bytes = 0;
  1179. }
  1180. if (file->f_mode & FMODE_READ) {
  1181. stop_adc(s);
  1182. synchronize_irq();
  1183. s->dma_adc.swptr = s->dma_adc.hwptr = s->dma_adc.count = s->dma_adc.total_bytes = 0;
  1184. }
  1185. prog_codec(s);
  1186. return 0;
  1187.         case SNDCTL_DSP_SPEED:
  1188.                 if (get_user(val, (int *)arg))
  1189. return -EFAULT;
  1190. if (val >= 0) {
  1191. stop_adc(s);
  1192. stop_dac(s);
  1193. s->dma_adc.ready = s->dma_dac.ready = 0;
  1194. /* program sampling rates */
  1195. if (val > 48000)
  1196. val = 48000;
  1197. if (val < 6300)
  1198. val = 6300;
  1199. div1 = (768000 + val / 2) / val;
  1200. rate1 = (768000 + div1 / 2) / div1;
  1201. div1 = -div1;
  1202. div2 = (793800 + val / 2) / val;
  1203. rate2 = (793800 + div2 / 2) / div2;
  1204. div2 = (-div2) & 0x7f;
  1205. if (abs(val - rate2) < abs(val - rate1)) {
  1206. rate1 = rate2;
  1207. div1 = div2;
  1208. }
  1209. s->rate = rate1;
  1210. s->clkdiv = div1;
  1211. prog_codec(s);
  1212. }
  1213. return put_user(s->rate, (int *)arg);
  1214.         case SNDCTL_DSP_STEREO:
  1215.                 if (get_user(val, (int *)arg))
  1216. return -EFAULT;
  1217. stop_adc(s);
  1218. stop_dac(s);
  1219. s->dma_adc.ready = s->dma_dac.ready = 0;
  1220. /* program channels */
  1221. s->channels = val ? 2 : 1;
  1222. prog_codec(s);
  1223. return 0;
  1224.         case SNDCTL_DSP_CHANNELS:
  1225.                 if (get_user(val, (int *)arg))
  1226. return -EFAULT;
  1227. if (val != 0) {
  1228. stop_adc(s);
  1229. stop_dac(s);
  1230. s->dma_adc.ready = s->dma_dac.ready = 0;
  1231. /* program channels */
  1232. s->channels = (val >= 2) ? 2 : 1;
  1233. prog_codec(s);
  1234. }
  1235. return put_user(s->channels, (int *)arg);
  1236. case SNDCTL_DSP_GETFMTS: /* Returns a mask */
  1237.                 return put_user(AFMT_S16_LE|AFMT_U16_LE|AFMT_S8|AFMT_U8, (int *)arg);
  1238. case SNDCTL_DSP_SETFMT: /* Selects ONE fmt*/
  1239. if (get_user(val, (int *)arg))
  1240. return -EFAULT;
  1241. if (val != AFMT_QUERY) {
  1242. stop_adc(s);
  1243. stop_dac(s);
  1244. s->dma_adc.ready = s->dma_dac.ready = 0;
  1245. /* program format */
  1246. if (val != AFMT_S16_LE && val != AFMT_U16_LE && 
  1247.     val != AFMT_S8 && val != AFMT_U8)
  1248. val = AFMT_U8;
  1249. s->fmt = val;
  1250. prog_codec(s);
  1251. }
  1252. return put_user(s->fmt, (int *)arg);
  1253. case SNDCTL_DSP_POST:
  1254.                 return 0;
  1255.         case SNDCTL_DSP_GETTRIGGER:
  1256. val = 0;
  1257. if (file->f_mode & s->ena & FMODE_READ)
  1258. val |= PCM_ENABLE_INPUT;
  1259. if (file->f_mode & s->ena & FMODE_WRITE)
  1260. val |= PCM_ENABLE_OUTPUT;
  1261. return put_user(val, (int *)arg);
  1262. case SNDCTL_DSP_SETTRIGGER:
  1263. if (get_user(val, (int *)arg))
  1264. return -EFAULT;
  1265. if (file->f_mode & FMODE_READ) {
  1266. if (val & PCM_ENABLE_INPUT) {
  1267. if (!s->dma_adc.ready && (ret = prog_dmabuf_adc(s)))
  1268. return ret;
  1269. s->dma_dac.enabled = 1;
  1270. start_adc(s);
  1271. if (inb(s->ddmabase+15) & 1)
  1272. printk(KERN_ERR "solo1: cannot start recording, DDMA mask bit stuck at 1n");
  1273. } else {
  1274. s->dma_dac.enabled = 0;
  1275. stop_adc(s);
  1276. }
  1277. }
  1278. if (file->f_mode & FMODE_WRITE) {
  1279. if (val & PCM_ENABLE_OUTPUT) {
  1280. if (!s->dma_dac.ready && (ret = prog_dmabuf_dac(s)))
  1281. return ret;
  1282. s->dma_dac.enabled = 1;
  1283. start_dac(s);
  1284. } else {
  1285. s->dma_dac.enabled = 0;
  1286. stop_dac(s);
  1287. }
  1288. }
  1289. return 0;
  1290. case SNDCTL_DSP_GETOSPACE:
  1291. if (!(file->f_mode & FMODE_WRITE))
  1292. return -EINVAL;
  1293. if (!s->dma_dac.ready && (val = prog_dmabuf_dac(s)) != 0)
  1294. return val;
  1295. spin_lock_irqsave(&s->lock, flags);
  1296. solo1_update_ptr(s);
  1297. abinfo.fragsize = s->dma_dac.fragsize;
  1298. count = s->dma_dac.count;
  1299. if (count < 0)
  1300. count = 0;
  1301.                 abinfo.bytes = s->dma_dac.dmasize - count;
  1302.                 abinfo.fragstotal = s->dma_dac.numfrag;
  1303.                 abinfo.fragments = abinfo.bytes >> s->dma_dac.fragshift;      
  1304. spin_unlock_irqrestore(&s->lock, flags);
  1305. return copy_to_user((void *)arg, &abinfo, sizeof(abinfo)) ? -EFAULT : 0;
  1306. case SNDCTL_DSP_GETISPACE:
  1307. if (!(file->f_mode & FMODE_READ))
  1308. return -EINVAL;
  1309. if (!s->dma_adc.ready && (val = prog_dmabuf_adc(s)) != 0)
  1310. return val;
  1311. spin_lock_irqsave(&s->lock, flags);
  1312. solo1_update_ptr(s);
  1313. abinfo.fragsize = s->dma_adc.fragsize;
  1314.                 abinfo.bytes = s->dma_adc.count;
  1315.                 abinfo.fragstotal = s->dma_adc.numfrag;
  1316.                 abinfo.fragments = abinfo.bytes >> s->dma_adc.fragshift;      
  1317. spin_unlock_irqrestore(&s->lock, flags);
  1318. return copy_to_user((void *)arg, &abinfo, sizeof(abinfo)) ? -EFAULT : 0;
  1319.         case SNDCTL_DSP_NONBLOCK:
  1320.                 file->f_flags |= O_NONBLOCK;
  1321.                 return 0;
  1322.         case SNDCTL_DSP_GETODELAY:
  1323. if (!(file->f_mode & FMODE_WRITE))
  1324. return -EINVAL;
  1325. if (!s->dma_dac.ready && (val = prog_dmabuf_dac(s)) != 0)
  1326. return val;
  1327. spin_lock_irqsave(&s->lock, flags);
  1328. solo1_update_ptr(s);
  1329.                 count = s->dma_dac.count;
  1330. spin_unlock_irqrestore(&s->lock, flags);
  1331. if (count < 0)
  1332. count = 0;
  1333. return put_user(count, (int *)arg);
  1334.         case SNDCTL_DSP_GETIPTR:
  1335. if (!(file->f_mode & FMODE_READ))
  1336. return -EINVAL;
  1337. if (!s->dma_adc.ready && (val = prog_dmabuf_adc(s)) != 0)
  1338. return val;
  1339. spin_lock_irqsave(&s->lock, flags);
  1340. solo1_update_ptr(s);
  1341.                 cinfo.bytes = s->dma_adc.total_bytes;
  1342.                 cinfo.blocks = s->dma_adc.count >> s->dma_adc.fragshift;
  1343.                 cinfo.ptr = s->dma_adc.hwptr;
  1344. if (s->dma_adc.mapped)
  1345. s->dma_adc.count &= s->dma_adc.fragsize-1;
  1346. spin_unlock_irqrestore(&s->lock, flags);
  1347.                 return copy_to_user((void *)arg, &cinfo, sizeof(cinfo));
  1348.         case SNDCTL_DSP_GETOPTR:
  1349. if (!(file->f_mode & FMODE_WRITE))
  1350. return -EINVAL;
  1351. if (!s->dma_dac.ready && (val = prog_dmabuf_dac(s)) != 0)
  1352. return val;
  1353. spin_lock_irqsave(&s->lock, flags);
  1354. solo1_update_ptr(s);
  1355.                 cinfo.bytes = s->dma_dac.total_bytes;
  1356. count = s->dma_dac.count;
  1357. if (count < 0)
  1358. count = 0;
  1359.                 cinfo.blocks = count >> s->dma_dac.fragshift;
  1360.                 cinfo.ptr = s->dma_dac.hwptr;
  1361. if (s->dma_dac.mapped)
  1362. s->dma_dac.count &= s->dma_dac.fragsize-1;
  1363. spin_unlock_irqrestore(&s->lock, flags);
  1364. #if 0
  1365. printk(KERN_DEBUG "esssolo1: GETOPTR: bytes %u blocks %u ptr %u, buforder %u numfrag %u fragshift %un"
  1366.        KERN_DEBUG "esssolo1: swptr %u count %u fragsize %u dmasize %u fragsamples %un",
  1367.        cinfo.bytes, cinfo.blocks, cinfo.ptr, s->dma_dac.buforder, s->dma_dac.numfrag, s->dma_dac.fragshift,
  1368.        s->dma_dac.swptr, s->dma_dac.count, s->dma_dac.fragsize, s->dma_dac.dmasize, s->dma_dac.fragsamples);
  1369. #endif
  1370.                 return copy_to_user((void *)arg, &cinfo, sizeof(cinfo));
  1371.         case SNDCTL_DSP_GETBLKSIZE:
  1372. if (file->f_mode & FMODE_WRITE) {
  1373. if ((val = prog_dmabuf_dac(s)))
  1374. return val;
  1375. return put_user(s->dma_dac.fragsize, (int *)arg);
  1376. }
  1377. if ((val = prog_dmabuf_adc(s)))
  1378. return val;
  1379. return put_user(s->dma_adc.fragsize, (int *)arg);
  1380.         case SNDCTL_DSP_SETFRAGMENT:
  1381.                 if (get_user(val, (int *)arg))
  1382. return -EFAULT;
  1383. if (file->f_mode & FMODE_READ) {
  1384. s->dma_adc.ossfragshift = val & 0xffff;
  1385. s->dma_adc.ossmaxfrags = (val >> 16) & 0xffff;
  1386. if (s->dma_adc.ossfragshift < 4)
  1387. s->dma_adc.ossfragshift = 4;
  1388. if (s->dma_adc.ossfragshift > 15)
  1389. s->dma_adc.ossfragshift = 15;
  1390. if (s->dma_adc.ossmaxfrags < 4)
  1391. s->dma_adc.ossmaxfrags = 4;
  1392. }
  1393. if (file->f_mode & FMODE_WRITE) {
  1394. s->dma_dac.ossfragshift = val & 0xffff;
  1395. s->dma_dac.ossmaxfrags = (val >> 16) & 0xffff;
  1396. if (s->dma_dac.ossfragshift < 4)
  1397. s->dma_dac.ossfragshift = 4;
  1398. if (s->dma_dac.ossfragshift > 15)
  1399. s->dma_dac.ossfragshift = 15;
  1400. if (s->dma_dac.ossmaxfrags < 4)
  1401. s->dma_dac.ossmaxfrags = 4;
  1402. }
  1403. return 0;
  1404.         case SNDCTL_DSP_SUBDIVIDE:
  1405. if ((file->f_mode & FMODE_READ && s->dma_adc.subdivision) ||
  1406.     (file->f_mode & FMODE_WRITE && s->dma_dac.subdivision))
  1407. return -EINVAL;
  1408.                 if (get_user(val, (int *)arg))
  1409. return -EFAULT;
  1410. if (val != 1 && val != 2 && val != 4)
  1411. return -EINVAL;
  1412. if (file->f_mode & FMODE_READ)
  1413. s->dma_adc.subdivision = val;
  1414. if (file->f_mode & FMODE_WRITE)
  1415. s->dma_dac.subdivision = val;
  1416. return 0;
  1417.         case SOUND_PCM_READ_RATE:
  1418. return put_user(s->rate, (int *)arg);
  1419.         case SOUND_PCM_READ_CHANNELS:
  1420. return put_user(s->channels, (int *)arg);
  1421.         case SOUND_PCM_READ_BITS:
  1422. return put_user((s->fmt & (AFMT_S8|AFMT_U8)) ? 8 : 16, (int *)arg);
  1423.         case SOUND_PCM_WRITE_FILTER:
  1424.         case SNDCTL_DSP_SETSYNCRO:
  1425.         case SOUND_PCM_READ_FILTER:
  1426.                 return -EINVAL;
  1427. }
  1428. return mixer_ioctl(s, cmd, arg);
  1429. }
  1430. static int solo1_release(struct inode *inode, struct file *file)
  1431. {
  1432. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1433. VALIDATE_STATE(s);
  1434. lock_kernel();
  1435. if (file->f_mode & FMODE_WRITE)
  1436. drain_dac(s, file->f_flags & O_NONBLOCK);
  1437. down(&s->open_sem);
  1438. if (file->f_mode & FMODE_WRITE) {
  1439. stop_dac(s);
  1440. outb(0, s->iobase+6);  /* disable DMA */
  1441. dealloc_dmabuf(s, &s->dma_dac);
  1442. }
  1443. if (file->f_mode & FMODE_READ) {
  1444. stop_adc(s);
  1445. outb(1, s->ddmabase+0xf); /* mask DMA channel */
  1446. outb(0, s->ddmabase+0xd); /* DMA master clear */
  1447. dealloc_dmabuf(s, &s->dma_adc);
  1448. }
  1449. s->open_mode &= ~(FMODE_READ | FMODE_WRITE);
  1450. wake_up(&s->open_wait);
  1451. up(&s->open_sem);
  1452. unlock_kernel();
  1453. return 0;
  1454. }
  1455. static int solo1_open(struct inode *inode, struct file *file)
  1456. {
  1457. int minor = MINOR(inode->i_rdev);
  1458. DECLARE_WAITQUEUE(wait, current);
  1459. struct solo1_state *s = NULL;
  1460. struct pci_dev *pci_dev;
  1461. pci_for_each_dev(pci_dev) {
  1462. struct pci_driver *drvr;
  1463. drvr = pci_dev_driver(pci_dev);
  1464. if (drvr != &solo1_driver)
  1465. continue;
  1466. s = (struct solo1_state*)pci_get_drvdata(pci_dev);
  1467. if (!s)
  1468. continue;
  1469. if (!((s->dev_audio ^ minor) & ~0xf))
  1470. break;
  1471. }
  1472. if (!s)
  1473. return -ENODEV;
  1474.         VALIDATE_STATE(s);
  1475. file->private_data = s;
  1476. /* wait for device to become free */
  1477. down(&s->open_sem);
  1478. while (s->open_mode & (FMODE_READ | FMODE_WRITE)) {
  1479. if (file->f_flags & O_NONBLOCK) {
  1480. up(&s->open_sem);
  1481. return -EBUSY;
  1482. }
  1483. add_wait_queue(&s->open_wait, &wait);
  1484. __set_current_state(TASK_INTERRUPTIBLE);
  1485. up(&s->open_sem);
  1486. schedule();
  1487. remove_wait_queue(&s->open_wait, &wait);
  1488. set_current_state(TASK_RUNNING);
  1489. if (signal_pending(current))
  1490. return -ERESTARTSYS;
  1491. down(&s->open_sem);
  1492. }
  1493. s->fmt = AFMT_U8;
  1494. s->channels = 1;
  1495. s->rate = 8000;
  1496. s->clkdiv = 96 | 0x80;
  1497. s->ena = 0;
  1498. s->dma_adc.ossfragshift = s->dma_adc.ossmaxfrags = s->dma_adc.subdivision = 0;
  1499. s->dma_adc.enabled = 1;
  1500. s->dma_dac.ossfragshift = s->dma_dac.ossmaxfrags = s->dma_dac.subdivision = 0;
  1501. s->dma_dac.enabled = 1;
  1502. s->open_mode |= file->f_mode & (FMODE_READ | FMODE_WRITE);
  1503. up(&s->open_sem);
  1504. prog_codec(s);
  1505. return 0;
  1506. }
  1507. static /*const*/ struct file_operations solo1_audio_fops = {
  1508. owner: THIS_MODULE,
  1509. llseek: no_llseek,
  1510. read: solo1_read,
  1511. write: solo1_write,
  1512. poll: solo1_poll,
  1513. ioctl: solo1_ioctl,
  1514. mmap: solo1_mmap,
  1515. open: solo1_open,
  1516. release: solo1_release,
  1517. };
  1518. /* --------------------------------------------------------------------- */
  1519. /* hold spinlock for the following! */
  1520. static void solo1_handle_midi(struct solo1_state *s)
  1521. {
  1522. unsigned char ch;
  1523. int wake;
  1524. if (!(s->mpubase))
  1525. return;
  1526. wake = 0;
  1527. while (!(inb(s->mpubase+1) & 0x80)) {
  1528. ch = inb(s->mpubase);
  1529. if (s->midi.icnt < MIDIINBUF) {
  1530. s->midi.ibuf[s->midi.iwr] = ch;
  1531. s->midi.iwr = (s->midi.iwr + 1) % MIDIINBUF;
  1532. s->midi.icnt++;
  1533. }
  1534. wake = 1;
  1535. }
  1536. if (wake)
  1537. wake_up(&s->midi.iwait);
  1538. wake = 0;
  1539. while (!(inb(s->mpubase+1) & 0x40) && s->midi.ocnt > 0) {
  1540. outb(s->midi.obuf[s->midi.ord], s->mpubase);
  1541. s->midi.ord = (s->midi.ord + 1) % MIDIOUTBUF;
  1542. s->midi.ocnt--;
  1543. if (s->midi.ocnt < MIDIOUTBUF-16)
  1544. wake = 1;
  1545. }
  1546. if (wake)
  1547. wake_up(&s->midi.owait);
  1548. }
  1549. static void solo1_interrupt(int irq, void *dev_id, struct pt_regs *regs)
  1550. {
  1551.         struct solo1_state *s = (struct solo1_state *)dev_id;
  1552. unsigned int intsrc;
  1553. /* fastpath out, to ease interrupt sharing */
  1554. intsrc = inb(s->iobase+7); /* get interrupt source(s) */
  1555. if (!intsrc)
  1556. return;
  1557. (void)inb(s->sbbase+0xe);  /* clear interrupt */
  1558. spin_lock(&s->lock);
  1559. /* clear audio interrupts first */
  1560. if (intsrc & 0x20)
  1561. write_mixer(s, 0x7a, read_mixer(s, 0x7a) & 0x7f);
  1562. solo1_update_ptr(s);
  1563. solo1_handle_midi(s);
  1564. spin_unlock(&s->lock);
  1565. }
  1566. static void solo1_midi_timer(unsigned long data)
  1567. {
  1568. struct solo1_state *s = (struct solo1_state *)data;
  1569. unsigned long flags;
  1570. spin_lock_irqsave(&s->lock, flags);
  1571. solo1_handle_midi(s);
  1572. spin_unlock_irqrestore(&s->lock, flags);
  1573. s->midi.timer.expires = jiffies+1;
  1574. add_timer(&s->midi.timer);
  1575. }
  1576. /* --------------------------------------------------------------------- */
  1577. static ssize_t solo1_midi_read(struct file *file, char *buffer, size_t count, loff_t *ppos)
  1578. {
  1579. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1580. DECLARE_WAITQUEUE(wait, current);
  1581. ssize_t ret;
  1582. unsigned long flags;
  1583. unsigned ptr;
  1584. int cnt;
  1585. VALIDATE_STATE(s);
  1586. if (ppos != &file->f_pos)
  1587. return -ESPIPE;
  1588. if (!access_ok(VERIFY_WRITE, buffer, count))
  1589. return -EFAULT;
  1590. if (count == 0)
  1591. return 0;
  1592. ret = 0;
  1593. add_wait_queue(&s->midi.iwait, &wait);
  1594. while (count > 0) {
  1595. spin_lock_irqsave(&s->lock, flags);
  1596. ptr = s->midi.ird;
  1597. cnt = MIDIINBUF - ptr;
  1598. if (s->midi.icnt < cnt)
  1599. cnt = s->midi.icnt;
  1600. if (cnt <= 0)
  1601. __set_current_state(TASK_INTERRUPTIBLE);
  1602. spin_unlock_irqrestore(&s->lock, flags);
  1603. if (cnt > count)
  1604. cnt = count;
  1605. if (cnt <= 0) {
  1606. if (file->f_flags & O_NONBLOCK) {
  1607. if (!ret)
  1608. ret = -EAGAIN;
  1609. break;
  1610. }
  1611. schedule();
  1612. if (signal_pending(current)) {
  1613. if (!ret)
  1614. ret = -ERESTARTSYS;
  1615. break;
  1616. }
  1617. continue;
  1618. }
  1619. if (copy_to_user(buffer, s->midi.ibuf + ptr, cnt)) {
  1620. if (!ret)
  1621. ret = -EFAULT;
  1622. break;
  1623. }
  1624. ptr = (ptr + cnt) % MIDIINBUF;
  1625. spin_lock_irqsave(&s->lock, flags);
  1626. s->midi.ird = ptr;
  1627. s->midi.icnt -= cnt;
  1628. spin_unlock_irqrestore(&s->lock, flags);
  1629. count -= cnt;
  1630. buffer += cnt;
  1631. ret += cnt;
  1632. break;
  1633. }
  1634. __set_current_state(TASK_RUNNING);
  1635. remove_wait_queue(&s->midi.iwait, &wait);
  1636. return ret;
  1637. }
  1638. static ssize_t solo1_midi_write(struct file *file, const char *buffer, size_t count, loff_t *ppos)
  1639. {
  1640. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1641. DECLARE_WAITQUEUE(wait, current);
  1642. ssize_t ret;
  1643. unsigned long flags;
  1644. unsigned ptr;
  1645. int cnt;
  1646. VALIDATE_STATE(s);
  1647. if (ppos != &file->f_pos)
  1648. return -ESPIPE;
  1649. if (!access_ok(VERIFY_READ, buffer, count))
  1650. return -EFAULT;
  1651. if (count == 0)
  1652. return 0;
  1653. ret = 0;
  1654.         add_wait_queue(&s->midi.owait, &wait);
  1655. while (count > 0) {
  1656. spin_lock_irqsave(&s->lock, flags);
  1657. ptr = s->midi.owr;
  1658. cnt = MIDIOUTBUF - ptr;
  1659. if (s->midi.ocnt + cnt > MIDIOUTBUF)
  1660. cnt = MIDIOUTBUF - s->midi.ocnt;
  1661. if (cnt <= 0) {
  1662. __set_current_state(TASK_INTERRUPTIBLE);
  1663. solo1_handle_midi(s);
  1664. }
  1665. spin_unlock_irqrestore(&s->lock, flags);
  1666. if (cnt > count)
  1667. cnt = count;
  1668. if (cnt <= 0) {
  1669. if (file->f_flags & O_NONBLOCK) {
  1670. if (!ret)
  1671. ret = -EAGAIN;
  1672. break;
  1673. }
  1674. schedule();
  1675. if (signal_pending(current)) {
  1676. if (!ret)
  1677. ret = -ERESTARTSYS;
  1678. break;
  1679. }
  1680. continue;
  1681. }
  1682. if (copy_from_user(s->midi.obuf + ptr, buffer, cnt)) {
  1683. if (!ret)
  1684. ret = -EFAULT;
  1685. break;
  1686. }
  1687. ptr = (ptr + cnt) % MIDIOUTBUF;
  1688. spin_lock_irqsave(&s->lock, flags);
  1689. s->midi.owr = ptr;
  1690. s->midi.ocnt += cnt;
  1691. spin_unlock_irqrestore(&s->lock, flags);
  1692. count -= cnt;
  1693. buffer += cnt;
  1694. ret += cnt;
  1695. spin_lock_irqsave(&s->lock, flags);
  1696. solo1_handle_midi(s);
  1697. spin_unlock_irqrestore(&s->lock, flags);
  1698. }
  1699. __set_current_state(TASK_RUNNING);
  1700. remove_wait_queue(&s->midi.owait, &wait);
  1701. return ret;
  1702. }
  1703. /* No kernel lock - we have our own spinlock */
  1704. static unsigned int solo1_midi_poll(struct file *file, struct poll_table_struct *wait)
  1705. {
  1706. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1707. unsigned long flags;
  1708. unsigned int mask = 0;
  1709. VALIDATE_STATE(s);
  1710. if (file->f_flags & FMODE_WRITE)
  1711. poll_wait(file, &s->midi.owait, wait);
  1712. if (file->f_flags & FMODE_READ)
  1713. poll_wait(file, &s->midi.iwait, wait);
  1714. spin_lock_irqsave(&s->lock, flags);
  1715. if (file->f_flags & FMODE_READ) {
  1716. if (s->midi.icnt > 0)
  1717. mask |= POLLIN | POLLRDNORM;
  1718. }
  1719. if (file->f_flags & FMODE_WRITE) {
  1720. if (s->midi.ocnt < MIDIOUTBUF)
  1721. mask |= POLLOUT | POLLWRNORM;
  1722. }
  1723. spin_unlock_irqrestore(&s->lock, flags);
  1724. return mask;
  1725. }
  1726. static int solo1_midi_open(struct inode *inode, struct file *file)
  1727. {
  1728. int minor = MINOR(inode->i_rdev);
  1729. DECLARE_WAITQUEUE(wait, current);
  1730. unsigned long flags;
  1731. struct solo1_state *s = NULL;
  1732. struct pci_dev *pci_dev;
  1733. pci_for_each_dev(pci_dev) {
  1734. struct pci_driver *drvr;
  1735. drvr = pci_dev_driver(pci_dev);
  1736. if (drvr != &solo1_driver)
  1737. continue;
  1738. s = (struct solo1_state*)pci_get_drvdata(pci_dev);
  1739. if (!s)
  1740. continue;
  1741. if (s->dev_midi == minor)
  1742. break;
  1743. }
  1744. if (!s)
  1745. return -ENODEV;
  1746.         VALIDATE_STATE(s);
  1747. file->private_data = s;
  1748. /* wait for device to become free */
  1749. down(&s->open_sem);
  1750. while (s->open_mode & (file->f_mode << FMODE_MIDI_SHIFT)) {
  1751. if (file->f_flags & O_NONBLOCK) {
  1752. up(&s->open_sem);
  1753. return -EBUSY;
  1754. }
  1755. add_wait_queue(&s->open_wait, &wait);
  1756. __set_current_state(TASK_INTERRUPTIBLE);
  1757. up(&s->open_sem);
  1758. schedule();
  1759. remove_wait_queue(&s->open_wait, &wait);
  1760. set_current_state(TASK_RUNNING);
  1761. if (signal_pending(current))
  1762. return -ERESTARTSYS;
  1763. down(&s->open_sem);
  1764. }
  1765. spin_lock_irqsave(&s->lock, flags);
  1766. if (!(s->open_mode & (FMODE_MIDI_READ | FMODE_MIDI_WRITE))) {
  1767. s->midi.ird = s->midi.iwr = s->midi.icnt = 0;
  1768. s->midi.ord = s->midi.owr = s->midi.ocnt = 0;
  1769. outb(0xff, s->mpubase+1); /* reset command */
  1770. outb(0x3f, s->mpubase+1); /* uart command */
  1771. if (!(inb(s->mpubase+1) & 0x80))
  1772. inb(s->mpubase);
  1773. s->midi.ird = s->midi.iwr = s->midi.icnt = 0;
  1774. outb(0xb0, s->iobase + 7); /* enable A1, A2, MPU irq's */
  1775. init_timer(&s->midi.timer);
  1776. s->midi.timer.expires = jiffies+1;
  1777. s->midi.timer.data = (unsigned long)s;
  1778. s->midi.timer.function = solo1_midi_timer;
  1779. add_timer(&s->midi.timer);
  1780. }
  1781. if (file->f_mode & FMODE_READ) {
  1782. s->midi.ird = s->midi.iwr = s->midi.icnt = 0;
  1783. }
  1784. if (file->f_mode & FMODE_WRITE) {
  1785. s->midi.ord = s->midi.owr = s->midi.ocnt = 0;
  1786. }
  1787. spin_unlock_irqrestore(&s->lock, flags);
  1788. s->open_mode |= (file->f_mode << FMODE_MIDI_SHIFT) & (FMODE_MIDI_READ | FMODE_MIDI_WRITE);
  1789. up(&s->open_sem);
  1790. return 0;
  1791. }
  1792. static int solo1_midi_release(struct inode *inode, struct file *file)
  1793. {
  1794. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1795. DECLARE_WAITQUEUE(wait, current);
  1796. unsigned long flags;
  1797. unsigned count, tmo;
  1798. VALIDATE_STATE(s);
  1799. lock_kernel();
  1800. if (file->f_mode & FMODE_WRITE) {
  1801. add_wait_queue(&s->midi.owait, &wait);
  1802. for (;;) {
  1803. __set_current_state(TASK_INTERRUPTIBLE);
  1804. spin_lock_irqsave(&s->lock, flags);
  1805. count = s->midi.ocnt;
  1806. spin_unlock_irqrestore(&s->lock, flags);
  1807. if (count <= 0)
  1808. break;
  1809. if (signal_pending(current))
  1810. break;
  1811. if (file->f_flags & O_NONBLOCK)
  1812. break;
  1813. tmo = (count * HZ) / 3100;
  1814. if (!schedule_timeout(tmo ? : 1) && tmo)
  1815. printk(KERN_DEBUG "solo1: midi timed out??n");
  1816. }
  1817. remove_wait_queue(&s->midi.owait, &wait);
  1818. set_current_state(TASK_RUNNING);
  1819. }
  1820. down(&s->open_sem);
  1821. s->open_mode &= (~(file->f_mode << FMODE_MIDI_SHIFT)) & (FMODE_MIDI_READ|FMODE_MIDI_WRITE);
  1822. spin_lock_irqsave(&s->lock, flags);
  1823. if (!(s->open_mode & (FMODE_MIDI_READ | FMODE_MIDI_WRITE))) {
  1824. outb(0x30, s->iobase + 7); /* enable A1, A2 irq's */
  1825. del_timer(&s->midi.timer);
  1826. }
  1827. spin_unlock_irqrestore(&s->lock, flags);
  1828. wake_up(&s->open_wait);
  1829. up(&s->open_sem);
  1830. unlock_kernel();
  1831. return 0;
  1832. }
  1833. static /*const*/ struct file_operations solo1_midi_fops = {
  1834. owner: THIS_MODULE,
  1835. llseek: no_llseek,
  1836. read: solo1_midi_read,
  1837. write: solo1_midi_write,
  1838. poll: solo1_midi_poll,
  1839. open: solo1_midi_open,
  1840. release: solo1_midi_release,
  1841. };
  1842. /* --------------------------------------------------------------------- */
  1843. static int solo1_dmfm_ioctl(struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg)
  1844. {
  1845. static const unsigned char op_offset[18] = {
  1846. 0x00, 0x01, 0x02, 0x03, 0x04, 0x05,
  1847. 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D,
  1848. 0x10, 0x11, 0x12, 0x13, 0x14, 0x15
  1849. };
  1850. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1851. struct dm_fm_voice v;
  1852. struct dm_fm_note n;
  1853. struct dm_fm_params p;
  1854. unsigned int io;
  1855. unsigned int regb;
  1856. switch (cmd) {
  1857. case FM_IOCTL_RESET:
  1858. for (regb = 0xb0; regb < 0xb9; regb++) {
  1859. outb(regb, s->sbbase);
  1860. outb(0, s->sbbase+1);
  1861. outb(regb, s->sbbase+2);
  1862. outb(0, s->sbbase+3);
  1863. }
  1864. return 0;
  1865. case FM_IOCTL_PLAY_NOTE:
  1866. if (copy_from_user(&n, (void *)arg, sizeof(n)))
  1867. return -EFAULT;
  1868. if (n.voice >= 18)
  1869. return -EINVAL;
  1870. if (n.voice >= 9) {
  1871. regb = n.voice - 9;
  1872. io = s->sbbase+2;
  1873. } else {
  1874. regb = n.voice;
  1875. io = s->sbbase;
  1876. }
  1877. outb(0xa0 + regb, io);
  1878. outb(n.fnum & 0xff, io+1);
  1879. outb(0xb0 + regb, io);
  1880. outb(((n.fnum >> 8) & 3) | ((n.octave & 7) << 2) | ((n.key_on & 1) << 5), io+1);
  1881. return 0;
  1882. case FM_IOCTL_SET_VOICE:
  1883. if (copy_from_user(&v, (void *)arg, sizeof(v)))
  1884. return -EFAULT;
  1885. if (v.voice >= 18)
  1886. return -EINVAL;
  1887. regb = op_offset[v.voice];
  1888. io = s->sbbase + ((v.op & 1) << 1);
  1889. outb(0x20 + regb, io);
  1890. outb(((v.am & 1) << 7) | ((v.vibrato & 1) << 6) | ((v.do_sustain & 1) << 5) | 
  1891.      ((v.kbd_scale & 1) << 4) | (v.harmonic & 0xf), io+1);
  1892. outb(0x40 + regb, io);
  1893. outb(((v.scale_level & 0x3) << 6) | (v.volume & 0x3f), io+1);
  1894. outb(0x60 + regb, io);
  1895. outb(((v.attack & 0xf) << 4) | (v.decay & 0xf), io+1);
  1896. outb(0x80 + regb, io);
  1897. outb(((v.sustain & 0xf) << 4) | (v.release & 0xf), io+1);
  1898. outb(0xe0 + regb, io);
  1899. outb(v.waveform & 0x7, io+1);
  1900. if (n.voice >= 9) {
  1901. regb = n.voice - 9;
  1902. io = s->sbbase+2;
  1903. } else {
  1904. regb = n.voice;
  1905. io = s->sbbase;
  1906. }
  1907. outb(0xc0 + regb, io);
  1908. outb(((v.right & 1) << 5) | ((v.left & 1) << 4) | ((v.feedback & 7) << 1) |
  1909.      (v.connection & 1), io+1);
  1910. return 0;
  1911. case FM_IOCTL_SET_PARAMS:
  1912. if (copy_from_user(&p, (void *)arg, sizeof(p)))
  1913. return -EFAULT;
  1914. outb(0x08, s->sbbase);
  1915. outb((p.kbd_split & 1) << 6, s->sbbase+1);
  1916. outb(0xbd, s->sbbase);
  1917. outb(((p.am_depth & 1) << 7) | ((p.vib_depth & 1) << 6) | ((p.rhythm & 1) << 5) | ((p.bass & 1) << 4) |
  1918.      ((p.snare & 1) << 3) | ((p.tomtom & 1) << 2) | ((p.cymbal & 1) << 1) | (p.hihat & 1), s->sbbase+1);
  1919. return 0;
  1920. case FM_IOCTL_SET_OPL:
  1921. outb(4, s->sbbase+2);
  1922. outb(arg, s->sbbase+3);
  1923. return 0;
  1924. case FM_IOCTL_SET_MODE:
  1925. outb(5, s->sbbase+2);
  1926. outb(arg & 1, s->sbbase+3);
  1927. return 0;
  1928. default:
  1929. return -EINVAL;
  1930. }
  1931. }
  1932. static int solo1_dmfm_open(struct inode *inode, struct file *file)
  1933. {
  1934. int minor = MINOR(inode->i_rdev);
  1935. DECLARE_WAITQUEUE(wait, current);
  1936. struct solo1_state *s = NULL;
  1937. struct pci_dev *pci_dev;
  1938. pci_for_each_dev(pci_dev) {
  1939. struct pci_driver *drvr;
  1940. drvr = pci_dev_driver(pci_dev);
  1941. if (drvr != &solo1_driver)
  1942. continue;
  1943. s = (struct solo1_state*)pci_get_drvdata(pci_dev);
  1944. if (!s)
  1945. continue;
  1946. if (s->dev_dmfm == minor)
  1947. break;
  1948. }
  1949. if (!s)
  1950. return -ENODEV;
  1951.         VALIDATE_STATE(s);
  1952. file->private_data = s;
  1953. /* wait for device to become free */
  1954. down(&s->open_sem);
  1955. while (s->open_mode & FMODE_DMFM) {
  1956. if (file->f_flags & O_NONBLOCK) {
  1957. up(&s->open_sem);
  1958. return -EBUSY;
  1959. }
  1960. add_wait_queue(&s->open_wait, &wait);
  1961. __set_current_state(TASK_INTERRUPTIBLE);
  1962. up(&s->open_sem);
  1963. schedule();
  1964. remove_wait_queue(&s->open_wait, &wait);
  1965. set_current_state(TASK_RUNNING);
  1966. if (signal_pending(current))
  1967. return -ERESTARTSYS;
  1968. down(&s->open_sem);
  1969. }
  1970. if (!request_region(s->sbbase, FMSYNTH_EXTENT, "ESS Solo1")) {
  1971. up(&s->open_sem);
  1972. printk(KERN_ERR "solo1: FM synth io ports in use, opl3 loaded?n");
  1973. return -EBUSY;
  1974. }
  1975. /* init the stuff */
  1976. outb(1, s->sbbase);
  1977. outb(0x20, s->sbbase+1); /* enable waveforms */
  1978. outb(4, s->sbbase+2);
  1979. outb(0, s->sbbase+3);  /* no 4op enabled */
  1980. outb(5, s->sbbase+2);
  1981. outb(1, s->sbbase+3);  /* enable OPL3 */
  1982. s->open_mode |= FMODE_DMFM;
  1983. up(&s->open_sem);
  1984. return 0;
  1985. }
  1986. static int solo1_dmfm_release(struct inode *inode, struct file *file)
  1987. {
  1988. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1989. unsigned int regb;
  1990. VALIDATE_STATE(s);
  1991. lock_kernel();
  1992. down(&s->open_sem);
  1993. s->open_mode &= ~FMODE_DMFM;
  1994. for (regb = 0xb0; regb < 0xb9; regb++) {
  1995. outb(regb, s->sbbase);
  1996. outb(0, s->sbbase+1);
  1997. outb(regb, s->sbbase+2);
  1998. outb(0, s->sbbase+3);
  1999. }
  2000. release_region(s->sbbase, FMSYNTH_EXTENT);
  2001. wake_up(&s->open_wait);
  2002. up(&s->open_sem);
  2003. unlock_kernel();
  2004. return 0;
  2005. }
  2006. static /*const*/ struct file_operations solo1_dmfm_fops = {
  2007. owner: THIS_MODULE,
  2008. llseek: no_llseek,
  2009. ioctl: solo1_dmfm_ioctl,
  2010. open: solo1_dmfm_open,
  2011. release: solo1_dmfm_release,
  2012. };
  2013. /* --------------------------------------------------------------------- */
  2014. static struct initvol {
  2015. int mixch;
  2016. int vol;
  2017. } initvol[] __initdata = {
  2018. { SOUND_MIXER_WRITE_VOLUME, 0x4040 },
  2019. { SOUND_MIXER_WRITE_PCM, 0x4040 },
  2020. { SOUND_MIXER_WRITE_SYNTH, 0x4040 },
  2021. { SOUND_MIXER_WRITE_CD, 0x4040 },
  2022. { SOUND_MIXER_WRITE_LINE, 0x4040 },
  2023. { SOUND_MIXER_WRITE_LINE1, 0x4040 },
  2024. { SOUND_MIXER_WRITE_LINE2, 0x4040 },
  2025. { SOUND_MIXER_WRITE_RECLEV, 0x4040 },
  2026. { SOUND_MIXER_WRITE_SPEAKER, 0x4040 },
  2027. { SOUND_MIXER_WRITE_MIC, 0x4040 }
  2028. };
  2029. static int setup_solo1(struct solo1_state *s)
  2030. {
  2031. struct pci_dev *pcidev = s->dev;
  2032. mm_segment_t fs;
  2033. int i, val;
  2034. /* initialize DDMA base address */
  2035. printk(KERN_DEBUG "solo1: ddma base address: 0x%lxn", s->ddmabase);
  2036. pci_write_config_word(pcidev, 0x60, (s->ddmabase & (~0xf)) | 1);
  2037. /* set DMA policy to DDMA, IRQ emulation off (CLKRUN disabled for now) */
  2038. pci_write_config_dword(pcidev, 0x50, 0);
  2039. /* disable legacy audio address decode */
  2040. pci_write_config_word(pcidev, 0x40, 0x907f);
  2041. /* initialize the chips */
  2042. if (!reset_ctrl(s)) {
  2043. printk(KERN_ERR "esssolo1: cannot reset controllern");
  2044. return -1;
  2045. }
  2046. outb(0xb0, s->iobase+7); /* enable A1, A2, MPU irq's */
  2047. /* initialize mixer regs */
  2048. write_mixer(s, 0x7f, 0); /* disable music digital recording */
  2049. write_mixer(s, 0x7d, 0x0c); /* enable mic preamp, MONO_OUT is 2nd DAC right channel */
  2050. write_mixer(s, 0x64, 0x45); /* volume control */
  2051. write_mixer(s, 0x48, 0x10); /* enable music DAC/ES6xx interface */
  2052. write_mixer(s, 0x50, 0);  /* disable spatializer */
  2053. write_mixer(s, 0x52, 0);
  2054. write_mixer(s, 0x14, 0);  /* DAC1 minimum volume */
  2055. write_mixer(s, 0x71, 0x20); /* enable new 0xA1 reg format */
  2056. outb(0, s->ddmabase+0xd); /* DMA master clear */
  2057. outb(1, s->ddmabase+0xf); /* mask channel */
  2058. /*outb(0, s->ddmabase+0x8);*/ /* enable controller (enable is low active!!) */
  2059. pci_set_master(pcidev);  /* enable bus mastering */
  2060. fs = get_fs();
  2061. set_fs(KERNEL_DS);
  2062. val = SOUND_MASK_LINE;
  2063. mixer_ioctl(s, SOUND_MIXER_WRITE_RECSRC, (unsigned long)&val);
  2064. for (i = 0; i < sizeof(initvol)/sizeof(initvol[0]); i++) {
  2065. val = initvol[i].vol;
  2066. mixer_ioctl(s, initvol[i].mixch, (unsigned long)&val);
  2067. }
  2068. val = 1; /* enable mic preamp */
  2069. mixer_ioctl(s, SOUND_MIXER_PRIVATE1, (unsigned long)&val);
  2070. set_fs(fs);
  2071. return 0;
  2072. }
  2073. static int
  2074. solo1_suspend(struct pci_dev *pci_dev, u32 state) {
  2075. struct solo1_state *s = (struct solo1_state*)pci_get_drvdata(pci_dev);
  2076. if (!s)
  2077. return 1;
  2078. outb(0, s->iobase+6);
  2079. /* DMA master clear */
  2080. outb(0, s->ddmabase+0xd); 
  2081. /* reset sequencer and FIFO */
  2082. outb(3, s->sbbase+6); 
  2083. /* turn off DDMA controller address space */
  2084. pci_write_config_word(s->dev, 0x60, 0); 
  2085. return 0;
  2086. }
  2087. static int
  2088. solo1_resume(struct pci_dev *pci_dev) {
  2089. struct solo1_state *s = (struct solo1_state*)pci_get_drvdata(pci_dev);
  2090. if (!s)
  2091. return 1;
  2092. setup_solo1(s);
  2093. return 0;
  2094. }
  2095. static int __devinit solo1_probe(struct pci_dev *pcidev, const struct pci_device_id *pciid)
  2096. {
  2097. struct solo1_state *s;
  2098. int ret;
  2099.   if ((ret=pci_enable_device(pcidev)))
  2100. return ret;
  2101. if (!(pci_resource_flags(pcidev, 0) & IORESOURCE_IO) ||
  2102.     !(pci_resource_flags(pcidev, 1) & IORESOURCE_IO) ||
  2103.     !(pci_resource_flags(pcidev, 2) & IORESOURCE_IO) ||
  2104.     !(pci_resource_flags(pcidev, 3) & IORESOURCE_IO))
  2105. return -ENODEV;
  2106. if (pcidev->irq == 0)
  2107. return -ENODEV;
  2108. /* Recording requires 24-bit DMA, so attempt to set dma mask
  2109.  * to 24 bits first, then 32 bits (playback only) if that fails.
  2110.  */
  2111. if (pci_set_dma_mask(pcidev, 0x00ffffff) &&
  2112.     pci_set_dma_mask(pcidev, 0xffffffff)) {
  2113. printk(KERN_WARNING "solo1: architecture does not support 24bit or 32bit PCI busmaster DMAn");
  2114. return -ENODEV;
  2115. }
  2116. if (!(s = kmalloc(sizeof(struct solo1_state), GFP_KERNEL))) {
  2117. printk(KERN_WARNING "solo1: out of memoryn");
  2118. return -ENOMEM;
  2119. }
  2120. memset(s, 0, sizeof(struct solo1_state));
  2121. init_waitqueue_head(&s->dma_adc.wait);
  2122. init_waitqueue_head(&s->dma_dac.wait);
  2123. init_waitqueue_head(&s->open_wait);
  2124. init_waitqueue_head(&s->midi.iwait);
  2125. init_waitqueue_head(&s->midi.owait);
  2126. init_MUTEX(&s->open_sem);
  2127. spin_lock_init(&s->lock);
  2128. s->magic = SOLO1_MAGIC;
  2129. s->dev = pcidev;
  2130. s->iobase = pci_resource_start(pcidev, 0);
  2131. s->sbbase = pci_resource_start(pcidev, 1);
  2132. s->vcbase = pci_resource_start(pcidev, 2);
  2133. s->ddmabase = s->vcbase + DDMABASE_OFFSET;
  2134. s->mpubase = pci_resource_start(pcidev, 3);
  2135. s->gameport.io = pci_resource_start(pcidev, 4);
  2136. s->irq = pcidev->irq;
  2137. ret = -EBUSY;
  2138. if (!request_region(s->iobase, IOBASE_EXTENT, "ESS Solo1")) {
  2139. printk(KERN_ERR "solo1: io ports in usen");
  2140. goto err_region1;
  2141. }
  2142. if (!request_region(s->sbbase+FMSYNTH_EXTENT, SBBASE_EXTENT-FMSYNTH_EXTENT, "ESS Solo1")) {
  2143. printk(KERN_ERR "solo1: io ports in usen");
  2144. goto err_region2;
  2145. }
  2146. if (!request_region(s->ddmabase, DDMABASE_EXTENT, "ESS Solo1")) {
  2147. printk(KERN_ERR "solo1: io ports in usen");
  2148. goto err_region3;
  2149. }
  2150. if (!request_region(s->mpubase, MPUBASE_EXTENT, "ESS Solo1")) {
  2151. printk(KERN_ERR "solo1: io ports in usen");
  2152. goto err_region4;
  2153. }
  2154. if (s->gameport.io && !request_region(s->gameport.io, GAMEPORT_EXTENT, "ESS Solo1")) {
  2155. printk(KERN_ERR "solo1: gameport io ports in usen");
  2156. s->gameport.io = 0;
  2157. }
  2158. if ((ret=request_irq(s->irq,solo1_interrupt,SA_SHIRQ,"ESS Solo1",s))) {
  2159. printk(KERN_ERR "solo1: irq %u in usen", s->irq);
  2160. goto err_irq;
  2161. }
  2162. printk(KERN_INFO "solo1: joystick port at %#xn", s->gameport.io+1);
  2163. /* register devices */
  2164. if ((s->dev_audio = register_sound_dsp(&solo1_audio_fops, -1)) < 0) {
  2165. ret = s->dev_audio;
  2166. goto err_dev1;
  2167. }
  2168. if ((s->dev_mixer = register_sound_mixer(&solo1_mixer_fops, -1)) < 0) {
  2169. ret = s->dev_mixer;
  2170. goto err_dev2;
  2171. }
  2172. if ((s->dev_midi = register_sound_midi(&solo1_midi_fops, -1)) < 0) {
  2173. ret = s->dev_midi;
  2174. goto err_dev3;
  2175. }
  2176. if ((s->dev_dmfm = register_sound_special(&solo1_dmfm_fops, 15 /* ?? */)) < 0) {
  2177. ret = s->dev_dmfm;
  2178. goto err_dev4;
  2179. }
  2180. if (setup_solo1(s)) {
  2181. ret = -EIO;
  2182. goto err;
  2183. }
  2184. /* register gameport */
  2185. gameport_register_port(&s->gameport);
  2186. /* store it in the driver field */
  2187. pci_set_drvdata(pcidev, s);
  2188. return 0;
  2189.  err:
  2190. unregister_sound_dsp(s->dev_dmfm);
  2191.  err_dev4:
  2192. unregister_sound_dsp(s->dev_midi);
  2193.  err_dev3:
  2194. unregister_sound_mixer(s->dev_mixer);
  2195.  err_dev2:
  2196. unregister_sound_dsp(s->dev_audio);
  2197.  err_dev1:
  2198. printk(KERN_ERR "solo1: initialisation errorn");
  2199. free_irq(s->irq, s);
  2200.  err_irq:
  2201. if (s->gameport.io)
  2202. release_region(s->gameport.io, GAMEPORT_EXTENT);
  2203. release_region(s->iobase, IOBASE_EXTENT);
  2204.  err_region4:
  2205. release_region(s->sbbase+FMSYNTH_EXTENT, SBBASE_EXTENT-FMSYNTH_EXTENT);
  2206.  err_region3:
  2207. release_region(s->ddmabase, DDMABASE_EXTENT);
  2208.  err_region2:
  2209. release_region(s->mpubase, MPUBASE_EXTENT);
  2210.  err_region1:
  2211. kfree(s);
  2212. return ret;
  2213. }
  2214. static void __devinit solo1_remove(struct pci_dev *dev)
  2215. {
  2216. struct solo1_state *s = pci_get_drvdata(dev);
  2217. if (!s)
  2218. return;
  2219. /* stop DMA controller */
  2220. outb(0, s->iobase+6);
  2221. outb(0, s->ddmabase+0xd); /* DMA master clear */
  2222. outb(3, s->sbbase+6); /* reset sequencer and FIFO */
  2223. synchronize_irq();
  2224. pci_write_config_word(s->dev, 0x60, 0); /* turn off DDMA controller address space */
  2225. free_irq(s->irq, s);
  2226. if (s->gameport.io) {
  2227. gameport_unregister_port(&s->gameport);
  2228. release_region(s->gameport.io, GAMEPORT_EXTENT);
  2229. }
  2230. release_region(s->iobase, IOBASE_EXTENT);
  2231. release_region(s->sbbase+FMSYNTH_EXTENT, SBBASE_EXTENT-FMSYNTH_EXTENT);
  2232. release_region(s->ddmabase, DDMABASE_EXTENT);
  2233. release_region(s->mpubase, MPUBASE_EXTENT);
  2234. unregister_sound_dsp(s->dev_audio);
  2235. unregister_sound_mixer(s->dev_mixer);
  2236. unregister_sound_midi(s->dev_midi);
  2237. unregister_sound_special(s->dev_dmfm);
  2238. kfree(s);
  2239. pci_set_drvdata(dev, NULL);
  2240. }
  2241. static struct pci_device_id id_table[] __devinitdata = {
  2242. { PCI_VENDOR_ID_ESS, PCI_DEVICE_ID_ESS_SOLO1, PCI_ANY_ID, PCI_ANY_ID, 0, 0 },
  2243. { 0, }
  2244. };
  2245. MODULE_DEVICE_TABLE(pci, id_table);
  2246. static struct pci_driver solo1_driver = {
  2247. name: "ESS Solo1",
  2248. id_table: id_table,
  2249. probe: solo1_probe,
  2250. remove: solo1_remove,
  2251. suspend: solo1_suspend,
  2252. resume: solo1_resume
  2253. };
  2254. static int __init init_solo1(void)
  2255. {
  2256. if (!pci_present())   /* No PCI bus in this machine! */
  2257. return -ENODEV;
  2258. printk(KERN_INFO "solo1: version v0.19 time " __TIME__ " " __DATE__ "n");
  2259. if (!pci_register_driver(&solo1_driver)) {
  2260. pci_unregister_driver(&solo1_driver);
  2261.                 return -ENODEV;
  2262. }
  2263. return 0;
  2264. }
  2265. /* --------------------------------------------------------------------- */
  2266. MODULE_AUTHOR("Thomas M. Sailer, sailer@ife.ee.ethz.ch, hb9jnx@hb9w.che.eu");
  2267. MODULE_DESCRIPTION("ESS Solo1 Driver");
  2268. MODULE_LICENSE("GPL");
  2269. static void __exit cleanup_solo1(void)
  2270. {
  2271. printk(KERN_INFO "solo1: unloadingn");
  2272. pci_unregister_driver(&solo1_driver);
  2273. }
  2274. /* --------------------------------------------------------------------- */
  2275. module_init(init_solo1);
  2276. module_exit(cleanup_solo1);