Local communication system
Examples of local communication systems are disclosed, based on a ring of point-to-point links, providing for transport of fixed rate synchronous, fixed rate asynchronous data and variable rate data in a flexible format. Different segments of the ring network can carry data at different bit rates, while remaining synchronised to a common frame rate and having a common control channel structure, for compatibility with earlier systems. Parallel channels are provided, either permanently or when required, for signalling errors of source data, data validity/padding, flow control. Parallel variable width channels are defined with free content (stream or packet). Null data symbols are defined for padding on a byte-by-byte basis. The allocation of capacity among variable width channels is revised block by block, and a transition period is defined to allow for ring latency. Calculations for allocation of capacity are performed during one block for the next block, locally at each source station, according to predetermined rules. Information as to bandwidth requirements is exchanged prior to the calculation via a special connection signalling channel and message format.
Latest Communication & Control Electronics Limited Patents:
The invention relates to a local communication system wherein plural stations are connected in a ring topology. The invention provides a novel local communication system, and stations and interface components for use in such a system.
A local communication system which combines source data (CD audio, MPEG video, telephone audio etc) with control messages in a low cost fibre network has been proposed in the form of D2B Optical. For details, see for example the “Conan Technology Brochure” and the “Conan IC Data Sheet” available from Communication & Control Electronics Limited, 2 Occam Court, Occam Road, The Surrey Research Park, Guildford, Surrey, GU2 5YQ (also http://www.candc.co.uk). See also German patent applications of Becker GmbH with filing numbers 19503206.3 (95P03), 19503207.1 (95P04), 19503209.8 (95P05), 19503210.1 (95P06), 9503212.8 (95P07), 19503213.6 (95P08), 19503214.4 (95P09) and 19503215.2 (95P10). “Conan” is a registered trade mark of Communication & Control Electronics Limited. “D2B” is a registered trade mark of Philips Electronics NV.
The present invention in a first aspect aims to enable expansion of the capacity of such a network, for use in vehicles and the like, while maintaining compatibility with existing D2B Optical Products and designs. The invention is nevertheless applicable in systems other than D2B Optical, where different components may operate at different speeds.
Other, independent aspects of the invention are concerned to provide for the transport of asynchronous data, whether at fixed or variable rates. Known proposals for carrying variable rate data between different stations adopt a purely packet-based protocol, which brings certain overheads and also reduces smoothness of each connection, increasing buffering requirements at the source and destination. In U.S. Pat. No. 5,257,259 (Tsurumi/Yamaha), for example, packet data for various asynchronous connections is carried effectively within a fixed rate channel established on a circuit-switched network.
Other aspects of the invention aim variously to improve the performance, flexibility or reliability of communication networks generally, which may be of ring or other topology, may be synchronous or asynchronous and which may find application in a wide range of fields.
According to a first aspect of the invention, there is disclosed a local communication system comprising a ring network, the data rate in a first segment of the ring being higher than that in a second segment of the ring.
Synchronisation may be maintained for example by the provision of a regular frame structure which has the same frame period in both segments of the network, but a larger quantity of data in each frame of the first segment.
In a network where each segment of the ring conveys one or more channels of user information at a relatively high data rate, and one or more channels of control information, the data rate for control information may be constant between the first and second segments, while the data rate for user information is different.
Depending on the distribution of source and destination stations around the ring, the user information flowing in the second segment may be a subset of that flowing in the first segment of the network.
It will be appreciated that stations in the second segment of the network may for example implement the existing D2B Optical protocols, and hence exploit existing product designs. The stations in the first segment of the ring can employ a novel transceiver adapted to the higher data rates. The transceiver disclosed can provide the necessary buffering and switching of user information to interface between the two segments of the network operating at different rates.
In the proposed embodiment, the frame rate is constant in each segment around the network, and within each frame the same number of bits are reserved to form the control message channel in every segment. The control frame format is thus continuous around the ring. On the other hand, the number of user information (“source data”) bits included in each frame is higher in the first segment of the network, and the bit rate in the optical fibre or other channel is much higher than in the second segment. By this means, the provision of higher data capacity does not require a development of new protocols and communication management software for control messages, but only minor adaptation to allow control of more versatile user information channels.
In a second aspect, the invention aims to improve error protection in a local communication system carrying source data from station to station by means of point-to-point links. In particular, errors due to noise on the physical layer may arise in data which is not itself protected by error protection codes. In the known D2B network, for example, such errors are not reported to all stations around the ring, yet they may affect audio samples or other data being carried.
In the embodiment disclosed, the invention in the second aspect is implemented by providing an error signalling flag within each frame (or subframe), which is set by a station to indicate that an error has been detected in the data of that frame, and is repeated by each station when repeating that data to a next station in the ring.
In the embodiment, a source data field of each frame or subframe can be assigned to various channels having respective source and destination stations around the ring. The error flag field may be shared between these channels, to reduce overhead. The station detecting an error sets the error flag, which travels around the ring with the source data, being subject to the same delays at each station. The station which sets the error flag resets it when the set flag has returned all the way around the ring, unless a new error is detected. This provides a simple mechanism for indicating the risk of error in source data received at each station. While it does not provide a definitive indication of error in a particular channel and while further the flag can be falsely set where two or more errors occur around the ring, the low risk of these further errors and overhead in terms of both channel capacity and circuitry makes the mechanism worthwhile.
A third aspect of the invention provides for the handling of asynchronous data within a network, while preserving the generally synchronous nature of channels in the network. The provision of synchronous channels (for example by allocating a particular field in each frame to a particular channel) brings great benefits in reduced buffering requirements and low overhead for certain applications, but does not suit all applications.
According to this third aspect of the invention, a flow signalling channel is provided for flow signalling in relation to one or more channels established within the network frame structure. The flow signalling channel may be synchronised with the data at a frame (or sub-frame, where provided) level.
The flow signalling channel may carry for example (from the source station) validity flags, start-of-packet or other structural flags, and/or (from the destination station) flow control signals such as stop/continue (buffer full).
The flow signalling channel may be established by a bit or bits reserved in every frame. Alternatively, the connection signalling channel may be built according to requirements within the fields generally available for source data. In the latter case, a greater bandwidth for signalling can be achieved, without imposing an overhead on the network when asynchronous connections are not required or are not required in great number. Set up of the connection signalling channel may be controlled through a lower data rate control message channel, which may also co-ordinate setting up of individual source data connections.
In a ring network, the same flow signalling channel may carry first flow signalling information (for example a validity signal) from the source to the destination, and second flow signalling information (for example a stop/continue signal) from the destination back to the source station.
The flow signalling channel may be implemented in the transceiver circuit, or by add-on circuitry based on an existing transceiver (for example the Conan transceiver).
Mechanisms may be provided in the various stations to allow for a latency of the flow signalling channel and/or the data channel being controlled.
According to a fourth aspect of the invention, there is provided a method of communication wherein source and destination stations interchange data via a ring network, such data being subject to a delay for buffering at one or more intervening stations, the delay depending on the network configuration, the destination station including means for determining said delay and for sending a flow control signal to the source station in advance of a buffer full condition, in accordance with the determined delay. The flow control signal may also be subject to delay, between the destination and the source station.
According to a fifth aspect of the invention, there is provided a method of communication wherein source and destination stations interchange data via a ring network, such data being subject to a delay in buffers at one or more intervening stations, the delay depending on the network configuration, the destination station including means for sending a flow control signal to the source station in the event a buffer full condition, wherein the source station is arranged upon reception of the flow control signal to repeat data already sent, whereby data already sent but not accepted by the destination is held circulating in the buffers of stations around the network until accepted by the destination station. The flow control signal may also be subject to delay, between the destination and the source station.
A sixth aspect of the invention provides a method for allocating capacity among a plurality of desired connections over a shared network medium, wherein stations of the network communicate to one another their requirements for network capacity, and each station responsible for establishing a respective connection performs a calculation to allocate to that connection a certain capacity, the calculation being performed by all such stations using a common set of rules so as to arrive at a consistent allocation of capacity between the connections.
The responsible station may be the source station for each connection. Responsibility is thereby distributed throughout the network, and allocation can be performed locally, and therefore quickly.
In one embodiment, the invention in its sixth aspect provides, in a local communication system wherein a plurality of stations interchange data via a shared network medium, a method of allocating capacity among a plurality of connections, each connection carrying data from a first station designated as source for that connection to at least one second station designated as destination connection, comprising:
-
- (a) generating for each connection a connection signalling message indicating a required capacity for the connection;
- (b) receiving the connection signalling messages for the plurality of connections;
- (c) determining a suitable allocation of capacity for each connection by a calculation based on the indicated required capacities and an available total capacity;
- (d) establishing each desired connection with the determined allocation,
whereby steps (b), (c), and (d) are performed independently at each first station following predetermined rules.
The connection signalling messages may be generated at least partially by the first station designated as source for the connection, and/or they may be generated at least partially by the second station designated as destination for the connection. The source station, for example, may indicate a maximum available data rate. On the other hand the destination station knows what is the minimum and maximum data rate it can cope with at a given time.
In one embodiment, a connection signalling message is generated by the source station, modified by the destination station, and read by the other source stations to obtain the necessary information for the calculation. Where the network is a ring network comprising a series of point-to-point links, the modified message is received by the source station and repeated around the ring to ensure that all responsible stations have the necessary information
The information exchanged and the set of rules may be comprehensive enough to have a capacity optimally taking into account portions of the ring where certain connections overlap or do not overlap. Alternatively, the rules may be simplified to ignore to some extent the potential capacity, and the exchange of information may be limited by time considerations. For example, where first and second connections overlap at one part of the ring, and the second connection overlaps with a third connection at another part of the ring, the calculation performed by the source station for the first connection may or may not take into account restrictions on the allocation to the second connection, caused by its overlap with the third connection.
The allocation may be varied from time to time, either periodically or as and when new connections are established or old connections deleted.
The connection signalling messages can be exchanged via a dedicated channel, or a general control message channel, depending on the amount of information to be exchanged (which is related to the number of connections) and the time available for establishing or revising the allocation.
According to a seventh aspect of the present invention, plural variable rate channels are established in a common frame structure, by allocating the same fields of each frame to a given channel throughout a block of frames, adapting the allocation of fields to channels for each successive block of frames.
The allocation may be determined by use of the sixth aspect of the invention, by command of a central controller, or otherwise. Each block of frames may be referred to as a rate control period or source data block. The block structure for this purpose may be independent of any other block structure.
A packet structure can be imposed within each variable-rate channel if desired for a given application. Nevertheless, the invention in this aspect ensures that some data for each channel arrives with each frame, substantially alleviating buffering requirements at source and destination.
According to an eighth aspect of the invention, there is provided a local communication system comprising a ring network conveying a source data in both variable rate and fixed rate channels, by means of a regular frame structure, each frame providing a fixed number of source data fields, wherein each field can be reserved dynamically to form part of a fixed rate channel which uses the same fields in each frame for the duration of a connection, and at other times can be allocated to form part of a variable rate channel whose width varies during the life time of the relevant connection and wherein, when a plurality of variable rate channels of non-zero width are established, each frame carries at least some data for every channel.
According to a ninth aspect of the invention, there are disclosed embodiments of a method of communication wherein a plurality of stations interchange data via a ring network in accordance with a plurality of logical connections established within a shared data channel, each connection carrying data from a first station designated as source for that connection to at least one second station designated as destination for that connection, such data being subject to a delay at one or more intervening stations relative to a frame sequence of the ring network, the method comprising:
-
- (a) defining a succession of rate control periods;
- (b) determining, in advance of a first rate control period, a first channel bandwidth for each of the plurality of connections, the first channel bandwidth imposing a maximum data rate on the corresponding connection;
- (c) during said first rate control period establishing a respective channel for each connection in accordance with the determined first channel bandwidth;
- (d) during said first rate control period transmitting data for each connection via the respective channel at a rate up to said maximum data rate;
- (e) determining in advance of a next rate control period a new channel bandwidth for each of the plurality of connections, the new channel bandwidth imposing a new maximum data rate for the corresponding connection for said next rate control period; and
1(f) repeating steps (b) to (e) for said succession of rate control periods,
wherein a rate transition period corresponding to said delay is included at the end of each rate control period and, in the event that the new channel width determined in step (e) is reduced relative to the first channel width, data is transmitted according to the new maximum rate during said rate transition period.
In an tenth aspect, the invention provides a local communication of system wherein a plurality of stations interchange data via a shared network medium carrying a regular frame structure, each frame providing a fixed number of data fields, and wherein a block of plural frames is established for the allocation of source data fields between a plurality of channels, the allocation being variable between blocks, wherein each successive station wishing to reserve an allocation of capacity places a header in a free field of the first frame in a given block, the header indicating directly or indirectly a next free field in accordance with the number of fields per frame reserved by the source device for its channel, each successive source station around the ring inserting its header to reserve an allocation of fields for the duration of the block at the free field position indicated by said header, such that fields are allocated to channels contiguously within each frame.
According to an eleventh aspect of the invention, there is provided a local communication system wherein a plurality of stations interchange data via a shared network medium, wherein a regular frame structure, each frame providing a fixed number of data fields, and wherein a block of plural frames is established for the allocation of source data fields between a plurality of connections, wherein each station acting as a source station for a connection reserves an allocated number of fields in each frame, and wherein each source station is responsible for removing the allocation of fields to a connection whose furthest destination station precedes the source in ring position.
The source station may for this purpose maintain a table of the positions of the final destination for each connection. A table of connection ID, source and destination addresses may be built from control messages received when the connection is first established. The connection ID alone need then accompany the data in real time.
According to a twelfth aspect of the invention, in a local communication system wherein plural stations communicate by the exchange of message frames addressed to one another, such messages competing for capacity in a common channel, there is provided a method of signalling occupancy of a message reception buffer of at least one particular station, whereby other stations wishing to send a message to that station will not attempt to do so during occupancy of that station's reception buffer.
While signalling of buffer occupancy for all possible destination stations might constitute an unacceptable overhead in network capacity, it has been found that, in many applications, that a large proportion of messages are in practice addressed to one particular station (a control centre, a gateway to another network, etc). The signalling of buffer occupancy for this particular station will avoid a large number of failed message transmissions by other stations, thereby freeing a far greater network capacity than the overhead required for the buffer occupancy signalling. Messages to stations other than the special station can then be more quickly delivered.
The buffer occupancy signal may be provided in an arbitration field of each message frame, or in a separate signalling channel. Buffer occupancy can in general be signalled by one or more special stations by modifying a predetermined field within messages generated by that station or other stations, rather than a field outside those messages. Where the message frames are generated empty by a system master station, the station whose buffer occupancy is signalled may be the master station.
Embodiments of the invention will now be described, by way of example only, with reference to the accompanying drawings, in which:
FIGS. 20 to 23 illustrate the handling of packet data in fixed-rate channels of the network.
FIGS. 36 to 38 show the division of the frame structure of the third example in to variable rate and fixed rate connections.
The various aspects of the invention will be illustrated by reference to examples of “Double Speed” and “High Speed” network systems. The D2B Optical system (referred to herein as “single speed”), will first be briefly described, as background.
The known (single speed) system illustrated in
The display function of the control and display unit 101 may for example provide for display of information read from memory devices by CD-ROM and/or display of video signals from tuner 108 or VCR 107.
The LAN interconnection in the known system comprises nine unidirectional point-to-point fibre optic links 111, 112 etc. linking interface modules 121 etc., each of which is substantially structurally identical, such that the nodes are all connected in a ring. Each fibre optic link carries a combination of digital audio/video signals, CD-ROM data and control messages in accordance with a signal frame structure to be described in detail below. A designated station (referred to hereinafter as the system master), such as the control/display unit 101, continuously generates the frame structure at a frame sample rate of 20-50 kHz (typically 44.1 kHz as for CD sampling). One station on the network is designated to act as system master on power-up although the role of system master may subsequently be re-allocated to another station, for example in fault conditions.
The implementation of a station's interface to the fibre optic ring is schematically illustrated in
As shown in
Double Speed Network
Electrical signals received from the optical fibre are detected, decoded and buffered by a network receiver block. Similarly a network transmitter block is provided to drive the optical transmitter for the next segment in the ring. All communications between one station and its neighbouring stations in the ring therefore effectively pass in serial form through the pins NET RX and NET TX. Four ports SR0-SR3, are provided for source data in serial format to be provided to the transceiver for transmission via the network. Similarly, source data outputs SX0-SX3 are provided for source data recovered from the network to be supplied to the various functional units of the apparatus in question. Between the network receiver and transmitter and the various source data ports, a source data router allows control over the routing of source data throughout the network and internally of the present station.
The entire network is synchronised with itself and with the sample rate of source data (when active), by means of the master station clock and the phase locked loop (PLL) working in the transceiver of each station. In particular, the PLL at each station around the ring recovers the serial data clock from the network signal at pin RX and generates timing signals for control of the apparatus, and for onward transmission at pin TX. For functioning as a master station, a crystal oscillator is provided. The clock manager comprises counters and registers suitable for adapting the functions of the entire circuit to different data rates, and for generating clock signals appropriate to other components within the device. An audio synchronising unit provides clock signals to external audio signal processing circuitry, such as a CD player mechanism. In the case where, for example, a digital audio broadcast is to be received, the audio synchronising unit may receive clock signals to act as the master clock for the entire network.
A speed control pin provides input to the clock manager, for use in providing compatibility with D2B Optical networks in a manner to be described hereinafter.
Finally, within the transceiver, a control unit provides various interfaces for microprocessor control of the network transceiver. Standard serial interfaces I2C/SPI are provided for serial control. A novel parallel interface provides for parallel control functions and/or source data output. Within the control unit, various functions and options within the transceiver are controlled and reported to the controlling microprocessor (not shown) via a number of dedicated registers, in a conventional manner. A control port provides access to the transparent channels of the Plus network.
The function of each pin is specified in Table 1 below. Some pins are omitted from the drawings, for clarity.
The new transceiver is designed to allow inter-operability with existing (single speed) D2B Optical products constructed for example around the Conan D2B Optical interface device (C&C Electronics Part Number OCC8001), while allowing higher data rates if wanted. A comparative list of the key performance benefits of the new “Double Speed” transceiver compared to D2B Optical is as follows:
-
- Source data rate is increased from 4.2336 to 9.867 Mbps (or 10.57 Mbps if using High Data Rate Mode for Source Data). This is of course somewhat more than “double”.
- The number of Serial Source Data Channels accessible from each interface transceiver is increased from three to four.
- The D2B Optical clocking and synchronisation mechanisms (master-slave sync using PLL) are maintained with no additional connections.
- The new transceiver provides the ability to select between Serial interface such as I2C/SPI or standard Microprocessor 8-bit Parallel Interface for control data as well as a total of 4 source Ports (SR0 to SR3) for serial or Parallel Interface. The data rate of the I2C control port is increased to 400 kHz and that of the SPI control port to 2 MHz.
- The frame structure of D2B Optical is maintained while doubling the source data capacity.
The new transceiver with these features enables networks which mix nodes based on either single speed (D2B Optical) or the new double speed transceiver to be constructed, as shown in
Frame Structure
The primary difference is that each subframe contains twice as many bits (128), with an encoded frequency of 22.5 MHz instead of 11.25 MHz (approx).
The fields of the subframe structure are:
-
- Preamble: The preamble synchronises the network receiver. There are three types of preamble, identical to those defined in the IEC-958 (SPDIF) specification. They contain bi-phase coding violations which the receiver can recognise. The three unique preambles identify left, right and block subframes. The left preamble identifies the beginning of a frame and the block preamble identifies the beginning of a block. The block preamble replaces every 48th left preamble. This provides a block structure to which the control frame data is synchronised.
- Transparent Channels: The four TC bits enable the transport of four serial channels for proprietary control or status information on the network, with no additional hardware or software overhead. The use of these channels can be left open to system designers, who must define their own protocols for applications. Typical applications include the transport of raw control or status information, such as RS232-type data, VICS data, GSM data, PIN Card data, etc.
- Source Data Bytes: The source data bytes carry the high-volume real-time digital source data. The bytes may be allocated flexibly, so that the devices in a system may use the source data bytes in the most efficient way for that system. The mechanism used for allocating the bytes is described below in the section headed Source Data Routing. Additional mechanisms can be provided for asynchronous data transport and flow control in these bytes.
- Status Bits: If an SPDIF (IEC-958) channel is being transported (using the ports SR0 and SX0 of the transceiver circuit), the V, U and C bits of the Double Speed subframe contain the validity, user and channel status bits of the SPDIF channel. The left/right convention of these bits is determined by the left/right preambles. The Start Block bit SB identifies the block boundary of a synchronous SPDIF channel and is set after every block of 192 frames (synchronised with the SPDIF signal that is being transported). This synchronisation is performed automatically by the transceiver chip. The Parity bit P generates even parity for the entire subframe.
- Control Bits: The control bits CF0 and CF1 carry the control messages (for controlling devices and sending status information). There are 2 CF bits per subframe, and a control frame is 192 bits long, therefore 96 subframes (48 left+48 right) are required to build-up a complete control frame. The control frame is shown in
FIG. 11 and is the same for Single Speed Optical and Double Speed segments.
As shown in
The fields of the control frame are:
-
- Arbitration bits: These indicate if the control frame is free or occupied. The transceiver handles these bits automatically.
- Destination Address: This is the 12-bit device address of the destination of the message, in the range ‘000’H to ‘FFF’H. The sending device writes this into its message transmit buffer for transmission. Certain addresses and address ranges have special meanings.
- Source Address: This is the 12-bit device address of the sender of the message, in the range ‘000’H to ‘FFF’H. The receiving device can read this from its message receive buffer after reception. Certain addresses and address ranges have special meanings.
- Message Type and Length: Two 4-bit fields normally used to indicate the type/length of the message. These bits are transported transparently by Conan.
- Data 0 to 15: The message data. All 16 bytes are always transported. The Message Length normally indicates how many of the 16 bytes are actually valid for the message. The sending device writes this into its message transmit buffer for transmission. The receiving device can read this from its message receive buffer after reception.
- CRC: A 16-bit Cyclic Redundancy Check value used to verify that the control frame has been transported without error. The CRC is generated by Conan automatically on message transmission and checked by Conan automatically on message reception.
- ACK/NAK: Acknowledge and Not Acknowledge (2-bits each) indicate successful message transmission. The use of separate ACK and NAK flags allow reliable point-to-point and broadcast message transport, as described in our application GB-A-2302243. The flags are automatically filled by the destination device(s) (if present) and read by the sendin, device.
- Reserved: 10 bits are reserved for future definition.
Transceiver Parallel Interface
The key features of the parallel interface (PI) in the novel transceiver are as follows: An 8 bit data bus provides connection to external microprocessors. A 2 by 32 byte internal buffer is provided for read and write to the Double Speed network. Sustained source data rates up to 10.584 Mbps (1.323 Mbytes per second) (at Fs=44.1 kHz) as possible using the 15 byte per frame transfer mode of Double Speed network. The parallel interface can be used for control data, source data or both under control of external configuration pins (P_S0, P_S1). Packet based data is automatically accommodated in the source data channel, as will be described later. Packet start signals P_SO (output) and P_SI (input) are provided in support of packet data handling for applications that require it.
Two 32×8 bit on-chip RAMs (not shown explicitly in the functional diagram of
At any one time, one of the two RAMs is assigned to serve the internal RISC processor of the transceiver, while the other is dedicated to the external microprocessor (not shown). Both the external device and the internal processor have direct access to these memories, by means of a full crossbar 2×2 switch. The RAMs are swapped whenever an interrupt is asserted. This operation is transparent to both the external device and the internal processor.
The external microprocessor communicates to the PI through an interrupt request line, an 8-bit bi-directional data bus DATA(7:0), a 4-bit address bus ADDR(3:0) and three registers: STATUS, ADDRESS and DATA. See Table 1 for a summary of those pins associated with the parallel interface PI. An ADDRESS register is used to store the address of the internal register that is accessed. All data is exchanged via the DATA register.
The general operation of the parallel interface is not relevant to the present invention, and will not be described further.
Source Data Handling
To maximise the application versatility of the chip, three serial source data ports are provided. This means that a product which needs to process source data for more than one internal source or destination can do so with only one transceiver chip. These source data ports can transfer 8, 16, 24 or 32 bit source data, left or right adjusted, in to and out of the device.
The source data ports provide access to the source data in the network bit-stream. Data can be input and output serially through seven serial inputs (SR0 to 3) and seven serial outputs (SX0 to 3) or using the Parallel Interface. When in serial mode all seven ports use a common frame synchronisation FSY and a serial bit clock SCK. FSY and SCK may be set as either inputs or outputs, depending on the external hardware. If they are configured as inputs, then the data source(s) must be clocked by RMCK to be synchronised in frequency to the network bit-stream (although not necessarily in phase). A special mode is provided which allows source data Port as SPDIF (SR0/SX0). With the control bits in a Source Data Port Control register, a variety of source data formats can be selected.
Like the Conan interface circuit the present transceiver maintains a Routing Information Table (RIT) which determines the connection between the various source data ports and bytes within the source data fields of the D2B Optical or Double Speed frames.
It will be seen that the RIT has an entry corresponding to each byte field on the “output” side, which includes equally bytes of the frames being transmitted to the network and bytes output within the network station from the ports SX0-SX2 of the transceiver. The value stored for each entry in the RIT acts as an index to identify the source of the data for the output, which may be a byte field of the incoming network segment, or a byte field from one of the source data ports SR0-SR2.
In the example of
Source data is always transmitted and received MSB first in each byte.
Asynchronous Data Transport
Asynchronous data is data whose rate of delivery is not matched on a frame level with the transport provided by D2B Optical. This situation applies in the following cases:
-
- where the source cannot provide continuous output
- where the source output is not matched with the nearest available D2B Optical transport rate (calculated from: bytes-per-frame*frame-rate)
- because of a variable rate of consumption in the receiver of the data.
Table 2 shows the various methods for transporting data in the Double Speed network and the data rates which are possible with these. The system is assumed to be operating at a frame rate of 44.1 kHz; “bps” means bits per second.
The control message is capable of supporting transport of non-real time data, using defined Data Transport Protocols. The data to be transmitted is segmented into control message frames which are transmitted then reassembled in the receiver.
At a frame rate of 44.1 kHz, the data capacity of the control message channel is (44100*4*16*8*192=)11700 bits/seconds. However, due to a minimum interval of milliseconds between message transmissions, the useable rate would be ˜11 re-transmissions) the receiver of the data should be able to clear the Transceiver's receiver buffer within Tserve=25 milliseconds). A further limitation of data rate arises from framing overheads (25%), leading to a transfer rate of up to ˜8 kbps.
Note also that the control message channel is not suitable for transporting real-time data since it is an asynchronous channel where the time to deliver a frame of data varies with:
-
- the arbitration time (time take to find a free control message frame), which depends on the current bus loading, this would be of the order of a few milliseconds.
- the time taken for the receiver to receive the message, which depends on how quickly the receiver reads its Rx and the number of other devices which are currently transmitting messages to that same device. Whilst the receiver remains busy a single frame could be delayed up to approx. 350 milliseconds (beyond which no further attempt would be made to retransmit the frame.
A generic mechanism for asynchronous data handling will now be described, which can be applied to the known single speed or double speed networks applications, where serial source data ports are used.
An asynchronous data stream can be matched to the synchronous flow on the network by the insertion of null data (padding), provided that:
-
- the rate of the asynchronous data is lower than the rate provided by D2B Optical (any peaks above this rate must be absorbed by buffering in the source device); and
- the receiver can detect and separate the required data from the padding.
Two mechanisms are described for the insertion of padding:
-
- 1. Within the byte-stream of a source data connection, at sub-frame-level, where a flag (generated by the source) indicates whether the bytes for the specified connection in that sub-frame contain useful data or padding.
- 2. Within a packetised data stream, where packets can either be null (completely empty) or be partially filled. In this case the destination can use information in the packet header to separate the data from the padding.
Byte Stream Flow Control
This mechanism, illustrated in
Each connection is allocated a number of source data channels within a subframe, in a conventional manner. At the same time as the connection is set up, however, a validity/flow control bit is reserved within the source data byte in one of the subframes. The bit is allocated for use only in conjunction with this connection and is used to signal Validity (from sender to receiver) or Receiver Buffer Full (from receiver to sender). Note that the same bit can be used for both functions (in different parts of the ring) because each ring segment is physically independent of the other segments.
Referring to
Referring to
Allowance should be made for the number of frames which are already in the course of transmission around the ring. This means that the full indication may need to be replaced by e.g. a half full warning so that capacity remains for the bytes which are in transmission. The number of bytes in transmission depends on the number of used per frame (for this connection) and on the number of devices with open source data bypasses between the source and the destination devices. To this must be added the delay in the source receiving the flow control flag, which depends on the number of devices with open source data between the destination and the source.
The total latency (in bytes): L=(number of sources*2)*number of bytes per frame, where the System Master is always counted as a source.
This latency can be determined when the system starts up by placing a recogniseable marker in the source data field of the D2B Optical frame and observing the number of frame delay before it is received back by the sending device. This total frame delay can then be reported to all other devices via a control message.
This is illustrated in the example of
In the state shown in
In the alternative mechanism shown in
In the state represented in
Packet Framing
Referring to
The Double Speed network transceiver of
As shown in
The validity flag (Vd) is set to ‘1’ when the source data for the asynchronous connection (contained in that frame) is valid. When the validity flag is set to ‘0’, the data is not valid.
The Start of Packet (Sp) is set to ‘1’ when the start of a new packet for the asynchronous connection (contained in that frame) has occurred in the left subframe. When the validity flag is set to ‘0’, the data is a continuation of an existing packet.
As illustrated in
Asynchronous Data Transport in High Data Rate Mode
Referring again to
Error Protection
The following sections explain the effects of bi-phase conding errors on each field in the subframe as shown in the
-
- Preamble: Errors in this field affect the ability of a receiver to recognise the start of the Frame/CF Block. The effect of errors are reduced by ignoring a single erroneous preamble, by the transceiver by counting bit periods from the previously received preamble.
- It is also possible for bit errors in another part of the frame to form a false preamble but this is avoided by the transceiver only looking for a preamble only during the expected time-window, once lock has been established.
- Control Message Field: Each Control Message is protected with a 16-bit CRC. Thus an error in a control message can be detected by the receiving device. When receiving device detects a control message error, it sets the NAK bit to notify the sender of the message and then disposes of the message.
- S/PDIF bits (VUC and SB): An error in the V (validity) bit could cause a problem for the destination of the S/PDIF source data connection, which might wrongly interpret the received source data. For example, if the validity bit changes to not valid this could cause a digital to analogue converter to be muted in an audio amplifier.
- The effect of an error in the User bit (U) is a function of the application.
- The Channel Status (C) is organised into blocks of 192 bits, each of which is protected with an 8 bit CRC.
- An error in the SB bit will cause a dislocation of the Channel Status and User Bits, possibly resulting in the loss of all these data up to the next valid start of block.
Each subframe is protected with a parity bit P which all the device receiving the frame to check whether an error has occurred during the transmission from the preceding node. The node detecting the parity error should not rely on any source data or transparent channel data within the affected subframe since the error could have affected these. However, the parity bit is generated anew at each node of the ring, and so the information about such errors is not propagated around the ring.
Error Protection of Source Data
There are two types of source data connection in the double speed networks:
-
- Synchronous Connections: these are connections which use the full capacity of the bytes allocated to the connection within each frame.
- Asynchronous Connections: these are connections which use a part of capacity of the bytes allocated to the connection within each frame. A connection such as this may be used to support ‘DMA’ data transfer between two devices on the network, or simply to adapt to an audio source of sample rate lower than the frame rate.
The effect of errors on the source data transported within source data connections is application dependent. For example, bit-errors in a PCM audio connection can result in audible clicks.
The probability of a bit error occurring in a particular segment of a ring depends on the fibre optic transceiver (FOT) units, (or noise susceptibility of an electric cable).
Suppose the following figures apply:
If a connection spans n segments and occupies x bytes of each frame, the probability (worst case) of a bit error occurring in any of these segments of a ring is approximately:
(x/32)*n*10−9.
Consider an example of a connection which has been allocated 8 bytes per frame (for example data for a double-speed CD ROM) and spans 5 nodes (passes over 4 segments). The probability (worst case) of a bit error which affects this connection is approximately:
(8/32)*4*10−9=10−9
At a bit-rate (for this connection) of (44100*8*8=)2.82 Mbits/sec, a single bit error affecting this connection is likely to occur once every (1/(10−9*2.82*106)=)354 seconds.
To protect against such errors, the double speed network disclosed provides a degree of protection. While ideally the means of protection would apply separately to each source data connection, this is relatively costly to implement. A simple approach has been devised here to give a warning to each affected device that there might be an error in the source data within a particular frame or subframe. For this purpose a Subframe Error Flag has been defined which gives a warning of an error in a subframe.
where it finds Se set to ‘1’. Except for these circumstances a device is not allowed to modify the value of Se. All devices may use the value of Se as an indication whether there is a risk of an error in any source data that they are receiving.
Note that there is no protection against an error in the Se flag. The consequence of an error in this bit is that either:
-
- the destination may encounter erroneous source data without warning (very low risk) or
- a destination may be given a false warning about a possible error in the source data within the accompanying subframe (more likely).
If a connection spans n segments the probability of a bit error affecting Se occurring in any of these segments of a ring is approximately:
<(1/128)*n*10−9.
Consider an example of a connection which spans 5 nodes i.e. passes over 4 segments. The probability (worst case) of a bit error which affects Se in the segments spanned by the connection is:
(1/128)*8*10−9=(1/16)*10−9
Se bits occur at the rate of (44100*2=)88.2 kbits/sec, a single bit error affecting an Se in the spanned segments is likely to occur once every (1/((1/16)*10−9*8.82*104)=)181405 seconds (approximately 50 hours).
As described above with reference to FIGS. 15 to 22, validity signalling bits can be sent in parallel with source data to achieve asynchronous data transport. The novel transceiver implements error protection of the validity bits as follows.
In normal rate mode the number of separate asynchronous source data connections in any segment of the double speed ring is limited to four, given a single byte validity signalling connection. Since these source data connections carry asynchronous data streams they may contain padding from time to time. As described already, the presence of padding (instead of valid data) is indicated via a Validity flag which is allocated to each of the asynchronous connections when they are set-up.
If there are no asynchronous connections present in the ring, then the byte containing the validity flags will not be occupied in the double speed network frame.
If at least one asynchronous connection is present then the final byte of the right subframe (DATA 13 in
In
Four validity flags are provided in this byte to allow up to four asynchronous connections to be present in any segment of the ring. The validity flags are automatically extracted by the destination transceiver and used to enable or inhibit output via the output port SX0-SX3 approximate to the respective connection. In this way, asynchronous communication is provided by the transceiver with only minimal buffering being required by the external device (and amplifier, for example) which is using the data.
Note that in this example it is the responsibility of the application to provide a mechanism for flow control i.e. if the destination needs to be able to regulate the data delivery.
As an example of the possible effect of this error, suppose that a navigation database is being read from a CD ROM over the network as shown in
To avoid this problem, the Validity Flags will be grouped into a set of four within one byte as shown in
A non correctable error will only occur when two or more of the validity flag are in error. This is an extremely unlikely occurrence.
It will be appreciated that the “double speed” system described has various novel and useful features, while the various aspects of the invention are in no way limited to the particular examples described herein.
High Speed Network—Introduction
While the “Double Speed” Network described above provides a substantial increase in source data capacity compared with the Single Speed D2B Optical network, the examples described below provide a High Speed or “HS” network protocol, which further increases capacity. Such a network will provide for multiple high bit-rate, multimedia applications, such as MPEG audio, MPEG2 video, digital audio broadcasting (DAB), digital versatile disc (DVC) and other data, in addition to conventional CD, audio and the like.
User require for the HS network are broadly for the provision of synchronous, connection-oriented data transfer and also asynchronous, or variable rate data transfer. The network runs at a frame rate in the range 16 to 50 kHz. Specific frame rates which are currently foreseen are CD compatible at 44.1 kHz, DAB/DVD audio at 48 kHz and telephony audio at 16 kHz.
It may further be noted that the DVD system provides storage devices with a maximum of 17 GByte (compared with 680 MBytes for CD). Interactive video from DVD requires the exchange of control information. Typical image resolution corresponding to MPEG2 is 720 by 480 pixels at 30 fps, all at 9.8 mbps maximum. Audio may be by Dolby AC3 5.1 with a 48 kHz sample rate, 448 kbps maximum rate, or by MBEG2 7.1, (48 kHz sample rate, 912 kbps) The average data rate for DVD is 4.69 Mbps, depending on content. A peak information rate of 10.08 Mbps is possible, but a peak system layer rate of 11.08 Mbps. It may be noted that the DVD system provides storage devices with a maximum of 17 GByte (compared with 680 MBytes for CD). Interactive video from DVD requires the exchange of control information. Typical image resolution corresponding to MPEG2 is 720 by 480 pixels at 30 aps, all at 9.8 mbps maximum. Audio may be by Dolby AC3 5.1 with a 48 kHz sample rate, 448 kbps maximum rate, or by MBEG2 7.1, (48 kHz sample rate, 912 kbps!) The average data rate for DVD is 4.69 Mbps, depending on content. A peak information rate of 10.08 Mbps is possible, but a peak system layer rate of 11.08 Mbps. The DVD standard also specifies mapping of audio data streams to IEC 958 (SPDIF) connections.
One feature of the new data types is variable bit rate. In the prior art, it is proposed simple to adopt a packet structure, with token ring or other multiplexing protocols to allow a fair sharing of capacity between the various connections. This provides a fair and flexible allocation of capacity, but increases the need for buffering in source and destination stations, to ensure a steady flow of, for example, audio data at the output. The imposition of a packet structure on all types of data also brings unnecessary overhead. It has been proposed, for example, in U.S. Pat. No. 5,257,259 to combine both asynchronous packet—switched data and circuit-switched data in a “hybrid” network. The packet information in that case, however, appears to be relatively low volume (musical note commands such as NIDI data may be inferred). According to one proposal therein, packet data is merely carried in certain connections established within a circuit-switched network. Accordingly, the prior proposal does not appear to address the problem of sending large volume but variable rate data economically, and particularly relies on a full-blown packet-switching protocol for such data.
Various examples of a novel High Speed (HS) network will now be described. In particular, mechanisms will be described for providing variable-rate channels for both packet and general stream data with minimal overhead in terms of both network utilisation and buffering requirements.
Five examples will be presented with detail of allocation and capacity of flow control being described in particular with reference to Example IV
Some terms will be defined to assist in the following discussion:
-
- Variable rate connections: These are source data connection whose use of the source data capacity can be adjusted to meet the requirements of the application without wasting source data capacity. They enable an efficient sharing of capacity between a number of applications whose need for bandwidth varies from time to time. This type of connection is suitable for variable bit rate signals such MPEG-encoded video streams from devices such as DVD players. Variable rate connections are asynchronous in general.
- Fixed Rate Connections: These are source data connection whose use of the source data capacity is fixed when the connection is set up and is guaranteed through the lifetime of the connection. This type of connection is suitable for fixed bit rate signals such as PCM audio. There are two types of fixed connection: synchronous and asynchronous.
- Asynchronous Connection (Variable or Fixed Rate): The raw synchronous rate provided by channels within the HS network source data field can adapted (padded) to data streams which require lower delivery rates. The application may provide data for an asynchronous connection either at a constant rate or in bursts, subject to buffer capacities within the source and destination devices. The HS network also provides a mechanism for regulating the delivery of data over an asynchronous connection according to the demands of the destination rather than the source. For example a destination for CD-ROM data may consume data at a variable rate and can demand data whenever it needs.
- Synchronous Connections (Fixed Rate): These are connections which take full advantage of the raw synchronous rate provided by channels within the HS network source data field. There is no packet overhead associated with this type of connection and thus it is a very efficient use of system capacity subject to the constraint that the source must provide data at a rate which matches the system frame rate and the destination must be able to consume the data at exactly this rate. This type of connection could be use to transport PCM audio from a DAB receiver to an audio amplifier, for example.
The frame structure for Example I is shown in
Referring to
The mode 0 subframe comprises simply 32 source data bytes, totalling 256 bits.
To accommodate the additional data at the same frame rate, the bit rate of the network segments is 22.5 Mbps, compared with 5.6 Mbps for the Single Speed network.
The mode 0 subframes can accommodate up to seven stereo CD audio channels compatible with the Double Speed frame structure. As in the known networks, each circuit-switched connection remains fixed in capacity throughout the duration of the connection, although it may be reallocated to different source data bytes as new connections are built.
The mode 1 subframes provide a continuous channel for packet switched data up to 12.288 Mbs at 48 kHz sample rate. At that sample rate, the gross data rate on the network segments is 24.576 NMbps, before line coding. ATM type protocols may be applied for allocating capacity between different sources in the mode 1 channel. Alternatively, the control message channel could be used, subject to traffic and arbitration delays. Alternatively, a fast control channel can be created to allocate the capacity. This fast channel may for example use a dedicated packet 1 to allocate mode 1 capacity, at 384 kbps). Referring to DVD video delivery by MPEG2, the compression ratio for DVD is 12.7 to 1. A maximum of 41 kB per frame is required, corresponding to 218 “PES” pay loads each of 188 bytes (1 PES payload every 160 microsecond). In DVD video, inter-frame encoding drives the compression, so that the maximum rate of change of data rate is once per frame (approximately 30 ms).
The delay at each network node in processing each frame of Example I is greater than 1 sub-frame when using a network containing both Single Speed and High Speed network nodes. While this is not a problem in principle, it does not provide. Compatibility with the known D2B Optical network, which can only handle a maximum of one sub-frame delay around the ring. One possible solution to this is adopted in Example II, so that the maximum delay is 12 High Speed bits(=3 D2B Optical bits). Therefore, the constraint of one frame delay can be met up to a theoretical limit of 20 nodes. After accounting for typical processing delays through each node, in practice the nodes can be placed in a mixed mode network.
In the Example I the allocation of circuit-switched synchronous traffic (Mode 0) and asynchronous packet based traffic (Mode 1) was fixed at 256 bits each. In Example II the traffic can be allocated in a flexible manner from 100% Mode 0 to 100% Mode 1 in increments of 1 source byte from 0 source bytes to 60 source bytes in a frame. Total source data capacity is now 23.04 MBPS at Fs=48 kHz (DVD sample rate). Capacity for variable rate traffic is allocated in source bytes from the end of frame—Synchronous traffic from the beginning of the frame.
The frame structure of Example II allows transmission of 1 complete ATM cell (53 bytes equivalent to a bit rate of 20.352 bps) in 1 frame as Mode 1 traffic with 7 bytes left for Mode 0 traffic (2.688 bps or, for example, 2 stereo digital CD channels). Thus the HS network can be used to transparently connect nodes with ATM data interfaces, if desired.
Compatibility is maintained as before by using a common control channel structure as currently used in Single Speed D2B Optical systems (at a rate of 176.4 kbps at Fs 44.1 kHz) and optionally the double speed network too.
When using a network in which all nodes are High Speed Nodes additional control channel capacity can be added by using the 4 bits in the Right Pre-amble to increase the control channel capacity to 352.8 kbps at Fs=44.1 kHz.
Line coding efficiency is improved using 4B/5B line coding to reduce the overhead to just 20%. Thus the rate at which optical transceivers are required to be driven reduces to 29.4912 MHz (at Fs=48 kHz) as compared to 49.152 MHz for bi-phase encoding.
Statistical multiplexing can be used to multiplex up to 4 DVD channels onto the High Speed bus. This relates to calculating node buffer sizes in a distributed video transmission network.
Control channel format is common to D2B Optical and the Double Speed network.
Additional control channel capacity may be used when all nodes are High Speed nodes, by use of right pre-amble to increase control capacity to 384 kbps at Fs=48 kHz.
High Speed Network EXAMPLE IIIA further example will now be presented, which differs from Example II in various ways.
The number of source data bytes per sub-frame is increased to 46, giving a continuously allocatable 92 source data bytes per frame. The frame rate is fixed at 48 kHz, giving a higher overall data rate than in Example II.
Example III also provides more detail of the control of variable with channel allocation, and a pocket structure for data within the variable rate channels.
Although the variable width channels and the fixed rate channels are again allocated within a single source data field from different ends, in this Example the variable with traffic is allocated in the source bytes from the beginning of the frame, not the end. At the start of each block of 48 frames, variable width block (VCB) headers are provided which indicate a channel ID and channel width which are fixed for the remainder of that block. The header for successive channels is found by counting through the source data bytes of the first frame in accordance with the width of each channel. The fixed rate data channels are allocated from the end of the source data field.
Packets carrying 42 bytes of source data in this example can also be grouped into packs of up to 256 packets. This can assist data handling in applications where larger segments of data, such as disk segments of 2 kbytes are expected. A DVD source, for example, normally provides data in so-called PES cells of 188 bytes, which could, if desired, be grouped as pack of five of the proposed asynchronous data packets.
A detailed description of Example III now follows. As seen in
Depending on its function, each Device in the system can:
-
- supply, receive or pass through source date (e.g. digital audio, video, etc.)
- send and receive control messages.
To support the sending and receiving messages, each device has two unique addresses an application-related (device address)address and a ring-position related address. It is also possible to broadcast a control message to all devices or to a pre-selected group of devices.
The protocols for control message communication are defined as required in application protocol specifications so as to ensure compatibility between components.
At a frame rate of 48 kHz the High speed D2B System offers a gross data rate of 36.864 Mbps and a net source data rate of 34.56 Mbps (organised as 92 source bytes per High Speed D2B Frame).
The frame and sub-frame structures for High Speed Example II are shown in
The subframe each comprise 384 bits. They correspond in form to the Double Speed subframe (
The control frame structure is again identical to that shown in
The HS frame is protected by two parity bits P, one in each subframe, which are set to generate even parity and protect against bi-phase coding errors in the individual links.
Source Data Transport
Whenever source data (e.g. digital audio or video) needs to be transported over the HS network, a source data connection must be established. This is called connection set-up. During the set-up, the required number of source data channels (bytes) are allocated from free channels within the HS frames. For example, to carry a stereo audio signal from a CD player requires an allocation of 4 bytes. Source Data Connection protocols based on control messages are used for setting-up and removing connections. Source data routing is similar to that of the Double Speed transceiver IC, but with a larger number of bytes per frame, and hence a far greater number of switching permutations. In practice, a connection list, rather than an explicit routing table, may therefore be implemented in the source data router. Connection building can be performed for example by protocols based on the disclosure of EP-A-0360338 (PHN 12678) and EP-A-0432316 (PHN 13189), adapted according to the ring topology. Protocols for this purpose are established using the control message frames to carry pre-arranged connection request instructions.
For fixed rate connections, this capacity remains allocated until the connection is removed. Synchronous connections have no superimposed framing or packet structure, although applications are free to provide structure as desired.
For variable rate connections, the connection set-up establishes the starting allocation. However this allocation can be varied during the lifetime of the connection as described in the section on variable Connection Blocks.
When all the capacity has been allocated attempts to build further connections will fail. When this happens, the controlling station (AVC) must decide which existing connection(s) (fixer or variable) need to be removed to release enough capacity for the new connection. The complexity of the allocation is hidden from the controlling AVC since each device is responsible for managing the allocation in its own output link (ring segment).
Allocation of Source Data Capacity
As shown in
The first part is allocated to variable-rate asynchronous transport, while the synchronous (or fixed-rate asynchronous) source data capacity is allocated starting from the end of the frame.
In the Figure, VC1 to VCn are variable rate data Connections of V bytes total width (variable). FrB represents free capacity for variable or fixed rate connections of 92−(V+S) bytes. FC represents the fixed rate data connections of total S bytes (variable). The FCB may comprise several fixed rate channels.
Variable rate Connection Blocks (VCB)
Variable rate connection blocks (VCB) are the means by which multiple variable-rate source data connection can be carried on the HS network. they are the containers for asynchronous connections within the HS frame, carrying the packet switched data. More than one VCB may be present in the frame allowing multiple simultaneous variable rate connections.
As shown in
Example Application
Variable Connection Block Structure
Each Variable Connection Block (VCB) is structured as shown in
The VCB-Header (VCB HDR in
The VCB ID enables a receiving device to identify the connection whose data is carried by this block.
The start of Packet flag indicates whether the first data byte of this VCB is also the first byte of a packet (flag set to 1) or whether it is a continuation of a packet. This allows for longer packets than the type detailed below, for example.
The Reserved fields are for future extensions.
The VCB width field indicates the number W of (consecutive) bytes allocated to this asynchronous connection within each frame, encoded such that 1 means 2 bytes, 2 means 3 bytes etc. The minimum width of two bytes ensures space for the header in the first frame of the block. The VCB width W may be restricted to ensure an integral number of packets within a block, where packet and/or frame sizes vary from these examples.
Within the capacity provided by the VCBs, source data (VCB-DATA) is carried in the form of packets. The packet format is describe in the following section.
The VCB header format and its field sizes can of course be different according to the application.
The free capacity (FrB) is held within an Asynchronous Connection Block (VCB) with ID=0. This allows the transceiver hardware or software to identify the synchronous connection block easily.
Fixed rate Connection Block (FCB)
This block can be used to carry both synchronous signals e.g. 16 bit PCM audio at 48 kHz or asynchronous signals whose bit-rate is fixed. Changes to the contents and size of this block can only be made by setting up a new connection or removing an old connection, by the exchange of control messages.
Packet Structure
Asynchronous Data carried within either variable or fixed rate connections is formatted into packets whose structure is described below. This provides framing to allow a device receiving the data to identify the data and recover it correctly. Since each packet has its own ID, it is possible to interleave different streams of data over the same connections. For example a particular connection might carry predominantly packets containing video data interleaved with an occasional packet for control purposes.
In the Packet Header, Packet Type identifies the format of the packet, for example longer packets may be defined for bulk data transfer, as opposed to real-time channels. Packet ID identifies the type of data contained in the packet, such as audio/video/general data, to assist routing in the destination device. Packet ID “7”H is reserved for control (e.g. connection management) messages, with low latency compared with the existing control message channel (CF bits). Flow control is used by a receiver of the data to indicate that its Rx buffer is full (when this flag is set to 1). When this is detected by the source of the data, it will normally suspend transmission. Remaining Packets indicates the number of packets remaining within the current pack (group of packets). Number of Bytes used indicates the number of bytes in this packet containing valid data (for type O, the total number of data bytes is always 42).
The flow control mechanism implemented via the flag in the packet header, requires there to be a connection from the destination device back to the source device. This connection, is built as part of the connection set-up of the signal whose flow is being controlled, and can have a much reduced capacity (minimum 1 byte per frame) compared with e.g. the video signal to which it refers. It may for example have same VCB ID, and use the Packet Header format alone. A single byte channel could also be allocated as an FCB.
The start of the packet is indicated by the Start of Packet bit in the VCB header. When this bit is set, the first byte of data following the VCB header is also the first byte of a packet. When this bit is not set, it indicates that the contents of the VCB are a continuation of a previous packet.
The number of HS frames required for transmission of a packet is a function of the size of the packet and the width of its containing VCB in each HS frame. If the VCB is w bytes wide then the packet will encompass (packet-size+size of VCB Header)/48 wHS frames.
Each station device which needs to send or receive packet data provides buffers for packets which have been received or are to be sent. The size of these buffers is defined according to requirements.
High Speed Network EXAMPLE IVA further example is now presented, which is substantially the same as Example III but further defines certain mechanisms and communication channels for flow control in the asynchronous data. A packet structure is not imposed.
For control of variable rate connections, a special connection signalling channel is built among the source data fields. Flow control implemented by each source adapts to minimum and maximum data rates signalled by other sources. A source data latency specific to the installation is accounted for in the flow control calculations and by means of a transition period between blocks. Mechanisms for determining the source data latency automatically are provided. The source data block is decoupled from the control frame block, as explained below.
Also buffer occupancy signalling for the control channel is provided, to improve the efficiency of utilisation where one station such as the system master or AVC receives a disproportionate amount of control message traffic.
Source Data Capacity is more than 43 Mbits/second, per point-to-point link. Since each link is physically independent of any other link, this means that, by optimisation of relative device positions, the total system capacity can be much greater than the capacity of any single link.
The network supports transport of Asynchronous Data as well as Synchronous Data. Data can be carried regardless of its timing relationship with the system, so that it is simpler to implement applications requiring asynchronous data. The networks supports Variable-rate connections as well as fixed rate connections, enabling more effective sharing of transport capacity between applications whose demand is variable. Same Control Message format as that of D2B Optical is again maintained, providing backwards compatibility for D2B Application Protocols. In addition, applications requiring faster control message transport can now make use of asynchronous data connections to provide as fast a link as required.
Operating at a frame rate of 48 kHz the High Speed System offers a gross data rate of 43.78 Mbps and a net source data rate of 43.01 Mbps (organised as 112 source bytes per High Speed D2B Frame).
The High Speed D2B System will again operate at a single frame rates: 48 kHz. The frame structure for High speed D2B shown in the
The frame structure contains the following fields.
Preamble: The preamble enables the receiver to recognise the start of an HS network frame and also to determine whether or not the frame is the starting frame of a CF block or not. The CF block structure, as described in the previous examples, is used for Control Message Frame transport. These preambles are as follows:
See the section on Line Encoding for further details. Compared with D2B Optical, the HS network frame preamble has been extended from 4 to 8 bits to suit the line encoding. However this increase is cancelled by the use of only one preamble per frame compare with one preamble per subframe in D2B Optical.
-
- CF0-3: Control Message Channel: This channel is supported with 4 CF bits/frame, in exactly the same way as D2B Optical. Applications requiring faster control message transport can use fixed asynchronous source data connections as very high speed control channels, where the control messages can be sent within the same packet format as source data. For example, with one frame byte allocated to the connection, such a channel could offer a gross rate of 384 kbits/sec., cf. the existing channel capacity of 192 kbits/second. Such high speed channels could be dedicated either to one particular application or could be shared among applications, depending on how the fixed asynchronous connection is built.
- SDB Bit: The first frame of the source data block (described below) is indicated by the SDB flag being set to 1 (by the System Master). In all other frames SDB is set to 0.
- Tr Bit: For the purpose of implementing variable rate connections, a Transition Period is defined for phasing in rate changes just prior to the start of a new source data block. The frames transmitted during the Transition period are marked by the Tr bit set to 1, whilst all other frames have this bit set to 0. See the section Phasing in VCB Width Changes for further details.
Transparent Channels are not provided in this Example, since the HS network provides other more flexible mechanisms for transporting asynchronous data over a much wider range of data rates. See the section on Source Data Connections for more details on this.
-
- Source Data Field: This field of 112 bytes carries all the data for source data connections. See the section on Source Data Connections for further details.
- Error Protection: The HS frame as a whole is not protected by a parity bit in this example. However note that the source data contained within the Source Data field may have its own protection where necessary. Also note that the control message frames have their own protection. Other specific protections can be applied, as in the Double Speed network described above.
There are two block structures in D2B
-
- one associated with the transport of control messages
- one associated with the transport of source data
CF Block
As shown in
The control message frame is shown in
The control frame is assembled from and aligned with a block of 96 sub-frames, i.e. the first four bits of a new control frame are taken from the HS frame with a block preamble, and subsequent quartets of bits are taken from subsequent frames to build up a control frame. The fields of the control frame are as follows:
Arbitration bits: This four bit field is used to signal whether or not the current control message frame is free. It is also used to indicate the occupancy of the system master's control message reception Rx Buffer. The first two bits (bit 0 and bit 1) of the arbitration field are reserved. The second two bits indicate the functions listed in the table below.
-
- Destination Address: This is the 12-bit device address of the destination of the message, in the range ‘000’H to ‘FFF’H. The sending device writes this into its message transmit buffer for transmission. Certain addresses and address ranges have special meanings.
- Source Address: This is the 12-bit device address of the sender of the message, in the range ‘000’H to ‘FFF’H. The receiving device can read this from its message receive buffer after reception. Certain addresses and address ranges have special meanings.
- Message Type and Length: Two 4-bit fields normally used to indicate the type/length of the message. These bits are transported transparently by the transceiver to the application software.
- Data 0 to 15: The message data. All 16 bytes are always transported. The Message Length normally indicates how many of the 16 bytes are actually valid for the message. The sending device writes this into its message transmit buffer for transmission. The receiving device can read this from its message receive buffer after reception.
- CRC: A 16-bit Cyclic Redundancy Check value is used to verify that the control frame has been transported without error. The CRC is generated by the transceiver automatically on message transmission and checked by the transceiver automatically on message reception.
- ACK/NAK: Acknowledge and Not Acknowledge (2-bits each) indicate successful message transmission. The use of separate ACK and NAK flags allow re-liable point-to-point and broadcast message transport. The flags are automatically filled by the destination device(s) (if present) and read by the sending device.
- Reserved: 8 bits reserved.
The data is always transmitted and received LSB first in each field.
Source Data Block
As shown in
Fixed Synchronous connections carry a constant amount of source data in each frame regardless of the position of the frame within a Source Data Block and are thus not dependent on the source data block structure. The start of a block is indicated via the SDB bit in the header of the HS frame (See the Frame Structure in
(Note that the Source Data Block is not necessarily aligned with the CF block described in the previous section).
Line Encoding
The line coding scheme for the HS network is 4B/5B as described below. 4B/5B encoding provides an average of over 3 transitions per 5 bit symbol, to ensure easy clock recovery in the receiver. Run length is limited to less than or equal to five. The data is free of DC frequency.
Within the Sender, The HS network Frame is segmented into nibbles. Each nibble (4 bits) of an HS network Frame to be transmitted is translated into a 5 bit symbol and then NRZI encoded for transmission by the fibre optic transceiver (FOT) or other physical medium as shown in
At the receiver (
Each symbol of the 4B/5B code is composed of 5 bits. Of the 32 possible symbols, seventeen are valid in this implementation and 15 symbols are invalid. The 17 valid symbols represent sixteen 4 bit data nibbles (hex 0 through F) and one Escape (X) code. The Escape code is used in the preamble of the HS network frame (see the following section). The table below lists the 4-bit nibble to 5-bit symbol conversions.
Note: The binary value for 4-bit data nibble and 5-bit symbol encoded are shown as most significant bit first (i.e. at left).
Nibbles which contain null i.e. invalid data (e.g. padding) will be indicated via a special 5B value (‘10011’B). This nibble is repeated to form a null byte, providing robustness against data dislocation being introduced by bit errors.
Each bit of the 5 bits symbols produced by the 4B/5B encoding is further encoded such that ‘1’ is encoded as a transition (0 to 1 or 1 to 0) and ‘0’ is encoded as a lack of a transition. The serial data rate following NRZI encoding matches the serial data rate prior to the encoding, thus the use of NRZI encoding does not reduce the data transport capacity of HS network. Clock recover is enhanced, however.
Source Data Transport
The HS network can accommodate three different types of source data connections:
-
- Fixed-rate synchronous connections
- Fixed-rate asynchronous connections
- Variable-rate asynchronous connections
Fixed-Rate Connections
These are source data connections whose use of the source data capacity is fixed when the connection is set up and is guaranteed through the lifetime of the connection. This type of connection is suitable for fixed bit rate signals such as PCM audio. MPEG1 video. There are two types of fixed-rate connection: synchronous and asynchronous.
Synchronous Connections (Fixed-Rate)
These are connections which take full advantage of the raw synchronous rate provided by channels within the HS network source data field. There is no packet overhead associated with this type of connection and thus it is the most efficient use of system capacity subject to the limitation that the source must provide data at a rate which matches the system frame rate and the destination must be able to consume the data at exactly this rate. This type of connection could be use to transport PCM audio from a DAB receiver to an audio amplifier, for example, where the network is synchronised with the broadcast sample rate.
Asynchronous Connections (Variable or Fixed Rate)
Source data may be carried within a packet structure which allows the raw synchronous rate provided by channels within the HS network source data field to be adapted (padded) to data which requires delivery at some lower rate. The application may provide data for an asynchronous connection either at a constant rate or in bursts, subject to buffer capacities within the source and destination devices. The HS network also provides a mechanism for regulating the delivery of data over an asynchronous connection according to the demands of the destination rather than the source. For example a destination for CD-ROM data may consume data at a variable rate.
Where the bit-rate of data to be delivered over an asynchronous connection varies over a wide range e.g. by a megabit per second or more, a variable-rate connection should be used. This type of connection enables any spare capacity released by one variable connection to be made available to other variable connections which can make use of it. The flow control for these connections enables a destination to specify the rate (or range of rates) at which the source should deliver data to it.
Connection Set-Up
Source Data Connection protocols based on control messages are used for setting-up and removing connections. Whenever source data (e.g. digital audio or video) needs to be transported over the HS network, a source data connection must be established. This is called connection set-up. During the set-up, the required number of source data channels (bytes) are allocated from free capacity within the source data field of the HS network frame. For example, to carry a stereo audio signal from a CD player requires an allocation of 4 bytes (2*16 bit samples) per frame.
When all the frame's source data capacity has been allocated, attempts to build further connections will fail. When this happens, the System Master (or other AVC) must decide which existing connections (fixed or variable-rate) need to be removed to release enough capacity for any new connection. The System Master (AVC) is not aware of which parts of the source data field are allocated to which connections, since each device is responsible for managing the allocation in its own output link (ring segment). However, the System Master AVC can find out the type of source data delivered by a particular source, via a message sent via the control (CF) channel (the Source Data Type status request and report. The rules by which the AVC selects which connections to remove first are not specified in the network protocols, but form part of the Application.
For variable-rate connections, the connection set-up establishes a reserve allocation, although the actual allocation from source data block to source data block can be varied during the lifetime of the connection as described below in the section on Variable Connection Blocks. The reserve allocation of variable rate connections is used for the purpose of calculating whether there is sufficient capacity to build a new connection. This means that a new connection (variable or fixed) would not be built if it meant that a source would have to reduce the VCB width for a variable rate connection below this reserved width.
As shown in
Variable Connections
These are source data connection whose use of the source data capacity can be adjusted to meet the requirements of the application. Variable rate connections are asynchronous in general. The bit-rate provided by a variable rate connection depends on the number of source data bytes allocated to that connection within each frame, referred to as the width of the connection.
The format of data carried within a variable connection is a matter for the application. Padding inserted into the transmitted variable connection data using the Null data symbol at any time when there is no data available from the source (see
The bit-rate (i.e. the width of a variable connection) cannot be varied from HS frame to HS frame, it can only be changed on source data block boundaries (once per 2.25 millisecond at a frame rate of 48 kHz). Thus within a source data connection block, the width of a variable connection remains constant.
Referring to
The amount of data in a VCB is: VCB width*108 bytes (less the header size and any restriction imposed during the Transition Period, see Phasing In VCB Width Changes below). Thus by varying the width of the variable-rate connection (VC) from one source data block to another, the capacity allocated to a variable-rate connection can be varied, subject to the limit of the total capacity of the frame.
The VCB header indicates the VC width and a reference number for that connection (the VC ID). The contents of the Variable Connection Blocks are unprotected.
In the VCB Header (VCB HDR in
The VC width field indicates the number w of (consecutive) bytes allocated to this variable-rate connection within each frame, encoded such that 4 means 4 bytes, 5 means 5 bytes etc. The VCB width field can be set to a minimum of 4 for error protection purposes. When the VCB width field is set to 0, this indicates that the remainder of the variable connection part of the frame is free. Note that when a VCB has a width of zero in a source data block, e.g. because its destination cannot accept further data, the VC is not carried in the frame and therefore has no VCB header. The VC ID enables a receiving device to identify the connection whose data is carried by this block. BCH Encoding protection (31,16) is used to protect the preceding fields against up to 3 bit errors, allowing both detection and correction.
The Reserved field is for future extensions and should be set to zero.
Example Application
The example system shown in
Variable Rate Flow Control Mechanism
While a source device directly controls the rate which is allocated to its connection(s), the source device needs to receive feedback from the destination about the rate required to prevent the receiver's buffers from either becoming empty (a serious problem for real-time signals such as audio and video) or from overflowing (where the data is lost).
The HS network transceiver of Example IV provides a mechanism which enables the destination to report the minimum quantity of data that it requires to have delivered during the next block for the application to survive without interruption. The destination also reports the maximum amount of data that it can receive without its buffer overflowing. This latter information can be used to take advantage of spare capacity to spread the ‘load’ on the data transport capacity.
This mechanism enables the bus capacity to be shared fairly between a number of competing variable-rate connections according their requirements and their priority.
When variable-rate connections are to be used within the system, there needs to be a Signalling Channel established for the purpose of transporting messages for signalling the delivery rate requirements of the destinations of these connections. This connection signalling channel takes the form of a fixed-rate synchronous connection occupying at least 1 byte of each HS frame, within the Fixed Connection section of the frame. This channel exists around the entire ring. This signalling channel can be built as soon as the system has started up.
The Connection Signalling channel carries a packet, containing a message for each of the current variable-rate connections. The messages are created by their sources in the order in which those source devices are positioned in the D2B Optical ring and, in order of connection ID (VC ID) (where a device is a source of multiple connections).
For example, consider a system with 3 current connections: two from the device at ring position 1 (VC IDs 1 and 2) and one from a device at ring position 2 (VC ID 4). Within the Connection Signalling packet, the following messages are found in the order shown below:
-
- 1) Connection signalling message 1 (CSM1) from the source at ring position 1, with VC ID 1,
- 2) CSM2 from the same source, with VC ID 2,
- 3) CSM3 would be from a source at ring position 2, VC ID 4
The messages CSM1 to CSMn are then transmitted again to allow devices to see the completed messages (since the messages will have been modified by their destinations during their first pass around the ring). The modified messages will be referred to as CSM11 etc.
Devices are allocated a ring position, relative to the System Master, such that the System Master is at position 0, then in the direction of light propagation, the next device is at position 1 etc.
The Connection Signalling Packet format is shown in
The signalling channel thus carries a packet, with the following format (starting with the first byte following the start of a block). Note that for the transmission of the modified Connection Signalling Messages (CSM11, etc), the source device in each case must store all the fields it receives from its first message and then transmit these in the next available message slot. Note that no device is permitted to overwrite any of the fields in this repeated message: thus all devices will have a chance to see this message in its final state.
The Packet Header (CS_HDR) comprises:
The Packet Data comprises
-
- 0{<Connection Signalling Message>}n <padding>
Each Connection Signalling Message comprises:
The remaining bytes with the packet, following the connection signalling messages, are reserved and filled with padding. If 21 connection signalling messages are present (the maximum number), there are 2 remaining bytes.
Packet Type distinguishes the format of the CS packet from that of other types (incl. header). Packet ID indicates the nature of the message carried by this packet, i.e. connection signalling in this case. VC ID: matches the connection to which this message refers. A VC ID of 0 indicates that this message slot is unused. Priority of Connection Flag indicates whether the priority of this signal is real-time (high priority) or non-real time. If real-time, the flag is set to ‘3’ (high priority). Otherwise it is set to a value between ‘0’ and ‘2’.
Min VC width is written by the destination of the connection. It indicates the minimum width required for the specified VC within the next source data block to ensure that the destination's buffer will not be completely emptied. When a connection is not yet complete, this value remains 0, since there is no destination yet. When the connection is active, the minimum VCB width varies between 0 and the maximum width of an VCB. The first non-zero value written by the destination, following set-up of a connection, indicates the reserve capacity which should be allocated to this connection.
Max VC width. This field is also written by the destination of the connection. It indicates the maximum width required for the specified VC within the next Source data block to ensure that the destination's buffer will not overflow. The destination must calculate this requested maximum VC width on the buffer level expected at the end of the current source data block (in which it is making the request). This is to prevent the buffer overflowing. The destination will be able to calculate the expected buffer size from the VC width which has been allocated by the source within the current source data block. When a connection is not yet complete, this value remains 0, since there is no destination yet. When the connection is active, this width varies between 0 and maximum width of an VC. Width I is not allowed, due to the size of the VCB Header. In the event that the Max VC Width is less than the Min VC Width (only possible with multiple destinations), the Max VC Width takes precedence.
The Reserved field is for future extensions.
There is a limit (in the example mechanism) on the number of variable rate connections which can be supported simultaneously within a system, due to the size of the connection messages and the need to repeat the messages twice.
The limit may be calculated as follows:
-
- ((width of CS channel)*(108−Num. of frame buffers)−CS_Hdr size)/(CSM size*num. of transmissions).
The width of connection signalling channel is normally 1 byte. The size of the Connection Signal Channels packet header is 1 byte. The Number of frame buffers (latency) in the system is equal to twice the number of sources in the system (including System Master), since each source contributes two frame buffers to the system. The message size as defined is 3 bytes and there are two transmissions in the proposed mechanism (CSM plus CSM1). Thus, for a system containing 10 sources, the number of variable rate connections supported is:
(108−(10*2)−1)/9=87/9=9 (when rounded down to the nearest integer)
The destination supplies the rate requirement, by writing minimum and maximum VC widths into the appropriate connection signalling message fields, to enable the source device to decide how much bit rate capacity to allocate for the next Source Data block (108 frames). The destination also supplies its ring position. In the case where more than one destination is defined, a destination is allowed to overwrite a previous destination in ring order, under the following conditions: (I) the Ring position may be overwritten if the new destination is further from the source ; (II) the Minimum requirement may be overwritten if this destination has a higher minimum requirement; (III) the Maximum requirement may be overwritten if this destination has a lower maximum requirement.
Immediately after a variable-rate connection has been set-up, the destination is responsible for writing the reserve allocation requirement into the Minimum requirement field of the first connection signalling message for the new connection.
Connection signalling messages are modified by the relevant destinations during their first pass around the system. These connection signalling messages are transmitted again, in their modified form, by the sources which generated the original messages.
A source which is generating connection signalling messages must:
-
- wait for an unused connection signalling message location in the CS packet (indicated by VC ID=0) before transmitting a connection signalling message on its output (sending the message). This rule applies both to the original transmission and also to repeat transmissions.
- when it receives its own connection signalling message back after transmission, replace each byte of its own message with a byte containing 0 on its output. This frees the connection signalling channel for use by downstream sources.
For determining the rate to be allocated to an variable-rate connection, the source of each variable-rate connection must take into account both the requirements of the destination(s) of that connection and also requirements of the other source data connections with which the system capacity must be shared.
There are two stages to the process in this Example:
-
- a determination of which other source data connections must be taken into account
- a determination of how much capacity (rate) should be allocated to each of these competing connections
The source must consider all the source data connections (fixed as well as variable) which affect the capacity that can be allocated to its own variable-rate connections, since the system capacity must be shared between all of these connections. This can be done in various ways. The mechanism adopted in this example shall be referred to as a “Global Search”
In the Global Search method the source looks at the ring positions of sources and destinations for each of the other source data connections in the ring. It then analyses the overlap relation between each of these connection and its own connection: either direct overlaps or indirect (where a connection which overlaps this connection is itself overlapped by another connection. The ring positions of sources and destinations will be provided via a Connection Status reports in the Control message channel. One of these is broadcast by the System Master following successful completion of set-up for each source data connection.
The source data field capacity must be shared between all source data connections both fixed and variable-rate, with the fixed rate connections having a guaranteed share. If the capacity was unlimited, all destinations would be given the maximum capacity (Max VC width) that they have requested. However, since capacity is limited, the source applies an algorithm to share the available variable rate capacity between the competing connections in such a way that:
-
- there is the least risk of interrupting an application and
- the available system capacity is used very efficiently, allowing more simultaneous applications to be supported.
There are several Stages in the Sharing Calculation
1. Allocate the minimum requested capacity
-
- a) first to all the high priority connections in order of VC
- b) secondly to the lower priority Connections
2. Allocate the remaining capacity:
-
- a) weighted according to the remaining requested capacity for each connection (max-min); or
- b) round robin allocation of to each connection in turn; or
- c) allocation of the full requested capacity to each connection in turn
In Stage 1: (Allocation of Minimum Requested Capacity) the source device calculates the total available width (capacity) by forming the sum of all current VC widths and the free width.
The source device should ‘allocate’ the minimum requested width to each of the relevant connections,
-
- a) first, to high priority connections in the order in which they are represented in the signalling channel
- b) to low priority connections, in signalling channel order
This stage ends either when there is no remaining available capacity or when all relevant connections have been allocated their minimum requested capacity.
In Stage 2: (Allocation of Remaining Capacity) if any capacity remains following Stage 1, it will be allocated to the relevant connections, for example according to the alternative (c) above.
In this method the full requested allocation is given to each high priority connection in connection signal channel order until all the capacity is used or until all high priority connections have their full requested allocation (Max VC Width, including the allocation from Stage 1).
If any capacity remains, then it is allocated giving the full requested allocation to each low priority connection in connection signal channel order until all the capacity is used.
Each source may only set the width of its own VC, according to the allocation calculation described above. Further if the new width is less than the width in the current block, then the width reduction must be phased in. See the section Phasing in VC Width Changes. Each source removes the VCs for any destination which precedes it in ring order and shifts the higher VCs down to fill the gap left by the deleted VC(s) before repeating the frame to the following station.
Because of the presence of source data buffers (latency) distributed around the ring (whose number depends on the ring configuration), the changes in VC width cannot in general be completed within a single frame. Each source therefore starts making adjustments to meet the calculated VC size for the next Source Data Block at the start of an interval called the Transition Period. The Transition Period is the period during which the master is transmitting frames in the old source data block whose contents will be copied by the system master into the first frames of the new source data block.
Frames transmitted by the system master during the transition period are marked via the Tr bit in the HS network frame (
-
- All connection signalling messages must complete their final pass around the ring before the start of the Transition period. This means that the number of simultanvariable connections
- During a period equal to the transition period following the start of a new source data block, VCs whose size has increased contain only the same amount of data as the corresponding (smaller) VCs in the previous source data block. This only applies to the section of the ring between the Master and the source for that VC.
- The number of frames in the Transition Period is equal to the number of sources*2, where the system master is always counted as a source.
Example of Variable Rate Connections
In
In the example: Connection 1 (Source 1 to Destination 1) is for a compressed video signal (a real-time signal, therefore high priority); Connection 2 (Source 2 to Destination 2) is for map data from a CD-ROM (non-real time, therefore low priority); and Connection 3 (Source 3 to Destination 3) is compressed video (high priority).
Initialisation
Each connection is set-up with a reserve VC width determined by the expected rate or by the size of the free block, from which bytes are allocated for the new VC.
Suppose, for this example, that the total available width for VCs is 80 bytes (including the Free block), since the remaining bytes of the source data field have been allocated to the fixed-rate connections.
Actions of Source 1
Suppose that at the start of Source Data Block n,
-
- 1. Destination 1 decides that it needs a width which is a minimum of 5 and a maximum of 10 bytes. (This will lead to a delivery of between 510 and 1020 bytes during the Source data block, assuming that at least the minimum requested capacity is available.)
- 2. Destination 2 decides that it needs a width which is a minimum of 10 and a maximum of 50 bytes (VCB width).
- 3. Destination 3 decides that it needs a width which is a minimum of 20 and a maximum of 40 bytes (VCB width).
The calculations given above in stages 1 and 2 (alternative (a)) apply to the calculation in this example.
Source 1 is aware of the requirements of all these destinations and tries first to allocate the maximum requested widths (total 10+50+40=100), but finds that this exceeds the available width (80). Then source 1 allocates the minimum requested capacity to each connection (5+10+20=35) and then shares the remaining capacity (80−35=45) between the high priority connections (from Source 1 and Source 3), leading to an additional width of
-
- 5 for Source 1
- 40 for Source 2
- 0 for Source 3
- There is no remaining width
Finally source 1 calculates the VCB width for connection 1: 5+5=10 bytes. This change will be phased-in as described above.
Actions of Source 2
Source 2 will have received the same information from destinations 1,2,3. It will perform the same calculation as source 1, leading to a VCB width of 10+40=50 bytes which it will set for connection 2. This change will be phased-in in as described above.
Actions of Source 3
Source 3 will have received the same information from destinations 1,2,3. It will perform the same calculation as sources 1 and 2, leading to a VCB width of 20+0=20 bytes which it will set for connection 3. This change will be phased-in in as described above.
Free Capacity (Free)
The free capacity is treated as a Variable Connection (VC) with ID=0.
Fixed Connections (FC)
This last section of the source data field can be used to carry both synchronous signals e.g. 16 bit PCM audio at 48 kHz or asynchronous signals whose bit-rate is fixed. Changes to the contents and size of this block can only be made by setting up a new connection or removing an old connection.
Fixed-Rate Asynchronous Connections
A fixed-rate asynchronous connection carries unformatted source data, modified only by the insertion of padding (Null Symbols) to match the bit-rate of the connection to the requirements of the application.
Padding is inserted into an asynchronous connection whenever there is no data available from the source. The insertion of padding reduces the effective bit-rate of the connection to match the output from the source.
Flow Control
In some applications, the source is able to deliver data at a range of bit-rates and it is the destination which must regulate the bit-rate in order to avoid overflow and thus loss of data in the receiver. The flow control mechanism enables the receiver to feedback a stop/continue indicator to the source. The stop indicator forces the source to stop transmitting data and to fill the connection with padding until a continue indicator is received
When a fixed-rate asynchronous connection is built, the system allocates a single bit within a flow control connection byte to carry the a stop/continue indicator. The flow control connection is built around the ring from the System Master to the destination. The System Master may build this flow control connection any time after the system initialisation is complete following start-up.
The bits are allocated in connection ID order, when fixed-rate connections are set up. The bits are released when fixed-rate connections are removed, thus becoming available for use with new connections.
The following range of connection IDs apply to Fixed Asynchronous Connections:
-
- ‘20’H: Flow Control Connection
- ‘21’ . . . ‘30’H Fixed Asynchronous Connections.
Asynchronous Data Transmission Example
The ‘Empty’ indicator from the source's transmit (Tx) buffer together with the Flow Control Bit determine whether or not padding needs to be inserted into the transmitted FC datastream.
The ‘Full’ indicator from the destination's Receive (Rx) buffer is used to determine the state of the flow control bit. Note that the ‘full’ level has to be set to take into account the latency, as described below.
In the case where there are multiple destinations, the flow control outputs are OR-ed together in the same flow control bit. Thus the device whose buffer fills first will set the flow control bit to stop. If the application wishes to pause delivery to one particular destination, then the flow control output from that destination should be kept at ‘0’ (continue) so that data can continue to be delivered to the other destinations for that connection.
The following rules are observed by the Stations:
When the Source Buffer is not empty & the Destination Buffer is not full:
-
- [In the Source] Data is transferred from the Tx Buffer into the bytes allocated to the (fixed asynchronous connection) FC within the source data field of the HS network frame.
- [In the Destination] Data is copied from the bytes allocated to the FC within the source data field of the HS network frame into the Rx Buffer
When the Source Buffer is empty & the Destination Buffer is not full:
-
- [In the Source] No Data is transferred from the Tx Buffer, so padding is inserted into the bytes allocated to the FC within the source data field of the HS network frame.
- [In the Destination] Padding is recognised by the receiver and thus no data is into the Rx Buffer
When the Source Buffer is not empty & the Destination Buffer is nearly full:
-
- [In the Source] Data is transferred from the Tx Buffer into the bytes allocated to the FC within the source data field of the HS network frame.
- [In the Destination] Data is copied from the bytes allocated to the FC within the source data field of the HS NETWORK frame into the Rx Buffer. When the buffer reaches full (less an amount due to the latency), the destination sets the Flow Control bit to ‘1’ (meaning stop).
When the Source detects that the Flow Control is set to Stop:
-
- [In the Source] No Data is transferred from the Tx Buffer, so padding is inserted into the bytes allocated to the FC within the source data field of the HS network frame.
- [In the Destination] Padding is recognised by the receiver and thus no data is put into the Rx Buffer. When the buffer is no longer full, the receiver sets the corresponding Flow Control bit to ‘0’ (meaning continue).
When the Destination Buffer is no longer full:
-
- [In the Destination] The destination sets the Flow Control bit to ‘0’ (meaning stop).
When the Source detects that the Flow Control is set to Continue:
-
- [In the Source] Data is transferred from the Tx Buffer into the bytes allocated to the FC within the source data field of the HS network frame.
- [In the Destination] Data is copied from the bytes allocated to the FC within the source data field of the HS NETWORK frame into the Rx Buffer.
As in the example of the Double Speed network (
This means that the flow control bit (‘1’ means stop, ‘0’ means start/continue) needs to be asserted before the receiver buffer is full, taking into account the amount of data which will be received before the flow control takes effect. This depends on the number of bytes used per frame (for this connection) and on the number of devices with open source data bypasses in the system.
The total latency (in bytes) is:
L=(number of sources*2)*number of bytes in FC per frame,
where FC stands for Fixed Asynchronous Connection and the System Master is always counted as a source.
This latency can be measured by the System Master when the system starts up, by counting the number of frames which elapse between transmission and reception of the frame containing the start of a source data block (indicated by the SDB bit set to 1 in the HS NETWORK frame header). The System Master then marks this number of frames at the end of the source data block with the Transition Period flag Tr set to 1.
Pack/Packet/Cell Hierarchy
The contents of a source data connection, either fixed or variable, are determined by the application.
-
- L . . . indicates that the first cell of a packet is not necessarily the first cell of a connection block (FCB or VCB).
- M . . . A packet must contain at least one cell and may contain a number of cells (given by M−L+1)
- P . . . The number of packets in a pack is defined by the application within the limits imposed by the Remaining packets field in the cell header: up to 256 packets/pack are supported.
A packet of source data may occupy an integral number of cells. The packets themselves may also be part of a pack as shown in
The cell provides framing to allow a device receiving the data to identify the data and recover it correctly.
The Cell Header comprises:
The Start of Packet flag indicates whether the first data byte of this cell is also the first byte of a packet (flag set to 1) or whether it is a continuation of a packet. The Packet Type identifies the remaining format of the cell. Cell type 0 indicates an unoccupied cell, i.e. no packet data. Remaining Packets indicates the number of packets remaining within the current pack (group of packets). Number of Bytes in Cell indicates the number of bytes in this cell which contain valid data. The Error Protection field use is currently undefined.
The data 102 bytes contained in the cell is unprotected against errors
The start of the packet is indicated by the Start of Packet bit (set to ‘1’ ) in the cell header. When this bit is set, the first byte of data following the cell header is also the first byte of the packet data (as opposed to being a continuation of a previous packet). When this bit is not set, it indicates that the contents of this cell are a continuation of a packet sent in the previous cell.
The number of HS frames required for transmission of a cell is a function of the size of the cell (108 bytes) and the width of its containing FC in each HS Frame. If the FC is n bytes wide then the cell will encompass (108)/n HS frames. Note that this calculation applies only to Fixed Connection blocks, since VCB have a reduced capacity during the transition period.
High Speed Network EXAMPLE VThe fifth example of the High Speed network corresponds closely to Example IV described above, but the frame structure is modified to reduce the number of bits per frame from 912 to 900. Taking into account the frame rate of 48 kHz, and taking into account the 25% overhead due to 4B/5B coding, this gives a gross rate of 54 MHz. compared with 54.72 MHz, for Example IV. This change may simplify docking of the transceiver in relation to DVD sources, for example, since 54 MHz and 27 MHz are standard master clocks for such digital video systems.
Change from 912 to 900 bits is achieved by reducing the number of source data bytes from 112 to 110. Spare capacity of four bits per frame is thus released, and can be used to increase the capacity of the control message channel (CF bits) from four bits per frame to eight bits per frame. To retain compatibility with the control channel of the D2B Optical Network, however, it is proposed that the eight CF bits should be regarded as two separate groups of four, providing in effect two independent control message channels.
Other changes in frame structure, the order of fields and so on are of course possible without departing from the principles of the invention in its various aspects.
Claims
1-65. (canceled)
66. A method for allocating capacity among a plurality of desired connections over a network wherein stations of the network communicate to one another their requirements for network capacity, and each station responsible for establishing a respective connection performs a calculation to allocate to that connection a certain capacity, the calculation being performed by all such stations using a common set of rules so as to arrive at a consistent allocation of capacity between the connections.
67. A method as in claim 66, wherein the responsible station for each connection is the source station for that connection.
68. A method as in claim 66 wherein connection signalling messages are exchanged in advance of said calculation, such that each responsible station knows the constraints imposed by at least other connections which overlap the given connection.
69. A method as in claim 66 wherein each connection carrying data from a first station designated as source for that connection to at least one second station designated as destination connection, the method further comprising:
- generating for each connection a connection signalling message indicating a required capacity for the connection;
- receiving the connection signalling messages for the plurality of connections;
- determining a suitable allocation of capacity for each connection by a calculation based on the indicated required capacities and an available total capacity;
- establishing each desired connection with the determined allocation,
- wherein steps (b), (c), and (d) are performed independently at each first station following predetermined rules.
70. A method as in claim 68, wherein the connection signalling messages are generated at least partially by the station designated as source for the connection.
71. A method as in claim 68, wherein the connection signalling messages are generated at least partially by the station designated as destination for the connection.
72. A method as in claim 71, wherein a connection signalling message is generated by the source station, modified by the destination station, and read by other source stations to obtain the necessary information for the calculation.
73. A method as in claim 72, wherein the network is a ring network comprising a series of point-to-point links, and the modified message is received by the source station and repeated around the ring to ensure that all responsible stations have the necessary information.
74. A method as in claim 66, wherein the allocation is re-calculated and varied from time to time.
75. A method as in claim 68, wherein the connection signalling messages are exchanged via a dedicated channel established at least for the duration of the associated connections.
76. A method as in claim 67, wherein the network comprises a series of station-to-station links and wherein the rules for allocating capacity to a given connection are defined so as to consider only connections which overlap the given connection.
77. A method as in claim 71, wherein the network comprises a series of station-to-station links and wherein the rules for allocating capacity to a given connection are defined so as to consider not only connections which overlap the given connection on one or more of said links but also further connections which overlap those connections without overlapping the given connection.
78. A method as in claim 68 wherein a first rule is defined so as to ensure a minimum capacity specified in the flow control message at least for each connection of a certain priority, and further rules are specified to distribute remaining capacity among the connections.
79. A method as in claim 78 wherein said further rules take account of a maximum capacity specified in the flow control message for each connection.
80. A method as in claim 69 wherein steps (a)-(d) are repeated periodically to cause adaptive allocation of capacity between connections.
81. A method as in claim 66 wherein a plurality of stations interchange data via a network in accordance with a plurality of logical connections, each connection carrying data from a first station designated as source for that connection to at least one second station designated as destination for that connection, such data being subject to a delay at one or more intervening stations relative to a frame sequence of the ring network, the method comprising:
- (a) defining a succession of rate control periods;
- (b) determining in advance of a first rate control period a first channel width for each of the plurality of connections, the first channel width determining a maximum data rate for the corresponding connection;
- (c) during said first rate control period establishing a respective channel for each connection in accordance with the determined first channel width; and
- (d) during said first rate control period transmitting data for each connection via the respective channel at a rate up to said maximum data rate;
- (e) determining in advance of a next rate control period a new channel width for each of the plurality of connections, the new channel width determining a new maximum data rate for the corresponding connection for said next rate control period; and
- (f) repeating steps (b) to (e) for said succession of rate control periods,
- wherein a rate transition period corresponding to said delay is included at the end of each rate control period and, in the event that the new channel width determined in step (e) is reduced relative to the first channel width, data is transmitted in step (d) only up to said new maximum rate during said rate transition period.
82. A method as in claim 81 wherein data transfer via the network is performed in a regular sequence of frames, each frame having a plurality of data fields for allocation to different said connections, each connection occupying the same data field or fields throughout each rate control period.
83. A method as in claim 82, wherein each rate control period and each transition period correspond to a predetermined number of frames.
84. A method as in claim 81, wherein the frame structure further includes a flag field for indicating the transition period.
85. A method as in claim 81, wherein the frame structure further includes a flag field for indicating the start of each rate control period.
86. A local communication system comprising a network conveying source data in variable channels, wherein capacity is allocated plurality of desired connections over a shared network medium, wherein stations of the network communicate to one another their requirements for network capacity, and each station responsible for establishing a respective connection performs a calculation to allocate to that connection a certain capacity, the calculation being performed by all such stations using a common set of rules so as to arrive at a consistent allocation of capacity between the connections.
87. A system as in claim 86, wherein the responsible station for each connection is the source station for that connection.
88. A system as in claim 86 wherein connection signalling messages are exchanged in advance of said calculation, such that each responsible station knows the constraints imposed by at least other connections which overlap the given connection.
89. A local communication system as in claim 86 wherein a plurality of stations interchange data via a network medium, wherein capacity is allocated among a plurality of connections, each connection carrying data from a first station designated as source for that connection to at least one second station designated as destination connection, the system comprising:
- (e) means for generating for each connection a connection signalling message indicating a required capacity for the connection;
- (f) means for receiving the connection signalling messages for the plurality of connections;
- (g) means for determining a suitable allocation of capacity for each connection by a calculation based on the indicated required capacities and an available total capacity;
- (h) means for establishing each desired connection with the determined allocation,
- wherein means (b), (c), and (d) are independently operable at each first station following predetermined rules.
90. A local communications system wherein a plurality of stations interchange data via a network in accordance with a plurality of logical connections, each connection carrying data from a first station designated as source for that connection to at least one second station designated as destination for that connection, such data being subject to a delay at one or more intervening stations relative to a frame sequence of the ring network, the system comprising:
- (a) means for defining a succession of rate control periods;
- (b) means for determining in advance of a first rate control period a first channel width for each of the plurality of connections, the first channel width determining a maximum data rate for the corresponding connection;
- (c) means for during said first rate control period establishing a respective channel for each connection in accordance with the determined first channel width; and
- (d) means for during said first rate control period transmitting data for each connection via the respective channel at a rate up to said maximum data rate;
- (e) means for determining in advance of a next rate control period a new channel width for each of the plurality of connections, the new channel width determining a new maximum data rate for the corresponding connection for said next rate control period; and
- (f) means for repeating steps (b) to (e) for said succession of rate control periods,
- wherein a rate transition period corresponding to said delay is included at the end of each rate control period and, in the event that the new channel width determined by means (e) is reduced relative to the first channel width, data is transmitted by means (d) only up to said new maximum rate during said rate transition period.
91. A network interface circuit for use in interfacing a station to a local communication system as in claim 86, each station being connected between successive segments of the network, the interface comprising means operable to connect the station between first and second segments of the network.
92. An apparatus for use as a station in a local communication system, the apparatus comprising at least one functional unit and a network interface circuit as in claim 91.
93. An apparatus as in claim 92 wherein said functional unit comprises a source or destination of audio data.
94. A local communication system comprising a network conveying source data in variable rate channels, by means of a regular frame structure, each frame providing a fixed number of source data fields, wherein each field can be reserved dynamically to form part of a variable rate channel whose width varies during the life time of the relevant connection, and wherein, when a plurality of variable rate channels of non-zero width are established, each frame carries at least some data for every channel.
95. A local communication system as claimed in claim 94 wherein a plurality of stations interchange data via said network by means of said regular frame structure, and wherein a block of plural frames is established for the allocation of source data fields between a plurality of channels, the allocation being variable between blocks, wherein each successive station wishing to reserve an allocation of capacity places a header in a free field of the first frame in a given block, the header indicating directly or indirectly a next free field in accordance with the number of fields per frame reserved by the source device for its channel, each successive source station in the network inserting its header to reserve an allocation of fields for the duration of the block at the free field position indicated by said header, such that fields are allocated to channels contiguously within each frame.
96. A local communication system as in claim 95 wherein a block of plural frames is established for the allocation of source data fields between a plurality of connections, wherein each station acting as a source station for a connection reserves an allocated number of fields in each frame, and wherein each source station is responsible for removing the allocation of fields to a connection whose furthest destination station precedes the source in network position.
97. A local communication system as in claim 94 wherein each field can be reserved dynamically to form part of a fixed rate channel which uses the same fields in each frame for the duration of a connection, and at other times can be allocated to form part of a variable rate channel whose width varies during the life time of the relevant connection.
98. A local communication system as in claim 94 wherein the network is a ring network.
99. A method of communication between stations in a network, wherein plural variable rate channels are established in a common frame structure, by allocating the same fields of each frame to a given channel throughout a block of frames, adapting the allocation of fields to channels for each successive block of frames.
100. A method as in claim 99 wherein there is further provided a method for allocating capacity among a plurality of desired connections over a shared network medium, wherein stations of the network communicate to one another their requirements for network capacity, and each station responsible for establishing a respective connection performs a calculation to allocate to that connection a certain capacity, the calculation being performed by all such stations using a common set of rules so as to arrive at a consistent allocation of capacity between the connections.
101. A method as in claim 99 each connection carrying data from a first station designated as source for that connection to at least one second station designated as destination connection, the method comprising:
- generating for each connection a connection signaling message indicating a required capacity for the connection;
- receiving the connection signaling messages for the plurality of connections;
- determining a suitable allocation of capacity for each connection by a calculation based on the indicated required capacities and an available total capacity;
- establishing each desired connection with the determined allocation,
- wherein steps (b), (c), and (d) are performed independently at each first station following predetermined rules.
102. A method as in claim 101, wherein a connection signalling message is generated by the source station, modified by the destination station, and read by other source stations to obtain the necessary information for the calculation.
103. A method as in claim 100, wherein the connection signalling messages are exchanged via a dedicated channel established at least for the duration of the associated connections.
104. A method as in claim 100, wherein the network comprises a series of station-to-station links and wherein the rules for allocating capacity to a given connection are defined so as to consider only connections which overlap the given connection.
105. A method as in claim 100, wherein the network comprises a series of station-to-station links and wherein the rules for allocating capacity to a given connection are defined so as to consider not only connections which overlap the given connection on one or more of said links but also further connections which overlap those connections without overlapping the given connection.
106. A method as in claim 100 wherein a first rule is defined so as to ensure a minimum capacity specified in the flow control message at least for each connection of a certain priority, and further rules are specified to distribute remaining capacity among the connections.
107. A method as in claim 106 wherein said further rules take account of a maximum capacity specified in the flow control message for each connection.
108. A method as in claim 101 wherein steps (a)-(d) are repeated periodically to cause adaptive allocation of capacity between connections.
109. A method of communication as in claim 99 wherein a plurality of stations interchange data via a network in accordance with a plurality of logical connections, each connection carrying data from a first station designated as source for that connection to at least one second station designated as destination for that connection, such data being subject to a delay at one or more intervening stations relative to a frame sequence of the network, the method comprising:
- (a) defining a succession of rate control periods;
- (b) determining in advance of a first rate control period a first channel width for each of the plurality of connections, the first channel width determining a maximum data rate for the corresponding connection;
- (c) during said first rate control period establishing a respective channel for each connection in accordance with the determined first channel width; and
- (d) during said first rate control period transmitting data for each connection via the respective channel at a rate up to said maximum data rate;
- (e) determining in advance of a next rate control period a new channel width for each of the plurality of connections, the new channel width determining a new maximum data rate for the corresponding connection for said next rate control period; and
- (f) repeating steps (b) to (e) for said succession of rate control periods,
- wherein a rate transition period corresponding to said delay is included at the end of each rate control period and, in the event that the new channel width determined in step (e) is reduced relative to the first channel width, data is transmitted in step (d) only up to said new maximum rate during said rate transition period.
110. A method as in claim 109 wherein data transfer via the network is performed in a regular sequence of frames, each frame having a plurality of data fields for allocation to different said connections, each connection occupying the same data field or fields throughout each rate control period.
111. A method as in claim 110, wherein each rate control period and each transition period correspond to a predetermined number of frames.
112. A method as in claim 109, wherein the frame structure further includes a flag field for indicating the transition period.
113. A method as in claim 109, wherein the frame structure further includes a flag field for indicating the start of each rate control period.
114. A network interface circuit for use in interfacing a station to a local communication system as in claim 94, each station being connected between successive segments of the network, the interface comprising means operable to connect the station between first and second segments of the network.
115. An apparatus for use as a station in a local communication system, the apparatus comprising at least one functional unit and a network interface circuit as in claim 114.
116. An apparatus as in claim 115 wherein said functional unit comprises a source or destination of audio data.
Type: Application
Filed: Feb 22, 2005
Publication Date: Jul 14, 2005
Applicant: Communication & Control Electronics Limited (Surrey)
Inventors: Andrew Stirling (Surrey), Simon Pendergast (Devon), Harivaden Parmar (Wokingham)
Application Number: 11/061,930