The revert in r3818 was wrong because r3816 was correct in svn. The revert error in r3818 happened, because svn r3816 had wrong git versiontags/v1.9.49fb8b55379the right git version of svn r3816 isc9bbc68a8dgit-svn-id: http://subversion.jackaudio.org/jack/jack2/trunk/jackmp@3820 0c269be4-1314-0410-8aa9-9f06e86f4224
| @@ -213,6 +213,7 @@ Note : To experiment with the -S option, jackdmp must be launched in a console. | |||
| 1.9.1 : Fix jackctl_server_unload_internal. Filter SIGPIPE to avoid having client get a SIGPIPE when trying to access a died server. Libjack shutdown handler does not "deactivate" (fActive = false) the client anymore, so that jack_deactivate correctly does the job later on. Better isolation of server and clients system resources to allow starting the server in several user account at the same time. Report ringbuffer.c fixes from jack1. Client and library global context cleanup in case of incorrect shutdown handling (that is applications not correctly closing client after server has shutdown). Use JACK_DRIVER_DIR variable in internal clients loader. For ALSA driver, synchronize with latest jack1 memops functions. Synchronize jack2 public headers with jack1 ones. Implement jack_client_real_time_priority and jack_client_max_real_time_priority API. Use up to BUFFER_SIZE_MAX frames in midi ports, fix for ticket #117. Cleanup server starting code for clients directly linked with libjackserver.so. JackMessageBuffer was using thread "Stop" scheme in destructor, now use the safer thread "Kill" way. Synchronize ALSA backend code with JACK1 one. Set default mode to 'slow' in JackNetDriver and JackNetAdapter. Simplify audio packet order verification. Fix JackNetInterface::SetNetBufferSize for socket buffer size computation and JackNetMasterInterface::DataRecv if synch packet is received, various cleanup. Better recovery of network overload situations, now "resynchronize" by skipping cycles.". Support for BIG_ENDIAN machines in NetJack2. Support for BIG_ENDIAN machines in NetJack2 for MIDI ports. Support for "-h" option in internal clients to print the parameters. In NetJack2, fix a bug when capture or playback only channels are used. Add a JACK_INTERNAL_DIR environment variable to be used for internal clients. Add a resample quality parameter in audioadapter. Now correctly return an error if JackServer::SetBufferSize could not change the buffer size (and was just restoring the current one). Use PRIu32 kind of macro in JackAlsaDriver again. Add a resample quality parameter in netadapter. | |||
| 1.9.2 : Solaris version. New "profiling" tools. Rework the mutex/signal classes. Support for BIG_ENDIAN machines in NetJack2. D-BUS based device reservation to better coexist with PulseAudio on Linux. Add auto_connect parameter in netmanager and netadapter. Use Torben Hohn PI controler code for adapters. Client incorrect re-naming fixed : now done at socket and fifo level. Virtualize and allow overriding of thread creation function, to allow Wine support (from JACK1). | |||
| 1.9.3 : New JackBoomerDriver class for Boomer driver on Solaris. Add mixed 32/64 bits mode (off by default). Native MIDI backend (JackCoreMidiDriver, JackWinMMEDriver). In ALSA audio card reservation code, tries to open the card even if reservation fails. Clock source setting on Linux. Add jackctl_server_switch_master API. Fix transport callback (timebase master, sync) issue when used after jack_activate (RT thread was not running). D-Bus access for jackctl_server_add_slave/jackctl_server_remove_slave API. Cleanup "loopback" stuff in server. Torben Hohn fix for InitTime and GetMicroSeconds in JackWinTime.c. New jack_free function added in jack.h. Reworked Torben Hohn fix for server restart issue on Windows. Correct jack_set_error_function, jack_set_info_function and jack_set_thread_creator functions. Correct JackFifo::TimedWait for EINTR handling. Move DBus based audio device reservation code in ALSA backend compilation. Correct JackTransportEngine::MakeAllLocating, sync callback has to be called in this case also. NetJack2 code : better error checkout, method renaming. Tim Bechmann patch : hammerfall, only release monitor thread, if it has been created. Tim Bechmann memops.c optimization patches. In combined --dbus and --classic compilation code, use PulseAudio acquire/release code. Big rewrite of Solaris boomer driver, seems to work in duplex mode at least. Loopback backend reborn as a dynamically loadable separated backend. | |||
| 1.9.4 : Solaris boomer backend now working in capture or playback only mode. Add a -G parameter in CoreAudio backend (the computation value in RT thread expressed as percent of period). Use SNDCTL_DSP_SYNCGROUP/SNDCTL_DSP_SYNCSTART API to synchronize input and output in Solaris boomer backend. Big endian bug fix in memops.c. Fix issues in JackNetDriver::DecodeTransportData and JackNetDriver::Initialize. Correct CPU timing in JackNetDriver, now take cycle begin time after Read. Simplify transport in NetJack2: master only can control transport. Change CoreAudio notification thread setup for OSX Snow Leopard. Correct server temporary mode : now set a global and quit after server/client message handling is finished. Add a string parameter to server ==> client notification, add a new JackInfoShutdownCallback type. CoreAudio backend now issue a JackInfoShutdownCallback when an unrecoverable error is detected (sampling rate change, stream configuration changeÉ). Correct jackdmp.cpp (failures case were not correct..). Improve JackCoreAudioDriver code. Raise default port number to 2048. Correct JackProcessSync::LockedTimedWait. Correct JACK_MESSAGE_SIZE value, particularly in OSX RPC code. Now start server channel thread only when backend has been started (so in JackServer::Start). Should solve race conditions at start time. jack_verbose moved to JackGlobals class. Improve aggregate device management in JackCoreAudioDriver : now a "private" device only and cleanup properly. Aggregate device code added to JackCoreAudioAdapter. Implement "hog mode" (exclusive access of the audio device) in JackCoreAudioDriver. Fix jack_set_sample_rate_callback to have he same behavior as in JACK1. Dynamic system version detection in JackCoreAudioDriver to either create public or private aggregate device. In JackCoreAudioDriver, force the SR value to the wanted one *before* creating aggregate device (otherwise creation will fail). In JackCoreAudioDriver, better cleanup of AD when intermediate open failure. In JackCoreAudioDriver::Start, wait for the audio driver to effectively start (use the MeasureCallback). In JackCoreAudioDriver, improve management of input/output channels: -1 is now used internally to indicate a wanted max value. In JackCoreAudioDriver::OpenAUHAL, correct stream format setup and cleanup. Correct crash bug in JackAudioAdapterInterface when not input is used in adapter (temporary fixÉ). Sync JackCoreAudioAdapter code on JackCoreAudioDriver one. JACK_SCHED_POLICY switched to SCHED_FIFO. Now can aggregate device that are themselves AD. No reason to make jack_on_shutdown deprecated, so revert the incorrect change. Thread AcquireRealTime and DropRealTime were (incorrectly) using fThread field. Use pthread_self()) (or GetCurrentThread() on Windows) to get the calling thread. Correctly save and restore RT mode state in freewheel mode. Correct freewheel code on client side. Fix AcquireRealTime and DropRealTime: now distinguish when called from another thread (AcquireRealTime/DropRealTime) and from the thread itself (AcquireSelfRealTime/DropSelfRealTime). Correct JackPosixThread::StartImp : thread priority setting now done in the RT case only. Correct JackGraphManager::GetBuffer for the "client loop with one connection" case : buffer must be copied. Correct JackInfoShutdownCallback prototype, two new JackClientProcessFailure and JackClientZombie JackStatus code. Correct JackCoreAudio driver when empty strings are given as -C, -P or -d parameter. Better memory allocation error checking on client (library) side. Better memory allocation error checking in ringbuffer.c, weak import improvements. Memory allocation error checking for jack_client_new and jack_client_open (server and client side). Memory allocation error checking in server for RPC. Simplify server temporary mode : now use a JackTemporaryException. Lock/Unlock shared memory segments (to test...). Sync with JACK1 : -r parameter now used for no-realtime, realtime (-R) is now default, usable backend given vie platform. In JackCoreAudio driver, (possibly) clock drift compensation when needed in aggregated devices. In JackCoreAudio driver, clock drift compensation in aggregated devices working. In JackCoreAudio driver, clock drift compensation semantic changed a bit : when on, does not activate if not needed (same clock domain). Sync JackCoreAudioAdapter code with JackCoreAudioDriver. | |||
| This is a work in progress but the implementation is now stable enough to be tested. jackdmp has been used successfully with the following applications : Ardour, Hydrogen, Jamin, Qjackctl, Jack-Rack, SooperLooper, AlsaPlayer... | |||
| @@ -26,12 +26,10 @@ | |||
| #include <stdlib.h> | |||
| #include <stdio.h> | |||
| #include <signal.h> | |||
| #include <ucontext.h> | |||
| #include <dlfcn.h> | |||
| #include <execinfo.h> | |||
| #include <errno.h> | |||
| #ifndef NO_CPP_DEMANGLE | |||
| //#include <cxxabi.h> | |||
| char * __cxa_demangle(const char * __mangled_name, char * __output_buffer, size_t * __length, int * __status); | |||
| #endif | |||
| @@ -56,6 +54,8 @@ static void signal_segv(int signum, siginfo_t* info, void*ptr) | |||
| #else | |||
| #include <ucontext.h> | |||
| static void signal_segv(int signum, siginfo_t* info, void*ptr) { | |||
| static const char *si_codes[3] = {"", "SEGV_MAPERR", "SEGV_ACCERR"}; | |||
| @@ -57,7 +57,7 @@ InternalMetro::InternalMetro(int freq, double max_amp, int dur_arg, int bpm, cha | |||
| client_name = (char *) malloc (9 * sizeof (char)); | |||
| strcpy (client_name, "metro"); | |||
| } | |||
| if ((client = jack_client_new (client_name)) == 0) { | |||
| if ((client = jack_client_open (client_name, JackNullOption, NULL)) == 0) { | |||
| fprintf (stderr, "jack server not running?\n"); | |||
| return ; | |||
| } | |||
| @@ -62,12 +62,10 @@ void parse_arguments(int argc, char *argv[]) | |||
| int main(int argc, char *argv[]) | |||
| { | |||
| int rc; | |||
| parse_arguments(argc, argv); | |||
| /* become a JACK client */ | |||
| if ((client = jack_client_new(package)) == 0) { | |||
| if ((client = jack_client_open(package, JackNullOption, NULL)) == 0) { | |||
| fprintf(stderr, "JACK server not running?\n"); | |||
| exit(1); | |||
| } | |||
| @@ -120,11 +120,12 @@ def build(bld): | |||
| prog.includes = os_incdir + ['../common/jack', '../common'] | |||
| prog.source = ['netsource.c', '../common/netjack_packet.c'] | |||
| prog.env.append_value("CCFLAGS", "-DNO_JACK_ERROR") | |||
| if bld.env['HAVE_CELT']: | |||
| if bld.env['HAVE_CELT_API_0_5']: | |||
| prog.defines = ['HAVE_CELT', 'HAVE_CELT_API_0_5'] | |||
| elif bld.env['HAVE_CELT_API_0_7']: | |||
| prog.defines = ['HAVE_CELT', 'HAVE_CELT_API_0_7'] | |||
| # Seems uneeded here... | |||
| #if bld.env['HAVE_CELT']: | |||
| #if bld.env['HAVE_CELT_API_0_5']: | |||
| # prog.defines = ['HAVE_CELT', 'HAVE_CELT_API_0_5'] | |||
| #elif bld.env['HAVE_CELT_API_0_7']: | |||
| # prog.defines = ['HAVE_CELT', 'HAVE_CELT_API_0_7'] | |||
| prog.uselib = 'CELT SAMPLERATE' | |||
| prog.uselib_local = 'clientlib' | |||
| prog.target = 'jack_netsource' | |||
| @@ -52,9 +52,8 @@ int | |||
| main (int argc, char *argv[]) | |||
| { | |||
| jack_client_t* client = NULL; | |||
| /* try to become a client of the JACK server */ | |||
| if ((client = jack_client_new ("zombie")) == 0) { | |||
| if ((client = jack_client_open ("zombie", JackNullOption, NULL)) == 0) { | |||
| fprintf (stderr, "jack server not running?\n"); | |||
| goto error; | |||
| } | |||
| @@ -69,6 +69,6 @@ def build(bld): | |||
| create_jack_driver_obj(bld, 'loopback', '../common/JackLoopbackDriver.cpp') | |||
| create_jack_driver_obj(bld, 'netone', [ '../common/JackNetOneDriver.cpp', | |||
| '../common/netjack.c', | |||
| '../common/netjack_packet.c' ], "SAMPLERATE CELT" ) | |||
| '../common/netjack.c', | |||
| '../common/netjack_packet.c' ], "SAMPLERATE CELT" ) | |||
| @@ -409,7 +409,8 @@ JackCoreAudioDriver::JackCoreAudioDriver(const char* name, const char* alias, Ja | |||
| fState(false), | |||
| fHogged(false), | |||
| fIOUsage(1.f), | |||
| fComputationGrain(-1.f) | |||
| fComputationGrain(-1.f), | |||
| fClockDriftCompensate(false) | |||
| {} | |||
| JackCoreAudioDriver::~JackCoreAudioDriver() | |||
| @@ -6,11 +6,12 @@ def create_jack_driver_obj(bld, target, sources, uselib = None): | |||
| driver.features.append('cc') | |||
| driver.env['shlib_PATTERN'] = 'jack_%s.so' | |||
| driver.defines = ['HAVE_CONFIG_H','SERVER_SIDE'] | |||
| if bld.env['HAVE_CELT']: | |||
| if bld.env['HAVE_CELT_API_0_5']: | |||
| driver.defines += ['HAVE_CELT', 'HAVE_CELT_API_0_5'] | |||
| elif bld.env['HAVE_CELT_API_0_7']: | |||
| driver.defines += ['HAVE_CELT', 'HAVE_CELT_API_0_7'] | |||
| # Seems uneeded here... | |||
| #if bld.env['HAVE_CELT']: | |||
| #if bld.env['HAVE_CELT_API_0_5']: | |||
| # driver.defines += ['HAVE_CELT', 'HAVE_CELT_API_0_5'] | |||
| #elif bld.env['HAVE_CELT_API_0_7']: | |||
| # driver.defines += ['HAVE_CELT', 'HAVE_CELT_API_0_7'] | |||
| driver.includes = ['.', '../macosx', '../posix', '../common', '../common/jack'] | |||
| driver.target = target | |||
| driver.source = sources | |||
| @@ -115,17 +115,17 @@ def configure(conf): | |||
| conf.sub_config('example-clients') | |||
| if conf.check_cfg(package='celt', atleast_version='0.7.0', args='--cflags --libs'): | |||
| conf.define('HAVE_CELT', 1) | |||
| conf.define('HAVE_CELT_API_0_7', 1) | |||
| conf.define('HAVE_CELT_API_0_5', 0) | |||
| conf.define('HAVE_CELT', 1) | |||
| conf.define('HAVE_CELT_API_0_7', 1) | |||
| conf.define('HAVE_CELT_API_0_5', 0) | |||
| elif conf.check_cfg(package='celt', atleast_version='0.5.0', args='--cflags --libs', required=True): | |||
| conf.define('HAVE_CELT', 1) | |||
| conf.define('HAVE_CELT_API_0_5', 1) | |||
| conf.define('HAVE_CELT_API_0_7', 0) | |||
| conf.define('HAVE_CELT', 1) | |||
| conf.define('HAVE_CELT_API_0_5', 1) | |||
| conf.define('HAVE_CELT_API_0_7', 0) | |||
| else: | |||
| conf.define('HAVE_CELT', 0) | |||
| conf.define('HAVE_CELT_API_0_5', 0) | |||
| conf.define('HAVE_CELT_API_0_7', 0) | |||
| conf.define('HAVE_CELT', 0) | |||
| conf.define('HAVE_CELT_API_0_5', 0) | |||
| conf.define('HAVE_CELT_API_0_7', 0) | |||
| conf.env['LIB_PTHREAD'] = ['pthread'] | |||
| conf.env['LIB_DL'] = ['dl'] | |||