File: jack-osc.text

package info (click to toggle)
jack-tools 20131226-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 712 kB
  • sloc: ansic: 6,183; makefile: 105; lisp: 54
file content (161 lines) | stat: -rw-r--r-- 6,090 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
JACK-OSC(1)
===========
Rohan Drape <rd@slavepianos.org>

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/>