/[svn]/linuxsampler/trunk/src/engines/gig/Engine.h
ViewVC logotype

Contents of /linuxsampler/trunk/src/engines/gig/Engine.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1748 - (show annotations) (download) (as text)
Sun Jun 22 14:46:46 2008 UTC (15 years, 9 months ago) by persson
File MIME type: text/x-c++hdr
File size: 11498 byte(s)
* bugfix: notes triggered at position 0 in the audio buffer were
  sometimes wrongly killed in the same buffer, causing no sound to be
  played
* fixes for audio drivers with varying buffer sizes
* Makefile fix: JACK_CFLAGS wasn't used
* JACK driver: use jack_client_open instead of the deprecated
  jack_client_new

1 /***************************************************************************
2 * *
3 * LinuxSampler - modular, streaming capable sampler *
4 * *
5 * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck *
6 * Copyright (C) 2005-2008 Christian Schoenebeck *
7 * *
8 * This program is free software; you can redistribute it and/or modify *
9 * it under the terms of the GNU General Public License as published by *
10 * the Free Software Foundation; either version 2 of the License, or *
11 * (at your option) any later version. *
12 * *
13 * This program is distributed in the hope that it will be useful, *
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
16 * GNU General Public License for more details. *
17 * *
18 * You should have received a copy of the GNU General Public License *
19 * along with this program; if not, write to the Free Software *
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, *
21 * MA 02111-1307 USA *
22 ***************************************************************************/
23
24 #ifndef __LS_GIG_ENGINE_H__
25 #define __LS_GIG_ENGINE_H__
26
27 #include "../../common/global.h"
28
29 #include <map>
30 #include <gig.h>
31
32 #include "EngineGlobals.h"
33 #include "../../common/RingBuffer.h"
34 #include "../../common/Pool.h"
35 #include "../../common/ArrayList.h"
36 #include "../../common/ConditionServer.h"
37 #include "../Engine.h"
38 #include "../common/Event.h"
39 #include "../../network/lscp.h"
40 #include "EngineChannel.h"
41
42 // identifier of this sampler engine
43 #define LS_GIG_ENGINE_NAME "GIG"
44
45 namespace LinuxSampler { namespace gig {
46
47 // just symbol prototyping
48 class Voice;
49 class DiskThread;
50 class InstrumentResourceManager;
51 class midi_key_info_t;
52 class EngineChannel;
53
54 /**
55 * Sampler engine for the Gigasampler format.
56 */
57 class Engine : public LinuxSampler::Engine {
58 public:
59 // methods
60 Engine();
61 virtual ~Engine();
62 void Connect(AudioOutputDevice* pAudioOut);
63 void SuspendAll();
64 void ResumeAll();
65 void Suspend(::gig::Region* pRegion);
66 void Resume(::gig::Region* pRegion);
67
68 // implementation of abstract methods derived from class 'LinuxSampler::Engine'
69 virtual int RenderAudio(uint Samples);
70 virtual void SendSysex(void* pData, uint Size);
71 virtual void Reset();
72 virtual void Enable();
73 virtual void Disable();
74 virtual uint VoiceCount();
75 virtual uint VoiceCountMax();
76 virtual bool DiskStreamSupported();
77 virtual uint DiskStreamCount();
78 virtual uint DiskStreamCountMax();
79 virtual String DiskStreamBufferFillBytes();
80 virtual String DiskStreamBufferFillPercentage();
81 virtual String Description();
82 virtual String Version();
83 virtual String EngineName();
84 virtual InstrumentManager* GetInstrumentManager();
85
86 // Simple array wrapper just to make sure memory is freed
87 // when liblinuxsampler is unloaded
88 class FloatTable {
89 private:
90 const float* array;
91 public:
92 FloatTable(const float* array) : array(array) { }
93 ~FloatTable() { delete[] array; }
94 const float& operator[](int i) const { return array[i]; }
95 };
96
97 static const FloatTable VolumeCurve; ///< Table that maps volume control change values 0..127 to amplitude. Unity gain is at 90.
98 static const FloatTable PanCurve; ///< Table that maps pan control change values 0..128 to right channel amplitude. Unity gain is at 64 (center).
99 static const FloatTable CrossfadeCurve; ///< Table that maps crossfade control change values 0..127 to amplitude. Unity gain is at 127.
100
101 //protected:
102 static InstrumentResourceManager instruments;
103
104 AudioOutputDevice* pAudioOutputDevice;
105 uint SampleRate; ///< Sample rate of the engines output audio signal (in Hz)
106 uint MaxSamplesPerCycle; ///< Size of each audio output buffer
107 DiskThread* pDiskThread;
108 RingBuffer<Event,false>* pEventQueue; ///< Input event queue for engine global events (e.g. SysEx messages).
109 Pool<Voice>* pVoicePool; ///< Contains all voices that can be activated.
110 EventGenerator* pEventGenerator;
111 RTList<Event>* pVoiceStealingQueue; ///< All voice-launching events which had to be postponed due to free voice shortage.
112 RTList<Event>* pGlobalEvents; ///< All engine global events for the current audio fragment (usually only SysEx messages).
113 Pool<Event>* pEventPool; ///< Contains all Event objects that can be used.
114 RingBuffer<uint8_t,false>* pSysexBuffer; ///< Input buffer for MIDI system exclusive messages.
115 int ActiveVoiceCount; ///< number of currently active voices (this value will be returned for public calls)
116 int ActiveVoiceCountTemp; ///< number of currently active voices (for internal usage, will be used for incrementation)
117 int ActiveVoiceCountMax; ///< the maximum voice usage since application start
118 int VoiceSpawnsLeft; ///< We only allow CONFIG_MAX_VOICES voices to be spawned per audio fragment, we use this variable to ensure this limit.
119 RTList<Voice>::Iterator itLastStolenVoice; ///< Only for voice stealing: points to the last voice which was theft in current audio fragment, NULL otherwise.
120 RTList<uint>::Iterator iuiLastStolenKey; ///< Only for voice stealing: key number of last key on which the last voice was theft in current audio fragment, NULL otherwise.
121 EngineChannel* pLastStolenChannel; ///< Only for voice stealing: points to the engine channel on which the previous voice was stolen in this audio fragment.
122 RTList<Voice>::Iterator itLastStolenVoiceGlobally; ///< Same as itLastStolenVoice, but engine globally
123 RTList<uint>::Iterator iuiLastStolenKeyGlobally; ///< Same as iuiLastStolenKey, but engine globally
124 bool SuspensionRequested;
125 ConditionServer EngineDisabled;
126 int8_t ScaleTuning[12]; ///< contains optional detune factors (-64..+63 cents) for all 12 semitones of an octave
127 int MinFadeOutSamples; ///< The number of samples needed to make an instant fade out (e.g. for voice stealing) without leading to clicks.
128 uint32_t RandomSeed; ///< State of the random number generator used by the random dimension.
129 Mutex ResetInternalMutex; ///< Mutex to protect the ResetInternal function for concurrent usage (e.g. by the lscp and instrument loader threads).
130 Pool< ::gig::DimensionRegion*>* pDimRegionPool[2]; ///< Double buffered pool, used by the engine channels to keep track of dimension regions in use.
131
132 void ProcessEvents(EngineChannel* pEngineChannel, uint Samples);
133 void RenderActiveVoices(EngineChannel* pEngineChannel, uint Samples);
134 void RenderStolenVoices(uint Samples);
135 void RouteAudio(EngineChannel* pEngineChannel, uint Samples);
136 void PostProcess(EngineChannel* pEngineChannel);
137 void ClearEventLists();
138 void ImportEvents(uint Samples);
139 void ProcessNoteOn(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent);
140 void ProcessNoteOff(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOffEvent);
141 void ProcessPitchbend(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itPitchbendEvent);
142 void ProcessControlChange(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itControlChangeEvent);
143 void ProcessSysex(Pool<Event>::Iterator& itSysexEvent);
144 void ProcessSuspensionsChanges();
145 void ProcessPendingStreamDeletions();
146 Pool<Voice>::Iterator LaunchVoice(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent, int iLayer, bool ReleaseTriggerVoice, bool VoiceStealing, bool HandleKeyGroupConflicts);
147 int StealVoice(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent);
148 void FreeVoice(EngineChannel* pEngineChannel, Pool<Voice>::Iterator& itVoice);
149 void FreeKey(EngineChannel* pEngineChannel, midi_key_info_t* pKey);
150 void ResetInternal();
151 void ResetScaleTuning();
152 void ResetSuspendedRegions();
153
154 static Engine* AcquireEngine(LinuxSampler::gig::EngineChannel* pChannel, AudioOutputDevice* pDevice);
155 static void FreeEngine(LinuxSampler::gig::EngineChannel* pChannel, AudioOutputDevice* pDevice);
156
157 void DisableAndLock(); // FIXME: should at least be protected
158
159 friend class Voice;
160 private:
161 Pool< ::gig::Region*> SuspendedRegions;
162 Mutex SuspendedRegionsMutex;
163 Condition SuspensionChangeOngoing;
164 ::gig::Region* pPendingRegionSuspension;
165 ::gig::Region* pPendingRegionResumption;
166 int iPendingStreamDeletions;
167
168 ArrayList<EngineChannel*> engineChannels; ///< All engine channels of a gig::Engine instance.
169
170 static std::map<AudioOutputDevice*,Engine*> engines; ///< All instances of gig::Engine.
171
172 int SostenutoKeys[128];
173 int SostenutoKeyCount;
174
175 uint8_t GSCheckSum(const RingBuffer<uint8_t,false>::NonVolatileReader AddrReader, uint DataSize);
176 void AdjustScale(int8_t ScaleTunes[12]);
177 void ReleaseAllVoices(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itReleaseEvent);
178 void KillAllVoices(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itKillEvent);
179 bool ShouldReleaseVoice(EngineChannel* pEngineChannel, int Key);
180 bool RegionSuspended(::gig::Region* pRegion);
181 static float* InitVolumeCurve();
182 static float* InitPanCurve();
183 static float* InitCrossfadeCurve();
184 static float* InitCurve(const float* segments, int size = 128);
185
186 unsigned long FrameTime; ///< Time in frames of the start of the current audio fragment
187 };
188
189 }} // namespace LinuxSampler::gig
190
191 #endif // __LS_GIG_ENGINE_H__

  ViewVC Help
Powered by ViewVC