aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2008-07-30 09:23:06 -0400
committerJaroslav Kysela <perex@perex.cz>2008-08-25 03:57:43 -0400
commit5503600a1c5c2c11e14ff428b5d07a1018927bd6 (patch)
tree80d8dcb53337abb5af9fc4ac3f5ca98b7063c0c0
parenta2e3961d0a26870eb23b70edab6814c7f08ce2e0 (diff)
ALSA: via82xx - check continuous pages in buffer setup
Check continuous pages in the buffer set up so that the number of BDL is reduced. Also increased the max buffer size. Signed-off-by: Takashi Iwai <tiwai@suse.de> Signed-off-by: Jaroslav Kysela <perex@perex.cz>
-rw-r--r--sound/pci/via82xx.c19
1 files changed, 9 insertions, 10 deletions
diff --git a/sound/pci/via82xx.c b/sound/pci/via82xx.c
index 57e33d7df5fa..1aafe956ee2b 100644
--- a/sound/pci/via82xx.c
+++ b/sound/pci/via82xx.c
@@ -313,6 +313,7 @@ struct snd_via_sg_table {
313} ; 313} ;
314 314
315#define VIA_TABLE_SIZE 255 315#define VIA_TABLE_SIZE 255
316#define VIA_MAX_BUFSIZE (1<<24)
316 317
317struct viadev { 318struct viadev {
318 unsigned int reg_offset; 319 unsigned int reg_offset;
@@ -456,9 +457,7 @@ static int build_via_table(struct viadev *dev, struct snd_pcm_substream *substre
456 } 457 }
457 addr = snd_pcm_sgbuf_get_addr(substream, ofs); 458 addr = snd_pcm_sgbuf_get_addr(substream, ofs);
458 ((u32 *)dev->table.area)[idx << 1] = cpu_to_le32(addr); 459 ((u32 *)dev->table.area)[idx << 1] = cpu_to_le32(addr);
459 r = PAGE_SIZE - (ofs % PAGE_SIZE); 460 r = snd_pcm_sgbuf_get_chunk_size(substream, ofs, rest);
460 if (rest < r)
461 r = rest;
462 rest -= r; 461 rest -= r;
463 if (! rest) { 462 if (! rest) {
464 if (i == periods - 1) 463 if (i == periods - 1)
@@ -1147,9 +1146,9 @@ static struct snd_pcm_hardware snd_via82xx_hw =
1147 .rate_max = 48000, 1146 .rate_max = 48000,
1148 .channels_min = 1, 1147 .channels_min = 1,
1149 .channels_max = 2, 1148 .channels_max = 2,
1150 .buffer_bytes_max = 128 * 1024, 1149 .buffer_bytes_max = VIA_MAX_BUFSIZE,
1151 .period_bytes_min = 32, 1150 .period_bytes_min = 32,
1152 .period_bytes_max = 128 * 1024, 1151 .period_bytes_max = VIA_MAX_BUFSIZE / 2,
1153 .periods_min = 2, 1152 .periods_min = 2,
1154 .periods_max = VIA_TABLE_SIZE / 2, 1153 .periods_max = VIA_TABLE_SIZE / 2,
1155 .fifo_size = 0, 1154 .fifo_size = 0,
@@ -1403,7 +1402,7 @@ static int __devinit snd_via8233_pcm_new(struct via82xx *chip)
1403 1402
1404 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV_SG, 1403 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV_SG,
1405 snd_dma_pci_data(chip->pci), 1404 snd_dma_pci_data(chip->pci),
1406 64*1024, 128*1024); 1405 64*1024, VIA_MAX_BUFSIZE);
1407 1406
1408 /* PCM #1: multi-channel playback and 2nd capture */ 1407 /* PCM #1: multi-channel playback and 2nd capture */
1409 err = snd_pcm_new(chip->card, chip->card->shortname, 1, 1, 1, &pcm); 1408 err = snd_pcm_new(chip->card, chip->card->shortname, 1, 1, 1, &pcm);
@@ -1421,7 +1420,7 @@ static int __devinit snd_via8233_pcm_new(struct via82xx *chip)
1421 1420
1422 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV_SG, 1421 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV_SG,
1423 snd_dma_pci_data(chip->pci), 1422 snd_dma_pci_data(chip->pci),
1424 64*1024, 128*1024); 1423 64*1024, VIA_MAX_BUFSIZE);
1425 return 0; 1424 return 0;
1426} 1425}
1427 1426
@@ -1455,7 +1454,7 @@ static int __devinit snd_via8233a_pcm_new(struct via82xx *chip)
1455 1454
1456 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV_SG, 1455 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV_SG,
1457 snd_dma_pci_data(chip->pci), 1456 snd_dma_pci_data(chip->pci),
1458 64*1024, 128*1024); 1457 64*1024, VIA_MAX_BUFSIZE);
1459 1458
1460 /* SPDIF supported? */ 1459 /* SPDIF supported? */
1461 if (! ac97_can_spdif(chip->ac97)) 1460 if (! ac97_can_spdif(chip->ac97))
@@ -1474,7 +1473,7 @@ static int __devinit snd_via8233a_pcm_new(struct via82xx *chip)
1474 1473
1475 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV_SG, 1474 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV_SG,
1476 snd_dma_pci_data(chip->pci), 1475 snd_dma_pci_data(chip->pci),
1477 64*1024, 128*1024) 1476 64*1024, VIA_MAX_BUFSIZE);
1478 return 0; 1477 return 0;
1479} 1478}
1480 1479
@@ -1504,7 +1503,7 @@ static int __devinit snd_via686_pcm_new(struct via82xx *chip)
1504 1503
1505 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV_SG, 1504 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV_SG,
1506 snd_dma_pci_data(chip->pci), 1505 snd_dma_pci_data(chip->pci),
1507 64*1024, 128*1024); 1506 64*1024, VIA_MAX_BUFSIZE);
1508 return 0; 1507 return 0;
1509} 1508}
1510 1509