diff options
Diffstat (limited to 'sound/pci/trident')
-rw-r--r-- | sound/pci/trident/trident_main.c | 22 | ||||
-rw-r--r-- | sound/pci/trident/trident_memory.c | 24 |
2 files changed, 30 insertions, 16 deletions
diff --git a/sound/pci/trident/trident_main.c b/sound/pci/trident/trident_main.c index a69b4206c69e..c612b435ca2b 100644 --- a/sound/pci/trident/trident_main.c +++ b/sound/pci/trident/trident_main.c | |||
@@ -2931,7 +2931,8 @@ static int snd_trident_pcm_mixer_build(struct snd_trident *trident, | |||
2931 | { | 2931 | { |
2932 | struct snd_trident_pcm_mixer *tmix; | 2932 | struct snd_trident_pcm_mixer *tmix; |
2933 | 2933 | ||
2934 | snd_assert(trident != NULL && voice != NULL && substream != NULL, return -EINVAL); | 2934 | if (snd_BUG_ON(!trident || !voice || !substream)) |
2935 | return -EINVAL; | ||
2935 | tmix = &trident->pcm_mixer[substream->number]; | 2936 | tmix = &trident->pcm_mixer[substream->number]; |
2936 | tmix->voice = voice; | 2937 | tmix->voice = voice; |
2937 | tmix->vol = T4D_DEFAULT_PCM_VOL; | 2938 | tmix->vol = T4D_DEFAULT_PCM_VOL; |
@@ -2946,7 +2947,8 @@ static int snd_trident_pcm_mixer_free(struct snd_trident *trident, struct snd_tr | |||
2946 | { | 2947 | { |
2947 | struct snd_trident_pcm_mixer *tmix; | 2948 | struct snd_trident_pcm_mixer *tmix; |
2948 | 2949 | ||
2949 | snd_assert(trident != NULL && substream != NULL, return -EINVAL); | 2950 | if (snd_BUG_ON(!trident || !substream)) |
2951 | return -EINVAL; | ||
2950 | tmix = &trident->pcm_mixer[substream->number]; | 2952 | tmix = &trident->pcm_mixer[substream->number]; |
2951 | tmix->voice = NULL; | 2953 | tmix->voice = NULL; |
2952 | snd_trident_notify_pcm_change(trident, tmix, substream->number, 0); | 2954 | snd_trident_notify_pcm_change(trident, tmix, substream->number, 0); |
@@ -3131,7 +3133,8 @@ static unsigned char snd_trident_gameport_read(struct gameport *gameport) | |||
3131 | { | 3133 | { |
3132 | struct snd_trident *chip = gameport_get_port_data(gameport); | 3134 | struct snd_trident *chip = gameport_get_port_data(gameport); |
3133 | 3135 | ||
3134 | snd_assert(chip, return 0); | 3136 | if (snd_BUG_ON(!chip)) |
3137 | return 0; | ||
3135 | return inb(TRID_REG(chip, GAMEPORT_LEGACY)); | 3138 | return inb(TRID_REG(chip, GAMEPORT_LEGACY)); |
3136 | } | 3139 | } |
3137 | 3140 | ||
@@ -3139,7 +3142,8 @@ static void snd_trident_gameport_trigger(struct gameport *gameport) | |||
3139 | { | 3142 | { |
3140 | struct snd_trident *chip = gameport_get_port_data(gameport); | 3143 | struct snd_trident *chip = gameport_get_port_data(gameport); |
3141 | 3144 | ||
3142 | snd_assert(chip, return); | 3145 | if (snd_BUG_ON(!chip)) |
3146 | return; | ||
3143 | outb(0xff, TRID_REG(chip, GAMEPORT_LEGACY)); | 3147 | outb(0xff, TRID_REG(chip, GAMEPORT_LEGACY)); |
3144 | } | 3148 | } |
3145 | 3149 | ||
@@ -3148,7 +3152,8 @@ static int snd_trident_gameport_cooked_read(struct gameport *gameport, int *axes | |||
3148 | struct snd_trident *chip = gameport_get_port_data(gameport); | 3152 | struct snd_trident *chip = gameport_get_port_data(gameport); |
3149 | int i; | 3153 | int i; |
3150 | 3154 | ||
3151 | snd_assert(chip, return 0); | 3155 | if (snd_BUG_ON(!chip)) |
3156 | return 0; | ||
3152 | 3157 | ||
3153 | *buttons = (~inb(TRID_REG(chip, GAMEPORT_LEGACY)) >> 4) & 0xf; | 3158 | *buttons = (~inb(TRID_REG(chip, GAMEPORT_LEGACY)) >> 4) & 0xf; |
3154 | 3159 | ||
@@ -3164,7 +3169,8 @@ static int snd_trident_gameport_open(struct gameport *gameport, int mode) | |||
3164 | { | 3169 | { |
3165 | struct snd_trident *chip = gameport_get_port_data(gameport); | 3170 | struct snd_trident *chip = gameport_get_port_data(gameport); |
3166 | 3171 | ||
3167 | snd_assert(chip, return 0); | 3172 | if (snd_BUG_ON(!chip)) |
3173 | return 0; | ||
3168 | 3174 | ||
3169 | switch (mode) { | 3175 | switch (mode) { |
3170 | case GAMEPORT_MODE_COOKED: | 3176 | case GAMEPORT_MODE_COOKED: |
@@ -3891,8 +3897,8 @@ static void snd_trident_clear_voices(struct snd_trident * trident, unsigned shor | |||
3891 | { | 3897 | { |
3892 | unsigned int i, val, mask[2] = { 0, 0 }; | 3898 | unsigned int i, val, mask[2] = { 0, 0 }; |
3893 | 3899 | ||
3894 | snd_assert(v_min <= 63, return); | 3900 | if (snd_BUG_ON(v_min > 63 || v_max > 63)) |
3895 | snd_assert(v_max <= 63, return); | 3901 | return; |
3896 | for (i = v_min; i <= v_max; i++) | 3902 | for (i = v_min; i <= v_max; i++) |
3897 | mask[i >> 5] |= 1 << (i & 0x1f); | 3903 | mask[i >> 5] |= 1 << (i & 0x1f); |
3898 | if (mask[0]) { | 3904 | if (mask[0]) { |
diff --git a/sound/pci/trident/trident_memory.c b/sound/pci/trident/trident_memory.c index 3fd7f1b29b0f..2fe3b1fab53a 100644 --- a/sound/pci/trident/trident_memory.c +++ b/sound/pci/trident/trident_memory.c | |||
@@ -196,9 +196,13 @@ snd_trident_alloc_sg_pages(struct snd_trident *trident, | |||
196 | int idx, page; | 196 | int idx, page; |
197 | struct snd_sg_buf *sgbuf = snd_pcm_substream_sgbuf(substream); | 197 | struct snd_sg_buf *sgbuf = snd_pcm_substream_sgbuf(substream); |
198 | 198 | ||
199 | snd_assert(runtime->dma_bytes > 0 && runtime->dma_bytes <= SNDRV_TRIDENT_MAX_PAGES * SNDRV_TRIDENT_PAGE_SIZE, return NULL); | 199 | if (snd_BUG_ON(runtime->dma_bytes <= 0 || |
200 | runtime->dma_bytes > SNDRV_TRIDENT_MAX_PAGES * | ||
201 | SNDRV_TRIDENT_PAGE_SIZE)) | ||
202 | return NULL; | ||
200 | hdr = trident->tlb.memhdr; | 203 | hdr = trident->tlb.memhdr; |
201 | snd_assert(hdr != NULL, return NULL); | 204 | if (snd_BUG_ON(!hdr)) |
205 | return NULL; | ||
202 | 206 | ||
203 | 207 | ||
204 | 208 | ||
@@ -245,9 +249,13 @@ snd_trident_alloc_cont_pages(struct snd_trident *trident, | |||
245 | dma_addr_t addr; | 249 | dma_addr_t addr; |
246 | unsigned long ptr; | 250 | unsigned long ptr; |
247 | 251 | ||
248 | snd_assert(runtime->dma_bytes> 0 && runtime->dma_bytes <= SNDRV_TRIDENT_MAX_PAGES * SNDRV_TRIDENT_PAGE_SIZE, return NULL); | 252 | if (snd_BUG_ON(runtime->dma_bytes <= 0 || |
253 | runtime->dma_bytes > SNDRV_TRIDENT_MAX_PAGES * | ||
254 | SNDRV_TRIDENT_PAGE_SIZE)) | ||
255 | return NULL; | ||
249 | hdr = trident->tlb.memhdr; | 256 | hdr = trident->tlb.memhdr; |
250 | snd_assert(hdr != NULL, return NULL); | 257 | if (snd_BUG_ON(!hdr)) |
258 | return NULL; | ||
251 | 259 | ||
252 | mutex_lock(&hdr->block_mutex); | 260 | mutex_lock(&hdr->block_mutex); |
253 | blk = search_empty(hdr, runtime->dma_bytes); | 261 | blk = search_empty(hdr, runtime->dma_bytes); |
@@ -279,8 +287,8 @@ struct snd_util_memblk * | |||
279 | snd_trident_alloc_pages(struct snd_trident *trident, | 287 | snd_trident_alloc_pages(struct snd_trident *trident, |
280 | struct snd_pcm_substream *substream) | 288 | struct snd_pcm_substream *substream) |
281 | { | 289 | { |
282 | snd_assert(trident != NULL, return NULL); | 290 | if (snd_BUG_ON(!trident || !substream)) |
283 | snd_assert(substream != NULL, return NULL); | 291 | return NULL; |
284 | if (substream->dma_buffer.dev.type == SNDRV_DMA_TYPE_DEV_SG) | 292 | if (substream->dma_buffer.dev.type == SNDRV_DMA_TYPE_DEV_SG) |
285 | return snd_trident_alloc_sg_pages(trident, substream); | 293 | return snd_trident_alloc_sg_pages(trident, substream); |
286 | else | 294 | else |
@@ -297,8 +305,8 @@ int snd_trident_free_pages(struct snd_trident *trident, | |||
297 | struct snd_util_memhdr *hdr; | 305 | struct snd_util_memhdr *hdr; |
298 | int page; | 306 | int page; |
299 | 307 | ||
300 | snd_assert(trident != NULL, return -EINVAL); | 308 | if (snd_BUG_ON(!trident || !blk)) |
301 | snd_assert(blk != NULL, return -EINVAL); | 309 | return -EINVAL; |
302 | 310 | ||
303 | hdr = trident->tlb.memhdr; | 311 | hdr = trident->tlb.memhdr; |
304 | mutex_lock(&hdr->block_mutex); | 312 | mutex_lock(&hdr->block_mutex); |