jack2 codebase
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

61 lines
3.8KB

  1. ---------------------
  2. Jackdmp Todo list
  3. ---------------------
  4. 2008-03-12 : Do not start the client RT thread if no callback or thread routine has been setup (no use of jack_set_process_callback or jack_set_process_thread). This require change in the server to avoid signaling the client in this case.
  5. 2008-02-07 : Pipelining idea:
  6. - cut the driver buffer size in n slices : clients see the divided value, server deal with the driver value, some clients may want to keep the driver buffer size (non pipelining)
  7. - new jack_set_buffer_divisor/jack_get_buffer_divisor and jack_set_pipelining/jack_get_pipelining API
  8. - jack_set_buffer_size changes the driver buffer size, jack_get_buffer_size get the divided value
  9. - buffer_size callback notify the divided value for pipelining clients
  10. 2008-02-06 : Do a "fork-exec" for the server (deamon..)
  11. 2008-02-05 : Hierarchical model : having several client graph running simultaneously (Fons) with a "link" between them (AKA NetJack)
  12. 2008-01-15 : Server control API (Nedko Arnoudov): would help to develop external control applications (DBUS or OSC based...)
  13. 2007-12-16 : Dynamic backend switch, so that audio backend can be switch off and replaced by the dummy backend.
  14. 2007-10-17 : Optimize activation call graph with multiple clients in a same process
  15. Andrzej Szombierski recently did interesting test to measure jack client activation speed in different context: jack client opened in separated processes, multiple jack clients running in the server, multiple jack clients running in a same separated process, this using jackd or jackdmp.
  16. jackd:
  17. - multiple jack clients in the server: fast because *direct function call* to the client process callback is done bypassing the fifo based activation system
  18. - jack clients in separated processes: slower using the fifo based activation system
  19. - multiple jack clients in a separated process: slower using the fifo based activation system
  20. jackdmp:
  21. - multiple jack clients in the server: slower using the fifo based activation system
  22. - jack clients in separated processes: slower using the fifo based activation system
  23. - multiple jack clients in a separated process: slower using the fifo based activation system
  24. So basically jackdmp use the same fifo based activated system in all cases, and jackd does some optimization in the "multiple jack clients in the server" case.
  25. Also having multiple clients in a same process (jack server or separated process) is not so common, it may still be interesting to be able to optimize the activation path with sequential clients in a same process (server or separated). I am thinking in a method that could be done in jackdmp data-flow model : since the activation path is "computed on the fly" when following links between clients, the step where a client activates all its output could be reworked a little with something like :
  26. - find one of the client in the output client list that is in the same process
  27. - activate all other output clients using the normal fifo based system
  28. - *direct* call the client process callback
  29. (and this would be done recursively following a sequential path in the graph until no more client in the same process is found)
  30. There is still an issue if a client uses the "Fons special" ((-: new jack_thread_wait API, where a client explicitly gives control back to libjack... I still don't have a clear idea if this optimization path could still be done.
  31. Even if the "multiple clients" way is not really used in existing applications, is it a desirable feature to have at some point?
  32. 2007-10-07 : Before doing an official package, check all public headers
  33. 2007-03-14 : Check JackGraphManager::GetPortsAux after MIDI branch merge.
  34. 2007-03-14 : Add Paul dynamic jack server location code.
  35. 2007-01-22 : Check the "dead" client removing code in the server : non running client may cause Desactivation and Close time out problems.