mirror of
				https://github.com/RaySollium99/picodrive.git
				synced 2025-10-26 08:19:38 -04:00 
			
		
		
		
	mcd, revisit track handling in cdd
This commit is contained in:
		
							parent
							
								
									db2b6d9966
								
							
						
					
					
						commit
						4447902711
					
				
					 1 changed files with 115 additions and 283 deletions
				
			
		
							
								
								
									
										398
									
								
								pico/cd/cdd.c
									
										
									
									
									
								
							
							
						
						
									
										398
									
								
								pico/cd/cdd.c
									
										
									
									
									
								
							|  | @ -196,6 +196,70 @@ static void cdd_change_track(int index, int lba) | ||||||
|   cdda_start_play(base, lba_offset, lb_len); |   cdda_start_play(base, lba_offset, lb_len); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static off_t read_pos = -1; | ||||||
|  | 
 | ||||||
|  | void cdd_seek(int index, int lba) | ||||||
|  | { | ||||||
|  |   int aindex = (index < 0 ? -index : index); | ||||||
|  | 
 | ||||||
|  | #ifdef USE_LIBTREMOR | ||||||
|  | #ifdef DISABLE_MANY_OGG_OPEN_FILES | ||||||
|  |   /* check if track index has changed */ | ||||||
|  |   if (index != cdd.index) | ||||||
|  |   { | ||||||
|  |     /* close previous track VORBIS file structure to save memory */ | ||||||
|  |     if (cdd.index >= 0 && cdd.toc.tracks[cdd.index].vf.datasource) | ||||||
|  |     { | ||||||
|  |       ogg_free(cdd.index); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /* open current track VORBIS file */ | ||||||
|  |     if (cdd.toc.tracks[aindex].vf.seekable) | ||||||
|  |     { | ||||||
|  |       ov_open(cdd.toc.tracks[aindex].fd,&cdd.toc.tracks[aindex].vf,0,0); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | #endif | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  |   /* update current track index and LBA */ | ||||||
|  |   cdd.index = aindex; | ||||||
|  |   cdd.lba = lba; | ||||||
|  | 
 | ||||||
|  |   /* stay within track limits when seeking files */ | ||||||
|  |   if (lba < cdd.toc.tracks[cdd.index].start) | ||||||
|  |   { | ||||||
|  |     lba = cdd.toc.tracks[cdd.index].start; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   /* seek to current block */ | ||||||
|  |   if (!is_audio(cdd.index)) | ||||||
|  |   { | ||||||
|  |     /* DATA track */ | ||||||
|  |     read_pos = lba * cdd.sectorSize; | ||||||
|  |     pm_seek(cdd.toc.tracks[cdd.index].fd, read_pos, SEEK_SET); | ||||||
|  |   } | ||||||
|  | #ifdef USE_LIBTREMOR | ||||||
|  |   else if (cdd.toc.tracks[cdd.index].vf.seekable) | ||||||
|  |   { | ||||||
|  |     /* VORBIS AUDIO track */ | ||||||
|  |     ov_pcm_seek(&cdd.toc.tracks[cdd.index].vf, (lba - cdd.toc.tracks[cdd.index].start) * 588 - cdd.toc.tracks[cdd.index].offset); | ||||||
|  |   } | ||||||
|  | #endif | ||||||
|  | #if 0 | ||||||
|  |   else if (cdd.toc.tracks[cdd.index].fd) | ||||||
|  |   { | ||||||
|  |     /* PCM AUDIO track */ | ||||||
|  |     fseek(cdd.toc.tracks[cdd.index].fd, (lba * 2352) - cdd.toc.tracks[cdd.index].offset, SEEK_SET); | ||||||
|  |   } | ||||||
|  | #else | ||||||
|  |   else | ||||||
|  |   { | ||||||
|  |     cdd_change_track(cdd.index, lba); | ||||||
|  |   } | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  | 
 | ||||||
| int cdd_context_save(uint8 *state) | int cdd_context_save(uint8 *state) | ||||||
| { | { | ||||||
|   int bufferptr = 0; |   int bufferptr = 0; | ||||||
|  | @ -213,19 +277,8 @@ int cdd_context_save(uint8 *state) | ||||||
| 
 | 
 | ||||||
| int cdd_context_load(uint8 *state) | int cdd_context_load(uint8 *state) | ||||||
| { | { | ||||||
|   int lba; |  | ||||||
|   int bufferptr = 0; |   int bufferptr = 0; | ||||||
| 
 | 
 | ||||||
| #ifdef USE_LIBTREMOR |  | ||||||
| #ifdef DISABLE_MANY_OGG_OPEN_FILES |  | ||||||
|   /* close previous track VORBIS file structure to save memory */ |  | ||||||
|   if (cdd.toc.tracks[cdd.index].vf.datasource) |  | ||||||
|   { |  | ||||||
|     ogg_free(cdd.index); |  | ||||||
|   } |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
|   load_param(&cdd.cycles, sizeof(cdd.cycles)); |   load_param(&cdd.cycles, sizeof(cdd.cycles)); | ||||||
|   load_param(&cdd.latency, sizeof(cdd.latency)); |   load_param(&cdd.latency, sizeof(cdd.latency)); | ||||||
|   load_param(&cdd.index, sizeof(cdd.index)); |   load_param(&cdd.index, sizeof(cdd.index)); | ||||||
|  | @ -234,45 +287,8 @@ int cdd_context_load(uint8 *state) | ||||||
|   load_param(&cdd.volume, sizeof(cdd.volume)); |   load_param(&cdd.volume, sizeof(cdd.volume)); | ||||||
|   load_param(&cdd.status, sizeof(cdd.status)); |   load_param(&cdd.status, sizeof(cdd.status)); | ||||||
| 
 | 
 | ||||||
|   /* adjust current LBA within track limit */ |  | ||||||
|   lba = cdd.lba; |  | ||||||
|   if (lba < cdd.toc.tracks[cdd.index].start) |  | ||||||
|   { |  | ||||||
|     lba = cdd.toc.tracks[cdd.index].start; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   /* seek to current track position */ |   /* seek to current track position */ | ||||||
|   if (!is_audio(cdd.index)) |   cdd_seek(-cdd.index, cdd.lba); | ||||||
|   { |  | ||||||
|     /* DATA track */ |  | ||||||
|     if (cdd.toc.tracks[cdd.index].fd) |  | ||||||
|     { |  | ||||||
|       pm_seek(cdd.toc.tracks[cdd.index].fd, lba * cdd.sectorSize, SEEK_SET); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| #ifdef USE_LIBTREMOR |  | ||||||
|   else if (cdd.toc.tracks[cdd.index].vf.seekable) |  | ||||||
|   { |  | ||||||
| #ifdef DISABLE_MANY_OGG_OPEN_FILES |  | ||||||
|     /* VORBIS file need to be opened first */ |  | ||||||
|     ov_open(cdd.toc.tracks[cdd.index].fd,&cdd.toc.tracks[cdd.index].vf,0,0); |  | ||||||
| #endif |  | ||||||
|     /* VORBIS AUDIO track */ |  | ||||||
|     ov_pcm_seek(&cdd.toc.tracks[cdd.index].vf, (lba - cdd.toc.tracks[cdd.index].start) * 588 - cdd.toc.tracks[cdd.index].offset); |  | ||||||
|   } |  | ||||||
| #endif |  | ||||||
| #if 0 |  | ||||||
|   else if (cdd.toc.tracks[cdd.index].fd) |  | ||||||
|   { |  | ||||||
|     /* PCM AUDIO track */ |  | ||||||
|     fseek(cdd.toc.tracks[cdd.index].fd, (lba * 2352) - cdd.toc.tracks[cdd.index].offset, SEEK_SET); |  | ||||||
|   } |  | ||||||
| #else |  | ||||||
|   else |  | ||||||
|   { |  | ||||||
|     cdd_change_track(cdd.index, lba); |  | ||||||
|   } |  | ||||||
| #endif |  | ||||||
| 
 | 
 | ||||||
|   return bufferptr; |   return bufferptr; | ||||||
| } | } | ||||||
|  | @ -280,6 +296,8 @@ int cdd_context_load(uint8 *state) | ||||||
| int cdd_context_load_old(uint8 *state) | int cdd_context_load_old(uint8 *state) | ||||||
| { | { | ||||||
|   memcpy(&cdd.lba, state + 8, sizeof(cdd.lba)); |   memcpy(&cdd.lba, state + 8, sizeof(cdd.lba)); | ||||||
|  |   cdd_seek(-cdd.index, cdd.lba); | ||||||
|  | 
 | ||||||
|   return 12 * 4; |   return 12 * 4; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -510,17 +528,29 @@ int cdd_unload(void) | ||||||
| void cdd_read_data(uint8 *dst) | void cdd_read_data(uint8 *dst) | ||||||
| { | { | ||||||
|   /* only read DATA track sectors */ |   /* only read DATA track sectors */ | ||||||
|   if (!is_audio(cdd.index) && (cdd.lba >= 0) && (cdd.lba < cdd.toc.tracks[cdd.index].end)) |   if (!is_audio(cdd.index) && (cdd.lba >= cdd.toc.tracks[cdd.index].start) && | ||||||
|  |                               (cdd.lba < cdd.toc.tracks[cdd.index].end)) | ||||||
|   { |   { | ||||||
|  |     off_t pos; | ||||||
|  | 
 | ||||||
|     /* BIN format ? */ |     /* BIN format ? */ | ||||||
|     if (cdd.sectorSize == 2352) |     if (cdd.sectorSize == 2352) | ||||||
|     { |     { | ||||||
|       /* skip 16-byte header */ |       /* skip 16-byte header */ | ||||||
|       pm_seek(cdd.toc.tracks[cdd.index].fd, cdd.lba * 2352 + 16, SEEK_SET); |       pos = cdd.lba * 2352 + 16; | ||||||
|  |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|  |       pos = cdd.lba * cdd.sectorSize; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     if (pos != read_pos) { | ||||||
|  |       pm_seek(cdd.toc.tracks[cdd.index].fd, pos, SEEK_SET); | ||||||
|  |       read_pos = pos; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* read sector data (Mode 1 = 2048 bytes) */ |     /* read sector data (Mode 1 = 2048 bytes) */ | ||||||
|     pm_read(dst, 2048, cdd.toc.tracks[cdd.index].fd); |     read_pos += pm_read(dst, 2048, cdd.toc.tracks[cdd.index].fd); | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -719,7 +749,7 @@ void cdd_update(void) | ||||||
|       header[3] = 0x01; |       header[3] = 0x01; | ||||||
| 
 | 
 | ||||||
|       /* data track sector read is controlled by CDC */ |       /* data track sector read is controlled by CDC */ | ||||||
|       cdd.lba += cdc_decoder_update(header); |       cdc_decoder_update(header); | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
|  | @ -734,51 +764,19 @@ void cdd_update(void) | ||||||
| 
 | 
 | ||||||
|       /* audio blocks are still sent to CDC as well as CD DAC/Fader */ |       /* audio blocks are still sent to CDC as well as CD DAC/Fader */ | ||||||
|       cdc_decoder_update(header); |       cdc_decoder_update(header); | ||||||
|   |  | ||||||
|       /* next audio block is automatically read */ |  | ||||||
|       cdd.lba++; |  | ||||||
|     } |     } | ||||||
|  |   | ||||||
|  |     /* next block is automatically read */ | ||||||
|  |     cdd.lba++; | ||||||
| 
 | 
 | ||||||
|     /* check end of current track */ |     /* check end of current track */ | ||||||
|     if (cdd.lba >= cdd.toc.tracks[cdd.index].end) |     if (cdd.lba >= cdd.toc.tracks[cdd.index].end) | ||||||
|     { |     { | ||||||
| #ifdef USE_LIBTREMOR |  | ||||||
| #ifdef DISABLE_MANY_OGG_OPEN_FILES |  | ||||||
|       /* close previous track VORBIS file structure to save memory */ |  | ||||||
|       if (cdd.toc.tracks[cdd.index].vf.datasource) |  | ||||||
|       { |  | ||||||
|         ogg_free(cdd.index); |  | ||||||
|       } |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
|       /* play next track */ |  | ||||||
|       cdd.index++; |  | ||||||
| 
 |  | ||||||
|       /* PAUSE between tracks */ |       /* PAUSE between tracks */ | ||||||
|       Pico_mcd->s68k_regs[0x36+0] = 0x01; |       Pico_mcd->s68k_regs[0x36+0] = 0x01; | ||||||
| 
 | 
 | ||||||
|       /* seek to next audio track start */ |       /* seek to next audio track start */ | ||||||
| #ifdef USE_LIBTREMOR |       cdd_seek(cdd.index + 1, cdd.lba); | ||||||
|       if (cdd.toc.tracks[cdd.index].vf.seekable) |  | ||||||
|       { |  | ||||||
| #ifdef DISABLE_MANY_OGG_OPEN_FILES |  | ||||||
|         /* VORBIS file need to be opened first */ |  | ||||||
|         ov_open(cdd.toc.tracks[cdd.index].fd,&cdd.toc.tracks[cdd.index].vf,0,0); |  | ||||||
| #endif |  | ||||||
|         ov_pcm_seek(&cdd.toc.tracks[cdd.index].vf, -cdd.toc.tracks[cdd.index].offset); |  | ||||||
|       } |  | ||||||
|       else |  | ||||||
| #endif  |  | ||||||
| #if 0 |  | ||||||
|       if (cdd.toc.tracks[cdd.index].fd) |  | ||||||
|       { |  | ||||||
|         fseek(cdd.toc.tracks[cdd.index].fd, (cdd.toc.tracks[cdd.index].start * 2352) - cdd.toc.tracks[cdd.index].offset, SEEK_SET); |  | ||||||
|       } |  | ||||||
| #else |  | ||||||
|       { |  | ||||||
|         cdd_change_track(cdd.index, cdd.lba); |  | ||||||
|       } |  | ||||||
| #endif |  | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  | @ -791,100 +789,45 @@ void cdd_update(void) | ||||||
|     /* check current track limits */ |     /* check current track limits */ | ||||||
|     if (cdd.lba >= cdd.toc.tracks[cdd.index].end) |     if (cdd.lba >= cdd.toc.tracks[cdd.index].end) | ||||||
|     { |     { | ||||||
| #ifdef USE_LIBTREMOR |  | ||||||
| #ifdef DISABLE_MANY_OGG_OPEN_FILES |  | ||||||
|       /* close previous track VORBIS file structure to save memory */ |  | ||||||
|       if (cdd.toc.tracks[cdd.index].vf.datasource) |  | ||||||
|       { |  | ||||||
|         ogg_free(cdd.index); |  | ||||||
|       } |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
|       /* next track */ |       /* next track */ | ||||||
|       cdd.index++; |       if (cdd.index >= cdd.toc.last) | ||||||
| 
 |  | ||||||
|       /* skip directly to track start position */ |  | ||||||
|       cdd.lba = cdd.toc.tracks[cdd.index].start; |  | ||||||
|        |  | ||||||
|       /* AUDIO track playing ? */ |  | ||||||
|       if (cdd.status == CD_PLAY) |  | ||||||
|       { |       { | ||||||
|         Pico_mcd->s68k_regs[0x36+0] = 0x00; |         /* no AUDIO track playing */ | ||||||
|  |         Pico_mcd->s68k_regs[0x36+0] = 0x01; | ||||||
|  | 
 | ||||||
|  |         /* end of disc */ | ||||||
|  |         cdd.lba = cdd.toc.end; | ||||||
|  |         cdd.status = CD_END; | ||||||
|  |       } | ||||||
|  |       else | ||||||
|  |       { | ||||||
|  |         cdd_seek(cdd.index + 1, cdd.toc.tracks[cdd.index+1].start); | ||||||
|  | 
 | ||||||
|  |         /* AUDIO track playing ? */ | ||||||
|  |         if (cdd.status == CD_PLAY && is_audio(cdd.index)) | ||||||
|  |         { | ||||||
|  |           Pico_mcd->s68k_regs[0x36+0] = 0x00; | ||||||
|  |         } | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|     else if (cdd.lba < cdd.toc.tracks[cdd.index].start) |     else if (cdd.lba < cdd.toc.tracks[cdd.index].start) | ||||||
|     { |     { | ||||||
| #ifdef USE_LIBTREMOR |  | ||||||
| #ifdef DISABLE_MANY_OGG_OPEN_FILES |  | ||||||
|       /* close previous track VORBIS file structure to save memory */ |  | ||||||
|       if (cdd.toc.tracks[cdd.index].vf.datasource) |  | ||||||
|       { |  | ||||||
|         ogg_free(cdd.index); |  | ||||||
|       } |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
|       /* previous track */ |       /* previous track */ | ||||||
|       cdd.index--; |       if (cdd.index <= 0) | ||||||
| 
 |       { | ||||||
|       /* skip directly to track end position */ |         cdd_seek(0, 0); | ||||||
|       cdd.lba = cdd.toc.tracks[cdd.index].end; |       } | ||||||
|  |       else | ||||||
|  |       { | ||||||
|  |         cdd_seek(cdd.index - 1, cdd.toc.tracks[cdd.index-1].end); | ||||||
|  |       } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* check disc limits */ |  | ||||||
|     if (cdd.index < 0) |  | ||||||
|     { |  | ||||||
|       cdd.index = 0; |  | ||||||
|       cdd.lba = 0; |  | ||||||
|     } |  | ||||||
|     else if (cdd.index >= cdd.toc.last) |  | ||||||
|     { |  | ||||||
|       /* no AUDIO track playing */ |  | ||||||
|       Pico_mcd->s68k_regs[0x36+0] = 0x01; |  | ||||||
| 
 |  | ||||||
|       /* end of disc */ |  | ||||||
|       cdd.index = cdd.toc.last; |  | ||||||
|       cdd.lba = cdd.toc.end; |  | ||||||
|       cdd.status = CD_END; |  | ||||||
|       return; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /* seek to current block */ |  | ||||||
|     if (!is_audio(cdd.index)) |     if (!is_audio(cdd.index)) | ||||||
|     { |     { | ||||||
|       /* no AUDIO track playing */ |       /* no AUDIO track playing */ | ||||||
|       Pico_mcd->s68k_regs[0x36+0] = 0x01; |       Pico_mcd->s68k_regs[0x36+0] = 0x01; | ||||||
| 
 |  | ||||||
|       /* DATA track */ |  | ||||||
|       pm_seek(cdd.toc.tracks[cdd.index].fd, cdd.lba * cdd.sectorSize, SEEK_SET); |  | ||||||
|     } |     } | ||||||
| #ifdef USE_LIBTREMOR |  | ||||||
|     else if (cdd.toc.tracks[cdd.index].vf.seekable) |  | ||||||
|     { |  | ||||||
| #ifdef DISABLE_MANY_OGG_OPEN_FILES |  | ||||||
|       /* check if a new track is being played */ |  | ||||||
|       if (!cdd.toc.tracks[cdd.index].vf.datasource) |  | ||||||
|       { |  | ||||||
|         /* VORBIS file need to be opened first */ |  | ||||||
|         ov_open(cdd.toc.tracks[cdd.index].fd,&cdd.toc.tracks[cdd.index].vf,0,0); |  | ||||||
|       } |  | ||||||
| #endif |  | ||||||
|       /* VORBIS AUDIO track */ |  | ||||||
|       ov_pcm_seek(&cdd.toc.tracks[cdd.index].vf, (cdd.lba - cdd.toc.tracks[cdd.index].start) * 588 - cdd.toc.tracks[cdd.index].offset); |  | ||||||
|     } |  | ||||||
| #endif  |  | ||||||
| #if 0 |  | ||||||
|     else if (cdd.toc.tracks[cdd.index].fd) |  | ||||||
|     { |  | ||||||
|       /* PCM AUDIO track */ |  | ||||||
|       fseek(cdd.toc.tracks[cdd.index].fd, (cdd.lba * 2352) - cdd.toc.tracks[cdd.index].offset, SEEK_SET); |  | ||||||
|     } |  | ||||||
| #else |  | ||||||
|     else |  | ||||||
|     { |  | ||||||
|       cdd_change_track(cdd.index, cdd.lba); |  | ||||||
|     } |  | ||||||
| #endif |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -910,7 +853,7 @@ void cdd_process(void) | ||||||
|             Pico_mcd->s68k_regs[0x38+1] == 0x00 || |             Pico_mcd->s68k_regs[0x38+1] == 0x00 || | ||||||
|             Pico_mcd->s68k_regs[0x38+1] == 0x01) |             Pico_mcd->s68k_regs[0x38+1] == 0x01) | ||||||
|         { |         { | ||||||
|           int lba = cdd.lba + 150; |           int lba = cdd.lba + 150 - cdd.latency; | ||||||
| 	  if (Pico_mcd->s68k_regs[0x38+1] == 0x01) | 	  if (Pico_mcd->s68k_regs[0x38+1] == 0x01) | ||||||
|             lba = abs(cdd.lba - cdd.toc.tracks[cdd.index].start); |             lba = abs(cdd.lba - cdd.toc.tracks[cdd.index].start); | ||||||
| 	  if (Pico_mcd->s68k_regs[0x38+1] == 0x0f) | 	  if (Pico_mcd->s68k_regs[0x38+1] == 0x0f) | ||||||
|  | @ -1081,66 +1024,10 @@ void cdd_process(void) | ||||||
|         cdd.latency += (((cdd.lba - lba) * 120) / 270000); |         cdd.latency += (((cdd.lba - lba) * 120) / 270000); | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       /* update current LBA */ |  | ||||||
|       cdd.lba = lba; |  | ||||||
| 
 |  | ||||||
|       /* get track index */ |       /* get track index */ | ||||||
|       while ((cdd.toc.tracks[index].end <= lba) && (index < cdd.toc.last)) index++; |       while ((cdd.toc.tracks[index].end <= lba) && (index < cdd.toc.last)) index++; | ||||||
| 
 | 
 | ||||||
| #ifdef USE_LIBTREMOR |       cdd_seek(index, lba); | ||||||
| #ifdef DISABLE_MANY_OGG_OPEN_FILES |  | ||||||
|       /* check if track index has changed */ |  | ||||||
|       if (index != cdd.index) |  | ||||||
|       { |  | ||||||
|         /* close previous track VORBIS file structure to save memory */ |  | ||||||
|         if (cdd.toc.tracks[cdd.index].vf.datasource) |  | ||||||
|         { |  | ||||||
|           ogg_free(cdd.index); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         /* open current track VORBIS file */ |  | ||||||
|         if (cdd.toc.tracks[index].vf.seekable) |  | ||||||
|         { |  | ||||||
|           ov_open(cdd.toc.tracks[index].fd,&cdd.toc.tracks[index].vf,0,0); |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
|       /* update current track index */ |  | ||||||
|       cdd.index = index; |  | ||||||
| 
 |  | ||||||
|       /* stay within track limits when seeking files */ |  | ||||||
|       if (lba < cdd.toc.tracks[index].start)  |  | ||||||
|       { |  | ||||||
|         lba = cdd.toc.tracks[index].start; |  | ||||||
|       } |  | ||||||
|        |  | ||||||
|       /* seek to current block */ |  | ||||||
|       if (!is_audio(cdd.index)) |  | ||||||
|       { |  | ||||||
|         /* DATA track */ |  | ||||||
|         pm_seek(cdd.toc.tracks[cdd.index].fd, lba * cdd.sectorSize, SEEK_SET); |  | ||||||
|       } |  | ||||||
| #ifdef USE_LIBTREMOR |  | ||||||
|       else if (cdd.toc.tracks[index].vf.seekable) |  | ||||||
|       { |  | ||||||
|         /* VORBIS AUDIO track */ |  | ||||||
|         ov_pcm_seek(&cdd.toc.tracks[index].vf, (lba - cdd.toc.tracks[index].start) * 588 - cdd.toc.tracks[index].offset); |  | ||||||
|       } |  | ||||||
| #endif |  | ||||||
| #if 0 |  | ||||||
|       else if (cdd.toc.tracks[index].fd) |  | ||||||
|       { |  | ||||||
|         /* PCM AUDIO track */ |  | ||||||
|         fseek(cdd.toc.tracks[index].fd, (lba * 2352) - cdd.toc.tracks[index].offset, SEEK_SET); |  | ||||||
|       } |  | ||||||
| #else |  | ||||||
|       else |  | ||||||
|       { |  | ||||||
|         cdd_change_track(index, lba); |  | ||||||
|       } |  | ||||||
| #endif |  | ||||||
| 
 | 
 | ||||||
|       /* no audio track playing (yet) */ |       /* no audio track playing (yet) */ | ||||||
|       Pico_mcd->s68k_regs[0x36+0] = 0x01; |       Pico_mcd->s68k_regs[0x36+0] = 0x01; | ||||||
|  | @ -1180,66 +1067,11 @@ void cdd_process(void) | ||||||
|         cdd.latency = ((cdd.lba - lba) * 120) / 270000; |         cdd.latency = ((cdd.lba - lba) * 120) / 270000; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       /* update current LBA */ |  | ||||||
|       cdd.lba = lba; |  | ||||||
| 
 |  | ||||||
|       /* get current track index */ |       /* get current track index */ | ||||||
|       while ((cdd.toc.tracks[index].end <= lba) && (index < cdd.toc.last)) index++; |       while ((cdd.toc.tracks[index].end <= lba) && (index < cdd.toc.last)) index++; | ||||||
| 
 | 
 | ||||||
| #ifdef USE_LIBTREMOR |  | ||||||
| #ifdef DISABLE_MANY_OGG_OPEN_FILES |  | ||||||
|       /* check if track index has changed */ |  | ||||||
|       if (index != cdd.index) |  | ||||||
|       { |  | ||||||
|         /* close previous track VORBIS file structure to save memory */ |  | ||||||
|         if (cdd.toc.tracks[cdd.index].vf.datasource) |  | ||||||
|         { |  | ||||||
|           ogg_free(cdd.index); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         /* open current track VORBIS file */ |  | ||||||
|         if (cdd.toc.tracks[index].vf.seekable) |  | ||||||
|         { |  | ||||||
|           ov_open(cdd.toc.tracks[index].fd,&cdd.toc.tracks[index].vf,0,0); |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
|       /* update current track index */ |  | ||||||
|       cdd.index = index; |  | ||||||
| 
 |  | ||||||
|       /* stay within track limits */ |  | ||||||
|       if (lba < cdd.toc.tracks[index].start)  |  | ||||||
|       { |  | ||||||
|         lba = cdd.toc.tracks[index].start; |  | ||||||
|       } |  | ||||||
|        |  | ||||||
|       /* seek to current block */ |       /* seek to current block */ | ||||||
|       if (!is_audio(cdd.index)) |       cdd_seek(index, lba); | ||||||
|       { |  | ||||||
|         /* DATA track */ |  | ||||||
|         pm_seek(cdd.toc.tracks[cdd.index].fd, lba * cdd.sectorSize, SEEK_SET); |  | ||||||
|       } |  | ||||||
| #ifdef USE_LIBTREMOR |  | ||||||
|       else if (cdd.toc.tracks[index].vf.seekable) |  | ||||||
|       { |  | ||||||
|         /* VORBIS AUDIO track */ |  | ||||||
|         ov_pcm_seek(&cdd.toc.tracks[index].vf, (lba - cdd.toc.tracks[index].start) * 588 - cdd.toc.tracks[index].offset); |  | ||||||
|       } |  | ||||||
| #endif |  | ||||||
| #if 0 |  | ||||||
|       else if (cdd.toc.tracks[index].fd) |  | ||||||
|       { |  | ||||||
|         /* PCM AUDIO track */ |  | ||||||
|         fseek(cdd.toc.tracks[index].fd, (lba * 2352) - cdd.toc.tracks[index].offset, SEEK_SET); |  | ||||||
|       } |  | ||||||
| #else |  | ||||||
|       else |  | ||||||
|       { |  | ||||||
|         cdd_change_track(index, lba); |  | ||||||
|       } |  | ||||||
| #endif |  | ||||||
| 
 | 
 | ||||||
|       /* no audio track playing */ |       /* no audio track playing */ | ||||||
|       Pico_mcd->s68k_regs[0x36+0] = 0x01; |       Pico_mcd->s68k_regs[0x36+0] = 0x01; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 kub
						kub