- Posts: 3333
Interrupts and MUSIC_Play()
- vlad_vy
- 
				Topic Author 
- Offline
		Less
		More
		
			
	
		
			
	
						07 May 2018 14:51				#69098
		by vlad_vy
	
	
		
			
	
			
			 		
	
												
	
				Interrupts and MUSIC_Play() was created by vlad_vy			
			
				I think we need remove MUSIC_Play() from all interrupts (Mixer and protocols), since MUSIC_Play() read "sound.ini" and can interfere with other flash memory read and write operations.
We can replace it by set of SOUND_SetFrequency() and SOUND_Start(), or by MUSIC_Beep().
					We can replace it by set of SOUND_SetFrequency() and SOUND_Start(), or by MUSIC_Beep().
Please Log in or Create an account to join the conversation.
- Moeder
- 
				
- Offline
		Less
		More
		
			
	
		- Posts: 796
			
	
						07 May 2018 15:57		 -  07 May 2018 15:57		#69099
		by Moeder
	
	
		
			
	
	
			 		
	
												
	
				Replied by Moeder on topic Interrupts and MUSIC_Play()			
			
				I noticed this back when working on implementation of voice (based on mwm's work) and didn't like the concept of rereading sound.ini each time a music is played either. But I didn't want to break anything so I didn't touch it. Actually we cannot easily replace it with SOUND_SetFrequency() etc., as each music consists of several notes and only the current music played is kept in memory. I think we will run into memory issues on devo7e if we try to keep all of sound.ini in memory by parsing sound.ini at startup (where it would make most sense).			
					
		Last edit: 07 May 2018 15:57  by Moeder.			
			Please Log in or Create an account to join the conversation.
- vlad_vy
- 
				Topic Author 
- Offline
		Less
		More
		
			
	
		- Posts: 3333
			
	
						07 May 2018 16:26				#69100
		by vlad_vy
	
	
		
			
	
			
			 		
	
												
	
				Replied by vlad_vy on topic Interrupts and MUSIC_Play()			
			
				Protocols use only MUSIC_Play(MUSIC_DONE_BINDING) 3 notes, mux "beep" MUSIC_Play(MUSIC_SAVING) 2 notes. It can be easily replaced.
But mux "voice" use MUSIC_Play(Model.voice.mixer[mixer->dest].music).
Q303 protocol use MUSIC_Beep("d2", 100, 100, (vtx_channel & 7) + 1) that don't use "sound.ini".
					But mux "voice" use MUSIC_Play(Model.voice.mixer[mixer->dest].music).
Q303 protocol use MUSIC_Beep("d2", 100, 100, (vtx_channel & 7) + 1) that don't use "sound.ini".
Please Log in or Create an account to join the conversation.
- Moeder
- 
				
- Offline
		Less
		More
		
			
	
		- Posts: 796
			
	
						07 May 2018 21:07				#69101
		by Moeder
	
	
		
			
				
sound.ini reading does not happen for mux voice alerts, because of // Play audio for switch
at the very beginning of MUSIC_Play
					
	
			
			 		
	
												
	
				Replied by Moeder on topic Interrupts and MUSIC_Play()			
			vlad_vy wrote: But mux "voice" use MUSIC_Play(Model.voice.mixer[mixer->dest].music).
sound.ini reading does not happen for mux voice alerts, because of // Play audio for switch
if ( music > MUSIC_TOTAL ) {
        if (AUDIO_VoiceAvailable())
            AUDIO_AddQueue(music);
        return;
    }at the very beginning of MUSIC_Play
Please Log in or Create an account to join the conversation.
		Time to create page: 0.099 seconds	
- 
											Home
					
											
							  
- 
											Forum
					
											
							  
- 
											Development
					
											
							  
- 
											Development
					
											
							  
- Interrupts and MUSIC_Play()
