/[svn]/linuxsampler/tags/v0_1_0/src/diskthread.h
ViewVC logotype

Annotation of /linuxsampler/tags/v0_1_0/src/diskthread.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 35 - (hide annotations) (download) (as text)
Fri Mar 5 13:46:15 2004 UTC (20 years, 3 months ago) by schoenebeck
Original Path: linuxsampler/trunk/src/diskthread.h
File MIME type: text/x-c++hdr
File size: 5285 byte(s)
* implemented parser for the LinuxSampler control protocol (LSCP) by using
  flex / bison (where src/network/lscp.l is the input file for lex / flex
  and src/network/lscp.y is the input file for yacc / bison), parser and
  scanner can be regenerated by 'make parser'
* implemented LSCP network server (only single threaded so far), LSCP
  server will be launched if LinuxSampler was started with "--server" flag,
  implemented the following LSCP commands so far: "LOAD INSTRUMENT", "GET
  CHANNEL VOICE_COUNT", "GET CHANNEL STREAM_COUNT", "GET CHANNEL
  BUFFER_FILL", "SET CHANNEL VOLUME" and "RESET CHANNEL"
* disk thread now started within the engine

1 schoenebeck 9 /***************************************************************************
2     * *
3     * LinuxSampler - modular, streaming capable sampler *
4     * *
5     * Copyright (C) 2003 by Benno Senoner *
6     * *
7     * This program is free software; you can redistribute it and/or modify *
8     * it under the terms of the GNU General Public License as published by *
9     * the Free Software Foundation; either version 2 of the License, or *
10     * (at your option) any later version. *
11     * *
12     * This program is distributed in the hope that it will be useful, *
13     * but WITHOUT ANY WARRANTY; without even the implied warranty of *
14     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
15     * GNU General Public License for more details. *
16     * *
17     * You should have received a copy of the GNU General Public License *
18     * along with this program; if not, write to the Free Software *
19     * Foundation, Inc., 59 Temple Place, Suite 330, Boston, *
20     * MA 02111-1307 USA *
21     ***************************************************************************/
22    
23     #ifndef __DISKTHREAD_H__
24     #define __DISKTHREAD_H__
25    
26 schoenebeck 18 #define REFILL_STREAMS_PER_RUN 4 ///< number of streams that should be refilled with each disk thread cycle
27     #define MIN_REFILL_SIZE 1024 ///< if no buffer was filled up more than this bottom limit, the disk thread will go to sleep
28     #define MAX_REFILL_SIZE 65536 ///< maximum of samples a buffer should be refilled in one cycle (256kB, as 16 bit stereo)
29     #define STREAM_BUFFER_SIZE 131072 ///< the diskstream ringbuffer size (256kB as sample_t is 16bit)
30     #define MAX_INPUT_STREAMS 100 ///< number of streams that should be allocated
31 schoenebeck 9
32     #include <stdio.h>
33     #include <stdlib.h>
34     #include <unistd.h>
35 senoner 10 #include <time.h>
36 schoenebeck 9
37     #include "global.h"
38     #include "thread.h"
39     #include "voice.h"
40     #include "ringbuffer.h"
41     #include "stream.h"
42    
43     int CompareStreamWriteSpace(const void* a, const void* b);
44    
45     class DiskThread : public Thread {
46     public:
47     // Methods
48     DiskThread(uint BufferWrapElements);
49     ~DiskThread();
50 schoenebeck 35 void Reset();
51     String GetBufferFillBytes();
52     String GetBufferFillPercentage();
53 schoenebeck 26 int OrderNewStream(Stream::reference_t* pStreamRef, gig::Sample* pSample, unsigned long SampleOffset, bool DoLoop);
54 schoenebeck 9 int OrderDeletionOfStream(Stream::reference_t* pStreamRef);
55     Stream* AskForCreatedStream(Stream::OrderID_t StreamOrderID);
56 senoner 10
57 schoenebeck 13 // the number of streams currently in usage
58 senoner 10 // printed on the console the main thread (along with the active voice count)
59     int ActiveStreamCount;
60 schoenebeck 13 int ActiveStreamCountMax;
61 senoner 10
62 schoenebeck 9 protected:
63     int Main(); ///< Implementation of virtual method from class Thread
64     private:
65     // Private Types
66     struct create_command_t {
67 schoenebeck 18 Stream::OrderID_t OrderID;
68     Stream::Handle hStream;
69 schoenebeck 9 Stream::reference_t* pStreamRef;
70     gig::Sample* pSample;
71     unsigned long SampleOffset;
72 schoenebeck 26 bool DoLoop;
73 schoenebeck 9 };
74     struct delete_command_t {
75     Stream* pStream;
76     Stream::Handle hStream;
77     Stream::OrderID_t OrderID;
78     };
79    
80     // Attributes
81 schoenebeck 18 bool IsIdle;
82     uint Streams;
83     RingBuffer<create_command_t>* CreationQueue; ///< Contains commands to create streams
84     RingBuffer<delete_command_t>* DeletionQueue; ///< Contains commands to delete streams
85     RingBuffer<Stream::Handle>* GhostQueue; ///< Contains handles to streams that are not used anymore and weren't deletable immediately
86     unsigned int RefillStreamsPerRun; ///< How many streams should be refilled in each loop run
87     Stream* pStreams[MAX_INPUT_STREAMS]; ///< Contains all disk streams (wether used or unused)
88     Stream* pCreatedStreams[MAX_INPUT_STREAMS + 1]; ///< This is where the voice (audio thread) picks up it's meanwhile hopefully created disk stream.
89     static Stream* SLOT_RESERVED; ///< This value is used to mark an entry in pCreatedStreams[] as reserved.
90 schoenebeck 9
91     // Methods
92 schoenebeck 18 void CreateStream(create_command_t& Command);
93     void DeleteStream(delete_command_t& Command);
94     void RefillStreams();
95     Stream::Handle CreateHandle();
96     Stream::OrderID_t CreateOrderID();
97 schoenebeck 9 };
98    
99     #endif // __DISKTHREAD_H__

  ViewVC Help
Powered by ViewVC