filename | src/aica/audio.c |
changeset | 1089:a3984d242909 |
prev | 1024:c67f2d61ab97 |
next | 1296:30ecee61f811 |
author | nkeynes |
date | Fri Mar 02 23:49:10 2012 +1000 (12 years ago) |
permissions | -rw-r--r-- |
last change | Android WIP: * Rename gui_jni.c to gui_android.c - now quite android specific. * Implement generic EGL driver with very minimal Java wrapper * Run emulation in separate thread, and implement simple queue for inter-thread communication. * Add menu/action-bar items for start + reset |
file | annotate | diff | log | raw |
1.1 --- a/src/aica/audio.c Sat Jun 13 00:50:48 2009 +00001.2 +++ b/src/aica/audio.c Fri Mar 02 23:49:10 2012 +10001.3 @@ -328,7 +328,7 @@1.4 switch( channel->sample_format ) {1.5 case AUDIO_FMT_16BIT:1.6 for( j=0; j<num_samples; j++ ) {1.7 - sample = ((int16_t *)(aica_main_ram + channel->start))[channel->posn];1.8 + sample = *(int16_t *)(aica_main_ram + ((channel->start + channel->posn*2)&AUDIO_MEM_MASK));1.9 result_buf[j][0] += sample * vol_left;1.10 result_buf[j][1] += sample * vol_right;1.12 @@ -352,7 +352,7 @@1.13 break;1.14 case AUDIO_FMT_8BIT:1.15 for( j=0; j<num_samples; j++ ) {1.16 - sample = ((int8_t *)(aica_main_ram + channel->start))[channel->posn] << 8;1.17 + sample = (*(int8_t *)(aica_main_ram + ((channel->start + channel->posn)&AUDIO_MEM_MASK))) << 8;1.18 result_buf[j][0] += sample * vol_left;1.19 result_buf[j][1] += sample * vol_right;1.21 @@ -395,7 +395,7 @@1.22 break;1.23 }1.24 }1.25 - uint8_t data = ((uint8_t *)(aica_main_ram + channel->start))[channel->posn>>1];1.26 + uint8_t data = *(uint8_t *)(aica_main_ram + ((channel->start + (channel->posn>>1))&AUDIO_MEM_MASK));1.27 if( channel->posn&1 ) {1.28 adpcm_yamaha_decode_nibble( channel, (data >> 4) & 0x0F );1.29 } else {
.