1. Field of the Invention
The present invention relates to a processing method of a fragmented packet in packet transfer equipment transmitting and receiving a packet data between terminals through a network, and packet transfer equipment using the method.
2. Description of the Related Art
A system for transmitting and receiving a packet data between terminals through a network is illustrated in
For this purpose, the encrypted data is fragmented (III). This fragmented packet is forwarded to IP tunnel 100.
Meanwhile, on a reception node B of IP tunnel 100, the fragmented packets having the encrypted data are reassembled (S3), and as a result, the encrypted data identical to the data generated in the node A is obtained (IV).
Subsequently, the node B decrypts the encrypted data, decapsulates so as to exclude an outer header (S4). Thus, the data before the encryption is obtained (V).
In
For example, in
In the IPv6 fragment format shown in
Further, the fragment header includes fragment offset value, continuation flag, and identifier. Moreover, the modified IPv6 header includes a source address. Using this source address and the identifier in the fragment header, the original encrypted data packet before segmentation can be identified. Also, using the fragment offset value in each fragment header and fragment continuation flag (1 or 0), each divided fragment data location can be identified.
Using hardware, it is relatively easy to perform the fragment processing (S2) at high speed in the transmission node A according to the fragment formats shown in
In contrast, as to the reassembly processing (S3) in the reception node B, it is necessary to monitor the reception of the entire fragmented packets, and to reassemble the packets. This reception processing becomes complicated, because the sequence within the fragmented packets may become out of sequence (sequence inversion) in the network, or a plurality of fragmented packets may be received from the network concurrently in a multiplexed form.
In
If no fragment header is existent, this packet is determined to be not a fragmented packet, and accordingly the packet is forwarded to a packet processor 5 (‘N’ in process step P1). If a fragment header is existent (‘Y’ in process step P1), a packet source address (IP_SA) and a fragment identifier ID in the packet header are compared with the entry data having been registered as object packets for reassembly processing, so as to search and identify from which encrypted packet the fragmented packet is produced (process step P2).
As a result of the above search processing, if no matched data is found among the registered objects for reassembly processing (‘N’ in process step P3), the packet is determined as a new fragmented packet. Accordingly, the source address (IP_SA) and the fragment ID are registered newly as a new entry (process step P4), and the search result indicating a new fragmented packet is reported together with the new entry to a reassembly processor 4 (process step P5).
Meanwhile, if the search results in a match (‘Y’ in process step P3), the search result indicating packet assembly (reassembly) is proceeding is reported (process step P6). Based on this, from the search result, a fragmented packet of an identical packet is identified using the fragment ID, and the packets are assembled in reassembly processor 4 for each reported entry, in order of the offset values (process step P7).
Thus, on completion of the fragment assembly (‘Y’ in process step P8), release of the entry is instructed to fragment decision search section 1 (process step P9).
Referring to the processing shown in
Based on the packet obtained in fragment decision search section 1 and the search information thereof, data parts (data 1, data 2 and data 3) are written in each assembly buffer 2 (i.e. buffer memory for assembly) of which address location corresponds to a fragment offset value L in the packet header, while headers (H1, H2 and H3) are stored in a header storage area 2a of assembly buffer 2.
Here, as shown in
Next, after the entire fragmented packets are received, in reassembly processor 4, the reassembly processing is performed by successively reading out the packet data from assembly buffer 2 corresponding to the entry. Also, processing including substitution of the header is performed in this reassembly processor 4. Then, the packet is forwarded to packet processor 5, and further transmitted from a packet transmitter 6.
As such, the processing performed in reassembly processor 4 shown in
In the exemplary configuration shown in
As shown in
This method requires a substantial time for packet sequence decision processing. However, since efficient use of assembly buffer 2 can be attained, the method is effective in such equipment that does not need fast processing, as effective method using software and firmware.
Also, as a technique related to the above, an invention related to packet processing has been disclosed in the official gazette of the Japanese Unexamined Patent Publication No. 2001-223704. In this disclosure, based on an ATM cell received from an extended line, packets are stored in an assembly memory. The packets are read out from the memory, and a packet of which address is resolvable is processed by hardware, while a packet of which address is not resolvable is processed by software.
Now, in packet transfer equipment provided in a system in which encrypted packets are transferred at high speed on the order of Gigabits/sec through IP tunnel 100 as shown in
High-speed processing may be actualized if the reassembly processing is performed by hardware, as in the conventional example shown in FIGS. 4 to 6. However, it is not possible to determine the packet length before fragmentation until the reception of the entire fragmented packets is completed. If a buffer of a certain length is prepared in advance, the reassembly cannot be performed when the packet length after reassembly exceeds the prepared buffer length.
In contrast, when reassembly processing is performed for the fragmented packets using software processor 8, as illustrated in the conventional example shown in
Further, when the fragmented packets are to be reassembled in the former processing shown in FIGS. 4 to 6 as described above, securing an area having the maximum packet length after reassembly is required for the packet assembly. Since the upper limit of the packet length flowing on the network may be 64 K Bytes, in order to ensure processing for the entire fragmented packet, a buffer memory amounting to 64 K Bytes×(concurrent processing number) is necessary. This is very disadvantageous in view of both memory cost and mounting space.
Accordingly, it is an object of the present invention to provide a method for performing reassembly of entire fragmented packets and packet transfer equipment using the same, enabling high-speed assembly processing with an efficient method of buffer use, with the provision of an assembly means for long packets.
In order to achieve the above-mentioned object, the inventors of the present invention take the following into consideration. Namely, as having been described in
Considering MTU in Ethernet (1, 500 bytes), it is most efficient to fragment into two packets in view of efficiency in fragmentation and transfer efficiency in the network.
From the above viewpoints, as to fragmentation caused by encapsulation and encryption in IP tunneling, fragmentation into two packets occurs in most cases. Therefore, according to the present invention, a packet fragmented into two packets is discriminated from the other, i.e. a packet fragmented into three or more packets. As to a packet fragmented into two packets, by proving each buffer memory capable of storing two packets, and storing the packets into the buffer according to the offset values, high-speed reassembly processing by hardware is performed.
Meanwhile, as to a packet fragmented into three or more packets, low-speed reassembly processing is performed by transferring the packet to a software processor, etc. Thus, fragmented packets received at high speed, including a long packet, can be reassembled.
The aforementioned high-speed reassembly processor is referred to as a first reassembly processor, whereas the reassembly processor by software processing for the packets fragmented into three or more is referred to as a second reassembly processor.
This processing method has the following feature, which is obtained by process sharing of high-speed reassembly processing and low-speed reassembly processing.
(1) A fragmented packet to be processed by low-speed processing is transferred to the software processor, or the second reassembly processor, in which proprietary reassembly processing is performed. The packet of which reassembly processing is completed is returned to the hardware processor, or the first reassembly processor.
(2) The addition of an entry resulting from the search by the high-speed reassembly processing in the hardware processor is handed over to the software processor, which enables reduction of a software load for searching. Also, loads of the software processor are reduced in the following cases: On the occurrence of an abnormality or a timeout detected in a fragmented packet for the low-speed reassembly processing during assembly processing by the hardware processor, the hardware processor discards the relevant packet (s) left in the buffer memory of the hardware processor. Further, when a part of the fragmented packets has already been transferred to the software processor, the hardware processor notifies the software processor of the packet discard information.
(3) It is also possible that the low-speed reassembly processing is performed by the hardware processor. At this time, a buffer memory used in the high-speed processing is also shared in the low-speed processing, enabling restraint of a buffer memory increase.
Thus, as a first aspect of a processing method of a fragmented packet to meet the aforementioned object, in packet transfer equipment for transmitting and receiving a packet data between terminals through a network, the processing method of a fragmented packet includes: receiving a packet; for the received packet, identifying whether the received packet is a packet fragmented into two from an original packet, or a packet fragmented into three or more; for the packet identified as being fragmented into two, securing in advance a buffer capable of storing two fragmented packets, storing the two fragmented packets into an assembly buffer in order of fragmentation, on a basis of the respective offset values in the packets, and reading out from the top; and for the packet fragmented into three or more, performing normality check of fragmentation and reception supervision of the entire fragmented packets only, and transferring the received packet to a software processor, and reassembling the packets fragmented into three or more in the software processor.
As a second aspect of a processing method of a fragmented packet to meet the aforementioned object, in the first aspect, for the packet fragmented into three or more, reassembly for the fragmented packets is performed by chain-connecting the assembly buffers and storing the packets therein in order of reception, and reading out the packets after deciding the order by comparing chain information and the offset values of the fragmented packets within the chain.
As a third aspect of a processing method of a fragmented packet to meet the aforementioned object, in packet transfer equipment for transmitting and receiving a packet data between terminals through a network, a processing method of a fragmented packet includes: receiving a packet; for the received packet, identifying whether the received packet is a packet fragmented into two from an original packet, and of which the original packet length is no greater than a predetermined value, or a packet fragmented into three or more; for the packet identified as being fragmented into two, and of which the original packet length is no greater than a predetermined value, securing in advance a buffer capable of storing two fragmented packets, storing the two fragmented packets into an assembly buffer in order of fragmentation, on a basis of the respective offset values in the packets, and reading out from the top; and, for the packet fragmented into three or more, and the packet fragmented into two of which the original packet length is greater than a predetermined value, performing normality check of the fragmentation and reception supervision of the entire fragmented packets only, and transferring the received packet to a software processor, and reassembling in the software processor the packets fragmented into three or more, and the packets fragmented into two of which the original packet length is greater than a predetermined value.
As a fourth aspect of a processing method of a fragmented packet to meet the aforementioned object, in the third aspect, for the packet fragmented into three or more, and the packet fragmented into two of which the original packet length is greater than a predetermined value, reassembly for the fragmented packets is performed by chain-connecting the assembly buffers and storing the packets therein in order of reception, and on receipt of the entire fragmented packets, reading out the packets after deciding the sequence by comparing chain information and the offset values of the fragmented packets within the chain.
Further, as a first aspect of packet transfer equipment transmitting and receiving a packet data between terminals through a network, the packet transfer equipment includes: a packet receiver; for the packet received in the receiver, a fragment decision search section deciding whether or not the received packet is a fragmented packet, and for the fragmented packet, searching and adding an entry for each packet before fragmentation; and a reassembly section reassembling the packets on an entry-by-entry basis. The reassembly section decides whether the fragmented packet is a packet fragmented into two from an original packet, or a packet fragmented into three or more. Further, the reassembly section includes a buffer memory having a buffer capable of storing two fragmented packets in advance for the packet decided as being fragmented into two, and a plurality of buffers for storing the two fragmented packets into an assembly buffer in order of fragmentation on a basis of the respective offset values in the packets, and for storing the packets fragmented into three or more; and a first output processor reading out the packet fragmented into two stored in the buffer of the buffer memory from the top; and a second output processor for the packet fragmented into three or more, performing reception supervision of the entire fragmented packets only, and transferring the received packet. The packet transfer equipment further includes: a software processor performing reassembly of the packets fragmented into three or more, which are transferred from the second output processor; and a packet processor multiplexing and outputting the reassembled packets fed from the first output processor and the software processor.
As a second aspect of packet transfer equipment transmitting and receiving a packet data between terminals through a network, the packet transfer equipment includes: a packet receiver; for the packet received in the receiver, a fragment decision search section deciding whether or not the received packet is a fragmented packet, and for the fragmented packet, searching and adding an entry for each packet before fragmentation; and a reassembly section reassembling the packets on an entry-by-entry basis. The reassembly section decides whether or not the fragmented packet is a packet fragmented into two from an original packet, and of which the original packet length is no greater than a predetermined value. Further, the reassembly section includes: a buffer memory having a buffer capable of storing two fragmented packets in advance for the packet decided as being fragmented into two, and of which the original packet length is no greater than a predetermined value, and a plurality of buffers for storing the two fragmented packets into an assembly buffer in order of fragmentation on a basis of the respective offset values in the packets, and for storing the packet fragmented into three or more and the packet fragmented into two of which the original packet length is greater than the predetermined value; a first output processor reading out the packet fragmented into two stored in the buffer of the buffer memory from the top; and a second output processor for the packet fragmented into three or more, and the packet fragmented into two of which the original packet length is greater than the predetermined value, performing reception supervision of the entire fragmented packets only, and transferring the received packet. The packet transfer equipment further includes: a software processor performing reassembly of the packets fragmented into three or more, and the packets fragmented into two of which the original packet length is greater than the predetermined value, which are transferred from the second output processor; and a packet processor multiplexing and outputting the reassembled packets fed from the first output processor and the software processor.
As a third aspect of packet transfer equipment, in the above first and the second aspects of the packet transfer equipment, for the fragmented packet transferred from the second output processor to the software processor, packet identification information is added based on an entry number handed over from the reassembly section to the second output processor, and in case that the second output processor detects abnormality in the fragmented packet to be transferred to the software processor, and that a portion of the fragmented packets is already transferred to the software processor, the reassembly section discards the fragmented packet of interest and notify the software processor of the detected abnormality together with the packet identification information.
As a fourth aspect of packet transfer equipment transmitting and receiving a packet data between terminals through a network, the packet transfer equipment includes: a packet receiver; a fragment decision section identifying whether a packet received in the packet receiver is a packet fragmented into two from an original packet, or a packet fragmented into three or more; and a reassembly section reassembling the two fragmented packets decided in the fragment decision section. The reassembly section decides whether the fragmented packet is a packet fragmented into two from an original packet, or a packet fragmented into three or more. The reassembly section further includes: a buffer memory having a buffer capable of storing two fragmented packets in advance for the packet decided as being fragmented into two, and a plurality of buffers for storing the two fragmented packets into an assembly buffer in order of fragmentation on a basis of the respective offset values in the packets, and for storing the packets fragmented into three or more; a first output processor reading out the packet fragmented into two stored in the buffer of the buffer memory from the top; and, for the packet fragmented into three or more, a second output processor having a means for storing the packets into the buffer in order of reception by successively chaining the plurality of buffers in the buffer memory, and after storing the entire fragmented packets into the buffer, handing over buffer chain information while preserving the packet stored in the buffer and packet information in the buffer without modification. In the above packet transfer equipment, the order of fragmentation is decided based on the buffer chain information and the packet information in the buffer entry by entry, which are handed over from the second output processor, and the packets are read out from the buffer memory in order of fragmentation.
As a fifth aspect of packet transfer equipment transmitting and receiving a packet data between terminals through a network, the packet transfer equipment includes: a packet receiver; for the packet received in the receiver, a fragment decision search section deciding whether or not the received packet is a fragmented packet, and for the fragmented packet, searching and adding an entry for each packet before fragmentation; and a reassembly section reassembling the packets on an entry-by-entry basis. The reassembly section decides whether or not the fragmented packet is a packet fragmented into two from an original packet, and of which the original packet length is no greater than a predetermined value. Further, the reassembly section includes: a buffer memory having a buffer capable of storing two fragmented packets in advance for the packet decided as being fragmented into two, and of which the original packet length is no greater than a predetermined value, and a plurality of buffers for storing the two fragmented packets into an assembly buffer in order of fragmentation on a basis of the respective offset values in the packets, and for storing the packet fragmented into three or more and the packet fragmented into two of which the original packet length is greater than the predetermined value; a first output processor reading out the packet fragmented into two stored in the buffer of the buffer memory from the top; and a second output processor for the packet fragmented into three or more, and the packet fragmented into two of which the original packet length is greater than the predetermined value, having a means for storing the packets into the buffer in order of reception by successively chaining the plurality of buffers in the buffer memory, and after storing the entire fragmented packets into the buffer, handing over buffer chain information while preserving the packet stored in the buffer and packet information in the buffer without modification. In the above packet transfer equipment, the order of fragmentation is decided based on the buffer chain information and the packet information in the buffer entry by entry, which are handed over from the second output processor, and the packets are read out from the buffer memory in order of fragmentation.
Further scopes and features of the present invention will become more apparent by the following description of the embodiments with the accompanied drawings.
The preferred embodiment of the present invention is described hereinafter referring to the charts and drawings. However, it is noted that the scope of the invention is not limited to the embodiments described below.
In
Further, fragment decision search section 1 decides whether there is a fragment header by checking a modified next header (NH) in case of the IPv6 format, as described earlier. On deciding that the packet is a fragmented packet having the fragment header, fragment decision search section 1 informs a reassembly section 4 of the packet after adding an entry number for the respective packets before fragmentation, based on the source IP address and the fragment ID in the header information. On the other hand, on deciding that the packet is not a fragmented packet, the packet concerned is forwarded to a packet processor 5 without any modification to the packet concerned.
Reassembly section 4 identifies whether the packet concerned is fragmented into two packets, or fragmented into three or more packets. As to the packet fragmented into two packets, reassembly section 4 performs high-speed reassembly, and forwards the reassembled packet to packet processor 5. In contrast, as to the packet fragmented into three or more packets, reassembly section 4 forwards the packet to software processor 8.
In order to manage the assembly processing, an assembly management memory 44 is provided, in which assembly management information is stored entry by entry. An assembly state is managed until the entire fragmented packets are completely received.
An assembly buffer 2, which is a buffer memory used for reassembly, is divided into a plurality of buffers of a fixed length, each capable of storing a packet fragmented into two. Considering that most packets divided into two fragments are those of which length exceeds the MTU value caused by encryption and encapsulation, if the buffer length is set to a value exceeding the MTU value by a certain amount, more efficient use of assembly buffer 2 can be attained.
In this case, when a packet is fragmented into two, and of which the packet length before fragmentation is not greater than a certain value, high-speed reassembly processing is performed for the packet of interest. Further, in a buffer management memory 20, buffer management information, which includes link control between the buffers and packet control information, is stored for each buffer.
Now,
Here, in
As shown in
In
In
Because the packet concerned is decided to be processed by a software hop, the first packet storage buffer and the second packet storage buffer are once retained in a software hop output queue SHQ. Also, since it has already been decided the relevant packet(s) is to be forwarded to the software hop, the third packet is also stored in a newly seized buffer, and is retained once in the software hop output queue SHQ.
The fragmented packets accumulated in the software hop output queue SHQ are successively forwarded to software processor 8 by a software hop output processor 42, according to a software hop output queue pointer 46.
The decision of whether the entire fragmented packets have been received is performed by referring to the assembly management information corresponding to each entry in assembly management memory 44 shown in
In software processor 8, as one example, the reassembly processing is performed according to the method explained earlier in
Here, in every assembly processing, during assembling (from the time of reception of the first fragment of the packet to the time of reception of the entire packets), reassembly section 4 supervises timing, entry by entry, in a timing supervision section 43. When a timeout occurs, the received packet is discarded.
On completion of the assembly, or on the occurrence of discard because of abnormality, the management information of the corresponding entry is erased from assembly management memory 44, and a notification indicating the entry is released is forwarded to fragment decision search section 1.
Further, on completion of the reassembly processing shown in
In
Next, packet assembly management section 40 refers to state indication of assembly management memory 44, and performs state decision on the input fragmented packet on an entry-by-entry basis (process step P12). In this decision, if the packet is decided as a new entry (‘Y’ in process step P13), then whether the packet is a final fragmented packet is decided. If the packet is the final fragmented packet (‘Y’ in process step P14), then it is decided whether the sum of the offset value and the payload length in the packet concerned is not greater than a set value (process step P15).
If the sum of the offset value and the payload length is smaller than, or equal to, the set value (‘Y’ in process step P15), because the fragmented packet is the final packet, packet assembly management section 40 seizes an assembly buffer and stores the packet into the final packet area (process step P16). Then, the corresponding entry state in assembly management memory 44 is set to an indication of ‘high-speed assembly proceeding, and the final packet reception completed’ (process step P17).
In the process step P15, when the sum of the offset value and the payload length in the packet concerned exceeds the set value (‘N’ in process step P 15), packet assembly management section 40 seizes a buffer and stores the packet therein, even when the number of fragments is not ‘three or more’, so that the software hop processing is performed in software processor 8 (process step P18). Next, the seized buffer is forwarded to software hop output queue SHQ (process step P19), and the corresponding entry state in assembly management memory 44 is set to ‘software hop assembly proceeding, and the final packet acceptance completed’ (process step P20).
Further, in the process step P14, if it is decided the fragmented packet is not the final packet (‘N’ in process step P14), and the offset value is zero (‘Y’ in process step P21), then it is decided the fragmented packet is a top packet.
Also, if the payload length of the packet concerned is smaller than or equal to the set value (‘Y’ in process step P22), because the received fragmented packet is the top packet, packet assembly management section 40 adds the payload length, seizes an assembly buffer, and stores the received packet into the top packet area (process step P23). Thereafter, the corresponding entry state in assembly management memory 44 is set to ‘high-speed assembly proceeding, and the final packet reception not completed’ (process step P24).
Further, when the offset value is not zero (‘N’ in process step P21), it is decided the packet concerned is a middle fragmented packet among three or more fragments. Also, if the packet concerned is the top packet of the packet fragmented into two, but the payload length of the packet concerned is greater than the set value (‘N’ in process step P22), the packet concerned is decided to be an object of software hop processing, as described earlier in the process step P15.
Accordingly, as in the case of the middle fragmented packet among the three or more fragments, in order to perform the software hop processing, a buffer is seized and the packet is stored into the buffer (process step P25). Then, the seized buffer is forwarded to the software hop output queue SHQ (process step P26), and the corresponding entry state in assembly management memory 44 is set to ‘software hop assembly proceeding, and the final packet reception not completed’ (process step P27).
Next, in the process step P13, if it is decided the packet is not a packet of new entry (‘N’ in process step P13), the process proceeds to the processing shown in
In this state decision, in case of high-speed assembly proceeding and the final packet reception completed, if the packet is decided as the final fragmented packet (‘Y’ in process step P31), both the packet(s) having been stored and the received packet are discarded (process step P32). Also, the entry and the assembly buffer(s) are released (process step P33).
If the packet is not the final packet (‘N’ in process step P31), then the payload lengths excluding the final packet payload are added (process step P34). At this time, if the final offset value is equal to the sum of the payload lengths in the packets excluding the final packet (‘Y’ in process step P35), and further, if the payload sum is smaller than, or equal to, the set value (‘Y’ in process step P36), the received packet is stored into the top packet area of assembly buffer 2, which is a buffer memory for assembling the received packets (process step P37).
Subsequently, assembly buffer 2 is forwarded to reassembly output queue RAQ (process step P38), and the entry is released (process step P39).
In the above process step P35, if the final offset value is not equal to the sum of the packet payload values of the packets excluding the final packet, and the final offset value is greater than the above sum of the packet payload values excluding the final packet (‘Y’ in process step P40), then the packet is decided as a packet fragmented into three or more packets. Then, a buffer is seized and the packet is stored therein, to forward to the software hop processing (process step P41). Subsequently, the buffer by which assembly is proceeding, as well as the received packet, is forwarded to the software hop output queue SHQ (process step P42), and the entry state is set to ‘software hop assembly proceeding, and the final packet acceptance completed’ (process step P43).
The processing in the state of ‘high-speed assembly proceeding, and the final packet reception incomplete’ is performed as follows. First, it is decided whether or not the received packet is a final fragmented packet (process step P44). When the received packet is the final fragmented packet, if the offset value of the final packet is equal to the sum of the payload lengths excluding the final packet (‘Y’ in process step P45), it is further decided whether the payload sum is smaller than, or equal to, the set value. If the payload sum is smaller than, or equal to, the set value (‘Y’ in process step P46), then the received packet is stored into the final packet area of the reception packet assembly buffer 2 (process step P47). Further, the assembly buffer is forwarded to the reassembly output queue RAQ (process step P48), and then the entry is released (process step P49).
In the process step P44, if the packet is not the final fragmented packet (‘N’ in process step P44), then the packet is decided as a packet fragmented into three or more packets, and the payload lengths excluding the final packet are added (process step P50). Then a buffer is seized and the packet is stored therein (process step P51), and the buffer in assembling and the received packet are forwarded to the software hop output queue SHQ (process step P52). Further, the entry state is set to ‘software hop assembly proceeding, and the final packet reception incomplete’ (process step P53).
Further, in the process step P45, if the offset value of the final packet is not equal to the sum of the payload lengths excluding the final packet (‘N’ in process step P45), then the process proceeds to the process step P40 and the subsequent steps.
Also, in the process step P46, if the payload sum exceeds the set value, then a buffer is seized and the packet is stored therein (process step P54). Then, the buffer in assembling and the received packet are forwarded to the software hop output queue SHQ (process step P55), and the entry is released (process step P56).
Now, in the entry-by-entry state decision (process step P30), the process performed when the software hop assembly is proceeding is illustrated in the flowchart shown in
In the case of the software hop assembly proceeding and the fragmented packet has been accepted, if the received packet is not the final fragmented packet (‘N’ in process step P60), then the sum of the payload lengths excluding the final packet is calculated (process step P61). On deciding the final offset is equal to the sum of the payload lengths excluding the final packet (‘Y’ in process step P62), a buffer is seized and the packet is stored therein (process step P63). Subsequently, the reception packet storage buffer is forwarded to the software hop output queue SHQ (process step P64), and the software hop assembly is completed. Then, the entry is released (process step P65).
In process step P62, in the case that the final offset is not equal to the sum of the payload lengths excluding the final packet, and that the final offset exceeds the sum of the payload lengths excluding the final packet (‘Y’ in process step P66), a buffer is seized and the packet is stored therein (process step P67). Subsequently, the reception packet storage buffer is forwarded to the software hop output queue SHQ (process step P68).
In the process step P60, if the packet is the final fragmented packet (‘Y’ in process step P60) and also, in the process step P66, if the final offset value does not exceed the sum of the payload lengths excluding the final packet (‘N’ in process step P66), then the packet(s) having been stored and the received packet are discarded (process step P69), and the entry is released (process step P70), and the discarded entry is reported to the software processor 8 (process step P71).
Meanwhile, in case of ‘the software hop assembly proceeding, and the final fragmented packet reception incomplete’, whether or not the packet is the final fragmented packet is decided (process step P72). If the packet is not the final fragmented packet (‘N’ in process step P72), then the sum of the payload lengths excluding the final packet is calculated (process step P73), and a buffer is seized and the packet is stored therein (process step P74).
If the packet is the final fragmented packet (‘Y’ in process step P72), and when the final offset value is equal to the sum of the payload lengths excluding the final packet (‘Y’ in process step P75), the process proceeds to the process step P63. When the final offset exceeds the sum of the payload lengths excluding the final packet (‘Y’ in process step P76), a buffer is seized and the packet is stored therein (process step P77), and the reception packet storage buffer is forwarded to the software hop output queue SHQ (process step P78).
When the final offset is not greater than the sum of the payload lengths excluding the final packet (‘N’ in process step P76), the process then proceeds to the process step P69 and the subsequent steps.
Further,
Also,
Further, buffer management memory information shown in
The packet data output from software hop output processor 42 for the packet fragmented into three or more packets is transferred with DMA to the buffer memory in software processor 8 by means of a DMA controller in interface 7. Further, software hop report information shown in
In addition, with the combination of the aforementioned first embodiment of the present invention, more effective use of hardware memory can be attained with the provision of low-speed hardware processing for a packet having the packet length prior to the fragmentation exceeding a predetermined value. As compared with the conventional configuration shown in
In this second embodiment of the present invention shown in
In the second embodiment, the processing for a packet fragmented into two is identical to the processing described earlier in the first embodiment (
As to the packet fragmented into three or more, as shown in
Similarly, in
Subsequently, the packet length before fragmentation is calculated, and a header after reassembly is generated (process step P82). Packets are read in from buffer memory 2 in order of fragmentation, and the reassembly is performed by adding the header after reassembly calculated above (process step P83). Thereafter, a queue pointer 47 for handing over the low-speed assembly processing information, and the buffer in use is released (process step P84).
To summarize, according to the present invention, in packet transfer equipment transferring an encrypted packet at high speed through in an IP tunnel, packet reassembly of the entire fragmented packets including a long packet can be performed using a relatively small amount of memory by effective use of an assembly buffer for reassembly.
The foregoing description of the embodiments is not intended to limit the invention to the particular details of the examples illustrated. Any suitable modification and equivalents may be resorted to the scope of the invention. All features and advantages of the invention which fall within the scope of the invention are covered by the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
2004-227221 | Aug 2004 | JP | national |