/[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 1879 - (show annotations) (download) (as text)
Sun Mar 29 18:43:40 2009 UTC (15 years ago) by schoenebeck
File MIME type: text/x-c++hdr
File size: 11838 byte(s)
* atomic.h was accidently included in the liblinuxsampler C++ API header
  files (fixes bug #122)

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

  ViewVC Help
Powered by ViewVC