Provided by: jack-tools_20131226-2build1_amd64 

NAME
jack-osc - JACK Transport Publication Daemon
SYNOPSIS
jack-osc [options]
OPTIONS
-c : Set the drift correction interval in periods (default=64). -p : Set the port number (default=57130).
DESCRIPTION
jack-osc publishes the transport state of the local JACK server as OSC packets over a UDP connection.
jack-osc allows any OSC enabled application to act as a JACK transport client, receiving sample accurate
pulse stream timing data, and monitoring and initiating transport state change.
Clients request to receive timing and change notification packets by sending a "request notification"
packet, /receive, to the jack-osc server. This packet has the form
/receive category
where category is a bit mask that indicates what categories of notification packets are requested. The
bit locations are:
Category Mask -------- ---- REQUEST_TICK 0x0000001 REQUEST_PULSE 0x0000002 REQUEST_CORRECTION 0x0000004
REQUEST_TRANSPORT 0x0000008 REQUEST_ALL 0xFFFFFFF
Clients request notification messages to be sent to an address that is not that of the packet that
requests the notification by sending a "request notification at" packet, /receive_at. This packet has the
form
/receive_at category port-number host-name
where category is as for /receive and where port-number and host-name give the address that notification
should be sent to.
Once a client is registered subsequent /receive and /receive_at messages edit the category value for that
client. To delete the client from the register send a request with a category value of negative one.
After requesting notification the client will receive all relevant timing packets sent by the server. All
jack-osc timing packets are sent at the start of a JACK period as OSC message and have the same shape:
tag ntp utc frm arg...
where tag is the command name, and ntp, utc and frm are time stamps that indicate the same time point,
the start of the JACK period when the packet was sent. ntp is an unsigned 64bit integer NTP value. utc is
a double precision real valued representation of the UTC time. frm is a signed 64bit integer frame
counter the absolute value of which is not defined but which increments synchronously with the ntp and
utc time stamps. arg... is the set of tag specific arguments.
The timing packets sent by jack-osc are:
/pulse ntp utc frm p-ntp p-utc p-frm pulse : Pulse Location. This packet indicates that the nearest frame
to the integer pulse pulse occurs at the time given by the time stamps p-ntp, p-utc and p-frm. The pulse
number is one based. This packet is sent at the start of the JACK period in which the integer pulse will
occur. This packet is not sent if the transport is stopped. This packet is sent before the /tick packet
for the same period.
/tick ntp utc frm frame pulse : Period Tick. This packet is sent once per JACK period. The integer value
frame is the transport location in frames, the double precision real value pulse is the transport
location in pulses. The pulse value is read from an accumulator and is approximate only, the accumulator
is corrected at each integer pulse location.
/drift ntp utc frm ntp-dif utc-dif : Drift Correction. This packet is sent whenever the clock drift
correction is run. The frequency of this is set by the -c option to the jack-osc server. The integer
value ntp-dif is the NTP form of the corrected drift value and utc-dif the UTC form. Since JACK is a
sample clock there is no frame drift value.
The state change packets sent by jack-osc are:
/transport ntp utc frm fps ppm ppc pt state : Transport state change. This packet is sent whenever the
JACK transport changes. The double precision real value fps is the sample rate in frames per second. The
double precision real value ppm is the tempo in pulses per minute. The double precision real value ppc is
the measure length in pulses per cycle. The double precision real value pt is the pulse type. The integer
value state is zero if the transport has stopped and one if it has started. See also the /status message
described below.
Clients can request the current frame and pulse values by sending a /current packet, which requires no
argument. The replies with a /current.reply packet, which has the same form as a /tick packet. The
precise interpretation of packets acquired in this manner is problematic.
Clients request a status packet by sending a "request status" packet, /status, which requires no
argument. The server replies immediately with a status reply packet, /status.reply. The status packet is
an OSC message and is not timestamped. It has the shape:
/status.reply fps ppm ppc pt state
where the argument values are as described for the /transport message. It is intended that a client will
request a single status packet before requesting notification for all subsequent state changes.
Clients initiate a change in transport roll state by sending a "request transport operation" packet,
/start or /stop to the jack-osc server. Neither requires an argument.
Clients initiate a change in transport location by sending a "request locate operation" packet, /locate,
to the jack-osc server. It has the shape:
/locate location
where the single precision real value location is the requested transport location in seconds.
Clients can connect and disconnect ports by sending /connect and /disconnect messages to the jack-osc
server. Both have the shape:
/[dis]connect left right
jack-osc implements only a subset of the OSC protocol. In particular it does not implement the patten
matching rules and does not implement a scheduler for incoming messages.
jack-osc drops all unrecognized incoming packets.
AUTHOR
Rohan Drape http://rd.slavepianos.org/
SEE ALSO
jackd(1), OSC(7) http://opensoundcontrol.org/
AUTHOR
Rohan Drape <rd@slavepianos.org>
Author.
04/18/2024 JACK-OSC(1)