| 
									
										
										
										
											2011-07-31 02:37:31 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  ** Supermodel | 
					
						
							|  |  |  |  ** A Sega Model 3 Arcade Emulator. | 
					
						
							| 
									
										
										
										
											2011-09-14 19:08:43 +00:00
										 |  |  |  ** Copyright 2011 Bart Trzynadlowski, Nik Henson | 
					
						
							| 
									
										
										
										
											2011-07-31 02:37:31 +00:00
										 |  |  |  ** | 
					
						
							|  |  |  |  ** This file is part of Supermodel. | 
					
						
							|  |  |  |  ** | 
					
						
							|  |  |  |  ** Supermodel is free software: you can redistribute it and/or modify it under | 
					
						
							|  |  |  |  ** the terms of the GNU General Public License as published by the Free  | 
					
						
							|  |  |  |  ** Software Foundation, either version 3 of the License, or (at your option) | 
					
						
							|  |  |  |  ** any later version. | 
					
						
							|  |  |  |  ** | 
					
						
							|  |  |  |  ** Supermodel is distributed in the hope that it will be useful, but WITHOUT | 
					
						
							|  |  |  |  ** ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | 
					
						
							|  |  |  |  ** FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for | 
					
						
							|  |  |  |  ** more details. | 
					
						
							|  |  |  |  ** | 
					
						
							|  |  |  |  ** You should have received a copy of the GNU General Public License along | 
					
						
							|  |  |  |  ** with Supermodel.  If not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							|  |  |  |  **/ | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2011-09-14 19:08:43 +00:00
										 |  |  |  * MPEG.h | 
					
						
							| 
									
										
										
										
											2011-07-31 02:37:31 +00:00
										 |  |  |  *  | 
					
						
							| 
									
										
										
										
											2011-09-14 19:08:43 +00:00
										 |  |  |  * Header file for MPEG decoder based on AMP by Tomislav Uzalec. Modified to | 
					
						
							|  |  |  |  * play from memory buffers by R. Belmont for his arcade music player, M1. | 
					
						
							| 
									
										
										
										
											2011-07-31 02:37:31 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | #ifndef INCLUDED_MPEG_H
 | 
					
						
							|  |  |  | #define INCLUDED_MPEG_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "Types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /******************************************************************************
 | 
					
						
							|  |  |  |  Functions | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  |  The MPEG decoder is not thread-safe and must not be used by multiple sources. | 
					
						
							|  |  |  |  These functions are located in audio.cpp and getbits.cpp. | 
					
						
							|  |  |  | ******************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-09 18:36:29 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * MPEG_IsPlaying(void): | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Returns: | 
					
						
							| 
									
										
										
										
											2011-09-08 06:34:18 +00:00
										 |  |  |  *		TRUE if an MPEG stream is currently playing, otherwise false. | 
					
						
							| 
									
										
										
										
											2011-08-09 18:36:29 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-09-08 06:34:18 +00:00
										 |  |  | extern bool MPEG_IsPlaying(void); | 
					
						
							| 
									
										
										
										
											2011-08-09 18:36:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-31 02:37:31 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * MPEG_GetProgress(void): | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Returns: | 
					
						
							| 
									
										
										
										
											2011-08-09 18:36:29 +00:00
										 |  |  |  * 		The current byte offset within the MPEG stream, relative to the start. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | extern int MPEG_GetProgress(void);							 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * MPEG_SetOffset(pos): | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Sets the playback position within an MPEG stream. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Parameters: | 
					
						
							|  |  |  |  *		pos		Byte offset relative to the beginning of the current MPEG | 
					
						
							|  |  |  |  *				stream. | 
					
						
							| 
									
										
										
										
											2011-07-31 02:37:31 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-08-09 18:36:29 +00:00
										 |  |  | extern void MPEG_SetOffset(int pos); | 
					
						
							| 
									
										
										
										
											2011-07-31 02:37:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * MPEG_SetLoop(loop, loopend): | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Sets the start and end offsets for looped playback. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Parameters: | 
					
						
							|  |  |  |  *		loop		Start address. | 
					
						
							| 
									
										
										
										
											2011-08-28 04:37:41 +00:00
										 |  |  |  *		loopend		End offset. Must NOT be 0! | 
					
						
							| 
									
										
										
										
											2011-07-31 02:37:31 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | extern void MPEG_SetLoop(const char *loop, int loopend);		 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * MPEG_Decode(outputs, length): | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Decodes the requested number of samples from the currently playing MPEG | 
					
						
							|  |  |  |  * stream and updates the internal play position. If an MPEG is not playing, | 
					
						
							|  |  |  |  * writes silence (zeros). | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Parameters: | 
					
						
							|  |  |  |  *		outputs		A two-element array of pointers to equal-length signed 16- | 
					
						
							|  |  |  |  *					bit sample buffers. The first is the left channel and the | 
					
						
							|  |  |  |  *					second is the right channel. Audio is decoded to these. | 
					
						
							|  |  |  |  *		length		Number of samples to decode. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | extern void MPEG_Decode(INT16 **outputs, int length);			 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * MPEG_PlayMemory(sa, length): | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Specifies the memory buffer to decode from. This initializes the playback | 
					
						
							| 
									
										
										
										
											2011-08-09 18:36:29 +00:00
										 |  |  |  * process and will decode the first MPEG frame internally. The loop start | 
					
						
							|  |  |  |  * position is cleared (set looping after this call). | 
					
						
							| 
									
										
										
										
											2011-07-31 02:37:31 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Parameters: | 
					
						
							|  |  |  |  *		sa		Start address of MPEG stream. | 
					
						
							|  |  |  |  *		length	Length in bytes. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | extern void MPEG_PlayMemory(const char *sa, int length);		 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * MPEG_StopPlaying(void): | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Stop playing the current MPEG stream. The decoder will return silence. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | extern void MPEG_StopPlaying(void);									 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * MPEG_Init(void): | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Initializes the MPEG decoder. This should be called once per program | 
					
						
							|  |  |  |  * session. Allocates an internal buffer for MPEG decoding. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Returns: | 
					
						
							|  |  |  |  *		OKAY if successful, FAIL if internal buffer could not be allocated. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-09-08 06:34:18 +00:00
										 |  |  | extern bool MPEG_Init(void); | 
					
						
							| 
									
										
										
										
											2011-07-31 02:37:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * MPEG_Shutdown(void): | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Shuts down the MPEG decoder. Releases internal memory. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | extern void MPEG_Shutdown(void);									 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif	// INCLUDED_MPEG_H
 |