Avoid arithmetics on void * in MusicPal audio code (Jan Kiszka).
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@4373 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
parent
58565070ee
commit
a350e69424
@ -244,7 +244,7 @@ typedef struct musicpal_audio_state {
|
|||||||
uint32_t status;
|
uint32_t status;
|
||||||
uint32_t irq_enable;
|
uint32_t irq_enable;
|
||||||
unsigned long phys_buf;
|
unsigned long phys_buf;
|
||||||
void *target_buffer;
|
int8_t *target_buffer;
|
||||||
unsigned int threshold;
|
unsigned int threshold;
|
||||||
unsigned int play_pos;
|
unsigned int play_pos;
|
||||||
unsigned int last_free;
|
unsigned int last_free;
|
||||||
@ -256,7 +256,7 @@ static void audio_callback(void *opaque, int free_out, int free_in)
|
|||||||
{
|
{
|
||||||
musicpal_audio_state *s = opaque;
|
musicpal_audio_state *s = opaque;
|
||||||
int16_t *codec_buffer;
|
int16_t *codec_buffer;
|
||||||
void *mem_buffer;
|
int8_t *mem_buffer;
|
||||||
int pos, block_size;
|
int pos, block_size;
|
||||||
|
|
||||||
if (!(s->playback_mode & MP_AUDIO_PLAYBACK_EN))
|
if (!(s->playback_mode & MP_AUDIO_PLAYBACK_EN))
|
||||||
@ -277,8 +277,8 @@ static void audio_callback(void *opaque, int free_out, int free_in)
|
|||||||
if (s->playback_mode & MP_AUDIO_MONO) {
|
if (s->playback_mode & MP_AUDIO_MONO) {
|
||||||
codec_buffer = wm8750_dac_buffer(s->wm, block_size >> 1);
|
codec_buffer = wm8750_dac_buffer(s->wm, block_size >> 1);
|
||||||
for (pos = 0; pos < block_size; pos += 2) {
|
for (pos = 0; pos < block_size; pos += 2) {
|
||||||
*codec_buffer++ = *(uint16_t *)mem_buffer;
|
*codec_buffer++ = *(int16_t *)mem_buffer;
|
||||||
*codec_buffer++ = *(uint16_t *)mem_buffer;
|
*codec_buffer++ = *(int16_t *)mem_buffer;
|
||||||
mem_buffer += 2;
|
mem_buffer += 2;
|
||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
@ -288,14 +288,14 @@ static void audio_callback(void *opaque, int free_out, int free_in)
|
|||||||
if (s->playback_mode & MP_AUDIO_MONO) {
|
if (s->playback_mode & MP_AUDIO_MONO) {
|
||||||
codec_buffer = wm8750_dac_buffer(s->wm, block_size);
|
codec_buffer = wm8750_dac_buffer(s->wm, block_size);
|
||||||
for (pos = 0; pos < block_size; pos++) {
|
for (pos = 0; pos < block_size; pos++) {
|
||||||
*codec_buffer++ = cpu_to_le16(256 * *(int8_t *)mem_buffer);
|
*codec_buffer++ = cpu_to_le16(256 * *mem_buffer);
|
||||||
*codec_buffer++ = cpu_to_le16(256 * *(int8_t *)mem_buffer++);
|
*codec_buffer++ = cpu_to_le16(256 * *mem_buffer++);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
codec_buffer = wm8750_dac_buffer(s->wm, block_size >> 1);
|
codec_buffer = wm8750_dac_buffer(s->wm, block_size >> 1);
|
||||||
for (pos = 0; pos < block_size; pos += 2) {
|
for (pos = 0; pos < block_size; pos += 2) {
|
||||||
*codec_buffer++ = cpu_to_le16(256 * *(int8_t *)mem_buffer++);
|
*codec_buffer++ = cpu_to_le16(256 * *mem_buffer++);
|
||||||
*codec_buffer++ = cpu_to_le16(256 * *(int8_t *)mem_buffer++);
|
*codec_buffer++ = cpu_to_le16(256 * *mem_buffer++);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user