A method of transmitting OSI layer 2 datacoms data by direct incorporation into a plurality of synchronous digital hierarchy virtual containers is disclosed, in which a higher bit rate OSI layer 2 data frame is multiplexed into a plurality of lower bit rate SDH (or SONET) virtual containers, which are transmitted simultaneously and in parallel over a synchronous communications network. The plurality of virtual containers are virtually concatenated by association of the payloads of the plurality of virtual containers. Re-assembly of the OSI layer 2 data frames from a plurality of virtually concatenated VCs is achieved by storing each received VC payload corresponding to an OSI layer 2 data frame in a corresponding respective memory location, and alternately reading interleaved bytes from the plurality of payloads under control of a plurality of read pointers.
|
0. 48. A method of recovering data from a plurality of virtual containers received over a synchronous digital network, said method comprising the steps of:
receiving said plurality of virtual containers each said virtual container having a payload section and a path overhead section;
reading association data from said path overheads of said plurality of virtual containers, said association data indicating an association between said plurality of virtual containers;
reading data bytes from said payloads of said plurality of associated virtual containers; and
re-assembling said data from said plurality of read payload data bytes in response to said indicated association.
0. 60. A method of recovering a data block carried in payloads of a plurality of streams of virtual containers of a synchronous digital network, said method comprising steps of:
reading association data from path overheads of virtual containers of each of said plurality of streams, said association data indicating an association between said plurality of virtual containers;
allocating a respective memory area for storage of payloads of virtual containers of each said stream;
storing virtual container payloads in said respective memory areas in dependence on said association; and
reading individual bytes of said plurality of stored virtual container payloads in sequence to recover said data block.
0. 56. A method of recovering data frames carried in payloads of a plurality of virtual containers of a synchronous digital network, said method comprising the steps of:
for each said virtual container: reading association data from a path overhead of said virtual container, said association data indicating an association between said virtual container and other ones of said plurality of virtual containers;
allocating a memory storage area for storing a payload of said virtual container; inputting said virtual container payload into said memory area; and reading data from said memory area in parallel with data read from other memory areas corresponding to payloads of other ones of said plurality of virtual containers, thereby to recover said data frames.
0. 63. Apparatus for recovering data from a plurality of virtual containers of a synchronous digital network, said apparatus comprising:
a random access memory configured into a plurality of individual memory areas allocated for storage of payloads of said plurality of virtual containers;
a data processor operating to read association data from path overheads of each of said virtual containers, said association data indicating an association between said plurality of virtual containers; and
a data processor arranged to generate read pointers for each said plurality of individual memory areas, said read pointers enabling data to be read from a plurality of memory locations of said memory areas, thereby to recover said data from said plurality of virtual containers, said read pointers being generated in dependence on said association data.
0. 43. Apparatus for preparing data for transmission over a synchronous digital network, said apparatus comprising:
a virtual container generator arranged to generate in parallel a plurality of virtual containers, each to be transmitted over said synchronous digital network at a lower bit rate than a bit rate of said data to be transmitted, each said virtual container having a payload section and a path overhead section;
a virtual container associator arranged to associate said plurality of virtual containers with each other by means of inputting association data into said path overheads of said plurality of virtual containers; and
a data inputter arranged to input said data to be transmitted into said payloads of said plurality of virtual containers,
wherein said data inputter is arranged to byte interleave bytes of a frame of said data to be transmitted between said payloads.
0. 55. A method of recovering data from a plurality of virtual containers received over a synchronous digital network, said method comprising the steps of:
receiving said plurality of virtual containers each said virtual container having a payload section and a path overhead section;
reading association data from said path overheads of said plurality of virtual containers, said association data indicating an association between said plurality of virtual containers;
reading data bytes from said payloads of said plurality of associated virtual containers; and
re-assembling said data from said plurality of read payload data bytes in response to said indicated association, wherein said association data comprises sequence identification data designating where in a sequence of virtual containers an individual virtual container belongs, and wherein said sequence identification data is read from a K3 byte of each of said plurality of virtual containers.
0. 44. Apparatus for preparing data for transmission over a synchronous digital network, said apparatus comprising:
a virtual container generator arranged to generate in parallel a plurality of virtual containers, each to be transmitted over said synchronous digital network at a lower bit rate than a bit rate of said data to be transmitted, each said virtual container having a payload section and a path overhead section;
a virtual container associator arranged to associate said plurality of virtual containers with each other by means of inputting association data into said path overheads of said plurality of virtual containers; and
a data inputter arranged to input said data to be transmitted into said payloads of said plurality of virtual containers, wherein said virtual container generator is arranged to generate said plurality of virtual containers as a plurality of streams of virtual containers, and said virtual container associator is arranged to associate said plurality of virtual containers with each other by associating said plurality of streams of virtual containers with each other.
0. 45. Apparatus for preparing data for transmission over a synchronous digital network, said apparatus comprising:
a virtual container generator arranged to generate in parallel a plurality of virtual containers, each to be transmitted over said synchronous digital network at a lower bit rate than a bit rate of said data to be transmitted, each said virtual container having a payload section and a path overhead section;
a virtual container associator arranged to associate said plurality of virtual containers with each other by means of inputting association data into said path overheads of said plurality of virtual containers; and
a data inputter arranged to input said data to be transmitted into said payloads of said plurality of virtual containers, wherein said virtual container generator is arranged to generate said plurality of virtual containers as a plurality of streams of virtual containers, and virtual container associator is arranged to associate said plurality of virtual containers with each other by inputting stream identification data into each said virtual container, said steam identification data identifying which of said plurality of streams said virtual container belongs to.
0. 34. A method of preparing data for transmission over a synchronous digital network, said method comprising the steps of:
generating in parallel a plurality of virtual containers, each to be transmitted over said synchronous digital network at a lower bit rate than a bit rate of said data to be transmitted, each said virtual container having a payload section and a path overhead section;
associating said plurality of virtual containers with each other by means of inputting association data into said path overheads of said plurality of virtual containers; and
inputting said data to be transmitted into said payloads of said plurality of virtual containers,
wherein said plurality of virtual containers are generated as a plurality of streams of virtual containers and said step of associating said plurality of virtual containers together by means of inputting association data comprises inputting sequence identification data to each said plurality of virtual containers, said sequence identification data designating a sequence in which said individual virtual containers are, generated with respect to each other,
and wherein said sequence identification data is input into a K3 byte of each said virtual container.
0. 42. A method of preparing data for transmission over a synchronous digital network, said method comprising the steps of:
generating in parallel a plurality of virtual containers, each to be transmitted over said synchronous digital network at a lower bit rate than a bit rate of said data to be transmitted, each said virtual container having a payload section and a path overhead section;
associating said plurality of virtual containers with each other by means of inputting association data into said path overheads of said plurality of virtual containers; and
inputting said data to be transmitted into said payloads of said plurality of virtual containers, wherein data indicating the time at which each virtual container was generated relative to other associated virtual containers is provided by a sequence marker for each virtual container, and wherein the maximum differential delay expected between virtual containers at a destination in said synchronous digital network determines the number of frames over which a sequence marker must increment before it is repeated, the sequence marker being incremented every 2N+1 frames wherein N is the number of frames generated in a time equivalent to the maximum differential delay.
0. 46. Apparatus for preparing data for transmission over a synchronous digital network, said apparatus comprising:
a virtual container generator arranged to generate in parallel a plurality of virtual containers, each to be transmitted over said synchronous digital network at a lower bit rate than a bit rate of said data to be transmitted, each said virtual container having a payload section and a path overhead section;
a virtual container associator arranged to associate said plurality of virtual containers with each other by means of inputting association data into said path overheads of said plurality of virtual containers; and
a data inputter arranged to input said data to be transmitted into said payloads of said plurality of virtual containers, wherein said virtual container generator is arranged to generate said plurality of virtual containers as a plurality of streams of virtual containers, and virtual container associator is arranged to associate said plurality of virtual containers with each other by inputting sequence identification data into each said plurality of virtual containers, said sequence identification data designating a sequence in which said individual virtual containers are generated with respect to each other.
0. 68. A method of transporting data over a synchronous digital network, said method comprising the steps of:
generating in parallel a plurality of virtual containers, each at a lower bit rate than bit rate of said data, each said virtual container having a payload section;
associating said plurality of virtual containers with each other by means of assigning association data describing said association into said plurality of virtual containers;
indicating for each virtual container a time at which each virtual container was generated relative to other associated virtual containers;
inputting said transported data into said payloads of said plurality of virtual containers; and
outputting said plurality of associated virtual containers onto a synchronous digital network,
wherein data indicating a time at which each virtual container was generated relative to other associated virtual containers is incorporated over several virtual containers by utilizing one or more bits from each successive virtual container of an association of virtual containers,
and wherein the data indicating a time at which each virtual container was generated relative to other associated virtual containers is incorporated over several virtual containers by utilizing one or more bits from the overhead each successive virtual container of an association of virtual containers.
0. 67. A method of transporting data over a synchronous digital network, said method comprising the steps of:
generating in parallel a plurality of virtual containers, each at a lower bit rate than bit rate of said data, each said virtual container having a payload section;
associating said plurality of virtual containers with each other by means of assigning association data describing said association into said plurality of virtual containers;
indicating for each virtual container a time at which each virtual container was generated relative to other associated virtual containers;
inputting said transported data into said payloads of said plurality of virtual containers; and
outputting said plurality of associated virtual containers onto a synchronous digital network,
wherein data indicating a time at which each virtual container was generated relative to other associated virtual containers is incorporated over several virtual containers by utilizing one or more bits from each successive virtual container of an association of virtual containers
and wherein the data indicating a time at which each virtual container was generated relative to other associated virtual containers is incorporated over several virtual containers by utilizing one or more bits from the payload of each successive virtual container of an association of virtual containers.
0. 41. A method of preparing data for transmission over a synchronous digital network, said method comprising the steps of:
generating in parallel a plurality of virtual containers, each to be transmitted over said synchronous digital network at a lower bit rate than a bit rate of said data to be transmitted, each said virtual container having a payload section and a path overhead section;
associating said plurality of virtual containers with each other by means of inputting association data into said path overheads of said plurality of virtual containers; and
inputting said data to be transmitted into said payloads of said plurality of virtual containers,
wherein said plurality of virtual containers are generated as a plurality of streams of virtual containers and said step of associating said plurality of virtual containers together by means of inputting association data comprises inputting sequence identification data to each said plurality of virtual containers, said sequence identification data designating a sequence in which said individual virtual containers are generated with respect to each other,
wherein said sequence identification data comprises a cyclically repeating code, and wherein said cyclically repeating code sequence has a repetition period of at least 2 N+1, where N is the number of frames generated in a period of time equivalent to a maximum differential delay expected between virtual containers.
0. 1. A method of transporting data preparing data for transmission over a synchronous digital network, said method comprising the steps of:
generating in parallel a plurality of synchronous virtual containers, each to be transmitted over said synchronous digital network at a lower bit rate than a bit rate of said data to be transmitted, each said virtual container having a payload section and a path overhead section;
associating said plurality of virtual containers with each other by means of inputting assigning association data describing said association into said path overheads of said plurality of virtual containers; and
inputting said transported data to be transmitted into said payloads of said plurality of virtual containers; and
outputting said plurality of associated virtual containers onto a synchronous digital network.
0. 2. The method as claimed in
0. 3. The method as claimed in
0. 4. The method as claimed in
0. 5. The method as claimed in
0. 6. The method as claimed in
0. 7. The method as claimed in
0. 8. The method as claimed in
0. 9. The method as claimed in
0. 10. The method as claimed in
0. 11. The method as claimed in
0. 12. The method as claimed in
0. 13. A method as claimed in
0. 14. The method as claimed in
0. 15. Apparatus for incorporating data input at a first data rate into a plurality of streams of synchronous digital hierarchy virtual containers each output at a second data rate, said apparatus comprising:
means for continuously generating a plurality of virtual containers in parallel;
means for generating data describing an association of said plurality of virtual containers, and for assigning said association data to said plurality of associated virtual containers; and
means for inserting said first data rate data into said plurality of payloads of said plurality of virtual containers. Apparatus for preparing data for transmission over a synchronous digital network, said apparatus comprising:
a virtual container generator arranged to generate in parallel a plurality of synchronous virtual containers, each to be transmitted over said synchronous digital network at a lower bit rate than a bit rate of said data to be transmitted, each said virtual container having a payload section and a path overhead section;
a virtual container associator arranged to associate said plurality of virtual containers with each other by means of inputting association data into said path overheads of said plurality of virtual containers; and
a data inputter arranged to input said data to be transmitted into said payloads of said plurality of virtual containers.
0. 16. A method of recovering data from a plurality of synchronous virtual containers received over a synchronous digital network, said method comprising the steps of:
receiving said plurality of virtual containers each said virtual container having a payload section and a path overhead section;
reading identifying associating data from said path overheads of said plurality of virtual containers, said association data indicating an association between individual ones of said plurality of virtual containers;
reading data bytes from each said payloads of said plurality of associated virtual containers; and
re-assembling said data from said plurality of read payload data bytes in response to said indicated association.
0. 17. The method as claimed in
0. 18. The method as claimed in
0. 19. The method as claimed in
0. 20. The method as claimed in
0. 21. The method as claimed in
0. 22. The method as claimed in
0. 23. A method of recovering data frames carried in payloads of a plurality of associated synchronous digital hierarchy virtual containers of a synchronous digital network, said method comprising the steps of:
for each said virtual container:
reading data association data from a path overhead of said virtual container, said association data indicating an association between said virtual container and other ones of said plurality of virtual containers
allocating a memory storage area for storing a payload of said virtual container;
inputting said virtual container payload into said memory area; and
reading said data from said memory area in parallel with data read from other said memory areas corresponding to payloads of other said virtual containers ones of said plurality of virtual containers, thereby to recover said data frames.
0. 24. The method as claimed in
for each said memory area, setting a read pointer to a memory location of said memory area;
wherein said plurality of read pointers are set to said memory locations such that successive bytes of said data frame are read from said plurality of memory locations in sequence.
0. 25. The method as claimed in
0. 26. The method as claimed in
0. 27. A method of recording a data block carried in payloads of a plurality of streams of payloads of a plurality of associated synchronous digital hierarchy virtual containers of a synchronous digital network, said method comprising steps of:
receiving a plurality of streams of said plurality of associated virtual containers;
reading association data from path overheads of virtual containers of each of said plurality of streams, said association data indicating an association between said plurality of virtual containers;
for each said received virtual container stream allocating a corresponding respective memory area for storage of data payloads of virtual containers of each said stream;
storing said plurality of virtual container payloads in said corresponding allocated respective memory areas in dependence on said association; and
reading individual bytes of said plurality of stored virtual container data payloads in sequence to reconstruct recover said data block.
0. 28. The method as claimed in
for each said memory area, setting a read pointer to a memory location corresponding to a next data byte of said data block to be read, contained within that data payload; and
reading said data byte once a preceding data byte of said data block has been read from a memory location of another said memory area.
0. 29. The method as claimed in
0. 30. Apparatus for recovering data from a plurality of synchronous digital hierarchy virtual containers of a synchronous digital network containing said data, said means apparatus comprising:
a random access memory configured into a plurality of individual memory areas allocated for storage of payloads of said plurality of virtual containers;
a data processor means operating to identify an read association data from path overheads of each of said virtual containers, said association data indicating an association of between said plurality of virtual containers; and
a data processor arranged to generate means for generating a plurality of read pointers for each said plurality of individual memory areas, said read pointers enabling data to be read from a operating to successively read a plurality of memory locations of said memory areas, thereby to recover said for recovering said data from said plurality of virtual containers, said read pointers being generated in dependence on said association data.
0. 31. A method of transporting data over a synchronous digital network, said method comprising the steps of:
generating in parallel a plurality of synchronous virtual containers, each at a lower bit rate than a bit rate of said data, each said virtual container having a payload section;
associating said plurality of virtual containers with each other by means of assigning association data describing said association into said plurality of virtual containers;
indicating for each virtual container the time at which each virtual container was generated relative to other associated virtual containers;
inputting said transported data into said payloads of said plurality of virtual containers; and outputting said plurality of associated virtual containers onto a synchronous digital network,
wherein data indicating the time at which each virtual container was generated relative to other associated virtual containers is incorporated over several virtual containers by utilizing one or more bits from each successive virtual container of an association of virtual containers.
0. 32. A method as claimed in
0. 33. A method as claimed in
0. 35. The method as claimed in
0. 36. The method as claimed in
0. 37. The method as claimed in
0. 38. The method as claimed in
0. 39. The method as claimed in
0. 40. A method as claimed in
0. 47. The apparatus as claimed in
0. 49. The method as claimed in
0. 50. The method as claimed in
0. 51. The method as claimed in
0. 52. The method as claimed in
0. 53. The method as claimed in
0. 54. The method as claimed in
0. 57. The method as claimed in
for each said memory area, setting a read pointer to a memory location of said memory area;
wherein said read pointers are set to said memory locations such that successive bytes of said data frame are read from said memory locations in sequence.
0. 58. The method as claimed in
0. 59. The method as claimed in
0. 61. The method as claimed in
for each said memory area, setting a read pointer to a memory location corresponding to a next data byte of said data block to be read, contained within that data payload; and
reading said data byte once a preceding data byte of said data block has been read from a memory location of another said memory area.
0. 62. The method as claimed in
0. 64. The apparatus as claimed in
0. 65. The apparatus as claimed in
0. 66. The apparatus as claimed in
|
The present invention relates to containers in a synchronous digital network, and particularly, although not exclusively, to a synchronous digital hierarchy (SDH) network or a synchronous optical network (SONET).
Historically, the telecommunications industry has developed separately and largely independently from the computing industry. Conventional telecommunications systems are characterized by having high reliability circuit switched networks for communicating over long distances, whereas data communications between communicating computers is largely based upon shared access packet communications.
Datacoms may operate over a local area, to form a local area network (LAN) or over a wide area to form a wide area network (WAN). Historically the difference between a LAN and a WAN is one of geographical coverage. A LAN may cover communicating computing devices distributed over an area of kilometers or tens of kilometers, whereas a WAN may encompass communicating computing devices distributed over a wider geographical area, of the order of hundreds of kilometers or greater.
However, the historical distinction between local area networks and wide area networks is becoming increasingly blurred.
Conventional local area networks are generally taken to be digital data networks operating at rates in excess of 1 MBits/s over distances of from a few meters up to several kilometers. Conventional local area networks are almost universally serial systems, in which both data and control functions are carried through the same channel or medium. Local area networks are primarily data transmission systems intended to link computer devices and associated devices within a restricted geographical area. However, many local area networks include speech transmission as a service. A plurality of computer and associated devices linked together in a LAN may range from anything from a full-scale mainframe computing system to a collection of small personal computers. Since a local area network is confined to a restricted geographical area, it is possible to employ vastly different transmission methods from those commonly used in telecommunications systems. Local area networks are usually specific to a particular organization which owns them and can be completely independent of the constraints imposed by public telephone authorities, the ITU, and other public services. Local area networks are characterized by comprising inexpensive line driving equipment rather than the relatively complex modems needed for public analog networks. High data transmission rates are achieved by utilizing the advantages of short distance.
On the other hand, conventional wide area networks operate in general on a greater scale than local area networks. A wide area network is generally employed whenever information in electronic form on cables leaves a site, even for short distances. Wide area networks are generally carried over public telecommunications networks.
Because conventional telecoms systems have developed in parallel with conventional datacoms systems, there is a significant mis-match in data rates between conventional datacoms protocols as used in LANs and WANs, and conventional telecoms protocols. In general, telecoms operators provide equipment having standard telecoms interfaces, for example E1, T1, E3, T3, STM-1, which are used by the datacoms industry to provide wide area network point to point links. However, this is inconvenient for datacoms providers since datacoms protocols have developed using a completely different set of interfaces and protocols, for example carrier sense multiple access collision detection CSMA/(CD systems, subject of IEEE standard 802.3, and Ethernet which is available in 10 MBits/s, 100 MBits/s and 1 GigaBits/s versions. Conventional datacoms protocols do not match up very well to conventional telecoms interfaces, for example E1, E3, T1, STM-1 data rates, because of a mis-match in data rates and technologies between conventional datacoms and conventional telecoms.
In order to provide transport of OSI layer 2 datacoms traffic cover a wide area in an efficient manner, the inventors have previously disclosed transport of OSI layer 2 data frames over synchronous digital hierarchy networks (including SONET).
In the applicant's co-pending US patent application entitled “Frame Based Data Transmission over Synchronous Digital Hierarchy Network”, a copy of which is filed herewith, there is disclosed a method of carrying OSI layer 2 frame based data, for example IEEE standard 802.3 carrier sense multiple access/collision detection (CSMA/CD) local area network packets, Ethernet packets, conventional token ring packets, conventional token bus packets, and fiber distributed data interface (FDDI) packets directly over a synchronous digital network. Such disclosed system may provide OSI layer 2 switching functionality such as was previously available in prior art local area networks, but extended over a wider geographical coverage area which has been historically considered to have been provided only by prior art wide area networks.
In the applicant's co-pending US patent application entitled “payload Mapping in Synchronous Networks”, a copy of which is filed herewith, there is disclosed a method and apparatus for containment of OSI layer 2 frame based data into a set of synchronous digital hierarchy (SDH) virtual containers, by rate adapting a plurality of OSI layer 2 data frames by invoking buffering and flow control in a rate adaption means, and mapping the rate adapted OSI 2 data frames directly into a plurality of SDH virtual containers. This process enables a virtual OSI 2 local area network to be constructed across a wide area network supported by a synchronous digital transport layer.
Since data rates used by conventional OSI layer 2 datacoms systems are either higher than data rates of individual virtual containers in SDH systems or fit inefficiently into available faster virtual containers, there is the problem of how to carry higher bit rate OSI layer 2 datacoms traffic in SDH virtual containers, to achieve the result of an OSI layer 2 channel carried over an SDH network.
An object of the present invention is to provide a synchronous digital container system within the confines of ITU-T recommendation G.70X which provides high efficiency and minimum delay for transport of frame based data packets directly over a synchronous digital network without further encapsulation in intermediate protocol layers.
A further object of the present invention is to provide an SDH frame structure suitable for transmitting and receiving frame based data in a manner which overcomes variations in delay between different paths across a synchronous network.
Specific implementations of the present invention aim to provide a method and apparatus for virtual concatenation of VC-3s, and VC-12s in a form which is suitable for carrying frame based data. In this specification, the term “virtual concatenation” is used where the underlying network is unaware of any special relationship between the virtual containers which make up a group of virtually concatenated virtual containers. Particularly, although not exclusively, such frame based data may comprise OSI layer 2 data frames.
According to one aspect of the present invention there is provided a method of transporting data over a synchronous digital network, said method comprising the steps of: generating in parallel a plurality of synchronous virtual containers, each at a lower bit rate than a bit rate of said data, each said virtual container having a payload section; associating said plurality of virtual containers with each other by means of assigning association data describing said association into said plurality of virtual containers; inputting said transported data into said payloads of said plurality of virtual containers; and outputting said plurality of associated virtual containers onto a synchronous digital network.
Preferably said plurality of associated virtual containers are output onto said synchronous digital network substantially in parallel. Said step of associating said plurality of virtual containers with each other preferably comprises inserting said association data into a plurality of payloads of said plurality of virtual containers, said association data permitting recovery of the original association at a destination end. Preferably said step of inputting said transported data into said plurality of virtual containers comprises byte interleaving bytes of a frame of said transported data between said plurality of payloads. Preferably said plurality of virtual containers are generated as a plurality of streams of virtual containers and said step of associating said plurality of virtual containers with each other comprises associating a plurality of said streams of virtual containers with each other.
Preferably said step of associating said plurality of virtual containers together by means of assigning association data comprises adding a stream of identification data to each said virtual container, said stream identification data identifying which of said plurality of streams said virtual container belongs to. The method preferably comprises including a sequence identification data to individual ones of said plurality of virtual containers, said sequence identification data designating a sequence in which said individual virtual containers are generated with respect to each other. Suitably the sequence identification data comprising a cyclically repeating code data. In the best mode, there is assigned to individual ones of said plurality of virtual containers a cyclically repeating code sequence having a repetition period of at least 2 N+1, where N is the number of sequentially received virtual container payloads in a single stream.
Alternatively, said step of associating said plurality of virtual containers together by means of assigning association data comprises utilizing a path trace byte in a virtual container overhead as a stream identifier data for identifying a virtual container as belonging to a particular said virtual container stream. Instead of including sequence identification data in the virtual container payload, said sequence identification data may be carried within a K3 byte of an overhead section of said virtual container. A sequence identification code data may extend over a plurality of said virtual containers of a said steam, for identifying a position of each said virtual container comprising said virtual container stream.
The invention includes an apparatus for incorporating data input at a first data rate into a plurality of streams of synchronous digital hierarchy virtual containers each output at a second data rate, said apparatus comprising: means for continuously generating a plurality of virtual containers in parallel; means for generating data describing an association of said plurality of virtual containers, and for assigning said association data to said plurality of associated virtual containers; and means for inserting said first data rate data into said plurality of payloads of said plurality of virtual containers.
According to a second aspect of the present invention there is provided a method of recovering data from a plurality of synchronous virtual containers, said method comprising the steps of: receiving said plurality of virtual containers; identifying an association data from said plurality of virtual containers, said association data indicating an association between individual ones of said plurality of virtual containers; reading data bytes from each payload of said plurality of associated virtual containers; and reassembling said data from said plurality of read payload data bytes.
Preferably said process of reading said data payloads comprises reading a plurality of said payloads in a byte interleaved manner. Preferably said step of identifying an association data from each of said plurality of virtual containers comprises reading a plurality of stream identification data from said plurality of virtual containers, said stream identification data designating which of a plurality of streams of virtual containers said virtual containers belong to. Preferably said step of identifying an association data between said plurality of virtual containers comprises reading a plurality of sequence identification data designating where in a sequence of virtual containers each individual virtual container belongs. A plurality of separate streams of associated virtual containers may be received simultaneously. Said step of reading data bytes from each payload of said plurality of associated virtual containers may comprise reading said data bytes substantially in parallel from a plurality of virtual containers of a same sequence identification from a plurality of associated virtual container streams. Where the association data are not carried in a virtual container payload section, said step of identifying an association data from said plurality of virtual containers may comprise inspecting a path trace byte of each of a plurality of said virtual containers, and distinguishing from which of a set of said stream of virtual containers said individual virtual containers belong, from said read path trace data bytes. A sequence identification data designating where in a stream of said virtual containers, a said virtual container belongs, may be read from a K3 byte of a said virtual container.
The invention includes a method of recovering data carried in payloads of a plurality of associated synchronous digital hierarchy virtual containers, said method comprising the steps of: for each said virtual container: reading data indicating an association between said virtual container and other ones of said plurality of virtual containers; allocating a memory storage area for storing a payload of said virtual container, inputting said virtual container payload into said memory area; and reading said data from said memory area in parallel with data read from other said memory areas corresponding to payloads of other said virtual containers of said plurality of virtual containers.
Said step of, for each virtual container, reading data in parallel with data of other virtual containers may comprise: for each said memory area, setting a read pointer to a memory location of said memory area; wherein said plurality of read pointers are set to said memory locations such that successive bytes of said data frame are read from said plurality of memory locations in sequence. A said data frame may be assembled from said parallel read data. A said data frame comprises an OSI layer 2 data frame. The invention includes a method of recovering a data block carried in a plurality of payloads of a plurality of associated synchronous digital hierarchy virtual containers, said method comprising steps of: receiving a plurality of streams of said plurality of associated virtual containers; for each said received virtual container stream allocating a corresponding respective memory area for storage of data payloads of virtual containers of said stream; storing said plurality of virtual container payloads in said corresponding allocated memory areas; and reading individual bytes of said plurality of stored virtual container data payloads in sequence to reconstruct said data block.
Preferably said step of reading individual bytes of said plurality of payloads comprises: for each said memory area, setting a read pointer to a memory location corresponding to a next data byte of said data block to be read, contained within that data payload; and reading said data byte once a preceding data byte of said data block has been read from a memory location of another said memory area. Said bytes are preferably read from each of a plurality of said memory areas in which said virtual container payloads are stored.
The invention includes apparatus for recovering data from a plurality of synchronous digital hierarchy virtual containers containing said data, said means comprising: a random access memory configured into a plurality of individual memory areas allocated for storage of payloads of said plurality of virtual containers; a data processor means operating to identify an association data of said virtual containers, said association data indicating an association of said plurality of virtual containers; and means for generating a plurality of read pointers operating to successively read a plurality of memory locations of said memory areas for recovering said data from said plurality of virtual containers.
For a better understanding of the invention and to show how the same may be carried into effect, there will now be described by way of example only, specific embodiments, methods and processes according to the present invention with reference to the accompanying drawings in which:
There will now be described by way of example the best mode contemplated by the inventors for carrying out the invention. In the following description numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent however, to one skilled in the art, that the present invention may be practiced without limitation to these specific details. In other instances, well known methods and structures have not been described in detail so as not to unnecessarily obscure the present invention.
In the following description there is used an example of a stream of OSI layer 2 data frames being transported over a plurality of streams of virtual containers as an example of the payload carried by a plurality of virtual concatenated virtual containers. However, it will be understood by a person skilled in the art that any data payload can be carried by a plurality of virtually concatenated virtual containers, and the advantages of the invention are most apparent for a data payload which has a data rate which is too fast to be carried in a nearest data rate virtual container (eg data 5% or more faster than a nearest equivalent virtual container data rate under ITU-T recommendation G.707), but which inefficiently fills a next higher up data rate virtual container (eg the data rate of the transported data is 30% or more slower than the higher data rate of the next available virtual container in which it could be carried).
Referring to
At each level of the SDH multiplex hierarchy, data is carried in the STM-N payload section 101 of the STM-N frame. For example, the basic transmission rate defined in the SDH standards for an STM-1 frame is 155.520 MBits/s. The STM-1 frame consists of 2,430 8 bit bytes which corresponds to a frame duration of 125 μs. Three higher bit rates are also defined: 622.08 Mbits/s (STM-4), 2488.32 Mbits/s (STM-16) and 9,953.28 MBits/s (STM-64). The higher bit rates are achieved by interleaving on a byte by byte basis a number N of the basic STM-1 frames.
The 2,430 byte payload section of an STM-1 frame, carries a plurality of virtual containers (VCs). Each virtual container comprises a plurality of data bytes divided into a path overhead component and a payload component. Various types of virtual container are defined in ITU-T recommendation G.70X, including VC-1, VC-2, VC-3, VC-4, VC-12. For VC-1 and VC-2, the path overhead bits comprise bits which are used for error performance monitoring and network integrity checking.
A VC-3 comprises an 85 byte column×9 row byte structure. For the VC-3 container, the path overhead component is located in a first column of the 9 row×85 column structure and includes bytes which verify a VC-3 path connection; a byte which provides bit error monitoring, a signal label byte indicating a composition of the VC-3 payload; a path status byte allowing the status of a received signal to be returned to a transmitting end; a plurality of path user channel bytes to provide a user specified communication channel; a position indicator byte for providing a generalized position indicator for payloads; an automatic protection switching byte; a national operator byte which is allocated for specific management purposes such as tandem connection maintenance; and a plurality of spare bytes.
A VC-4 container comprises a 261 byte column×9 byte row structure, having similar path overhead byte functions as for a VC-3 container as described above.
A plurality of virtual containers are incorporated into an STM-1 frame as follows. Firstly, the virtual container is positioned in a tributary unit (TU), or an administrative unit (AU) with a pointer indicating the start of the virtual container relative to the tributary unit or administrative unit as appropriate. VC-1s and VC-2s are always positioned in tributary units, whereas VC-4s are always positioned in an AU4 administrative unit. Tributary units and administrative units are each bundled into their respective groups: tributary unit groups (TUGS) for tributary units, and administrative unit groups (AUGs) for administrative units. Tributary unit groups are multiplexed into higher order virtual containers which in turn are positioned in administrative units with a pointer indicating the start of the virtual container relative to the administrative unit. Administrative unit pointers indicate the position of the administrative units in relation to the STM-1 frame, and form part of the section overhead area of the frame.
Referring to
A system for sending and recovering frame data over an SDH network according to the best mode implementation of the present invention will now be described.
Referring to
The embodiment of
Datacoms frame based data is incorporated into synchronous virtual containers by the datacoms port cards of the synchronous multiplexers. The datacoms port cards are not restricted to inclusion in add-drop multiplexers, but may be incorporated in any synchronous digital multiplexer, for example an SDH terminal multiplexer.
Referring to
By incorporating OSI layer 2 data frames directly into synchronous digital hierarchy ITU-T recommendation G.701 channels, the high data rates available using OSI layer 2 frames can be provided in a geographically widespread system, which is unlimited by the conventional distance limitations imposed on prior art local area network systems.
However, there exists the practical problem of how to incorporate and extract OSI layer 2 data frames, which are generated at a first set of bit rates with SDH virtual containers which are defined to operate at a second set of bit rates. Table 1 herein illustrates a comparison of Ethernet data rates (in a left column of Table 1) as an example of OSI layer 2 data rates, with nearest available SDH virtual container rates (in the central column of Table 1), and how the Ethernet data rates can be accommodated in a plurality of SDH virtual containers (in the right column of table 1). In general, the Ethernet data rates at higher bit rates than the nearest available bit rate virtual containers. However, the prior art Ethernet data rates are well matched to integer multiples of the synchronous digital hierarchy virtual container payload data rates, as illustrated in Table 1. The SDH payload data rates have a granularity of a minimum incremental step of ˜2 MBits/s. A minimum granularity of Ethernet rates is 10 MBits/s, and so 5 SDH VC-12 containers each of 2 MBits/s can accommodate neatly a single 10 MBits/s Ethernet channel. Similarly, a 100 MBits/s Ethernet data rate can be accommodated in 2 VC-3 containers, each of approximately 50 MBits/s.
TABLE 1
Ethernet
Virtual Containers
Multiple Virtual Containers
10 MBits/s
VC-12 (˜2 MBits/s)
1-5 × VC-12 (2 MBits/s-10
MBits/s)
10 MBits/s
VT
1-8 × VT 1-5 (2 MBits/s-10
MBits/s
100 MBits/s
VC-3 (˜50 MBits/s)
1-2 × VC-3 (50 MBits/s-100
MBits/s)
100 MBits/s
STS-1
1-2 × STS-1 (50 MBits/s-100
MBits/s)
1 Gbits/s
VC-4 (˜155 MBits/s)
N × VC-4 (155 MBits/s-1.2
GBits/s)
VC-4-4c (622 MBits/s)
N = 1-8
1 Gbits/s
N × STS-1 (155 MBits/s-1.2
GBits/s)
N = 3, 6, 9 12, 15, 18, 21, 24
Referring to
The datacoms port card of
Rate adaption means 601 comprises an OSI layer 2 datacoms port, eg operating at 10 MBits/s or 100 MBits/s in accordance with IEEE standard 802.3; and a synchronous port operating at 2 MBits/s, 50 MBits/s or 100 MBits/s communicating with SDH payload mapper 600. Rate adaption means 601 comprises a through channel for adapting OSI layer 2 data frames into bitstreams having an appropriate data rate of 2 MBits/s, 50 MBits/s or 100 MBits/s.
The function of the rate adaption means is to handle the frequency difference between an exact data rate at the OSI layer 2 port and an approximate rate achieved over a plurality N of virtual containers.
SDH payload mapper 600 maps OSI layer 2 datacoms data frames directly into SDH data frames.
Further details of construction and operation of payload mapper 600 will now be described.
The datacoms port card of
A method and apparatus for directly mapping frame based data as described above, directly into synchronous digital virtual containers, is described in the applicant's co-pending US patent application reference ID 0889 filed contemporaneously with the present application, and entitled “Payload Mapping in Synchronous Networks”. Data frames are mapped into SDH VCs without encapsulation in an intermediate protocol, in a manner in which data frames carried within synchronous digital frames are identifiable as such, through provision of start and/or boundary markers delineating data frame packets contained within synchronous digital frames, and by other encoding schemes used to distinguish data frame packets from other data traffic carried within synchronous digital frames. Identification of frame data packets within a synchronous digital frame is disclosed, maintaining a known packet transfer rate, and with limited and known packet size expansion.
SDH payload mapper 600 communicates with a bitstream channel of rate s adaption means 601. SDH payload mapper maps bitstream channel of rate adaption means 601 into a plurality of SDH virtually concatenated virtual containers.
However, where a plurality of virtual containers of lower bit rates are used to carry a data frame of a higher bit rate, the higher rate data frame needs to be re-assembled from the plurality of lower rate virtual containers at a destination end.
Referring to
This problem occurs with conventional SDH virtual containers and does not cause undue problem where the virtual containers are filled with data traffic from an appropriate telecoms tributary of an appropriate data rate, for example a 2 MBits/s tributary in the case of a VC-12.
However, where a plurality of associated virtual containers containing a single OSI layer 2 data frame are sent at substantially the same time from the first node, the plurality of virtual containers carrying collectively a higher data rate OSI layer 2 channel, the differential delay between a set of virtual containers transmitted substantially at the same time from the first node over the network becomes significant in re-assembly of the OSI layer 2 data frame. A set of virtual containers carrying a higher bit rate OSI layer 2 channel which are sent from the first node 701 simultaneously, may arrive at the destination node, third node 702 displaced in time.
Assuming that two virtual containers are used to accommodate an OSI layer 2 data rate, the two virtual containers may leave a source as two streams of virtual containers 1 and 2. At the source, the Nth frame of a virtual container in stream 1 and the Nth frame of the virtual container in stream 2 are generated simultaneously. However, at the destination, the Nth frame of one stream (1 or 2) could arrive coincident with the N±Xth frame of the other stream (where X is any arbitrary number).
Delays occur due to transmission delays along fiber links, and delays within the nodes themselves. A typical delay for a 125 μs STM-1 frame at a node is 9 bytes per STM-1 frame. This gives a lowest time delay per node of the order of 5 μs. Additionally, the delay incurred due to the transmission along optical fiber is of the order of 5 μs per kilometer. Thus, if 2 VC-4 containers are sent across a network by different routes, having a round trip geographical distance difference of 1000 kilometers, the containers could arrive at the same destination 5 milliseconds apart due just to the difference in fiber delay between the two routes. This is in addition to any delays incurred through passing through additional nodes, which can be of the order of up to 50-100 μs per node. A differential delay between source and destination over a large network of the order of 10 ms may be incurred.
The above delays do not occur for all virtual containers. For example for 2 VC-3s that run over the same physical route contained in the same VC-4, then the differential delay will be null (because the two VC-3s traverse the same route). On the other hand, where 2 VC-3s run over different routes, which could happen if a path protection switch only occurs on one VC, then the differential delay as described above may be incurred.
The problem is addressed in the best mode implementation herein by virtually concatenating a plurality of virtual containers at the send transmitter. In this specification, by virtual concatenation it is meant that the underlying network is unaware of any special relationship between the virtual containers which make up the group of associated virtual containers. No action is taken at intermediate nodes to suppress the differential delay between virtual containers, but rather that the responsibility for maintaining bit sequence integrity in the payload of a plurality of virtual containers is left with the terminating equipment.
The following example relates to the case where an OSI layer 2 data frame at a first data rate is contained within a pair of simultaneously created VC-3s, each having a second, lower, data rate, the 2 VC-3s being virtually concatenated together and transmitted on to a synchronous network simultaneously.
Referring to
The virtual container stream numbers data indicate to which of a plurality of associated streams of virtual containers an individual virtual container belongs, whilst the sequence marker data indicates a time at which the virtual container was generated in relation to other previously and future generated virtual containers in the same stream and in associated other streams of virtual containers.
In the best mode described herein, the stream identification data and the sequence identification data (sequence markers) are incorporated in the VC payload section, preferably immediately after the VC overhead. However, in further alternative implementations, the path trace bytes present in the VC overhead may be used to identify a stream of virtual containers to which a particular virtual container belongs. The path trace byte is used conventionally to provide a 16 byte (or 64 byte in the case of SONET) identifier data for identifying which particular circuits a virtual container belongs to, ie for example the 16 byte path trace overhead may be used for example by a network operator to check that they have correctly connected paths across a network, path trace bytes may be used to specify a source and destination location, a customer, and a bit rate of a path or connection. Provided each of a plurality of streams of virtual containers have a unique path trace byte data, then the path trace byte identification data may be used additionally as the stream identification data.
Similarly, in the further implementation the sequence identification data may also be incorporated in the path overhead of the virtual containers. Options for incorporating sequence identification data in the VC path overhead, include using part of the K3 byte in the VC path overhead for sequence identification purposes. In the prior art, the K3 byte of the VC overhead has bits 1-4 already allocated in ITU-T recommendations. However, bits 5-8 of the K3 byte are user definable and in the alternative specific implementation described herein, may be used for carrying the sequence identification data. However, use of the K3 byte would enable only short sequences of virtual containers to be implemented before repetition of the sequence cycle occurs, due to the low number of bits available. Secondly, a sequence identification data pattern may be incorporated over several virtual containers by utilizing one bit or more from the payload of each successive virtual container of a VC stream. In an extreme case, only one bit per VC overhead needs to be taken to implement the sequence pattern. A pattern of ones and zeroes collected from successive virtual containers of a steam may be decoded to give the information of where in the VC stream sequence, a particular virtual container occurs. However, this implementation requires collection of a plurality of virtual containers in order to determine the start and finish of a sequence. By using appropriate prior art sequences, it is theoretically possible to cater for theoretically infinite delays between received virtual containers from different streams. Additionally, the scheme may be vulnerable to bit errors in the sequence bits. In this alternative implementation, efficiency is improved over the first implementation, since no payload data needs to be displaced by the association data, however the hardware and software required for identifying sequences in the second implementation herein becomes more complex and a larger number of virtual containers need to be received before sequence identification can commence.
Referring to
Incorporation of the OSI layer 2 data frame into the plurality of virtual containers is by byte interleaving as illustrated schematically in
Referring to
At a destination end, the first and second VC-3s may arrive with a differential delay, as illustrated schematically in
Referring to
As the virtual containers arrive, their contents are stored in the appropriate memory areas in parallel in real time. For ease of illustration a case of two virtual containers which arrive within a differential delay of 125 μs is shown in
The overall parallel process for receiving VCs operated at the destination apparatus is illustrated schematically in
Referring again to
Referring again to
As the first and second memory areas fill up with received bytes of the respective first and second VCs, alternate bytes from the first and second VCs are read by moving the read pointer along the memory locations in parallel and reading alternate byte interleaved data comprising the OSI layer 2 data frame from the payloads of the first and second VCs. The earliest time at which reading can commence limited by the latest time at which the latter arriving of the first and second VCs with the same sequence marker begins to be stored in the memory.
Referring to
In a best mode implementation for performing the read operation, each memory area allocated to a virtual container stream is preferably large enough to contain enough bytes corresponding to twice the maximum anticipated differential delay between arrival of two virtual containers. Although this implementation is inefficient of memory usage, in that only enough memory to accommodate the different delay is required in theory, operation is simplified.
Referring to
Shields, James, Goodman, David Michael, Russell, John Paul, Murton, Christopher David, Ramsden, Christopher Thomas William
Patent | Priority | Assignee | Title |
8086104, | Feb 15 2008 | Acacia Research Group LLC | System, method and computer readable medium for providing dual rate transmission on a gigabit passive optical network |
Patent | Priority | Assignee | Title |
5065396, | Jan 02 1990 | AT&T Bell Laboratories | Inverse multiplexer and demultiplexer techniques |
5461622, | Jun 14 1994 | TTI Inventions A LLC | Method and apparatus for using SONET overheat to align multiple inverse multiplexed data streams |
5581566, | Jan 06 1995 | The Regents of the Univ. of California Office of Technology Transfer | High-performance parallel interface to synchronous optical network gateway |
5666351, | Jun 03 1992 | Nokia Technologies Oy | Method for disassembling and assembling frame structures containing pointers |
5675585, | Jul 29 1994 | Alcatel Telspace | Method and system for interleaving and deinterleaving SDH frames |
5706285, | Apr 02 1992 | QUARTERHILL INC ; WI-LAN INC | Network interfacing method and a network interface for a digital transmission network |
5757804, | Jul 05 1996 | Racal-Datacom, Inc. | Method and apparatus for eliminating offset calculations |
5978377, | Aug 09 1996 | Electronics and Telecommunications Research Institute | STM-based ATM cell physical layer processing circuit |
6058119, | Apr 15 1995 | International Business Machines Corporation | SDH/sonet interface |
6094442, | Nov 13 1996 | Nippon Telegraph & Telephone Corporation | Optical path signal termination equipment |
6094737, | Dec 20 1996 | Oki Electric Industry Co., Ltd. | Path test signal generator and checker for use in a digital transmission system using a higher order virtual container VC-4-Xc in STM-N frames |
6112236, | Jan 29 1996 | Viavi Solutions Inc | Method and apparatus for making quality of service measurements on a connection across a network |
6134217, | Apr 15 1996 | CALIFORNIA, THE BOARD OF REGENTS OF THE UNIVERSITY OF | Traffic scheduling system and method for packet-switched networks with fairness and low latency |
6266345, | Apr 24 1998 | XNAN ZHON NI, RICHARD AND NIKKI SZETO, KUANG-HUA KEN HUANG, MEI LING SUN AND CHRISTOPHER TAN COLLECTIVELY, THE NI GROUP | Method and apparatus for dynamic allocation of bandwidth to data with varying bit rates |
6556593, | Dec 11 1996 | International Business Machines Corporation | Digital cross connect and add/drop multiplexing device for SDH or SONET signals |
EP773645, | |||
EP901306, | |||
WO9733398, | |||
WO9804072, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Oct 24 2005 | Nortel Networks Limited | (assignment on the face of the patent) | / | |||
Mar 19 2010 | Nortel Networks Limited | CIENA LUXEMBOURG S A R L | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 024213 | /0653 | |
Mar 19 2010 | CIENA LUXEMBOURG S A R L | Ciena Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 024252 | /0060 | |
Jul 15 2014 | Ciena Corporation | DEUTSCHE BANK AG NEW YORK BRANCH | SECURITY INTEREST | 033329 | /0417 | |
Jul 15 2014 | Ciena Corporation | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | PATENT SECURITY AGREEMENT | 033347 | /0260 | |
Oct 28 2019 | DEUTSCHE BANK AG NEW YORK BRANCH | Ciena Corporation | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 050938 | /0389 | |
Oct 28 2019 | Ciena Corporation | BANK OF AMERICA, N A , AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 050969 | /0001 | |
Oct 24 2023 | BANK OF AMERICA, N A | Ciena Corporation | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 065630 | /0232 |
Date | Maintenance Fee Events |
Sep 01 2010 | ASPN: Payor Number Assigned. |
Dec 12 2012 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Jan 03 2017 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Jan 31 2017 | ASPN: Payor Number Assigned. |
Jan 31 2017 | RMPN: Payer Number De-assigned. |
Date | Maintenance Schedule |
Jul 06 2013 | 4 years fee payment window open |
Jan 06 2014 | 6 months grace period start (w surcharge) |
Jul 06 2014 | patent expiry (for year 4) |
Jul 06 2016 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jul 06 2017 | 8 years fee payment window open |
Jan 06 2018 | 6 months grace period start (w surcharge) |
Jul 06 2018 | patent expiry (for year 8) |
Jul 06 2020 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jul 06 2021 | 12 years fee payment window open |
Jan 06 2022 | 6 months grace period start (w surcharge) |
Jul 06 2022 | patent expiry (for year 12) |
Jul 06 2024 | 2 years to revive unintentionally abandoned end. (for year 12) |