2 * Support for VIA 82Cxxx Audio Codecs
3 * Copyright 1999,2000 Jeff Garzik <jgarzik@mandrakesoft.com>
5 * Distributed under the GNU GENERAL PUBLIC LICENSE (GPL) Version 2.
6 * See the "COPYING" file distributed with this software for more info.
8 * For a list of known bugs (errata) and documentation,
9 * see via-audio.pdf in linux/Documentation/DocBook.
10 * If this documentation does not exist, run "make pdfdocs".
11 * If "make pdfdocs" fails, obtain the documentation from
12 * the driver's Website at
13 * http://gtf.org/garzik/drivers/via82cxxx/
18 #define VIA_VERSION "1.1.8"
21 #include <linux/config.h>
22 #include <linux/module.h>
23 #include <linux/kernel.h>
25 #include <linux/pci.h>
26 #include <linux/init.h>
27 #include <linux/proc_fs.h>
28 #include <linux/spinlock.h>
29 #include <linux/sound.h>
30 #include <linux/poll.h>
31 #include <linux/soundcard.h>
32 #include <linux/ac97_codec.h>
34 #include <asm/delay.h>
35 #include <asm/uaccess.h>
36 #include <asm/hardirq.h>
38 /* much better to duplicate this value than include
39 * drivers/sound/sound_config.h just for this definition */
40 #define SND_DEV_DSP16 5
43 #undef VIA_DEBUG /* define to enable debugging output and checks */
45 /* note: prints function name for you */
46 #define DPRINTK(fmt, args...) printk(KERN_DEBUG "%s: " fmt, __FUNCTION__ , ## args)
48 #define DPRINTK(fmt, args...)
51 #define VIA_NDEBUG /* define to disable lightweight runtime checks */
55 #define assert(expr) \
57 printk( "Assertion failed! %s,%s,%s,line=%d\n", \
58 #expr,__FILE__,__FUNCTION__,__LINE__); \
62 /* user switch: undefine to exclude /proc data */
65 /* don't mess with this */
66 #ifndef CONFIG_PROC_FS
70 #define arraysize(x) (sizeof(x)/sizeof(*(x)))
76 #define VIA_CARD_NAME "VIA 82Cxxx Audio driver " VIA_VERSION
77 #define VIA_MODULE_NAME "via82cxxx"
78 #define PFX VIA_MODULE_NAME ": "
80 #define VIA_COUNTER_LIMIT 100000
82 /* size of DMA buffers */
83 #define VIA_DMA_BUFFERS 16
84 #define VIA_DMA_BUF_SIZE PAGE_SIZE
86 /* 82C686 function 5 (audio codec) PCI configuration registers */
87 #define VIA_ACLINK_CTRL 0x41
88 #define VIA_FUNC_ENABLE 0x42
89 #define VIA_PNP_CONTROL 0x43
90 #define VIA_FM_NMI_CTRL 0x48
93 * controller base 0 (scatter-gather) registers
95 * NOTE: Via datasheet lists first channel as "read"
96 * channel and second channel as "write" channel.
97 * I changed the naming of the constants to be more
98 * clear than I felt the datasheet to be.
101 #define VIA_BASE0_PCM_OUT_CHAN 0x00 /* output PCM to user */
102 #define VIA_BASE0_PCM_OUT_CHAN_STATUS 0x00
103 #define VIA_BASE0_PCM_OUT_CHAN_CTRL 0x01
104 #define VIA_BASE0_PCM_OUT_CHAN_TYPE 0x02
105 #define VIA_BASE0_PCM_OUT_BLOCK_COUNT 0x0C
107 #define VIA_BASE0_PCM_IN_CHAN 0x10 /* input PCM from user */
108 #define VIA_BASE0_PCM_IN_CHAN_STATUS 0x10
109 #define VIA_BASE0_PCM_IN_CHAN_CTRL 0x11
110 #define VIA_BASE0_PCM_IN_CHAN_TYPE 0x12
112 /* offsets from base */
113 #define VIA_PCM_STATUS 0x00
114 #define VIA_PCM_CONTROL 0x01
115 #define VIA_PCM_TYPE 0x02
116 #define VIA_PCM_TABLE_ADDR 0x04
118 /* XXX unused DMA channel for FM PCM data */
119 #define VIA_BASE0_FM_OUT_CHAN 0x20
120 #define VIA_BASE0_FM_OUT_CHAN_STATUS 0x20
121 #define VIA_BASE0_FM_OUT_CHAN_CTRL 0x21
122 #define VIA_BASE0_FM_OUT_CHAN_TYPE 0x22
124 #define VIA_BASE0_AC97_CTRL 0x80
125 #define VIA_BASE0_SGD_STATUS_SHADOW 0x84
126 #define VIA_BASE0_GPI_INT_ENABLE 0x8C
128 /* VIA_BASE0_AUDIO_xxx_CHAN_TYPE bits */
129 #define VIA_IRQ_ON_FLAG (1<<0) /* int on each flagged scatter block */
130 #define VIA_IRQ_ON_EOL (1<<1) /* int at end of scatter list */
131 #define VIA_INT_SEL_PCI_LAST_LINE_READ (0) /* int at PCI read of last line */
132 #define VIA_INT_SEL_LAST_SAMPLE_SENT (1<<2) /* int at last sample sent */
133 #define VIA_INT_SEL_ONE_LINE_LEFT (1<<3) /* int at less than one line to send */
134 #define VIA_PCM_FMT_STEREO (1<<4) /* PCM stereo format (bit clear == mono) */
135 #define VIA_PCM_FMT_16BIT (1<<5) /* PCM 16-bit format (bit clear == 8-bit) */
136 #define VIA_PCM_FIFO (1<<6) /* enable FIFO? documented as "reserved" */
137 #define VIA_RESTART_SGD_ON_EOL (1<<7) /* restart scatter-gather at EOL */
138 #define VIA_PCM_FMT_MASK (VIA_PCM_FMT_STEREO|VIA_PCM_FMT_16BIT)
139 #define VIA_CHAN_TYPE_MASK (VIA_RESTART_SGD_ON_EOL | \
143 #define VIA_CHAN_TYPE_INT_SELECT (VIA_INT_SEL_LAST_SAMPLE_SENT)
145 /* PCI configuration register bits and masks */
146 #define VIA_CR40_AC97_READY 0x01
147 #define VIA_CR40_AC97_LOW_POWER 0x02
148 #define VIA_CR40_SECONDARY_READY 0x04
150 #define VIA_CR41_AC97_ENABLE 0x80 /* enable AC97 codec */
151 #define VIA_CR41_AC97_RESET 0x40 /* clear bit to reset AC97 */
152 #define VIA_CR41_AC97_WAKEUP 0x20 /* wake up from power-down mode */
153 #define VIA_CR41_AC97_SDO 0x10 /* force Serial Data Out (SDO) high */
154 #define VIA_CR41_VRA 0x08 /* enable variable sample rate */
155 #define VIA_CR41_PCM_ENABLE 0x04 /* AC Link SGD Read Channel PCM Data Output */
156 #define VIA_CR41_FM_PCM_ENABLE 0x02 /* AC Link FM Channel PCM Data Out */
157 #define VIA_CR41_SB_PCM_ENABLE 0x01 /* AC Link SB PCM Data Output */
158 #define VIA_CR41_BOOT_MASK (VIA_CR41_AC97_ENABLE | \
159 VIA_CR41_AC97_WAKEUP | \
161 #define VIA_CR41_RUN_MASK (VIA_CR41_AC97_ENABLE | \
162 VIA_CR41_AC97_RESET | \
166 #define VIA_CR42_SB_ENABLE 0x01
167 #define VIA_CR42_MIDI_ENABLE 0x02
168 #define VIA_CR42_FM_ENABLE 0x04
169 #define VIA_CR42_GAME_ENABLE 0x08
171 #define VIA_CR44_SECOND_CODEC_SUPPORT (1 << 6)
172 #define VIA_CR44_AC_LINK_ACCESS (1 << 7)
174 #define VIA_CR48_FM_TRAP_TO_NMI (1 << 2)
176 /* controller base 0 register bitmasks */
177 #define VIA_INT_DISABLE_MASK (~(0x01|0x02))
178 #define VIA_SGD_STOPPED (1 << 2)
179 #define VIA_SGD_ACTIVE (1 << 7)
180 #define VIA_SGD_TERMINATE (1 << 6)
181 #define VIA_SGD_FLAG (1 << 0)
182 #define VIA_SGD_EOL (1 << 1)
183 #define VIA_SGD_START (1 << 7)
185 #define VIA_CR80_FIRST_CODEC 0
186 #define VIA_CR80_SECOND_CODEC (1 << 30)
187 #define VIA_CR80_FIRST_CODEC_VALID (1 << 25)
188 #define VIA_CR80_VALID (1 << 25)
189 #define VIA_CR80_SECOND_CODEC_VALID (1 << 27)
190 #define VIA_CR80_BUSY (1 << 24)
191 #define VIA_CR83_BUSY (1)
192 #define VIA_CR83_FIRST_CODEC_VALID (1 << 1)
193 #define VIA_CR80_READ (1 << 23)
194 #define VIA_CR80_WRITE_MODE 0
195 #define VIA_CR80_REG_IDX(idx) ((((idx) & 0xFF) >> 1) << 16)
197 /* h r puff n stuff */
198 #define VIA_FMT_STEREO 0x01
199 #define VIA_FMT_16BIT 0x02
200 #define VIA_FMT_MASK 0x03
201 #define VIA_DAC_SHIFT 0
202 #define VIA_ADC_SHIFT 4
204 /* undocumented(?) values for setting rate, from Via's source */
205 #define VIA_SET_RATE_IN 0x00320000 /* set input rate */
206 #define VIA_SET_RATE_OUT 0x002c0000 /* set output rate */
209 /* scatter-gather DMA table entry, exactly as passed to hardware */
210 struct via_sgd_table
{
212 u32 count
; /* includes additional bits also */
214 #define VIA_EOL (1 << 31)
215 #define VIA_FLAG (1 << 30)
218 enum via_channel_states
{
224 struct via_sgd_data
{
226 volatile void *cpuaddr
;
231 unsigned rate
; /* sample rate */
233 u8 pcm_fmt
; /* VIA_PCM_FMT_xxx */
239 volatile struct via_sgd_table
*sgtable
;
240 dma_addr_t sgt_handle
;
242 struct via_sgd_data sgbuf
[VIA_DMA_BUFFERS
];
244 wait_queue_head_t wait
;
250 /* data stored for each chip */
252 struct pci_dev
*pdev
;
255 struct ac97_codec ac97
;
257 int card_num
; /* unique card number, from 0 */
259 int dev_dsp
; /* /dev/dsp index from register_sound_dsp() */
263 wait_queue_head_t open_wait
;
266 struct via_channel ch_in
;
267 struct via_channel ch_out
;
271 /* number of cards, used for assigning unique numbers to cards */
272 static unsigned via_num_cards
= 0;
275 /****************************************************************
282 static int via_init_one (struct pci_dev
*dev
, const struct pci_device_id
*id
);
283 static void via_remove_one (struct pci_dev
*pdev
);
285 static ssize_t
via_dsp_read(struct file
*file
, char *buffer
, size_t count
, loff_t
*ppos
);
286 static ssize_t
via_dsp_write(struct file
*file
, const char *buffer
, size_t count
, loff_t
*ppos
);
287 static unsigned int via_dsp_poll(struct file
*file
, struct poll_table_struct
*wait
);
288 static int via_dsp_ioctl (struct inode
*inode
, struct file
*file
, unsigned int cmd
, unsigned long arg
);
289 static int via_dsp_open (struct inode
*inode
, struct file
*file
);
290 static int via_dsp_release(struct inode
*inode
, struct file
*file
);
292 static u16
via_ac97_read_reg (struct ac97_codec
*codec
, u8 reg
);
293 static void via_ac97_write_reg (struct ac97_codec
*codec
, u8 reg
, u16 value
);
294 static u8
via_ac97_wait_idle (struct via_info
*card
);
296 static void via_chan_free (struct via_info
*card
, struct via_channel
*chan
);
297 static void via_chan_clear (struct via_channel
*chan
);
298 static void via_chan_pcm_fmt (struct via_info
*card
,
299 struct via_channel
*chan
, int reset
);
302 /****************************************************************
304 * Various data the driver needs
310 static struct pci_device_id via_pci_tbl
[] __initdata
= {
311 { PCI_VENDOR_ID_VIA
, PCI_DEVICE_ID_VIA_82C686_5
, PCI_ANY_ID
, PCI_ANY_ID
, },
314 MODULE_DEVICE_TABLE(pci
,via_pci_tbl
);
317 static struct pci_driver via_driver
= {
318 name
: VIA_MODULE_NAME
,
319 id_table
: via_pci_tbl
,
321 remove
: via_remove_one
,
325 /****************************************************************
327 * Low-level base 0 register read/write helpers
333 * via_chan_stop - Terminate DMA on specified PCM channel
334 * @iobase: PCI base address for SGD channel registers
336 * Terminate scatter-gather DMA operation for given
337 * channel (derived from @iobase), if DMA is active.
339 * Note that @iobase is not the PCI base address,
340 * but the PCI base address plus an offset to
341 * one of three PCM channels supported by the chip.
345 static inline void via_chan_stop (int iobase
)
347 if (inb (iobase
+ VIA_PCM_STATUS
) & VIA_SGD_ACTIVE
)
348 outb (VIA_SGD_TERMINATE
, iobase
+ VIA_PCM_CONTROL
);
353 * via_chan_status_clear - Clear status flags on specified DMA channel
354 * @iobase: PCI base address for SGD channel registers
356 * Clear any pending status flags for the given
357 * DMA channel (derived from @iobase), if any
358 * flags are asserted.
360 * Note that @iobase is not the PCI base address,
361 * but the PCI base address plus an offset to
362 * one of three PCM channels supported by the chip.
366 static inline void via_chan_status_clear (int iobase
)
368 u8 tmp
= inb (iobase
+ VIA_PCM_STATUS
);
371 outb (tmp
, iobase
+ VIA_PCM_STATUS
);
376 * sg_begin - Begin recording or playback on a PCM channel
377 * @chan: Channel for which DMA operation shall begin
379 * Start scatter-gather DMA for the given channel.
383 static inline void sg_begin (struct via_channel
*chan
)
385 outb (VIA_SGD_START
, chan
->iobase
+ VIA_PCM_CONTROL
);
390 * via_chan_bufs_in_use - Number of buffers waiting to be consumed
391 * @chan: Channel for which DMA buffers will be counted
393 * Count the number of buffers waiting to be consumed. For a
394 * playback operation, this is the number of buffers which have
395 * yet to be sent to the DAC. For a recording operation, this
396 * is the number of buffers waiting to be consumed by software
397 * calling read() system call.
401 static inline int via_chan_bufs_in_use (struct via_channel
*chan
)
403 return atomic_read(&chan
->next_buf
) -
404 atomic_read(&chan
->buf_in_use
);
409 * via_chan_full - Check for no-free-buffers condition
410 * @chan: Channel for which DMA full condition will be checked
412 * Count the number of buffers waiting to be consumed, and return
413 * true (non-zero) if no buffers are available to be filled on the
418 static inline int via_chan_full (struct via_channel
*chan
)
420 return (via_chan_bufs_in_use (chan
) == VIA_DMA_BUFFERS
);
425 * via_chan_empty - Check for no-buffers-in-use condition
426 * @chan: Channel for which DMA empty condition will be checked
428 * Count the number of buffers waiting to be consumed, and return
429 * true (non-zero) if no buffers are currently in use.
433 static inline int via_chan_empty (struct via_channel
*chan
)
435 return (atomic_read(&chan
->next_buf
) ==
436 atomic_read(&chan
->buf_in_use
));
440 /****************************************************************
442 * Miscellaneous debris
449 * via_stop_everything - Stop all audio operations
450 * @card: Private info for specified board
452 * Stops all DMA operations and interrupts, and clear
453 * any pending status bits resulting from those operations.
456 static void via_stop_everything (struct via_info
*card
)
460 assert (card
!= NULL
);
463 * terminate any existing operations on audio read/write channels
465 via_chan_stop (card
->baseaddr
+ VIA_BASE0_PCM_OUT_CHAN
);
466 via_chan_stop (card
->baseaddr
+ VIA_BASE0_PCM_IN_CHAN
);
467 via_chan_stop (card
->baseaddr
+ VIA_BASE0_FM_OUT_CHAN
);
470 * clear any existing stops / flags (sanity check mainly)
472 via_chan_status_clear (card
->baseaddr
+ VIA_BASE0_PCM_OUT_CHAN
);
473 via_chan_status_clear (card
->baseaddr
+ VIA_BASE0_PCM_IN_CHAN
);
474 via_chan_status_clear (card
->baseaddr
+ VIA_BASE0_FM_OUT_CHAN
);
477 * clear any enabled interrupt bits, reset to 8-bit mono PCM mode
479 outb (0, card
->baseaddr
+ VIA_BASE0_PCM_OUT_CHAN
);
480 outb (0, card
->baseaddr
+ VIA_BASE0_PCM_IN_CHAN
);
481 outb (0, card
->baseaddr
+ VIA_BASE0_FM_OUT_CHAN
);
487 * via_set_rate - Set PCM rate for given channel
488 * @card: Private info for specified board
489 * @rate: Desired PCM sample rate, in Khz
490 * @inhale_deeply: Boolean. If non-zero (true), the recording sample rate
491 * is set. If zero (false), the playback sample rate
494 * Sets the PCM sample rate for a channel.
496 * Values for @rate are clamped to a range of 4000 Khz through 48000 Khz,
497 * due to hardware constraints.
499 * FIXME: @inhale_deeply argument is ignored, and %AC97_PCM_FRONT_DAC_RATE
500 * is the only rate which is really set. This needs to be fixed when
501 * recording support is added.
504 static int via_set_rate (struct via_info
*card
, unsigned rate
, int inhale_deeply
)
507 DPRINTK ("ENTER, rate = %d, inhale = %s\n",
508 rate
, inhale_deeply
? "yes" : "no");
510 if (rate
> 48000) rate
= 48000;
511 if (rate
< 4000) rate
= 4000;
513 via_ac97_write_reg (&card
->ac97
, AC97_POWER_CONTROL
,
514 (via_ac97_read_reg (&card
->ac97
, AC97_POWER_CONTROL
) & ~0x0200) |
516 via_ac97_write_reg (&card
->ac97
, AC97_PCM_FRONT_DAC_RATE
, rate
);
517 via_ac97_write_reg (&card
->ac97
, AC97_POWER_CONTROL
,
518 via_ac97_read_reg (&card
->ac97
, AC97_POWER_CONTROL
) & ~0x0200);
520 DPRINTK ("EXIT, returning 0\n");
526 * via_set_adc_rate - Set PCM rate for recording channel
527 * @card: Private info for specified board
528 * @rate: Desired PCM sample rate, in Khz
530 * Sets the PCM sample rate for a recording channel.
532 * FIXME: @inhale_deeply argument to via_set_rate is ignored, and %AC97_PCM_FRONT_DAC_RATE
533 * is the only rate which is really set. Thus, this function will
534 * not work until via_set_rate is fixed.
537 static inline int via_set_adc_rate (struct via_info
*card
, int rate
)
539 return via_set_rate (card
, rate
, 1);
544 * via_set_dac_rate - Set PCM rate for playback channel
545 * @card: Private info for specified board
546 * @rate: Desired PCM sample rate, in Khz
548 * Sets the PCM sample rate for a playback channel.
551 static inline int via_set_dac_rate (struct via_info
*card
, int rate
)
553 return via_set_rate (card
, rate
, 0);
557 /****************************************************************
559 * Channel-specific operations
565 * via_chan_init - Initialize PCM channel
566 * @card: Private audio chip info
567 * @chan: Channel to be initialized
568 * @chan_ofs: Offset from PCI address, which determines the
569 * set of SGD registers to use.
571 * Performs all the preparations necessary to begin
572 * using a PCM channel.
574 * Currently the preparations include allocating the
575 * scatter-gather DMA table and buffers, setting the
576 * PCM channel to a known state, and passing the
577 * address of the DMA table to the hardware.
579 * Note that special care is taken when passing the
580 * DMA table address to hardware, because it was found
581 * during driver development that the hardware did not
582 * always "take" the address.
585 static int via_chan_init (struct via_info
*card
,
586 struct via_channel
*chan
, long chan_ofs
)
593 memset (chan
, 0, sizeof (*chan
));
595 /* alloc DMA-able memory for scatter-gather table */
596 chan
->sgtable
= pci_alloc_consistent (card
->pdev
,
597 (sizeof (struct via_sgd_table
) * VIA_DMA_BUFFERS
),
599 if (!chan
->sgtable
) {
600 printk (KERN_ERR PFX
"DMA table alloc fail, aborting\n");
605 memset ((void*)chan
->sgtable
, 0,
606 (sizeof (struct via_sgd_table
) * VIA_DMA_BUFFERS
));
608 /* alloc DMA-able memory for scatter-gather buffers */
609 for (i
= 0; i
< VIA_DMA_BUFFERS
; i
++) {
610 chan
->sgbuf
[i
].cpuaddr
=
611 pci_alloc_consistent (card
->pdev
, VIA_DMA_BUF_SIZE
,
612 &chan
->sgbuf
[i
].handle
);
614 if (!chan
->sgbuf
[i
].cpuaddr
)
617 if (i
< (VIA_DMA_BUFFERS
- 1))
618 chan
->sgtable
[i
].count
= cpu_to_le32 (VIA_DMA_BUF_SIZE
| VIA_FLAG
);
620 chan
->sgtable
[i
].count
= cpu_to_le32 (VIA_DMA_BUF_SIZE
| VIA_EOL
);
621 chan
->sgtable
[i
].addr
= cpu_to_le32 (chan
->sgbuf
[i
].handle
);
624 memset (chan
->sgbuf
[i
].cpuaddr
, 0xBC, VIA_DMA_BUF_SIZE
);
628 DPRINTK ("dmabuf #%d (h=%lx, 32(h)=%lx, v2p=%lx, a=%p)\n",
629 i
, (long)chan
->sgbuf
[i
].handle
,
630 (long)chan
->sgtable
[i
].addr
,
631 virt_to_phys(chan
->sgbuf
[i
].cpuaddr
),
632 chan
->sgbuf
[i
].cpuaddr
);
636 init_waitqueue_head (&chan
->wait
);
638 chan
->pcm_fmt
= VIA_PCM_FMT_MASK
;
639 chan
->iobase
= card
->baseaddr
+ chan_ofs
;
641 spin_lock_irqsave (&card
->lock
, flags
);
643 /* stop any existing channel output */
644 via_chan_clear (chan
);
645 via_chan_status_clear (chan
->iobase
);
646 via_chan_pcm_fmt (card
, chan
, 1);
648 spin_unlock_irqrestore (&card
->lock
, flags
);
650 /* set location of DMA-able scatter-gather info table */
651 DPRINTK("outl (0x%X, 0x%04lX)\n",
652 cpu_to_le32 (chan
->sgt_handle
),
653 card
->baseaddr
+ chan_ofs
+ VIA_PCM_TABLE_ADDR
);
655 via_ac97_wait_idle (card
);
656 outl (cpu_to_le32 (chan
->sgt_handle
),
657 card
->baseaddr
+ chan_ofs
+ VIA_PCM_TABLE_ADDR
);
659 via_ac97_wait_idle (card
);
661 DPRINTK("inl (0x%lX) = %x\n",
662 chan
->iobase
+ VIA_PCM_TABLE_ADDR
,
663 inl(chan
->iobase
+ VIA_PCM_TABLE_ADDR
));
669 printk (KERN_ERR PFX
"DMA buffer alloc fail, aborting\n");
670 via_chan_free (card
, chan
);
677 * via_chan_free - Release a PCM channel
678 * @card: Private audio chip info
679 * @chan: Channel to be released
681 * Performs all the functions necessary to clean up
682 * an initialized channel.
684 * Currently these functions include disabled any
685 * active DMA operations, setting the PCM channel
686 * back to a known state, and releasing any allocated
690 static void via_chan_free (struct via_info
*card
, struct via_channel
*chan
)
699 spin_lock_irqsave (&card
->lock
, flags
);
701 /* stop any existing channel output */
702 via_chan_stop (chan
->iobase
);
703 via_chan_status_clear (chan
->iobase
);
704 via_chan_pcm_fmt (card
, chan
, 1);
706 spin_unlock_irqrestore (&card
->lock
, flags
);
708 /* zero location of DMA-able scatter-gather info table */
709 via_ac97_wait_idle(card
);
710 outl (0, chan
->iobase
+ VIA_PCM_TABLE_ADDR
);
712 for (i
= 0; i
< VIA_DMA_BUFFERS
; i
++)
713 if (chan
->sgbuf
[i
].cpuaddr
) {
714 pci_free_consistent (card
->pdev
, VIA_DMA_BUF_SIZE
,
715 (void*)chan
->sgbuf
[i
].cpuaddr
,
716 chan
->sgbuf
[i
].handle
);
717 chan
->sgbuf
[i
].cpuaddr
= NULL
;
718 chan
->sgbuf
[i
].handle
= 0;
722 pci_free_consistent (card
->pdev
,
723 (sizeof (struct via_sgd_table
) * VIA_DMA_BUFFERS
),
724 (void*)chan
->sgtable
, chan
->sgt_handle
);
725 chan
->sgtable
= NULL
;
733 * via_chan_pcm_fmt - Update PCM channel settings
734 * @card: Private audio chip info
735 * @chan: Channel to be updated
736 * @reset: Boolean. If non-zero, channel will be reset
737 * to 8-bit mono mode.
739 * Stores the settings of the current PCM format,
740 * 8-bit or 16-bit, and mono/stereo, into the
741 * hardware settings for the specified channel.
742 * If @reset is non-zero, the channel is reset
743 * to 8-bit mono mode. Otherwise, the channel
744 * is set to the values stored in the channel
745 * information struct @chan.
748 static void via_chan_pcm_fmt (struct via_info
*card
,
749 struct via_channel
*chan
, int reset
)
751 DPRINTK ("ENTER, pcm_fmt=0x%02X, reset=%s\n",
752 chan
->pcm_fmt
, reset
? "yes" : "no");
754 assert (card
!= NULL
);
755 assert (chan
!= NULL
);
758 /* reset to 8-bit mono mode */
761 /* enable interrupts on FLAG and EOL */
762 chan
->pcm_fmt
|= VIA_CHAN_TYPE_MASK
;
764 /* set interrupt select bits where applicable (PCM & FM out channels) */
765 if (chan
== &card
->ch_out
)
766 chan
->pcm_fmt
|= VIA_CHAN_TYPE_INT_SELECT
;
768 outb (chan
->pcm_fmt
, chan
->iobase
+ 2);
770 DPRINTK ("EXIT, pcm_fmt = 0x%02X, reg = 0x%02X\n",
772 inb (chan
->iobase
+ 2));
777 * via_chan_clear - Stop DMA channel operation, and reset pointers
778 * @chan: Channel to be cleared
780 * Call via_chan_stop to halt DMA operations, and then resets
781 * all software pointers which track DMA operation.
784 static void via_chan_clear (struct via_channel
*chan
)
786 via_chan_stop (chan
->iobase
);
787 atomic_set (&chan
->state
, sgd_stopped
);
788 atomic_set (&chan
->buf_in_use
, 0);
789 atomic_set (&chan
->next_buf
, 0);
794 * via_chan_set_speed - Set PCM sample rate for given channel
795 * @card: Private info for specified board
796 * @chan: Channel whose sample rate will be adjusted
797 * @val: New sample rate, in Khz
799 * Helper function for the %SNDCTL_DSP_SPEED ioctl. OSS semantics
800 * demand that all audio operations halt (if they are not already
801 * halted) when the %SNDCTL_DSP_SPEED is given.
803 * This function halts all audio operations for the given channel
804 * @chan, and then calls via_set_rate to set the audio hardware
808 static int via_chan_set_speed (struct via_info
*card
,
809 struct via_channel
*chan
, int val
)
811 DPRINTK ("ENTER, requested rate = %d\n", val
);
813 via_chan_clear (chan
);
815 val
= via_set_rate (card
, val
, chan
== &card
->ch_in
);
817 DPRINTK ("EXIT, returning %d\n", val
);
823 * via_chan_set_fmt - Set PCM sample size for given channel
824 * @card: Private info for specified board
825 * @chan: Channel whose sample size will be adjusted
826 * @val: New sample size, use the %AFMT_xxx constants
828 * Helper function for the %SNDCTL_DSP_SETFMT ioctl. OSS semantics
829 * demand that all audio operations halt (if they are not already
830 * halted) when the %SNDCTL_DSP_SETFMT is given.
832 * This function halts all audio operations for the given channel
833 * @chan, and then calls via_chan_pcm_fmt to set the audio hardware
834 * to the new sample size, either 8-bit or 16-bit.
837 static int via_chan_set_fmt (struct via_info
*card
,
838 struct via_channel
*chan
, int val
)
840 DPRINTK ("ENTER, val=%s\n",
841 val
== AFMT_U8
? "AFMT_U8" :
842 val
== AFMT_S16_LE
? "AFMT_S16_LE" :
845 via_chan_clear (chan
);
849 chan
->pcm_fmt
&= ~VIA_PCM_FMT_16BIT
;
850 via_chan_pcm_fmt (card
, chan
, 0);
853 chan
->pcm_fmt
|= VIA_PCM_FMT_16BIT
;
854 via_chan_pcm_fmt (card
, chan
, 0);
857 printk (KERN_WARNING PFX
"unknown AFMT\n");
862 DPRINTK ("EXIT, returning %d\n", val
);
868 * via_chan_set_stereo - Enable or disable stereo for a DMA channel
869 * @card: Private info for specified board
870 * @chan: Channel whose stereo setting will be adjusted
871 * @val: New sample size, use the %AFMT_xxx constants
873 * Helper function for the %SNDCTL_DSP_CHANNELS and %SNDCTL_DSP_STEREO ioctls. OSS semantics
874 * demand that all audio operations halt (if they are not already
875 * halted) when %SNDCTL_DSP_CHANNELS or SNDCTL_DSP_STEREO is given.
877 * This function halts all audio operations for the given channel
878 * @chan, and then calls via_chan_pcm_fmt to set the audio hardware
879 * to enable or disable stereo.
882 static int via_chan_set_stereo (struct via_info
*card
,
883 struct via_channel
*chan
, int val
)
885 DPRINTK ("ENTER, channels = %d\n", val
);
887 via_chan_clear (chan
);
893 chan
->pcm_fmt
&= ~VIA_PCM_FMT_STEREO
;
894 via_chan_pcm_fmt (card
, chan
, 0);
899 chan
->pcm_fmt
|= VIA_PCM_FMT_STEREO
;
900 via_chan_pcm_fmt (card
, chan
, 0);
905 printk (KERN_WARNING PFX
"unknown number of channels\n");
910 DPRINTK ("EXIT, returning %d\n", val
);
917 * via_chan_dump_bufs - Display DMA table contents
918 * @chan: Channel whose DMA table will be displayed
920 * Debugging function which displays the contents of the
921 * scatter-gather DMA table for the given channel @chan.
924 static void via_chan_dump_bufs (struct via_channel
*chan
)
928 for (i
= 0; i
< VIA_DMA_BUFFERS
; i
++) {
929 DPRINTK ("#%02d: addr=%x, count=%u, flag=%d, eol=%d\n",
930 i
, chan
->sgtable
[i
].addr
,
931 chan
->sgtable
[i
].count
& 0x00FFFFFF,
932 chan
->sgtable
[i
].count
& VIA_FLAG
? 1 : 0,
933 chan
->sgtable
[i
].count
& VIA_EOL
? 1 : 0);
935 DPRINTK ("buf_in_use = %d, nextbuf = %d\n",
936 atomic_read (&chan
->buf_in_use
),
937 atomic_read (&chan
->next_buf
));
942 /****************************************************************
944 * Interface to ac97-codec module
950 * via_ac97_wait_idle - Wait until AC97 codec is not busy
951 * @card: Private info for specified board
953 * Sleep until the AC97 codec is no longer busy.
954 * Returns the final value read from the SGD
955 * register being polled.
958 static u8
via_ac97_wait_idle (struct via_info
*card
)
961 int counter
= VIA_COUNTER_LIMIT
;
963 DPRINTK ("ENTER/EXIT\n");
965 assert (card
!= NULL
);
966 assert (card
->pdev
!= NULL
);
969 if (current
->need_resched
)
974 spin_lock_irq (&card
->lock
);
975 tmp8
= inb (card
->baseaddr
+ 0x83);
976 spin_unlock_irq (&card
->lock
);
977 } while ((tmp8
& VIA_CR83_BUSY
) && (counter
-- > 0));
984 * via_ac97_read_reg - Read AC97 standard register
985 * @codec: Pointer to generic AC97 codec info
986 * @reg: Index of AC97 register to be read
988 * Read the value of a single AC97 codec register,
989 * as defined by the Intel AC97 specification.
991 * Defines the standard AC97 read-register operation
992 * required by the kernel's ac97_codec interface.
994 * Returns the 16-bit value stored in the specified
998 static u16
via_ac97_read_reg (struct ac97_codec
*codec
, u8 reg
)
1001 struct via_info
*card
;
1004 DPRINTK ("ENTER\n");
1006 assert (codec
!= NULL
);
1007 assert (codec
->private_data
!= NULL
);
1009 card
= codec
->private_data
;
1011 data
= (reg
<< 16) | VIA_CR80_READ
;
1013 outl (data
, card
->baseaddr
+ VIA_BASE0_AC97_CTRL
);
1016 for (counter
= VIA_COUNTER_LIMIT
; counter
> 0; counter
--) {
1017 if (inl (card
->baseaddr
+ 0x80) & VIA_CR80_VALID
)
1020 if (current
->need_resched
)
1024 printk (KERN_WARNING PFX
"timeout while reading AC97 codec\n");
1028 data
= inl (card
->baseaddr
+ 0x80);
1029 outb (0x02, card
->baseaddr
+ 0x83);
1031 if (((data
& 0x007F0000) >> 16) == reg
) {
1032 DPRINTK ("EXIT, success, data=0x%x, retval=0x%x\n",
1033 data
, data
& 0x0000FFFF);
1034 return data
& 0x0000FFFF;
1037 DPRINTK ("WARNING: not our index: reg=0x%x, newreg=0x%x\n",
1038 reg
, ((data
& 0x007F0000) >> 16));
1041 DPRINTK ("EXIT, returning 0\n");
1047 * via_ac97_write_reg - Write AC97 standard register
1048 * @codec: Pointer to generic AC97 codec info
1049 * @reg: Index of AC97 register to be written
1050 * @value: Value to be written to AC97 register
1052 * Write the value of a single AC97 codec register,
1053 * as defined by the Intel AC97 specification.
1055 * Defines the standard AC97 write-register operation
1056 * required by the kernel's ac97_codec interface.
1059 static void via_ac97_write_reg (struct ac97_codec
*codec
, u8 reg
, u16 value
)
1062 struct via_info
*card
;
1065 DPRINTK ("ENTER\n");
1067 assert (codec
!= NULL
);
1068 assert (codec
->private_data
!= NULL
);
1070 card
= codec
->private_data
;
1072 data
= (reg
<< 16) + value
;
1073 outl (data
, card
->baseaddr
+ VIA_BASE0_AC97_CTRL
);
1076 for (counter
= VIA_COUNTER_LIMIT
; counter
> 0; counter
--) {
1077 if ((inb (card
->baseaddr
+ 0x83) & VIA_CR83_BUSY
) == 0)
1080 if (current
->need_resched
)
1084 printk (KERN_WARNING PFX
"timeout after AC97 codec write\n");
1091 static int via_mixer_open (struct inode
*inode
, struct file
*file
)
1093 int minor
= MINOR(inode
->i_rdev
);
1094 struct via_info
*card
;
1095 struct pci_dev
*pdev
;
1096 struct pci_driver
*drvr
;
1098 DPRINTK ("ENTER\n");
1100 pci_for_each_dev(pdev
) {
1101 drvr
= pci_dev_driver (pdev
);
1102 if (drvr
== &via_driver
) {
1103 assert (pdev
->driver_data
!= NULL
);
1105 card
= pdev
->driver_data
;
1106 if (card
->ac97
.dev_mixer
== minor
)
1111 DPRINTK ("EXIT, returning -ENODEV\n");
1115 file
->private_data
= &card
->ac97
;
1117 DPRINTK ("EXIT, returning 0\n");
1121 static int via_mixer_ioctl (struct inode
*inode
, struct file
*file
, unsigned int cmd
,
1124 struct ac97_codec
*codec
= file
->private_data
;
1127 assert (codec
!= NULL
);
1129 rc
= codec
->mixer_ioctl(codec
, cmd
, arg
);
1135 static loff_t
via_llseek(struct file
*file
, loff_t offset
, int origin
)
1137 DPRINTK ("ENTER\n");
1139 DPRINTK("EXIT, returning -ESPIPE\n");
1144 static struct file_operations via_mixer_fops
= {
1146 open
: via_mixer_open
,
1148 ioctl
: via_mixer_ioctl
,
1152 #if 0 /* values reasoned from debugging dumps of via's driver */
1156 } mixer_init_vals
[] __devinitdata
= {
1175 static int __init
via_ac97_reset (struct via_info
*card
)
1177 struct pci_dev
*pdev
= card
->pdev
;
1181 DPRINTK ("ENTER\n");
1183 assert (pdev
!= NULL
);
1187 u8 r40
,r41
,r42
,r43
,r44
,r48
;
1188 pci_read_config_byte (card
->pdev
, 0x40, &r40
);
1189 pci_read_config_byte (card
->pdev
, 0x41, &r41
);
1190 pci_read_config_byte (card
->pdev
, 0x42, &r42
);
1191 pci_read_config_byte (card
->pdev
, 0x43, &r43
);
1192 pci_read_config_byte (card
->pdev
, 0x44, &r44
);
1193 pci_read_config_byte (card
->pdev
, 0x48, &r48
);
1194 DPRINTK("PCI config: %02X %02X %02X %02X %02X %02X\n",
1195 r40
,r41
,r42
,r43
,r44
,r48
);
1197 spin_lock_irq (&card
->lock
);
1198 DPRINTK ("regs==%02X %02X %02X %08X %08X %08X %08X\n",
1199 inb (card
->baseaddr
+ 0x00),
1200 inb (card
->baseaddr
+ 0x01),
1201 inb (card
->baseaddr
+ 0x02),
1202 inl (card
->baseaddr
+ 0x04),
1203 inl (card
->baseaddr
+ 0x0C),
1204 inl (card
->baseaddr
+ 0x80),
1205 inl (card
->baseaddr
+ 0x84));
1206 spin_unlock_irq (&card
->lock
);
1212 * reset AC97 controller: enable, disable, enable
1213 * pause after each command for good luck
1215 pci_write_config_byte (pdev
, VIA_ACLINK_CTRL
, VIA_CR41_AC97_ENABLE
|
1216 VIA_CR41_AC97_RESET
| VIA_CR41_AC97_WAKEUP
);
1219 pci_write_config_byte (pdev
, VIA_ACLINK_CTRL
, 0);
1222 pci_write_config_byte (pdev
, VIA_ACLINK_CTRL
,
1223 VIA_CR41_AC97_ENABLE
| VIA_CR41_PCM_ENABLE
|
1224 VIA_CR41_VRA
| VIA_CR41_AC97_RESET
);
1227 #if 0 /* this breaks on K7M */
1228 /* disable legacy stuff */
1229 pci_write_config_byte (pdev
, 0x42, 0x00);
1233 /* route FM trap to IRQ, disable FM trap */
1234 pci_write_config_byte (pdev
, 0x48, 0x05);
1237 /* disable all codec GPI interrupts */
1238 outl (0, pci_resource_start (pdev
, 0) + 0x8C);
1240 /* enable variable rate */
1241 tmp16
= via_ac97_read_reg (&card
->ac97
, 0x2A);
1242 via_ac97_write_reg (&card
->ac97
, 0x2A, tmp16
| 0x01);
1244 /* boost headphone vol if disabled */
1245 tmp16
= via_ac97_read_reg (&card
->ac97
, AC97_HEADPHONE_VOL
);
1247 via_ac97_write_reg (&card
->ac97
, AC97_HEADPHONE_VOL
, 0x1F1F);
1249 pci_read_config_byte (pdev
, VIA_ACLINK_CTRL
, &tmp8
);
1250 if ((tmp8
& (VIA_CR41_AC97_ENABLE
| VIA_CR41_AC97_RESET
)) == 0) {
1251 printk (KERN_ERR PFX
"cannot enable AC97 controller, aborting\n");
1252 DPRINTK ("EXIT, tmp8=%X, returning -ENODEV\n", tmp8
);
1256 DPRINTK ("EXIT, returning 0\n");
1261 static int __init
via_ac97_init (struct via_info
*card
)
1266 DPRINTK ("ENTER\n");
1268 assert (card
!= NULL
);
1270 memset (&card
->ac97
, 0, sizeof (card
->ac97
));
1271 card
->ac97
.private_data
= card
;
1272 card
->ac97
.codec_read
= via_ac97_read_reg
;
1273 card
->ac97
.codec_write
= via_ac97_write_reg
;
1275 card
->ac97
.dev_mixer
= register_sound_mixer (&via_mixer_fops
, -1);
1276 if (card
->ac97
.dev_mixer
< 0) {
1277 printk (KERN_ERR PFX
"unable to register AC97 mixer, aborting\n");
1278 DPRINTK("EXIT, returning -EIO\n");
1282 rc
= via_ac97_reset (card
);
1284 printk (KERN_ERR PFX
"unable to reset AC97 codec, aborting\n");
1288 if (ac97_probe_codec (&card
->ac97
) == 0) {
1289 printk (KERN_ERR PFX
"unable to probe AC97 codec, aborting\n");
1294 tmp16
= via_ac97_read_reg (&card
->ac97
, 0x2A);
1295 via_ac97_write_reg (&card
->ac97
, 0x2A, tmp16
| 0x01);
1297 DPRINTK ("EXIT, returning 0\n");
1301 unregister_sound_mixer (card
->ac97
.dev_mixer
);
1302 DPRINTK("EXIT, returning %d\n", rc
);
1307 static void via_ac97_cleanup (struct via_info
*card
)
1311 assert (card
!= NULL
);
1312 assert (card
->ac97
.dev_mixer
>= 0);
1314 unregister_sound_mixer (card
->ac97
.dev_mixer
);
1321 /****************************************************************
1323 * Interrupt-related code
1327 static inline void via_interrupt_write (struct via_channel
*chan
)
1329 assert (atomic_read(&chan
->buf_in_use
) <
1330 atomic_read(&chan
->next_buf
));
1332 /* XXX sanity check: read h/w counter to
1333 * ensure no lost frames */
1335 atomic_inc (&chan
->buf_in_use
);
1337 /* if SG ptr catches up with userland ptr, stop playback */
1338 if (atomic_read(&chan
->buf_in_use
) == atomic_read(&chan
->next_buf
)) {
1339 atomic_set (&chan
->state
, sgd_stopped
);
1340 via_chan_stop (chan
->iobase
);
1343 /* wake up anybody listening */
1344 if (waitqueue_active (&chan
->wait
))
1345 wake_up (&chan
->wait
);
1350 static void via_interrupt(int irq
, void *dev_id
, struct pt_regs
*regs
)
1352 struct via_info
*card
= dev_id
;
1353 struct via_channel
*chan
;
1356 status
= inb (card
->baseaddr
+ 0x00);
1358 assert (card
->open_mode
& FMODE_WRITE
);
1360 chan
= &card
->ch_out
;
1362 if (status
& VIA_SGD_FLAG
) {
1363 assert ((status
& VIA_SGD_EOL
) == 0);
1364 outb (VIA_SGD_FLAG
, chan
->iobase
+ 0x00);
1365 DPRINTK("FLAG intr, status=0x%02X\n", status
);
1366 via_interrupt_write (chan
);
1369 if (status
& VIA_SGD_EOL
) {
1370 assert ((status
& VIA_SGD_FLAG
) == 0);
1371 outb (VIA_SGD_EOL
, chan
->iobase
+ 0x00);
1372 DPRINTK("EOL intr, status=0x%02X\n", status
);
1373 via_interrupt_write (chan
);
1376 if (status
& VIA_SGD_STOPPED
) {
1377 outb (VIA_SGD_STOPPED
, chan
->iobase
+ 0x00);
1378 DPRINTK("STOPPED intr, status=0x%02X\n", status
);
1382 via_chan_dump_bufs (&card
->ch_out
);
1388 static void via_interrupt_disable (struct via_info
*card
)
1391 unsigned long flags
;
1393 DPRINTK ("ENTER\n");
1395 assert (card
!= NULL
);
1397 spin_lock_irqsave (&card
->lock
, flags
);
1399 pci_read_config_byte (card
->pdev
, VIA_FM_NMI_CTRL
, &tmp8
);
1400 if ((tmp8
& VIA_CR48_FM_TRAP_TO_NMI
) == 0) {
1401 tmp8
|= VIA_CR48_FM_TRAP_TO_NMI
;
1402 pci_write_config_byte (card
->pdev
, VIA_FM_NMI_CTRL
, tmp8
);
1405 outb (inb (card
->baseaddr
+ VIA_BASE0_PCM_OUT_CHAN_TYPE
) &
1406 VIA_INT_DISABLE_MASK
,
1407 card
->baseaddr
+ VIA_BASE0_PCM_OUT_CHAN_TYPE
);
1408 outb (inb (card
->baseaddr
+ VIA_BASE0_PCM_IN_CHAN_TYPE
) &
1409 VIA_INT_DISABLE_MASK
,
1410 card
->baseaddr
+ VIA_BASE0_PCM_IN_CHAN_TYPE
);
1411 outb (inb (card
->baseaddr
+ VIA_BASE0_FM_OUT_CHAN_TYPE
) &
1412 VIA_INT_DISABLE_MASK
,
1413 card
->baseaddr
+ VIA_BASE0_FM_OUT_CHAN_TYPE
);
1415 spin_unlock_irqrestore (&card
->lock
, flags
);
1421 static int via_interrupt_init (struct via_info
*card
)
1423 DPRINTK ("ENTER\n");
1425 assert (card
!= NULL
);
1426 assert (card
->pdev
!= NULL
);
1428 /* check for sane IRQ number. can this ever happen? */
1429 if (card
->pdev
->irq
< 2) {
1430 printk (KERN_ERR PFX
"insane IRQ %d, aborting\n",
1432 DPRINTK ("EXIT, returning -EIO\n");
1436 if (request_irq (card
->pdev
->irq
, via_interrupt
, SA_SHIRQ
, VIA_MODULE_NAME
, card
)) {
1437 printk (KERN_ERR PFX
"unable to obtain IRQ %d, aborting\n",
1439 DPRINTK ("EXIT, returning -EBUSY\n");
1443 /* we don't want interrupts until we're opened */
1444 via_interrupt_disable (card
);
1446 DPRINTK ("EXIT, returning 0\n");
1451 static void via_interrupt_cleanup (struct via_info
*card
)
1453 DPRINTK ("ENTER\n");
1455 assert (card
!= NULL
);
1456 assert (card
->pdev
!= NULL
);
1458 via_interrupt_disable (card
);
1460 free_irq (card
->pdev
->irq
, card
);
1466 /****************************************************************
1472 static struct file_operations via_dsp_fops
= {
1475 release
: via_dsp_release
,
1477 write
: via_dsp_write
,
1480 ioctl
: via_dsp_ioctl
,
1484 static int __init
via_dsp_init (struct via_info
*card
)
1488 DPRINTK ("ENTER\n");
1490 assert (card
!= NULL
);
1492 /* turn off legacy features, if not already */
1493 pci_read_config_byte (card
->pdev
, VIA_FUNC_ENABLE
, &tmp8
);
1494 tmp8
&= ~(VIA_CR42_SB_ENABLE
| VIA_CR42_MIDI_ENABLE
|
1495 VIA_CR42_FM_ENABLE
);
1496 pci_write_config_byte (card
->pdev
, VIA_FUNC_ENABLE
, tmp8
);
1498 via_stop_everything (card
);
1500 card
->dev_dsp
= register_sound_dsp (&via_dsp_fops
, -1);
1501 if (card
->dev_dsp
< 0) {
1502 DPRINTK ("EXIT, returning -ENODEV\n");
1505 DPRINTK ("EXIT, returning 0\n");
1510 static void via_dsp_cleanup (struct via_info
*card
)
1512 DPRINTK ("ENTER\n");
1514 assert (card
!= NULL
);
1515 assert (card
->dev_dsp
>= 0);
1517 via_stop_everything (card
);
1519 unregister_sound_dsp (card
->dev_dsp
);
1525 static ssize_t
via_dsp_read(struct file
*file
, char *buffer
, size_t count
, loff_t
*ppos
)
1527 struct via_info
*card
;
1529 DPRINTK ("ENTER\n");
1531 assert (file
!= NULL
);
1532 assert (buffer
!= NULL
);
1533 card
= file
->private_data
;
1534 assert (card
!= NULL
);
1536 DPRINTK("EXIT, returning -EINVAL\n");
1542 #define sgcount(n) (sgtable[(n)].count & 0x00FFFFFF)
1543 #define NEXTBUF (atomic_read(&chan->next_buf) % VIA_DMA_BUFFERS)
1544 #define BUF_IN_USE (atomic_read(&chan->buf_in_use) % VIA_DMA_BUFFERS)
1545 #define STATE_STOPPED (atomic_read (state) == sgd_stopped)
1546 #define STATE_STARTED (atomic_read (state) == sgd_in_progress)
1547 static ssize_t
via_dsp_do_write (struct via_info
*card
,
1548 const char *userbuf
, size_t count
,
1551 const char *orig_userbuf
= userbuf
;
1552 struct via_channel
*chan
= &card
->ch_out
;
1553 volatile struct via_sgd_table
*sgtable
= chan
->sgtable
;
1554 atomic_t
*state
= &chan
->state
;
1556 int nextbuf
, prevbuf
, n
, realcount
;
1560 if (current
->need_resched
)
1563 spin_lock_irq (&card
->lock
);
1564 DPRINTK ("regs==%02X %02X %02X %08X %08X %08X %08X\n",
1565 inb (card
->baseaddr
+ 0x00),
1566 inb (card
->baseaddr
+ 0x01),
1567 inb (card
->baseaddr
+ 0x02),
1568 inl (card
->baseaddr
+ 0x04),
1569 inl (card
->baseaddr
+ 0x0C),
1570 inl (card
->baseaddr
+ 0x80),
1571 inl (card
->baseaddr
+ 0x84));
1572 spin_unlock_irq (&card
->lock
);
1574 size
= (count
< VIA_DMA_BUF_SIZE
) ? count
: VIA_DMA_BUF_SIZE
;
1576 /* case 1: SGD not active, list is ours for the mangling */
1578 if (STATE_STOPPED
) {
1579 DPRINTK ("case 1\n");
1581 if (copy_from_user ((void*)chan
->sgbuf
[0].cpuaddr
,
1585 assert (sgtable
[0].addr
== cpu_to_le32 (chan
->sgbuf
[0].handle
));
1586 sgtable
[0].count
= size
| VIA_FLAG
;
1588 atomic_set (state
, sgd_in_progress
);
1589 atomic_set (&chan
->buf_in_use
, 0);
1590 atomic_set (&chan
->next_buf
, 1);
1595 spin_lock_irq (&card
->lock
);
1597 spin_unlock_irq (&card
->lock
);
1604 prevbuf
= nextbuf
- 1;
1606 prevbuf
= VIA_DMA_BUFFERS
- 1;
1608 /* case 2: if final buffer is (a) a fragment, and (b) not
1609 * currently being consumed by the SGD engine, then append
1610 * as much data as possible to the fragment. */
1612 realcount
= sgcount(prevbuf
);
1613 if (STATE_STARTED
&& (prevbuf
!= BUF_IN_USE
) &&
1614 (realcount
< VIA_DMA_BUF_SIZE
)) {
1615 DPRINTK ("case 2\n");
1616 DPRINTK ("st=%d, fb=%d -- nb=%d, pb=%d, n=%d, rc=%d\n",
1617 atomic_read (state
),
1626 if ((VIA_DMA_BUF_SIZE
- realcount
) < size
)
1627 size
= VIA_DMA_BUF_SIZE
- realcount
;
1629 if (copy_from_user ((void*)(chan
->sgbuf
[n
].cpuaddr
+
1634 /* slack way to try and prevent races */
1635 if (prevbuf
== BUF_IN_USE
|| !STATE_STARTED
)
1638 assert (sgtable
[n
].addr
== cpu_to_le32 (chan
->sgbuf
[n
].handle
));
1639 if (n
== (VIA_DMA_BUFFERS
- 1))
1640 sgtable
[n
].count
= (realcount
+ size
) | VIA_EOL
;
1642 sgtable
[n
].count
= (realcount
+ size
) | VIA_FLAG
;
1649 /* case 3: if there are buffers left, use one
1650 * XXX needs more review for possible races */
1652 else if (STATE_STARTED
&& !via_chan_full (chan
)) {
1653 DPRINTK ("case 3\n");
1654 DPRINTK ("st=%d, fb=%d -- nb=%d, pb=%d, n=%d\n",
1655 atomic_read (state
),
1663 if (copy_from_user ((void*)chan
->sgbuf
[n
].cpuaddr
,
1667 if (n
== (VIA_DMA_BUFFERS
- 1))
1668 sgtable
[n
].count
= size
| VIA_EOL
;
1670 sgtable
[n
].count
= size
| VIA_FLAG
;
1672 /* if SGD stopped during data copy or SG table update,
1673 * then loop back to the beginning without updating
1675 * ie. slack way to prevent race */
1679 atomic_inc (&chan
->next_buf
);
1686 /* case 4, final SGT active case: no free buffers, wait for one */
1689 DPRINTK ("case 4\n");
1690 DPRINTK ("st=%d, fb=%d -- nb=%d, pb=%d\n",
1691 atomic_read (state
),
1696 /* if playback stopped, no need to sleep */
1700 /* if buffer free, no need to sleep */
1701 if (!via_chan_full (chan
))
1705 rc
= userbuf
- orig_userbuf
;
1711 DPRINTK ("sleeping\n");
1712 interruptible_sleep_on (&chan
->wait
);
1713 if (signal_pending (current
))
1714 return -ERESTARTSYS
;
1720 u8 r40
,r41
,r42
,r43
,r44
,r48
;
1721 pci_read_config_byte (card
->pdev
, 0x40, &r40
);
1722 pci_read_config_byte (card
->pdev
, 0x41, &r41
);
1723 pci_read_config_byte (card
->pdev
, 0x42, &r42
);
1724 pci_read_config_byte (card
->pdev
, 0x43, &r43
);
1725 pci_read_config_byte (card
->pdev
, 0x44, &r44
);
1726 pci_read_config_byte (card
->pdev
, 0x48, &r48
);
1727 DPRINTK("PCI config: %02X %02X %02X %02X %02X %02X\n",
1728 r40
,r41
,r42
,r43
,r44
,r48
);
1732 DPRINTK ("EXIT, returning %d\n",
1733 userbuf
- orig_userbuf
);
1734 return userbuf
- orig_userbuf
;
1739 #undef STATE_STOPPED
1740 #undef STATE_STARTED
1743 static ssize_t
via_dsp_write(struct file
*file
, const char *buffer
, size_t count
, loff_t
*ppos
)
1745 struct via_info
*card
;
1748 DPRINTK ("ENTER, file=%p, buffer=%p, count=%u, ppos=%lu\n",
1749 file
, buffer
, count
, ppos
? ((unsigned long)*ppos
) : 0);
1751 assert (file
!= NULL
);
1752 assert (buffer
!= NULL
);
1753 card
= file
->private_data
;
1754 assert (card
!= NULL
);
1756 if (ppos
!= &file
->f_pos
) {
1757 DPRINTK ("EXIT, returning -ESPIPE\n");
1761 rc
= via_dsp_do_write (card
, buffer
, count
, (file
->f_flags
& O_NONBLOCK
));
1763 DPRINTK("EXIT, returning %ld\n",(long) rc
);
1768 static unsigned int via_dsp_poll(struct file
*file
, struct poll_table_struct
*wait
)
1770 struct via_info
*card
;
1771 unsigned int mask
= 0;
1773 DPRINTK ("ENTER\n");
1775 assert (file
!= NULL
);
1776 assert (wait
!= NULL
);
1777 card
= file
->private_data
;
1778 assert (card
!= NULL
);
1780 if ((file
->f_mode
& FMODE_WRITE
) &&
1781 (atomic_read (&card
->ch_out
.state
) != sgd_stopped
)) {
1782 poll_wait(file
, &card
->ch_out
.wait
, wait
);
1784 /* XXX is this correct */
1785 if (atomic_read (&card
->ch_out
.buf_in_use
) <
1786 atomic_read (&card
->ch_out
.next_buf
))
1787 mask
|= POLLOUT
| POLLWRNORM
;
1790 DPRINTK("EXIT, returning %u\n", mask
);
1795 static int via_dsp_drain_dac (struct via_info
*card
, int non_block
)
1797 DPRINTK ("ENTER, non_block = %d\n", non_block
);
1799 while (!via_chan_empty (&card
->ch_out
)) {
1801 DPRINTK ("EXIT, returning -EBUSY\n");
1804 if (signal_pending (current
)) {
1805 DPRINTK ("EXIT, returning -ERESTARTSYS\n");
1806 return -ERESTARTSYS
;
1811 u8 r40
,r41
,r42
,r43
,r44
,r48
;
1812 pci_read_config_byte (card
->pdev
, 0x40, &r40
);
1813 pci_read_config_byte (card
->pdev
, 0x41, &r41
);
1814 pci_read_config_byte (card
->pdev
, 0x42, &r42
);
1815 pci_read_config_byte (card
->pdev
, 0x43, &r43
);
1816 pci_read_config_byte (card
->pdev
, 0x44, &r44
);
1817 pci_read_config_byte (card
->pdev
, 0x48, &r48
);
1818 DPRINTK("PCI config: %02X %02X %02X %02X %02X %02X\n",
1819 r40
,r41
,r42
,r43
,r44
,r48
);
1821 spin_lock_irq (&card
->lock
);
1822 DPRINTK ("regs==%02X %02X %02X %08X %08X %08X %08X\n",
1823 inb (card
->baseaddr
+ 0x00),
1824 inb (card
->baseaddr
+ 0x01),
1825 inb (card
->baseaddr
+ 0x02),
1826 inl (card
->baseaddr
+ 0x04),
1827 inl (card
->baseaddr
+ 0x0C),
1828 inl (card
->baseaddr
+ 0x80),
1829 inl (card
->baseaddr
+ 0x84));
1830 spin_unlock_irq (&card
->lock
);
1835 DPRINTK ("sleeping\n");
1836 interruptible_sleep_on (&card
->ch_out
.wait
);
1844 static int via_dsp_ioctl_space (struct via_info
*card
,
1845 struct via_channel
*chan
,
1848 audio_buf_info info
;
1851 info
.fragstotal
= VIA_DMA_BUFFERS
;
1852 info
.fragsize
= VIA_DMA_BUF_SIZE
;
1854 /* number of full fragments we can read without blocking */
1855 n
= atomic_read (&chan
->next_buf
) - atomic_read (&chan
->buf_in_use
);
1856 info
.fragments
= VIA_DMA_BUFFERS
- n
;
1858 /* number of bytes that can be read or written immediately
1859 * without blocking. FIXME: we are lazy and ignore partially-full
1862 info
.bytes
= info
.fragments
* VIA_DMA_BUF_SIZE
;
1864 DPRINTK ("EXIT, returning fragstotal=%d, fragsize=%d, fragments=%d, bytes=%d\n",
1870 return copy_to_user (arg
, &info
, sizeof (info
));
1875 static int via_dsp_ioctl (struct inode
*inode
, struct file
*file
,
1876 unsigned int cmd
, unsigned long arg
)
1878 int rc
= -EINVAL
, rd
=0, wr
=0, val
=0;
1879 struct via_info
*card
;
1881 DPRINTK ("ENTER, cmd = 0x%08X\n", cmd
);
1883 assert (file
!= NULL
);
1884 card
= file
->private_data
;
1885 assert (card
!= NULL
);
1887 if (file
->f_mode
& FMODE_WRITE
)
1889 if (file
->f_mode
& FMODE_READ
)
1894 /* OSS API version. XXX unverified */
1895 case OSS_GETVERSION
:
1896 DPRINTK("EXIT, returning SOUND_VERSION\n");
1897 return put_user (SOUND_VERSION
, (int *)arg
);
1899 /* list of supported PCM data formats */
1900 case SNDCTL_DSP_GETFMTS
:
1901 DPRINTK("EXIT, returning AFMT U8|S16_LE\n");
1902 return put_user (AFMT_U8
| AFMT_S16_LE
, (int *)arg
);
1904 /* query or set current channel's PCM data format */
1905 case SNDCTL_DSP_SETFMT
:
1906 get_user_ret(val
, (int *)arg
, -EFAULT
);
1907 if (val
!= AFMT_QUERY
) {
1910 spin_lock_irq (&card
->lock
);
1912 rc
= via_chan_set_fmt (card
, &card
->ch_in
, val
);
1914 rc
= via_chan_set_fmt (card
, &card
->ch_out
, val
);
1915 spin_unlock_irq (&card
->lock
);
1918 return rc
? rc
: -EINVAL
;
1921 spin_lock_irq (&card
->lock
);
1922 if ((rd
&& (card
->ch_in
.pcm_fmt
& VIA_PCM_FMT_16BIT
)) ||
1923 (wr
&& (card
->ch_out
.pcm_fmt
& VIA_PCM_FMT_16BIT
)))
1927 spin_unlock_irq (&card
->lock
);
1929 DPRINTK("SETFMT EXIT, returning %d\n", val
);
1930 return put_user (val
, (int *)arg
);
1932 /* query or set number of channels (1=mono, 2=stereo) */
1933 case SNDCTL_DSP_CHANNELS
:
1934 get_user_ret(val
, (int *)arg
, -EFAULT
);
1937 spin_lock_irq (&card
->lock
);
1939 rc
= via_chan_set_stereo (card
, &card
->ch_in
, val
);
1941 rc
= via_chan_set_stereo (card
, &card
->ch_out
, val
);
1942 spin_unlock_irq (&card
->lock
);
1944 return rc
? rc
: -EINVAL
;
1947 spin_lock_irq (&card
->lock
);
1948 if ((rd
&& (card
->ch_in
.pcm_fmt
& VIA_PCM_FMT_STEREO
)) ||
1949 (wr
&& (card
->ch_out
.pcm_fmt
& VIA_PCM_FMT_STEREO
)))
1953 spin_unlock_irq (&card
->lock
);
1955 DPRINTK("CHANNELS EXIT, returning %d\n", val
);
1956 return put_user (val
, (int *)arg
);
1958 /* enable (val is not zero) or disable (val == 0) stereo */
1959 case SNDCTL_DSP_STEREO
:
1960 get_user_ret(val
, (int *)arg
, -EFAULT
);
1962 spin_lock_irq (&card
->lock
);
1964 rc
= via_chan_set_stereo (card
, &card
->ch_in
, val
? 2 : 1);
1966 rc
= via_chan_set_stereo (card
, &card
->ch_out
, val
? 2 : 1);
1967 spin_unlock_irq (&card
->lock
);
1969 return rc
? rc
: -EINVAL
;
1970 DPRINTK("STEREO EXIT, returning %d\n", val
);
1973 /* query or set sampling rate */
1974 case SNDCTL_DSP_SPEED
:
1975 get_user_ret(val
, (int *)arg
, -EFAULT
);
1980 spin_lock_irq (&card
->lock
);
1982 rc
= via_chan_set_speed (card
, &card
->ch_in
, val
);
1984 rc
= via_chan_set_speed (card
, &card
->ch_out
, val
);
1985 spin_unlock_irq (&card
->lock
);
1987 return rc
? rc
: -EINVAL
;
1990 spin_lock_irq (&card
->lock
);
1992 val
= card
->ch_in
.rate
;
1994 val
= card
->ch_out
.rate
;
1997 spin_unlock_irq (&card
->lock
);
1999 DPRINTK("SPEED EXIT, returning %d\n", val
);
2000 return put_user (val
, (int *)arg
);
2002 /* wait until all buffers have been played, and then stop device */
2003 case SNDCTL_DSP_SYNC
:
2005 DPRINTK("SYNC EXIT (after calling via_dsp_drain_dac)\n");
2006 return via_dsp_drain_dac (card
, file
->f_flags
& O_NONBLOCK
);
2010 /* stop recording/playback immediately */
2011 case SNDCTL_DSP_RESET
:
2012 spin_lock_irq (&card
->lock
);
2014 via_chan_clear (&card
->ch_in
);
2015 via_chan_pcm_fmt (card
, &card
->ch_in
, 1);
2018 via_chan_clear (&card
->ch_out
);
2019 via_chan_pcm_fmt (card
, &card
->ch_out
, 1);
2021 spin_unlock_irq (&card
->lock
);
2022 DPRINTK("RESET EXIT, returning 0\n");
2025 /* obtain bitmask of device capabilities, such as mmap, full duplex, etc. */
2026 case SNDCTL_DSP_GETCAPS
:
2027 DPRINTK("GETCAPS EXIT\n");
2028 return put_user(DSP_CAP_REVISION
, (int *)arg
);
2030 /* obtain bitmask of device capabilities, such as mmap, full duplex, etc. */
2031 case SNDCTL_DSP_GETBLKSIZE
:
2032 DPRINTK("GETBLKSIZE EXIT\n");
2033 return put_user(VIA_DMA_BUF_SIZE
, (int *)arg
);
2035 /* obtain information about input buffering */
2036 case SNDCTL_DSP_GETISPACE
:
2037 DPRINTK("GETISPACE EXIT\n");
2038 return via_dsp_ioctl_space (card
, &card
->ch_in
, (void*) arg
);
2040 /* obtain information about output buffering */
2041 case SNDCTL_DSP_GETOSPACE
:
2042 DPRINTK("GETOSPACE EXIT\n");
2043 return via_dsp_ioctl_space (card
, &card
->ch_out
, (void*) arg
);
2045 /* return number of bytes remaining to be played by DMA engine */
2046 case SNDCTL_DSP_GETODELAY
:
2050 n
= atomic_read (&card
->ch_out
.next_buf
) -
2051 atomic_read (&card
->ch_out
.buf_in_use
);
2057 val
= (n
- 1) * VIA_DMA_BUF_SIZE
;
2058 val
+= inl (card
->ch_out
.iobase
+ VIA_BASE0_PCM_OUT_BLOCK_COUNT
);
2061 DPRINTK("GETODELAY EXIT, val = %d bytes\n", val
);
2062 return put_user (val
, (int *)arg
);
2065 /* set fragment size. implemented as a successful no-op for now */
2066 case SNDCTL_DSP_SETFRAGMENT
:
2067 get_user_ret(val
, (int *)arg
, -EFAULT
);
2069 DPRINTK ("SNDCTL_DSP_SETFRAGMENT (fragshift==0x%04X (%d), maxfrags==0x%04X (%d))\n",
2072 (val
>> 16) & 0xFFFF,
2073 (val
>> 16) & 0xFFFF);
2075 /* just to shut up some programs */
2078 /* inform device of an upcoming pause in input (or output). not implemented */
2079 case SNDCTL_DSP_POST
:
2080 DPRINTK("POST EXIT (null ioctl, returning -EINVAL)\n");
2083 /* not implemented */
2085 DPRINTK ("unhandled ioctl\n");
2089 DPRINTK("EXIT, returning %d\n", rc
);
2094 static int via_dsp_open (struct inode
*inode
, struct file
*file
)
2096 int open_mode
, rc
= -EINVAL
, minor
= MINOR(inode
->i_rdev
);
2097 int got_read_chan
= 0, is_busy
;
2098 struct via_info
*card
;
2099 struct pci_dev
*pdev
;
2100 struct pci_driver
*drvr
;
2101 unsigned long flags
;
2103 DPRINTK ("ENTER, minor=%d, file->f_mode=0x%x\n", minor
, file
->f_mode
);
2105 if (file
->f_mode
& FMODE_READ
) /* no input ATM */
2109 pci_for_each_dev(pdev
) {
2110 drvr
= pci_dev_driver (pdev
);
2111 if (drvr
== &via_driver
) {
2112 assert (pdev
->driver_data
!= NULL
);
2114 card
= pdev
->driver_data
;
2115 DPRINTK ("dev_dsp = %d, minor = %d, assn = %d\n",
2116 card
->dev_dsp
, minor
,
2117 (card
->dev_dsp
^ minor
) & ~0xf);
2119 if (((card
->dev_dsp
^ minor
) & ~0xf) == 0)
2124 DPRINTK ("no matching %s found\n", card
? "minor" : "driver");
2129 file
->private_data
= card
;
2131 /* wait for device to become free */
2132 spin_lock_irqsave (&card
->lock
, flags
);
2133 open_mode
= card
->open_mode
;
2134 if (open_mode
& file
->f_mode
)
2138 card
->open_mode
|= file
->f_mode
;
2139 open_mode
= card
->open_mode
;
2141 spin_unlock_irqrestore (&card
->lock
, flags
);
2147 DPRINTK("open_mode now 0x%x\n", open_mode
);
2149 /* handle input from analog source */
2150 if (file
->f_mode
& FMODE_READ
) {
2151 rc
= via_chan_init (card
, &card
->ch_in
, 0x10);
2153 goto err_out_clear_mode
;
2157 /* why is this forced to 16-bit stereo in all drivers? */
2158 card
->ch_in
.pcm_fmt
=
2159 VIA_PCM_FMT_16BIT
| VIA_PCM_FMT_STEREO
;
2161 spin_lock_irqsave (&card
->lock
, flags
);
2162 via_chan_pcm_fmt (card
, &card
->ch_out
, 0);
2163 spin_unlock_irqrestore (&card
->lock
, flags
);
2165 via_set_adc_rate (card
, 8000);
2168 /* handle output to analog source */
2169 if (file
->f_mode
& FMODE_WRITE
) {
2170 rc
= via_chan_init (card
, &card
->ch_out
, 0x00);
2172 goto err_out_clear_mode
;
2174 if ((minor
& 0xf) == SND_DEV_DSP16
)
2175 card
->ch_out
.pcm_fmt
|= VIA_PCM_FMT_16BIT
;
2177 spin_lock_irqsave (&card
->lock
, flags
);
2178 via_chan_pcm_fmt (card
, &card
->ch_out
, 0);
2179 spin_unlock_irqrestore (&card
->lock
, flags
);
2181 via_set_dac_rate (card
, 8000);
2184 DPRINTK ("EXIT, returning 0\n");
2189 via_chan_free (card
, &card
->ch_in
);
2190 spin_lock_irqsave (&card
->lock
, flags
);
2191 card
->open_mode
&= ~file
->f_mode
;
2192 spin_unlock_irqrestore (&card
->lock
, flags
);
2194 DPRINTK("ERROR EXIT, returning %d\n", rc
);
2199 static int via_dsp_release(struct inode
*inode
, struct file
*file
)
2201 struct via_info
*card
;
2202 unsigned long flags
;
2204 DPRINTK ("ENTER\n");
2206 assert (file
!= NULL
);
2207 card
= file
->private_data
;
2208 assert (card
!= NULL
);
2210 if (file
->f_mode
& FMODE_READ
)
2211 via_chan_free (card
, &card
->ch_in
);
2213 if (file
->f_mode
& FMODE_WRITE
) {
2214 via_dsp_drain_dac (card
, file
->f_flags
& O_NONBLOCK
);
2215 via_chan_free (card
, &card
->ch_out
);
2218 spin_lock_irqsave (&card
->lock
, flags
);
2219 card
->open_mode
&= ~(file
->f_mode
);
2220 spin_unlock_irqrestore (&card
->lock
, flags
);
2222 wake_up (&card
->open_wait
);
2224 DPRINTK("EXIT, returning 0\n");
2231 /****************************************************************
2233 * /proc/driver/via/info
2238 static int via_info_read_proc (char *page
, char **start
, off_t off
,
2239 int count
, int *eof
, void *data
)
2241 #define YN(val,bit) (((val) & (bit)) ? "yes" : "no")
2242 #define ED(val,bit) (((val) & (bit)) ? "enable" : "disable")
2245 u8 r40
, r41
, r42
, r44
;
2246 struct via_info
*card
= data
;
2248 DPRINTK ("ENTER\n");
2250 assert (card
!= NULL
);
2252 len
+= sprintf (page
+len
, VIA_CARD_NAME
"\n\n");
2254 pci_read_config_byte (card
->pdev
, 0x40, &r40
);
2255 pci_read_config_byte (card
->pdev
, 0x41, &r41
);
2256 pci_read_config_byte (card
->pdev
, 0x42, &r42
);
2257 pci_read_config_byte (card
->pdev
, 0x44, &r44
);
2259 len
+= sprintf (page
+len
,
2260 "Via 82Cxxx PCI registers:\n"
2262 "40 Codec Ready: %s\n"
2263 " Codec Low-power: %s\n"
2264 " Secondary Codec Ready: %s\n"
2266 "41 Interface Enable: %s\n"
2267 " De-Assert Reset: %s\n"
2268 " Force SYNC high: %s\n"
2269 " Force SDO high: %s\n"
2270 " Variable Sample Rate On-Demand Mode: %s\n"
2271 " SGD Read Channel PCM Data Out: %s\n"
2272 " FM Channel PCM Data Out: %s\n"
2273 " SB PCM Data Out: %s\n"
2275 "42 Game port enabled: %s\n"
2276 " SoundBlaster enabled: %s\n"
2278 " MIDI enabled: %s\n"
2280 "44 AC-Link Interface Access: %s\n"
2281 " Secondary Codec Support: %s\n"
2285 YN (r40
, VIA_CR40_AC97_READY
),
2286 YN (r40
, VIA_CR40_AC97_LOW_POWER
),
2287 YN (r40
, VIA_CR40_SECONDARY_READY
),
2289 ED (r41
, VIA_CR41_AC97_ENABLE
),
2298 YN (r42
, VIA_CR42_GAME_ENABLE
),
2299 YN (r42
, VIA_CR42_SB_ENABLE
),
2300 YN (r42
, VIA_CR42_FM_ENABLE
),
2301 YN (r42
, VIA_CR42_MIDI_ENABLE
),
2303 YN (r44
, VIA_CR44_AC_LINK_ACCESS
),
2304 YN (r44
, VIA_CR44_SECOND_CODEC_SUPPORT
)
2308 DPRINTK("EXIT, returning %d\n", len
);
2316 /****************************************************************
2318 * /proc/driver/via/... setup and cleanup
2323 static int __init
via_init_proc (void)
2325 DPRINTK ("ENTER\n");
2327 if (!proc_mkdir ("driver/via", 0))
2330 DPRINTK ("EXIT, returning 0\n");
2335 static void via_cleanup_proc (void)
2337 DPRINTK ("ENTER\n");
2339 remove_proc_entry ("driver/via", NULL
);
2345 static int __init
via_card_init_proc (struct via_info
*card
)
2350 DPRINTK ("ENTER\n");
2352 sprintf (s
, "driver/via/%d", card
->card_num
);
2353 if (!proc_mkdir (s
, 0)) {
2358 sprintf (s
, "driver/via/%d/info", card
->card_num
);
2359 if (!create_proc_read_entry (s
, 0, 0, via_info_read_proc
, card
)) {
2364 sprintf (s
, "driver/via/%d/ac97", card
->card_num
);
2365 if (!create_proc_read_entry (s
, 0, 0, ac97_read_proc
, &card
->ac97
)) {
2370 DPRINTK ("EXIT, returning 0\n");
2374 sprintf (s
, "driver/via/%d/info", card
->card_num
);
2375 remove_proc_entry (s
, NULL
);
2378 sprintf (s
, "driver/via/%d", card
->card_num
);
2379 remove_proc_entry (s
, NULL
);
2382 DPRINTK ("EXIT, returning %d\n", rc
);
2387 static void via_card_cleanup_proc (struct via_info
*card
)
2391 DPRINTK ("ENTER\n");
2393 sprintf (s
, "driver/via/%d/ac97", card
->card_num
);
2394 remove_proc_entry (s
, NULL
);
2396 sprintf (s
, "driver/via/%d/info", card
->card_num
);
2397 remove_proc_entry (s
, NULL
);
2399 sprintf (s
, "driver/via/%d", card
->card_num
);
2400 remove_proc_entry (s
, NULL
);
2408 static inline int via_init_proc (void) { return 0; }
2409 static inline void via_cleanup_proc (void) {}
2410 static inline int via_card_init_proc (struct via_info
*card
) { return 0; }
2411 static inline void via_card_cleanup_proc (struct via_info
*card
) {}
2413 #endif /* VIA_PROC_FS */
2416 /****************************************************************
2418 * Chip setup and kernel registration
2423 static int __init
via_init_one (struct pci_dev
*pdev
, const struct pci_device_id
*id
)
2426 struct via_info
*card
;
2428 static int printed_version
= 0;
2430 DPRINTK ("ENTER\n");
2432 if (printed_version
++ == 0)
2433 printk (KERN_INFO
"Via 686a audio driver " VIA_VERSION
"\n");
2435 if (!request_region (pci_resource_start (pdev
, 0),
2436 pci_resource_len (pdev
, 0),
2438 printk (KERN_ERR PFX
"unable to obtain I/O resources, aborting\n");
2443 if (pci_enable_device (pdev
)) {
2448 card
= kmalloc (sizeof (*card
), GFP_KERNEL
);
2450 printk (KERN_ERR PFX
"out of memory, aborting\n");
2455 pdev
->driver_data
= card
;
2457 memset (card
, 0, sizeof (*card
));
2459 card
->baseaddr
= pci_resource_start (pdev
, 0);
2460 card
->card_num
= via_num_cards
++;
2461 spin_lock_init (&card
->lock
);
2462 init_waitqueue_head(&card
->open_wait
);
2464 /* if BAR 2 is present, chip is Rev H or later,
2465 * which means it has a few extra features */
2466 if (pci_resource_start (pdev
, 2) > 0)
2469 if (pdev
->irq
< 1) {
2470 printk (KERN_ERR PFX
"invalid PCI IRQ %d, aborting\n", pdev
->irq
);
2475 if (!(pci_resource_flags (pdev
, 0) & IORESOURCE_IO
)) {
2476 printk (KERN_ERR PFX
"unable to locate I/O resources, aborting\n");
2482 * init AC97 mixer and codec
2484 rc
= via_ac97_init (card
);
2486 printk (KERN_ERR PFX
"AC97 init failed, aborting\n");
2493 rc
= via_dsp_init (card
);
2495 printk (KERN_ERR PFX
"DSP device init failed, aborting\n");
2496 goto err_out_have_mixer
;
2500 * per-card /proc info
2502 rc
= via_card_init_proc (card
);
2504 printk (KERN_ERR PFX
"card-specific /proc init failed, aborting\n");
2505 goto err_out_have_dsp
;
2509 * init and turn on interrupts, as the last thing we do
2511 rc
= via_interrupt_init (card
);
2513 printk (KERN_ERR PFX
"interrupt init failed, aborting\n");
2514 goto err_out_have_proc
;
2517 pci_read_config_byte (pdev
, 0x3C, &tmp
);
2518 if ((tmp
& 0x0F) != pdev
->irq
) {
2519 printk (KERN_WARNING PFX
"IRQ fixup, 0x3C==0x%02X\n", tmp
);
2522 pci_write_config_byte (pdev
, 0x3C, tmp
);
2523 DPRINTK("new 0x3c==0x%02x\n", tmp
);
2525 DPRINTK("IRQ reg 0x3c==0x%02x, irq==%d\n",
2529 printk (KERN_INFO PFX
"board #%d at 0x%04lX, IRQ %d\n",
2530 card
->card_num
+ 1, card
->baseaddr
, pdev
->irq
);
2532 DPRINTK ("EXIT, returning 0\n");
2536 via_card_cleanup_proc (card
);
2539 via_dsp_cleanup (card
);
2542 via_ac97_cleanup (card
);
2546 memset (card
, 0xAB, sizeof (*card
)); /* poison memory */
2551 release_region (pci_resource_start (pdev
, 0), pci_resource_len (pdev
, 0));
2553 pdev
->driver_data
= NULL
;
2554 DPRINTK ("EXIT - returning %d\n", rc
);
2559 static void __exit
via_remove_one (struct pci_dev
*pdev
)
2561 struct via_info
*card
;
2563 DPRINTK ("ENTER\n");
2565 assert (pdev
!= NULL
);
2566 card
= pdev
->driver_data
;
2567 assert (card
!= NULL
);
2569 via_interrupt_cleanup (card
);
2570 via_card_cleanup_proc (card
);
2571 via_dsp_cleanup (card
);
2572 via_ac97_cleanup (card
);
2574 release_region (pci_resource_start (pdev
, 0), pci_resource_len (pdev
, 0));
2577 memset (card
, 0xAB, sizeof (*card
)); /* poison memory */
2581 pdev
->driver_data
= NULL
;
2583 pci_set_power_state (pdev
, 3); /* ...zzzzzz */
2590 /****************************************************************
2592 * Driver initialization and cleanup
2597 static int __init
init_via82cxxx_audio(void)
2601 DPRINTK ("ENTER\n");
2603 rc
= via_init_proc ();
2605 DPRINTK ("EXIT, returning %d\n", rc
);
2609 rc
= pci_register_driver (&via_driver
);
2612 pci_unregister_driver (&via_driver
);
2613 via_cleanup_proc ();
2614 DPRINTK ("EXIT, returning -ENODEV\n");
2618 DPRINTK ("EXIT, returning 0\n");
2623 static void __exit
cleanup_via82cxxx_audio(void)
2627 pci_unregister_driver (&via_driver
);
2628 via_cleanup_proc ();
2634 module_init(init_via82cxxx_audio
);
2635 module_exit(cleanup_via82cxxx_audio
);