FR2857538A1 - Systeme et methode de compression d'en-tete de paquets bases sur la creation dynamique d'un gabarit - Google Patents

Systeme et methode de compression d'en-tete de paquets bases sur la creation dynamique d'un gabarit Download PDF

Info

Publication number
FR2857538A1
FR2857538A1 FR0308318A FR0308318A FR2857538A1 FR 2857538 A1 FR2857538 A1 FR 2857538A1 FR 0308318 A FR0308318 A FR 0308318A FR 0308318 A FR0308318 A FR 0308318A FR 2857538 A1 FR2857538 A1 FR 2857538A1
Authority
FR
France
Prior art keywords
template
header
compression
packet
label
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
FR0308318A
Other languages
English (en)
Other versions
FR2857538B1 (fr
Inventor
Pennec Jean Francois Le
Claude Galand
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
AT&T Corp
Original Assignee
AT&T Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by AT&T Corp filed Critical AT&T Corp
Priority to FR0308318A priority Critical patent/FR2857538B1/fr
Priority to CA002472908A priority patent/CA2472908A1/fr
Priority to US10/886,956 priority patent/US7664881B2/en
Publication of FR2857538A1 publication Critical patent/FR2857538A1/fr
Application granted granted Critical
Publication of FR2857538B1 publication Critical patent/FR2857538B1/fr
Priority to US12/647,492 priority patent/US8065437B2/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/04Protocols for data compression, e.g. ROHC
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M7/00Conversion of a code where information is represented by a given sequence or number of digits to a code where the same, similar or subset of information is represented by a different sequence or number of digits
    • H03M7/30Compression; Expansion; Suppression of unnecessary data, e.g. redundancy reduction
    • H03M7/3066Compression; Expansion; Suppression of unnecessary data, e.g. redundancy reduction by means of a mask or a bit-map
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/40Network security protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/22Parsing or analysis of headers

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Theoretical Computer Science (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

Système de compression d'en-tête pour compresser l'en-tête des paquets de données d'une communication transmis entre un noeud d'entrée (10) et un noeud de sortie (12) à travers un réseau de transmission de données (14) comprenant des moyens de création de gabarit dans le noeud d'entrée et le noeud de sortie, adaptés pour créer le même gabarit de compression à partir d'un nombre prédéterminé de paquets de données non compressées au début de la communication respectivement transmis par le noeud d'entrée et reçus par le noeud de sortie, et des moyens de compression d'en-tête dans le noeud d'entrée, adaptés pour compresser l'en-tête de chaque paquet qui suit le nombre prédéterminé de paquets de données non compressés avant de le transmettre à travers le réseau de transmission de données, la compression étant réalisée en utilisant le gabarit de compression.

Description

1 2002-0151
Domaine technique La présente invention concerne de façon générale la compression des en-têtes des paquets de données transmis dans un réseau de transmission de données et concerne en particulier un système et une méthode de compression d'en-tête de paquets basés sur la création dynamique d'un gabarit.
Etat de la technique L'utilisation de la compression d'en-têtes des paquets de données transmis à travers un réseau de transmission de données utilisant le protocole IP ou d'autres protocoles s'appuie sur le fait que beaucoup de champs de l'en-tête sont constants ou changent rarement dans les paquets de données consécutifs appartenant à la même communication. La règle commune utilisée dans la technique de compression est basée sur le fait que les champs d'en-tête qui ne changent pas entre les paquets successifs n'ont pas besoin d'être transmis. Les champs qui changent souvent ou avec des valeurs faibles et/ou prévisibles (par exemple les numéros de séquence TCP) peuvent être codés par incréments de manière à ce que le nombre de bits nécessaire à ces champs décroisse de façon significative. Seuls les champs qui changent souvent ou de façon erratique, par exemple les sommes de contrôle ou les données d'authentification n'ont pas besoin d'être transmis dans chaque en-tête.
La technique de compression est basée sur des gabarits qui définissent quels bits de l'en-tête ont besoin d'être transmis. La plupart des mécanismes standards utilisent des gabarits fixes. Mais, dans l'environnement IP complexe (VoIP, IPv4, IPv6, tunnel), toutes les combinaisons de la pile IP n'ont pas de gabarits prédéfinis qui soient disponibles. En outre, la coexistence de plusieurs mécanismes différents est difficile voire impossible. Ainsi, de nos jours, la 2 2002-0151 compression d'en-tête n'est pas très souvent utilisée ou est limitée à quelques protocoles.
L'IETF (Internet Ingineering Task Force) comporte plusieurs mécanismes de compression d'en-tête qui sont basés sur les règles mentionnées ci-dessus. Le mécanisme de compression d'en-têtes d'origine, CTCP, compresse l'entête IP + TCP de 40 octets en 4 octets. Le compresseur CTCP détecte les retransmissions au niveau de la transmission et envoie un en-tête qui remet le contexte à jour lorsqu elles surviennent.
Ce mécanisme de réparation n'exige pas une signalisation explicite entre le compresseur et le décompresseur.
Un autre mécanisme CRTP, est une compression d'en-têtes qui compresse les 40 octets des en-têtes IPv4/UDP/RTP en un minimum de 2 octets lorsque la vérification par la somme de contrôle UDP n'est pas activée. Si la vérification par la somme de contrôle UDP est activée, l'en-tête CRTP Minimum est de 4 octets. CRTP ne peut pas utiliser le même mécanisme de réparation que CTCP puisque UDP/RTP ne retransmet pas. A la place, CRTP utilise des messages de signalisation explicites entre le décompresseur et le compresseur, appelés messages CONTEXT STATE pour indiquer que la transmission n'est pas synchronisée. Le temps de transmission total limite ainsi la vitesse de ce mécanisme de réparation. Sur les liaisons à taux d'erreur élevé avec des temps de transmission aller/retour importants telles que la plupart des liaisons cellulaires, CRTP ne fonctionne pas bien. Chaque paquet perdu sur la liaison provoque la perte de plusieurs paquets suivants puisque la transmission n'est pas synchronisée durant au moins un temps de transmission aller/retour.
La plupart des règles ci-dessus relatives à la compression d'en-tête sont basées sur des gabarits statiques définis pour un seul protocole ou un groupe de protocoles. Un gabarit spécifique est donc construit pour l'entête de chaque type de protocole dans lequel seuls les champs variables à 3 2002-0151 transmettre sont inclus. Les deux dispositifs d'extrémité qui utilisent ce mécanisme de compression sont configurés pour l'utiliser, soit de façon statique dans la configuration, soit de façon dynamique avec un protocole définissant quelle méthode doit être utilisée. Puis, lorsqu'une communication de données d'un n ud source à un n ud de destination est initialisée, la première trame est transmise avec un paquet complet, et, pour les trames suivantes, seulement des en-têtes compressés sont transmis en conformité avec un gabarit prédéfini ou déjà élaboré.
Avec les gabarits statiques, il existe plusieurs problèmes. Ainsi, tous les gabarits nécessaires doivent être prédéfinis, et il est également nécessaire de maintenir le gabarit adéquat pour une communication. Un autre problème est d'avoir un seul traitement qui n'affecte ni l'unité de traitement ni la mémoire et qui peut être appliqué indépendamment à plusieurs communications de données. Un autre problème est l'efficacité de la compression dans la mesure où certaines communications ne peuvent pas être compressées correctement sans des gabarits prédéfinis, ce qui est quasiment impossible vu le nombre de protocoles différents à supporter. Enfin, il y a aussi le problème de la négociation et du surplus de trafic qui y est associé.
Jusqu'à maintenant la plupart des efforts ont été réalisés pour réduire le surplus de trafic dû à l'en-tête pour des liaisons à vitesse faible ou moyenne dans lesquels l'impact du traitement de compression d'en-tête n'est pas trop important. Les méthodes de compression mentionnées cidessus nécessitent beaucoup de traitement dans la mesure ou elles sont orientées bit et basées sur des gabarits spécifiques utilisant chacun des règles différentes. Or, la compression d'en-tête devrait aussi concerner les liaisons à grande vitesse et pas seulement la compression d'en-tête IP mais un ensemble d'en-têtes relatifs à plusieurs couches de protocole 2857538 4 2002-0151 dès que plusieurs champs sont inchangés entre les paquets d'une même communication.
Outre ces mécanismes de compression d'en-tête utilisé avec IPv4, d'autres mécanismes ont été développés pour IPv6.
La mise en oeuvre de ces mécanismes différents est complexe dans la mesure où la compression basée sur un gabarit concerne généralement seulement un protocole parmi un ensemble de protocoles prédéfinis et n'est pas compatible et ne coexiste pas avec un autre mécanisme. Ainsi, le mécanisme CRTP est valable seulement pour les en-têtes VoIP et ne fonctionne pas avec d'autres types de communications.
Exposé de l'invention En conséquence, le but principale de l'invention est de fournir un système et de réaliser une méthode dans lesquels le gabarit à utiliser pour la compression ou décompression d'en-tête est créé dynamiquement pour chaque communication de données et de façon identique dans le noeud d'entrée et le noeud de sortie sans nécessiter la transmission du gabarit entre les deux n uds.
L'objet de l'invention est donc un système de compression d'en-tête pour compresser l'en-tête des paquets de données d'une communication transmis entre un n ud d'entrée et un noeud de sortie à travers un réseau de transmission de données, comprenant des moyens de création de gabarit dans le n ud d'entrée et le noeud de sortie adaptés pour créer le même gabarit de compression à partir d'un nombre prédéterminé de paquets de données non compressées au début de la communication respectivement transmis par le noeud d'entrée et reçus par le noeud de sortie, et des moyens de compression d'en-tête dans le noeud d'entrée adaptés pour compresser l'entête de chaque paquet qui suit le nombre prédéterminé de paquets de données non compressés avant de le transmettre à 2857538 5 2002-0151 travers le réseau de transmission de données, la compression étant réalisée en utilisant le gabarit de compression.
Description brève des dessins
Les buts, objets et caractéristiques de l'invention apparaîtront plus clairement à la lecture de la description qui suit faite en référence aux dessins dans lesquels: la figure 1 est un bloc-diagramme représentant schématiquement un système de mise en oeuvre de l'invention dans lequel un noeud d'entrée transmet des données à un noeud de sortie à travers un réseau de transmission de données; la Figure 2 représente un blocdiagramme du mécanisme dans le n ud d'entrée qui est utilisé pour créer le gabarit et compresser les en-têtes des paquets à transmettre; la figure 3 représente un bloc-diagramme du mécanisme dans le noeud de sortie utilisé pour créer le gabarit et décompresser les en-têtes des paquets reçus; les figure 4A, 4B, et 4C montrent respectivement la structure des paquets de données, sans l'utilisation de est un organigramme de la méthode selon est utilisée dans le noeud d'entrée et, est un organigramme de la méthode selon est utilisée dans le noeud de sortie.
Description détaillée de l'invention
En référence à la figure 1, un système dans lequel l'invention peut être mise en oeuvre comprend essentiellement un noeud d'entrée 10 en tant que source transmettant des paquets de données à un noeud de sortie 12 comme destination à travers un réseau de transmission de données 14. Dans le mode de réalisation préféré, le réseau 14 est un réseau à commutation d'étiquettes qui pourrait être n'importe quelle l'invention, en cas d'entête non compressé et en cas d'en-tête compressé; la figure 5 l'invention qui la figure 6 l'invention qui 2857538 6 2002-0151 sorte de réseau à zone étendue (WAN) dans lequel les données sont transmises par commutation de paquets.
Comme expliqué ci-dessous, le noeud d'entrée dispose d'un système dans lequel l'en-tête est compressé au moyen d'un gabarit de compression qui est construit de façon dynamique pour chaque communication. Par conséquent, le noeud d'entrée contient trois blocs de construction principaux qui sont un bloc de consultation de communications qui détermine si un gabarit existant peut être utilisé pour le paquet entrant, un bloc de création dynamique de gabarit utilisé pour construire un nouveau gabarit pour un paquet qui ne peut pas utiliser des gabarits existants et un bloc de compression d'en-têtes qui effectue la compression de l'en-tête du paquet lorsqu'un gabarit existe.
De façon similaire, le noeud de sortie dispose d'un système dans lequel l'en-tête est décompressé au moyen d'un gabarit de compression qui est construit de façon dynamique pour chaque communication en utilisant le même procédé que le noeud d'entrée. Le n ud de sortie contient trois blocs de construction principaux, à savoir un bloc de consultation d'étiquettes qui détermine si le paquet entrant contient un en-tête compressé ou non, et dans le premier cas à quel gabarit l'étiquette d'entrée est associée. Dans l'autre cas, un bloc de création dynamique de gabarit est utilisé pour construire un nouveau gabarit. Finalement, un bloc de décompression d'en-tête effectue la décompression de l'en-tête du paquet lorsqu'un gabarit existe et est fourni par la consultation d'étiquettes.
Une caractéristique essentielle consiste à utiliser une phase d'apprentissage pour construire les gabarits de façon dynamique. Durant cette phase d'apprentissage, les paquets de communication sont transmis de façon transparente c'est à dire sans compression d'en-tête. Dans le mode de réalisation préféré, une étiquette dédiée appelée LABX est utilisée pour 7 2002-0151 les paquets non compressés, tandis qu'une étiquette spécifique LABC est associée à chaque gabarit pour les paquets transmis ayant des en-têtes compressés en relation avec le gabarit correspondant.
La phase d'apprentissage est effectuée sur les paquets IP normaux qui débutent une communication. Un masque est construit en se basant sur l'analyse de plusieurs paquets consécutifs. Pour ceci, un OU exclusif est effectué sur tous les paquets et devient le gabarit de base (orienté bit) qui nécessite seulement d'être amélioré par l'identification de champs de numéros de séquence. Ce procédé sera décrit ci-après en détail.
Le procédé est le même à la transmission et à la réception de sorte que le gabarit n'est pas transmis. Puis, les champs variables sont identifiés et agrégés pour construire l'en-tête compressé. Un mécanisme optimise la longueur du gabarit en se basant sur le taux de densité des bits compressibles. Pour éliminer le risque de désynchronisation entre les procédés utilisés à la source et à la destination pour la création du gabarit, l'étiquette utilisée pour la transmission en clair des paquets (en-tête non compressé) est suivie par un champ de numéros de séquence. En outre, l'intégrité du paquet est assurée par la somme de contrôle du paquet IP.
Un exemple pour la construction du gabarit dans lequel sont utilisés quelques octets (7) en notation binaire et quelques paquets est décrit cidessous: Paquet 1: 01011010 10010101 01100110 11010101 11011000 11100101 11010110 30 Paquet 2: 01011110 10000101 11111111 11010101 11011001 11100101 11010110 Paquet 3: 01011010 10011101 01100110 11010111 11011010 11111101 11010110 8 2002-0151 A noter qu'un plus grand nombre de paquets (par ex 8 paquets) doit être utilisé de manière à au moins identifier les champs de numéros de séquence.
Le gabarit est comme suit: Masque: 00000100 00011000 10011001 00000010 00000011 00011000 00000000 Référence: olollxlo looxxlol xllxxllx llololxl 11011oYY 111XX1ol 11010110 Comme illustré ci-dessus, le gabarit comprend le masque qui résulte du X-OR de tous les paquets et dans lequel les bits 0 correspondent aux bits constants et les bit 1 correspondent aux bits changeants et la référence dans laquelle les bits 0 et 1 correspondent aux bits réels et les X correspondent aux bits qui ont été changés durant la phase d'apprentissage des paquets.
On suppose que, après la phase d'apprentissage, le paquet N suivant est reçu: Paquet N: 01011010 10000101 01100110 11010111 11011011 11111101 11010110 Le paquet N étant conforme à la référence, le masque s'applique: tous les bits du paquet N définis à partir du masque sont agrégés pour la transmission. Ceci correspond à 000000011111.
En fait, dans l'exemple, deux bits ont été identifiés YY du fait qu'ils ressemblent à un champ d'agrémentation. Dans un tel cas, au moins un octet entier (le choix prédéfini est généralement d'un ou plusieurs octets) n'est pas compressé de sorte qu'un nouveau gabarit est créé : Gabarit Masque: 00000100 00011000 10011001 00000010 11111111 00011000 00000000 Référence: olollxlo looxxlol x11xx11x llololxl YYYYYYYY 111XX1ol 11010110 9 2002-0151 Ce qui a pour résultat un en-tête compressé du paquet N qui est le suivant: 000000011101101111 La récupération, le réalignement et l'ajustement du gabarit sont effectués lorsque des erreurs surviennent en redémarrant la phase d'apprentissage, soit à partir du début du procédé de création, soit en utilisant le gabarit actif précédent comme point de départ. Dans ce cas, une nouvelle étiquette basée sur la valeur LABC est utilisée pour modifier le gabarit correspondant en utilisant des nouveaux paquets transmis en clair avec cette étiquette. Par exemple, une communication gardera deux étiquettes ayant seulement un bit différent pour transporter les paquets ayant des en-têtes compressés ou les paquets en clair pour la mise à jour du gabarit. Comme mentionné ci-dessus, les étiquettes suivies de paquets en clair sont suivis de numéros de séquence. Par conséquent, un registre conserve le numéro de séquence courant pour chaque étiquette LABX de façon à vérifier qu'aucun paquet n'a été perdu ou trouvé erroné dans la transmission. Une autre amélioration de l'intégrité du paquet est d'ajouter CRC (de l'en-tête d'origine) pour la vérification de transmission d'erreurs de façon à identifier un besoin de récupération.
Une amélioration du gabarit peut aussi être réalisée en transmettant un ou plusieurs paquets entiers lorsque l'en-tête du paquet entrant ne correspond pas à la référence de l'en- tête courant (définie comme étant l'ensemble des bits inchangés du gabarit). Ceci active un procédé de modification du gabarit. Le gabarit converge ainsi vers un état stable. La procédure de compression doit quelquefois être réactualisée pour être mieux optimisée. Ceci peut être réalisé par un seuil dans le taux de compression, un nombre de paquets transmis ou un compteur de temps.
L'en-tête compressé comprend un champ qui indique que c'est un en-tête compressé : 2002-0151 Ce champ appartient généralement à une couche inférieure (étiquette, Vc, champ dans le PPP) et a déjà été considéré dans des mécanismes de compression d'en-têtes existants. Dans le mode de réalisation préféré, une valeur LABC est utilisée pour un en-tête compressé et une valeur LABX pour un en-tête non compressé avec une valeur LABX dédiée pour les communications basées sur la valeur LABC correspondante (un bit inversé) ce qui perfectionne le procédé d'amélioration du gabarit.
La figure 2 décrit les blocs fonctionnels implémentés dans le noeud d'entrée. Un paquet d'origine arrivant sur l'entrée est analysé dans le bloc 20 qui effectue une consultation de communication. Dans IP, une communication est définie par des paquets ayant au moins la même adresse source, la même adresse destination et qui utilisent généralement le même protocole. Ainsi, l'étape de consultation compare les valeurs d'en-tête du paquet avec les gabarits disponibles dans la table 22. On notera que des actions ou analyses de protocole additionnelles sont effectuées à ce stade si elles n'ont pas été effectuées plus tôt dans le processus. Elles comprennent le routage, le filtrage si besoin et la décrémentation TTL. Par exemple, la table de gabarit peut contenir des instructions de routages associées à une communication ou la consultation peut être mise en oeuvre séparément du procédé de compression d'en-tête. Un tel traitement de paquet IP ne sera pas détaillé ici dans la mesure où il ne fait pas partie de l'invention. La sélection des communications pour lesquelles la compression d'en-tête est activée peut aussi être effectuée à ce stade ou plus tôt dans le traitement dans la mesure où toutes les communications ne nécessitent pas la compression d'en-tête. Une ou plusieurs étiquettes peuvent être réservées pour transporter des paquets qui ne sont pas impliqués dans le mécanisme de compression d'en-tête. De tels paquets ne doivent pas utiliser les 11 2002-0151 étiquettes employées pour le transport des paquets non compressés pour lesquels la compression est définie dans la mesure où ils auront un impact dans le procédé de compression. Ceci peut aussi être une façon de résoudre la limitation du calcul de performance. Lorsqu'un niveau de traitement défini est atteint, les communications entrantes supplémentaires ne sont pas compressées pour éviter un surplus de traitement le temps d'atteindre un niveau souhaitable.
La table de gabarit 22 dans laquelle la consultation est effectuée peut contenir une ou plusieurs communications correspondant à la consultation ou aucune. Dans ce dernier cas, le procédé du bloc 25 est activé de façon à créer un nouveau gabarit pour cette communication. Dans le premier cas, et si plus d'un gabarit est disponible, une seconde consultation sélectionne le gabarit qui a le moins de champs indéfinis correspondant par exemple au nombre de bits 1 dans le masque correspondant, ce qui est un calcul facile. Une fois que le gabarit à utiliser est défini, le procédé de compression d'en-tête du bloc 24 est activé en utilisant le mécanisme décrit à la figure 1. Le procédé de création du nouveau gabarit représenté par le bloc 25 peut fonctionner, soit en mode de création pour une nouvelle communication, soit en mode d'amélioration. Ce mode est fourni par l'analyse effectuée par le bloc d'analyse de paquet et consultation 20 qui détermine si l'adresse source et/ou l'adresse de destination de la communication sont présentes dans le gabarit. Si soit l'adresse source, soit l'adresse de destination n'est pas définie dans la table de gabarit pour une communication, alors une création d'un nouveau gabarit est nécessaire. Si les champs d'adresse source et de destination existent dans un gabarit mémorisé dans la table 22, alors un mode d'amélioration doit être utilisé. La différence essentielle entre les deux modes est qu'ils utilisent des étiquettes différentes pour transmettre les paquets non 12 2002-0151 compressés ce qui aide des deux côté à construire le nouveau gabarit. En rappel, un gabarit est construit en parallèle dans les noeuds d'entrée et de sortie grâce à l'ensemble de paquets non compressés transmis avant la compression. Pour cela, on utilise une étiquette dédiée dont la valeur est dérivée de l'étiquette utilisée pour transmettre des paquets ayant des en-têtes compressés associés au gabarit de la communication. Des étiquettes pour des en-têtes compressés sont appelées LABC tandis que les étiquettes pour les en-têtes non compressés associés sont appelées LABX. Elles diffèrent seulement par un bit inversé de sorte que c'est un moyen facile de les différencier.
Un gabarit est créé en utilisant la méthode de la figure 1 en utilisant plusieurs paquets non compressés consécutifs. Une fois défini, un nouveau gabarit doit être associé à une nouvelle étiquette (une LABC et LABX correspondante pour des modifications ultérieures). Lorsque le premier paquet est reçu pour construire le gabarit, le bloc 25 demande au bloc de gestion d'étiquettes 26 de fournir une nouvelle étiquette pour ce gabarit et la mémorise dans la table 22 dans la rangée où le nouveau gabarit à été mis. Lorsque le procédé est terminé, le bloc 25 mémorise ce nouveau gabarit dans la table de gabarit 22 avec son étiquette associée.
La méthode d'affectation et de gestion d'étiquette ne fait pas partie de l'invention et peut être mise en oeuvre au moyen de méthodes différentes. Une méthode est l'utilisation d'un protocole de distribution d'étiquette qui affecte une nouvelle étiquette pour le noeud d'entrée et le noeud de sortie pour chaque nouvelle communication. Un tel protocole de distribution d'étiquettes dépend en principe de l'infrastructure réseau utilisée telle que MPLS. Une autre méthode est d'affecter des étiquettes LABC/LABX seulement dans le noeud d'entrée en utilisant une procédure d'auto- 13 2002-0151 affectation. L'autre côté (noeud de sortie) comprendra que pour chaque nouvelle étiquette LABX pas encore définie, une nouvelle communication a commencé et mettra à jour sa base de données avec les étiquettes LABC et LABX correspondantes. Dans cette dernière implémentation, seules les étiquettes pour les communications non compressées définies LABU doivent être prédéfinies de façon à éviter une incompréhension due aux affectations d'étiquettes entre le noeud d'entrée et le noeud de sortie. Un procédé additionnel est nécessaire pour effacer les étiquettes avant de les réaffecter quand il n'y plus d'étiquettes disponibles. Le champ de contrôle d'option des étiquettes est utilisé pour un tel but pour les étiquettes existantes.
Le procédé de création d'une nouvelle communication transmet chaque paquet avec un en-tête non compressé et l'étiquette LABX associée au constructeur de paquet 28 qui dans ce cas transmet juste le paquet à l'interface de sortie après l'ajout d'un numéro de séquence entre l'étiquette et le paquet. Le numéro de séquence est nécessaire pour éviter de construire des gabarits différents des deux côtés si un paquet est perdu. Si un paquet est modifié, le CRC du paquet doit permettre d'identifier l'erreur. En cas d'erreur, soit un mécanisme de récupération est utilisé pour retransmette le paquet manquant, soit la création de gabarit est réinitialisée pour cette communication. La réinitialisation est effectuée grâce à un champ de contrôle d'option qui suit l'étiquette tel que décrit avec plus de détail dans la figure 4.
Comme mentionné ci-dessus, lorsqu'un gabarit est trouvé pour un paquet entrant dans le bloc 20 le procédé continue au bloc 24. Le bloc 20 procure au bloc 24 le paquet lui-même ou au moins la partie (nombre d'octets) qui est incluse dans le gabarit, le gabarit lui-même et l'étiquette associée (LABC) à utiliser. Le mécanisme de compression d'en- tête est très simple puisqu'il extrait simplement les bits qui sont définis 14 2002-0151 comme pouvant être modifiés dans l'en-tête du paquet et les agrège dans le même ordre que dans l'en-tête d'origine. En d'autres termes, tous les bits constants de l'en-tête sont retirés ce qui donne l'en-tête compressé. En option, un CRC de l'en-tête d'origine est calculé.
L'en-tête compressé, les données restantes (directement à partir du bloc 24 ou d'une autre mémoire intermédiaire dépendant de l'implémentation matérielle), l'étiquette LABC et de façon optionnelle le CRC de l'en-tête sont fournis par le bloc 24 au bloc de construction de paquet 28 qui juxtapose tous ces champs pour obtenir la trame compressée qui est transmise à l'interface de sortie. Le constructeur de paquet peut ajouter, si nécessaire, des champs optionnels (CRC, longueur, contrôle) pour une gestion améliorée du mécanisme de compression entre l'étiquette et l'entête compressé tel que défini à la figure 4.
La figure 3 décrit les blocs fonctionnels implémentés dans les n uds de sortie. Un paquet venant de l'entrée est analysé dans le bloc 30 qui effectue une consultation d'étiquettes. Ainsi, la consultation indique d'abord si le paquet utilise un en-tête compressé ou est un paquet non compressé. Si l'étiquette est une étiquette LABC, le paquet est compressé et un gabarit est associé. Si l'étiquette est une étiquette LABX, le paquet n'est pas compressé. Dans ce dernier cas, soit l'étiquette LABX est une nouvelle valeur LABX auquel cas un procédé de création de gabarit doit débuter, soit LABX est une étiquette existante associée à un gabarit (différent d'un bit de la valeur LABC existante) et une modification de gabarit (ou un effacement d'étiquette) débute. La table d'étiquettes et gabarits 32 dans laquelle la consultation est effectuée contient ou non une concordance pour cette étiquette.
Si une valeur LABC est utilisée, le paquet (au moins les champs comprenant l'en-tête compressé) est fourni au bloc 2857538 15 2002-0151 de décompression d'en-tête 34 qui reconstruit l'en- tête d'origine. Si une valeur LABX est détectée, le paquet est transmis au bloc de création et de mise à jour de gabarit 35 qui crée un nouveau gabarit pour la communication correspondant au paquet entrant. Le bloc 35 valide le numéro de séquence entrant pour continuer à créer le gabarit. En cas d'erreur, le procédé est arrêté et une alerte est fournie au constructeur de paquets du noeud d'entrée 28 de façon à commencer la procédure de récupération.
Un procédé de création de nouveau gabarit représenté sur le bloc 35 est identique au procédé du bloc 25 et aboutit à la même définition de gabarit qu'il travaille en mode de création pour une nouvelle communication ou en mode d'amélioration. Comme mentionné sur la figure 2, le même gabarit dynamique est construit en parallèle dans les noeuds d'entrée et de sortie grâce à des paquets non compressés transmis avant la compression et traités respectivement par les bloc 25 et 35.
Un gabarit est par conséquent créé dans le noeud de sortie en utilisant la méthode décrite dans la figure 1 grâce à plusieurs paquets non compressés consécutifs. Une fois défini, un nouveau gabarit a besoin d'être associé à une nouvelle étiquette (une LABC et la LABX correspondante pour des modifications ultérieures). Lorsque le premier paquet est reçu pour construire le gabarit, le bloc 35 ajoute une rangée LABX et LABC associéedans la table 32 qui définit les champs où le nouveau gabarit pour la communication correspondante est ajouté. Lorsque le processus est terminé, le bloc 35 mémorise ce nouveau gabarit et son étiquette associée dans la table des gabarits 32.
L'objectif de l'affectation d'étiquette et d'avoir finalement la même étiquette pour le même gabarit. L'affectation automatique de l'invention dans le noeud d'entrée 16 2002-0151 avec reconnaissance dans le n ud de sortie satisfait une telle exigence.
Le procédé de création de communication transmet chaque paquet avec un entête non compressé et l'étiquette LABX associé au constructeur de paquet 38 qui, dans ce cas, envoie le paquet à l'interface de sortie après retrait de l'étiquette et des champs optionnels pour conserver seulement le paquet d'origine reçu à l'entrée de la figure 2.
Comme mentionné ci-dessus, lorsqu'un paquet du type LABC est reçu et qu'un gabarit est trouvé pour le paquet entrant au bloc 30, le procédé continue au bloc 34. Le bloc 30 fournit au bloc 34 le paquet lui-même ou au moins les champs comprenant l'en-tête compressé et le gabarit lui-même de façon à reconstruire l'en-tête d'origine et à effectuer la vérification si un CRC est ajouté. Le mécanisme de compression d'en-tête est très simple puisqu'il remplace seulement les bits manquants, qui sont définis comme étant susceptibles de changer dans le gabarit, par les bits reçus de l'en-tête compressé ce qui restaure l'en-tête d'origine.
L'en-tête reconstruit et les données restantes (directement du bloc 34 ou d'une autre mémoire intermédiaire dépendant de l'implémentation) sont fournis par le bloc 34 au bloc constructeur de paquets 38 qui transmet ensuite le paquet reconstruit à l'interface de sortie.
En référence à la figure 4A, le paquet d'origine 40 comprend 2 champs, les données et l'en-tête. Le point de démarcation entre les deux champs n'est pas nécessairement en relation avec l'en-tête réel et la définition du bloc de données mais simplement avec la longueur maximum du gabarit.
Par exemple, la taille maximale du gabarit peut être arbitrairement établie à 128 octets à cause de l'implémentation matérielle, ce qui ne correspond pas nécessairement aux tailles d'en-têtes définies par les protocoles.
17 2002-0151 Dans le mode de réalisation préféré, les types de paquets sont identifiés par des étiquettes. Les paquets d'origine 42 illustrés sur la figure 4B utilisent une étiquette du type LABX. Une telle étiquette est simplement ajoutée à l'en-tête du paquet d'origine transmis sur le réseau. Les paquets 44 avec des en-têtes compressés, illustrés sur la figure 4C, utilisent une structure différente avec un format d'étiquette spécifique. Les étiquettes LABC et LABX sont décrites en détail ci-dessous.
Le format d'étiquette comprend un champ "option" (OP) qui indique si des champs additionnels sont ajoutés entre la valeur de l'étiquette de commutation (valeur SW + 1 bit de compression) et l'en-tête (compressé ou non). Ce bit de compression est ensuite suivi de plusieurs champs dont la présence est établie en utilisant le champ "option" mentionné ci-dessus. Ils comprennent un premier champ optionnel qui est la somme de contrôle de l'en-tête d'origine (CRC) pour vérifier l'en-tête reconstruit) en cas de LABC ou un champ de numéros de séquence (SEQ) en cas de LABX, un second champ de contrôle CTL pour la gestion bout à bout utilisé pour l'amélioration de l'en-tête, effacement d'étiquettes ou restauration de gabarits, et finalement le champ requis des bits delta (000000011101101111 dans l'exemple) aussi appelé données d'en-tête compressé dans le cas de LABC. Pour LABX, l'en-tête normal suit le dernier champ additionnel alors que c'est l'en-tête compressé en cas de LABC. On notera que, en cas d'erreur, de façon à accélérer le processus de récupération, un paquet vide LABX avec seulement un champ de contrôle peut être renvoyé s'en y inclure de données en réponse à un problème découvert dans la direction de trafic opposée.
Dans le mode de réalisation préféré, la valeur SW a une longueur prédéfinie telle que 16 bits par défaut. Cette taille peut changer selon la vitesse du lien et le nombre maximum des 18 2002-0151 différentes communications à supporter. Si la commutation d'étiquettes est utilisée, cette valeur (et longueur) peut changer à chaque n ud (remplacement d'étiquette) mais la distribution d'étiquettes prend en compte ce remplacement. Le bit de compression suit ce champ de valeur SW. Une valeur 0 indique que l'étiquette est une étiquette LABX alors qu'une valeur 1 indique une étiquette LABC. Le champ "option" (OP) est établi à 2 bits dont la valeur indique la présence ou non des champs optionnels.
É00 signifie aucun champ optionnel additionnel ^ 01 signifie première option seulement: numéro de séquence (SEQ) si LABX ou somme de contrôle d'en-tête (CRC) si LABC É 10 signifie seconde option seulement: champ de contrôle 15 dans les deux cas É 11 signifie les deux options Le numéro de séquence est un champ de 2 octets, le CRC est un champ de 2 ou 4 octets, le champ de contrôle est un octet dans le mode de réalisation proposé avec possibilité d'extension défini dans le champ de contrôle. Le champ de contrôle permet d'échanger des informations ou des commandes entre le n ud d'entrée et le n ud de sortie telles que le mode commande, le mode configuration, le mode d'échange d'étiquettes, le mode d'échange de gabarits, le mode sécurité et le mode récupération. Le mode est défini avec les trois premiers bits. Les trois bits suivants définissent l'action et les deux derniers bits l'extension du champ de contrôle pour échanger plus de données et dépend du type d'action.
Des exemples d'utilisation du champ de contrôle sont de: restaurer une création de gabarit, renvoyer un paquet perdu ou erroné, modifier les paramètres de configuration tels que la longueur du gabarit, le nombre de paquets à analyser pour créer un gabarit, la longueur d'étiquette ou la longueur du champ d'incrémentation des gabarits. La vérification 19 2002-0151 d'intégrité des gabarits/tables d'étiquettes est aussi réalisée en utilisant ce champ avec une possibilité de restauration de tables.
Le procédé selon l'invention qui est implémenté dans le noeud d'entrée, illustré sur la figure 5, commence lorsqu'un paquet d'origine est reçu à l'étape 50 et doit être transmis sur le réseau WAN pour lequel la compression de l'en-tête est validée. Les en-têtes du paquet définis par le protocole sont analysés à l'étape 51 (au moins le premier en-tête de protocole qui est IP). En se basant sur le filtrage prédéfini, le paquet correspond à un type pour lequel la compression d'en-tête doit être appliquée ou non. Cette sélection à l'étape 52 peut être simplement faite sur les champs d'adresse et de protocole de l'en-tête. Si aucune compression d'en-tête est nécessaire, le paquet est alors traité à l'étape 58 en y ajoutant une étiquette prédéfinie appelée LABU utilisant la structure LABX pour laquelle on n'utilise pas de champ additionnel mais seulement la valeur SW suivie par un 0 parce que le procédé est très similaire au transport de paquets non compressés, mais cette valeur ne doit pas être utilisée pour la création de gabarits.
Si le paquet appartient à une communication pour laquelle la compression d'en-têtes est admise, une consultation est effectuée pour vérifier si ce paquet appartient à une communication existante pour laquelle un gabarit existe déjà. A l'étape 53, si au moins un gabarit existe, le meilleur est sélectionné et le procédé continue à l'étape 55 où les bits qui diffèrent entre le gabarit et l'en-tête du paquet entrant sont extraits et groupés pour construire l'en-tête différentiel. Puis, à l'étape 57 une étiquette est utilisée, fournie par d'autres moyens qui utilisent la structure des étiquettes LABC. Le champ CRC, si il existe, est élaboré avec des valeurs correspondant à l'en-tête. Le champ de contrôle est ajouté si des données de 2002-0151 contrôle doivent être transmises à l'étape finale 59 et tous les champs sont agrégés selon la structure 44 définie à la figure 4 suivi par la transmission du paquet et son étiquette sur le réseau WAN.
Si la consultation de l'étape 53 se termine sans trouver de gabarit pour le paquet, un nouveau gabarit doit être construit. Un numéro de sequence est affecté temporairement de sorte que les autres paquets de la même communication auront le même traitement et participeront à la création du gabarit. Cette fonction de l'étape 54 peut fonctionner en deux modes. Soit la création d'un nouveau gabarit est effectuée, soit une mise à jour du gabarit est activée. Cette dernière est seulement possible si on a pu, à l'étape 53, trouver un gabarit proche du gabarit à utiliser mais avec quelques différences mineures empêchant de l'utiliser directement. Dans ce cas, ce gabarit est fourni pour la création de gabarits en tant que référence mais non comme gabarit réel de sorte que le gabarit créé sera plus restrictif avec plus de bits delta à transmettre. Ce peut être le cas dans une communication où les paquets ont des champs d'adresse et de protocole communs et dans lesquels d'autres champs ne changent pas au début de la transmission mais seulement après un nombre significatif de paquets. Pour une telle communication, l'apprentissage avec les premiers paquets ne fournit pas un gabarit valide pour tous les paquets de cette communication.
Le gabarit est construit dans les deux cas en utilisant les paquets consécutifs de la même communication qui sont identifiés comme aboutissant au même résultat après consultation des gabarits résultant en une même affectation du numéro de communication. L'étiquette LABC est requise à l'étape 56 lorsqu'un paquet commence une création de gabarit.
Les paquets suivants de la même communication évitent l'étape 56. Le procédé à l'étape 58' finit par la transmission sur le 21 2002-0151 réseau WAN du paquet d'origine non compressé ayant une étiquette LABX utilisant le format 44 défini à la figure 4. A ce stade, le numéro de séquence est incrémenté et si nécessaire un champ de contrôle est ajouté dans LABX.
La figure 6 décrit le procédé de réception dans le noeud de sortie qui débute avec un paquet et son étiquette reçus à partir du réseau WAN à l'étape 60. Le choix du procédé est effectué à l'étape 61 avec trois voies possibles. Si l'étiquette du paquet entrant est du type LABX, le procédé va à l'étape 63 correspondant au paquet non compressé reçu pour la création de gabarit. Si l'étiquette entrante est du type LABU, le procédé va à l'étape 68 correspondant à des paquets non compressés qui ne nécessitent pas la création de gabarits dans la mesure où ils sont transmis de façon transparente. Si l'étiquette est une étiquette LABC connue, le procédé va à l'étape 65 correspondant aux paquets ayant des en-têtes compressés pour lesquels l'en-tête devrait être recréé. Les étiquettes LABC inconnues sont traitées par un procédé d'erreur non montré.
Le procédé détaillé pour les paquets transmis avec des étiquettes LABX débute à l'étape 63 où un nouveau gabarit est créé en utilisant exactement le même procédé défini à la figure 5 dans la mesure où les noeuds d'entrée et de sortie suivent le même procédé qui aboutit au même gabarit. Si une LABX est utilisée pour laquelle une LABC est déjà affectée, la création de gabarit utilise le mode mise à jour tandis que si aucune étiquette LABC n'est associée, ce qui correspond à une LABX inconnue, une nouvelle création est effectuée. Pour chaque paquet reçu le numéro de séquence est vérifié aussi bien que l'intégrité du paquet (vérification de la somme de contrôle). Au cas d'erreur de paquet découverte à l'étape 64, la création de gabarit est arrêtée puisqu'elle aurait pour conséquence de créer un gabarit différent des deux côtés. Par conséquent, le procédé de récupération de l'étape 70 est 22 2002-0151 appelé par l'étape 64 de façon, soit à restaurer la création de gabarit, soit à demander la retransmission du paquet erroné si possible, ce qui est fait en utilisant les champs de contrôle du côté transmission du noeud correspondant à la liaison entre les blocs 35 et 28 des figures 3 et 2 respectivement. Puis le procédé continue à l'étape 68. Lorsque aucune erreur n'est trouvée à l'étape 64, une nouvelle rangée LABC et gabarit correspondant à l'étiquette LABX reçue est mémorisée à l'étape 66 lorsque le premier paquet est traité en cas de nouvelle étiquette LABX inconnue. Etape 66, la création de rangée dans la base de donnés est évitée pour les paquets suivants de la même communication utilisée pour la même création de gabarit et en cas de LABX existante correspondant à une mise à jour du gabarit. Finalement, à l'étape 68, l'étiquette LABX ou LABU d'un paquet transparent est retirée et ces paquets sont transmis à l'interface de destination de sortie. Les paquets erronés de l'étape 62 sont transmis comme s'ils devaient être éliminés, ceci n'étant pas une fonction incluse dans la présente invention.
Le procédé LABC détaillé commence à l'étape 65 lorsque l'étiquette LABC est retirée et une consultation fournit le gabarit correspondant qui permet de reconstruire l'en-tête d'origine à l'étape suivante 67. A cette étape une vérification d'intégrité peut être effectuée si l'option de CRC d'en-tête est activée. Autrement, le paquet entier CRC, si il est présent et inchangé depuis le noeud d'entrée, peut être utilisé pour valider la reconstitution de l'en-tête. Finalement à l'étape 69 le paquet reconstruit est transmis à l'interface de destination du noeud de sortie.

Claims (1)

  1. 23 2002-0151 REVENDICATIONS
    1. Système de compression d'en-tête pour compresser l'en-tête des paquets de données d'une communication transmis entre un n ud d'entrée (10) et un n ud de sortie (12) à travers un réseau de transmission de données (14); caractérisé en ce qu'il comprend: - des moyens de création de gabarit (20, 22, 25 ou 30, 32, 35), dans le n ud d'entrée et le n ud de sortie, adaptés pour créer le même gabarit de compression à partir d'un nombre prédéterminé de paquets de données non compressées au début de ladite communication respectivement transmis par ledit n ud d'entrée et reçus par ledit n ud de sortie, et - des moyens de compression d'en-tête (24) dans ledit n ud d'entrée, adaptés pour compresser l'en-tête de chaque paquet qui suit ledit nombre prédéterminé de paquets de données non compressés avant de le transmettre à travers ledit réseau de transmission de données, la compression étant réalisée en utilisant ledit gabarit de compression.
    2. Système de compression de données selon la revendication 1, dans lequel ledit n ud de sortie (12) comprend des moyens de décompression (34) pour décompresser l'en-tête de chaque paquet reçu après ledit nombre prédéterminé de paquets de données, la décompression étant réalisée en utilisant ledit gabarit de compression.
    3. Système de compression de données selon la revendication 2, dans lequel ledit n ud d'entrée (10) comprend en outre un bloc de gestion d'étiquettes (26) adapté pour fournir une première étiquette ajoutée à l'en-tête de chaque paquet de données parmi le nombre prédéterminé de paquets de données 24 2002-0151 non compressés et une seconde étiquette à ajouter à l'en- tête de chaque paquet de données compressés transmis après ledit nombre prédéterminé de paquets de données non compressés.
    4. Système de compression de données selon la revendication 3, dans lequel ladite première étiquette et ladite seconde étiquette comprennent chacune un bit de compression qui a une valeur prédéterminée (0) dans ladite première étiquette et dans lequel ladite seconde étiquette correspond à ladite première étiquette dans laquelle ledit bit de compression est établi à la valeur complémentaire (1).
    Système de compression de données selon la revendication 4, dans lequel lesdits moyens de création de gabarit comprennent une table de gabarits et d'étiquettes (22 ou 32) contenant les gabarits qui ont été créés, un bloc d'analyse de paquets et de consultation (20 ou 30) pour comparer respectivement l'en-tête de chaque paquet à transmettre par ledit n ud d'entrée (10) ou reçu par ledit n ud de sortie (12) avec les gabarits contenus dans ladite table de gabarits et d'étiquettes et un bloc de création de gabarit (25 ou 35) pour créer un nouveau gabarit lorsqu'il n'y a pas de gabarit pour la communication associée auxdits paquets de données, ledit nouveau gabarit étant mémorisé dans ladite table avec l'étiquette ajoutée auxdits paquets de données.
    6. Système de compression de données selon l'une quelconque des revendications 1 à 5, dans lequel ledit gabarit de compression comprend un masque composé d'autant d'octets que l'en-tête à compresser et dans lequel les bits changeants dudit en-tête sont des bits 1 tandis que les bits constants dudit en-tête sont des bits 0, ledit masque 2002-0151 résultant d'un OU exclusif logique entre les bits correspondants des en- têtes de paquets appartenant audit nombre prédéterminé de paquets.
    7. Procédé de compression pour compresser l'en-tête des paquets de données d'une communication transmise entre un noeud d'entrée (10) et un noeud de sortie (12) à travers un réseau de transmission de données (14), ledit procédé étant caractérisé en ce qu'il 10 consiste à : - créer un même gabarit de compression dans le n ud d'entrée et le noeud de sortie en utilisant un nombre prédéterminé de paquets de données non compressés au début de ladite communication respectivement transmis par ledit noeud d'entrée et reçus par ledit noeud de sortie; et - compresser l'en-tête de chaque paquet qui suit ledit nombre prédéterminé de paquets de données non compressés avant de le transmettre à travers ledit réseau de transmission de données, la compression étant réalisée en utilisant ledit gabarit de compression.
    8. Procédé de compression selon la revendication 7, dans lequel dans ledit noeud d'entrée (10), une étiquette d'un premier type (LABX) est ajoutée à l'en-tête de chaque paquet de données parmi le nombre prédéterminé de paquets de données non compressés et une étiquette d'un second type (LABC) est ajoutée à l'en-tête de chaque paquet de données compressés transmis après ledit nombre prédéterminé de paquets de données.
    9. Procédé de compression selon la revendication 8, dans lequel ladite étiquette d'une premier type (LABX) comprend un bit de compression qui a une valeur prédéterminée (0) et dans lequel ladite étiquette d'un second type (LABC) 26 2002-0151 correspond à ladite première étiquette dans laquelle ledit bit de compression a une valeur complémentaire (1).
    10. Procédé de compression selon la revendication 9, dans lequel une étiquette d'un troisième type (LABU) est ajouté à l'en-tête de chaque paquet de données d'une communication pour laquelle une compression d'entête n'est pas requise.
    11. Procédé de compression selon la revendication 10, comprenant en outre, une étape initiale avant ladite étape de création de gabarit dans ledit noeud d'entrée (10) consistant à déterminer si il y a déjà un gabarit pour la communication à laquelle le paquet de données appartient et à réaliser ladite étape de création de gabarit seulement si il n'y a pas de gabarit existant.
    12. Procédé de compression selon la revendication 11, dans lequel l'étape initiale a déterminé plusieurs gabarits existants pour ladite communication et dans lequel le gabarit ayant le moins de champs indéfinis est choisi parmi lesdits gabarits existants.
    13. Procédé de compression selon la revendication 11, dans lequel ladite étape consistant à créer un gabarit dans ledit noeud d'entrée (10) est utilisée en mode de mise à jour lorsqu'il est déterminé qu'il n'y a pas de gabarit existant pour la communication à laquelle appartient ledit paquet de données mais qu'il y a une communication antérieure ayant les mêmes adresses source et de destination.
    14. Procédé de compression selon la revendication 13, dans lequel ladite étiquette d'un premier type (LABX) à ajouter à l'en-tête de chaque paquet non compressé parmi le nombre 27 2002-0151 prédéterminé de paquets de données est l'étiquette d'un second type (LABC) associée à ladite communication antérieure dans laquelle ledit bit de compression a été mis à ladite valeur prédéterminée (0).
    15. Procédé de compression selon la revendication 14, dans lequel ladite étape de création d'un gabarit de compression est réalisée seulement si l'en-tête du paquet de données reçu comporte une étiquette du premier type (LABX).
    16. Procédé de compression selon la revendication 15, dans lequel une étiquette du second type (LABC) correspondant à ladite étiquette du premier type (LABX) comprise dans l'en-tête dudit paquet de données reçu dans lequel le bit de compression a été mis à ladite valeur complémentaire (1) est mémorisée de façon à être utilisée pour les paquets de données compressées de la même communication reçus plus tard.
    17. Procédé de compression selon la revendication 16, comprenant en outre l'étape de décompression de chaque paquet reçu par ledit noeud de sortie (12) comprenant ladite étiquette d'un second type (LABC).
    18. Procédé de compression selon la revendication 17, dans lequel l'entête de chaque paquet de données comprenant ladite étiquette d'un second type (LABC) est décompressé dans ledit noeud de sortie (12) en utilisant ledit gabarit de compression créé par l'utilisation dudit nombre prédéterminé de paquets de données non compressés.
    19. Procédé de compression selon la revendication 18, dans lequel l'étiquette dudit premier type (LABX) ajoutée à l'en-tête de chaque paquet de données appartenant audit 28 2002-0151 nombre prédéterminé de paquet de données non compressés comprend un numéro de séquence de façon à vérifier dans lesdits n uds de sortie (12) qu'aucun paquet de données n'a été perdu.
    20. Procédé de compression selon l'une des revendications 7 à 19, dans lequel ledit gabarit de compression comprend un masque composé d'autant d'octets que l'en-tête à compresser dans lequel les bits changeants dudit en-tête sont des bits 1 tandis que les bits constants dudit en-tête sont des bits 0, ledit masque résultant d'un OU exclusif logique entre les bits correspondants des en-têtes de paquets appartenant auxdits nombres prédéterminés de paquets.
FR0308318A 2003-07-08 2003-07-08 Systeme et methode de compression d'en-tete de paquets bases sur la creation dynamique d'un gabarit Expired - Fee Related FR2857538B1 (fr)

Priority Applications (4)

Application Number Priority Date Filing Date Title
FR0308318A FR2857538B1 (fr) 2003-07-08 2003-07-08 Systeme et methode de compression d'en-tete de paquets bases sur la creation dynamique d'un gabarit
CA002472908A CA2472908A1 (fr) 2003-07-08 2004-07-05 Systeme de compression d'en-tete de paquet et methode basee sur la creation d'un modele dynamique
US10/886,956 US7664881B2 (en) 2003-07-08 2004-07-08 Packet header compression system and method based upon a dynamic template creation
US12/647,492 US8065437B2 (en) 2003-07-08 2009-12-26 Packet header compression system and method based upon a dynamic template creation

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
FR0308318A FR2857538B1 (fr) 2003-07-08 2003-07-08 Systeme et methode de compression d'en-tete de paquets bases sur la creation dynamique d'un gabarit

Publications (2)

Publication Number Publication Date
FR2857538A1 true FR2857538A1 (fr) 2005-01-14
FR2857538B1 FR2857538B1 (fr) 2006-10-06

Family

ID=33522844

Family Applications (1)

Application Number Title Priority Date Filing Date
FR0308318A Expired - Fee Related FR2857538B1 (fr) 2003-07-08 2003-07-08 Systeme et methode de compression d'en-tete de paquets bases sur la creation dynamique d'un gabarit

Country Status (3)

Country Link
US (2) US7664881B2 (fr)
CA (1) CA2472908A1 (fr)
FR (1) FR2857538B1 (fr)

Families Citing this family (58)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
FR2857538B1 (fr) * 2003-07-08 2006-10-06 At & T Corp Systeme et methode de compression d'en-tete de paquets bases sur la creation dynamique d'un gabarit
US20050078704A1 (en) * 2003-10-14 2005-04-14 International Business Machines Corporation Method and apparatus for translating data packets from one network protocol to another
US8327026B1 (en) * 2004-07-01 2012-12-04 Hewlett-Packard Development Company, L.P. Method and system for selecting a data compression technique for data transfer through a data network
US7529845B2 (en) * 2004-09-15 2009-05-05 Nokia Corporation Compressing, filtering, and transmitting of protocol messages via a protocol-aware intermediary node
US20060153196A1 (en) * 2005-01-11 2006-07-13 Conexant Systems, Inc. Systems and methods for achieving improved ADSL data rates over USB 1.1 channel
EP1686732B1 (fr) * 2005-01-28 2007-10-31 Siemens Aktiengesellschaft Procédé et système de transmission d'unités de données de protocole
US7664041B2 (en) * 2005-05-26 2010-02-16 Dale Trenton Smith Distributed stream analysis using general purpose processors
US7602778B2 (en) * 2005-06-29 2009-10-13 Cisco Technology, Inc. System and methods for compressing message headers
US8054826B2 (en) * 2005-07-29 2011-11-08 Alcatel Lucent Controlling service quality of voice over Internet Protocol on a downlink channel in high-speed wireless data networks
US8257177B1 (en) 2005-10-04 2012-09-04 PICO Mobile Networks, Inc Proximity based games for mobile communication devices
US8411662B1 (en) 2005-10-04 2013-04-02 Pico Mobile Networks, Inc. Beacon based proximity services
US8619623B2 (en) * 2006-08-08 2013-12-31 Marvell World Trade Ltd. Ad-hoc simple configuration
US8233456B1 (en) 2006-10-16 2012-07-31 Marvell International Ltd. Power save mechanisms for dynamic ad-hoc networks
US8732315B2 (en) 2006-10-16 2014-05-20 Marvell International Ltd. Automatic ad-hoc network creation and coalescing using WiFi protected setup
US9308455B1 (en) 2006-10-25 2016-04-12 Marvell International Ltd. System and method for gaming in an ad-hoc network
US7889686B1 (en) 2006-11-21 2011-02-15 Picomobile Networks, Inc. Seamless switching of media streams between different networks
US7961756B1 (en) 2006-11-21 2011-06-14 Picomobile Networks, Inc. Integrated multimedia system
US7970384B1 (en) 2006-11-21 2011-06-28 Picomobile Networks, Inc. Active phone book enhancements
US8279884B1 (en) 2006-11-21 2012-10-02 Pico Mobile Networks, Inc. Integrated adaptive jitter buffer
US7978699B1 (en) * 2006-11-21 2011-07-12 Picomobile Networks, Inc. Protocol compression with synchronized sequence numbers
US8036133B2 (en) * 2007-03-05 2011-10-11 Nokia Corporation Efficient techniques for error detection and authentication in wireless networks
US8484214B2 (en) * 2007-03-28 2013-07-09 Cisco Technology, Inc. Record compression using incremental reverse templating
US8156174B2 (en) 2007-04-13 2012-04-10 Platform Computing Corporation Method and system for information exchange utilizing an asynchronous persistent store protocol
US8918051B1 (en) 2007-06-18 2014-12-23 Marvell International Ltd. Method and apparatus for performing a handoff of a data communication session from one network to another network
US8628420B2 (en) * 2007-07-03 2014-01-14 Marvell World Trade Ltd. Location aware ad-hoc gaming
US20110010465A1 (en) * 2007-07-18 2011-01-13 Andrea G Forte Methods and Systems for Providing Template Based Compression
KR101366254B1 (ko) * 2007-08-03 2014-02-20 삼성전자주식회사 방송망을 통하여 전송되는 ip 패킷의 압축 및 복원 방법
US7885294B2 (en) * 2007-08-23 2011-02-08 Cisco Technology, Inc. Signaling compression information using routing protocols
US8488553B2 (en) * 2008-06-05 2013-07-16 Alcatel Lucent Method for providing seamless transition between networks following different protocols
GB2463920B (en) * 2008-09-30 2012-08-22 Cambridge Broadband Networks Ltd Improved data compression
US8804535B2 (en) * 2009-03-25 2014-08-12 Avaya Inc. System and method for sending packets using another device's network address
US8165030B2 (en) * 2009-04-30 2012-04-24 Avaya Inc. System and method for monitoring a network communication at multiple network layers
US8072890B2 (en) * 2009-05-01 2011-12-06 Avaya Inc. System and method for testing a dynamic communication across a network
US8144734B2 (en) * 2009-05-06 2012-03-27 Avaya Inc. Intelligent multi-packet header compression
US8238254B2 (en) * 2009-05-14 2012-08-07 Avaya Inc. Detection and display of packet changes in a network
US8619594B2 (en) * 2009-07-31 2013-12-31 Avaya Inc. System and method for comparing packet traces for failed and successful communications
US8874793B2 (en) * 2009-11-30 2014-10-28 Qualcomm Innovation Center, Inc. Methods and apparatus for improving header compression
EP2334017B1 (fr) * 2009-12-10 2018-01-03 Alcatel Lucent Transmission d'un paquet dans un réseau de domaine personnel à capteur
US9380401B1 (en) 2010-02-03 2016-06-28 Marvell International Ltd. Signaling schemes allowing discovery of network devices capable of operating in multiple network modes
WO2012031269A1 (fr) * 2010-09-03 2012-03-08 Loglogic, Inc. Compression de données à accès direct
US8705533B1 (en) * 2010-12-10 2014-04-22 Juniper Networks, Inc. Fast packet encapsulation using templates
US8863256B1 (en) 2011-01-14 2014-10-14 Cisco Technology, Inc. System and method for enabling secure transactions using flexible identity management in a vehicular environment
US9154363B2 (en) 2011-05-13 2015-10-06 Qualcomm Incorporated Systems and methods for wireless communication of packets having a plurality of formats
US9515925B2 (en) * 2011-05-19 2016-12-06 Qualcomm Incorporated Apparatus and methods for media access control header compression
WO2012175132A1 (fr) * 2011-06-22 2012-12-27 Telefonaktiebolaget L M Ericsson (Publ) Compression d'en-tête à l'aide d'un livre de codes
JP6053692B2 (ja) * 2011-12-20 2016-12-27 キヤノン株式会社 データ転送装置、データ転送方法およびチップ間通信システム
KR20130116424A (ko) * 2012-03-16 2013-10-24 삼성전자주식회사 컨텐츠 중심 네트워크에서 ccn 패킷을 전송 및 수신하는 노드 및 그 방법
US9374443B2 (en) * 2013-07-11 2016-06-21 Qualcomm Incorporated Method and apparatus for efficient packet compression
US9674803B2 (en) 2013-09-23 2017-06-06 Qualcomm Incorporated Out-of synchronization detection and correction during compression
US9351195B2 (en) * 2013-09-23 2016-05-24 Qualcomm Incorporated Handling incompressible data packets on multiple data flows
CN105308927B (zh) * 2014-05-30 2019-03-19 华为技术有限公司 报文编辑处理方法和相关设备
US10798000B2 (en) * 2014-12-22 2020-10-06 Arista Networks, Inc. Method and apparatus of compressing network forwarding entry information
US9680749B2 (en) 2015-02-27 2017-06-13 Arista Networks, Inc. System and method of using an exact match table and longest prefix match table as a combined longest prefix match
CN106817350A (zh) * 2015-11-30 2017-06-09 中兴通讯股份有限公司 报文处理方法及装置
US11190206B2 (en) 2017-02-07 2021-11-30 European Space Agency Compression and decompression of time series data
JP6455541B2 (ja) * 2017-03-30 2019-01-23 日本電気株式会社 通信システム
CN113542125B (zh) * 2018-03-31 2022-11-25 华为技术有限公司 一种基于集成流表转发报文的方法及装置
MX2021015835A (es) 2019-08-27 2022-04-11 Lutron Tech Co Llc Dispositivo de control con un indicador visible.

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2002026860A1 (fr) * 2000-09-28 2002-04-04 Roke Manor Research Limited Procede de traitement de paquets de donnees

Family Cites Families (21)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5467087A (en) * 1992-12-18 1995-11-14 Apple Computer, Inc. High speed lossless data compression system
US5850526A (en) * 1996-02-07 1998-12-15 Kingston Technology Co. LAN station for determining the destination LAN station is capable of decompressing by comparing destination address to block of addresses assigned by a LAN manufacturer
US6041054A (en) * 1997-09-24 2000-03-21 Telefonaktiebolaget Lm Ericsson Efficient transport of internet protocol packets using asynchronous transfer mode adaptation layer two
US6032197A (en) * 1997-09-25 2000-02-29 Microsoft Corporation Data packet header compression for unidirectional transmission
FI107000B (fi) * 1999-02-17 2001-05-15 Nokia Mobile Phones Ltd Otsikon pakkaaminen reaaliaikaisissa palveluissa
US6680955B1 (en) * 1999-08-20 2004-01-20 Nokia Networks Oy Technique for compressing a header field in a data packet
US7158491B1 (en) * 1999-11-05 2007-01-02 Nokia Corporation Terminal-based link adaptation scheme having a detector which monitors application signaling and a requestor which requests a special channel based on the detection
US6711164B1 (en) * 1999-11-05 2004-03-23 Nokia Corporation Method and apparatus for performing IP-ID regeneration to improve header compression efficiency
US6967964B1 (en) * 2000-10-03 2005-11-22 Telefonaktiebolaget Lm Ericsson (Publ) Context identification using header compression key at link layer
US7069495B2 (en) * 2000-10-30 2006-06-27 Telefonaktiebolaget Lm Ericsson (Publ) Bit error resilience for an internet protocol stack
US6883035B2 (en) * 2000-11-16 2005-04-19 Telefonaktiebolaget Lm Ericsson (Publ) System and method for communicating with temporary compression tables
US7010727B1 (en) * 2001-06-15 2006-03-07 Nortel Networks Limited Method and system for negotiating compression techniques to be utilized in packet data communications
US6976081B2 (en) * 2002-01-30 2005-12-13 Motorola, Inc. Session initiation protocol compression
GB2386805B (en) * 2002-03-22 2004-05-26 Roke Manor Research Apparatus and method for compression of a signalling portion of a communications packet
US7359974B1 (en) * 2002-03-29 2008-04-15 Packeteer, Inc. System and method for dynamically controlling aggregate and individual packet flow characteristics within a compressed logical data tunnel
WO2004034651A1 (fr) * 2002-09-30 2004-04-22 Nokia Corporation Acheminement de paquets de donnees dans un domaine a en-tete comprime
US7065087B2 (en) * 2003-07-08 2006-06-20 Cisco Technology, Inc. Performing compression of user datagram protocol packets
FR2857538B1 (fr) * 2003-07-08 2006-10-06 At & T Corp Systeme et methode de compression d'en-tete de paquets bases sur la creation dynamique d'un gabarit
US7317724B2 (en) * 2003-07-08 2008-01-08 Cisco Technology, Inc. Performing compression of user datagram protocol packets
US7420992B1 (en) * 2005-03-17 2008-09-02 Packeteer, Inc. Adaptive network traffic compression mechanism including dynamic selection of compression algorithms
US7154416B1 (en) * 2005-09-22 2006-12-26 Packeteer, Inc. Adaptive control of codebook regeneration in data compression mechanisms

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2002026860A1 (fr) * 2000-09-28 2002-04-04 Roke Manor Research Limited Procede de traitement de paquets de donnees

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
BORMANN C ET AL: "RObust Header Compression (ROHC)", INTERNET DRAFT, 24 November 2000 (2000-11-24), XP002211014 *
JACOBSON V: "Compressing TCP/IP Headers for Low-Speed Serial Links", RFC 1144, February 1990 (1990-02-01), XP002139708 *

Also Published As

Publication number Publication date
FR2857538B1 (fr) 2006-10-06
US20050041660A1 (en) 2005-02-24
US8065437B2 (en) 2011-11-22
US7664881B2 (en) 2010-02-16
CA2472908A1 (fr) 2005-01-08
US20100098109A1 (en) 2010-04-22

Similar Documents

Publication Publication Date Title
FR2857538A1 (fr) Systeme et methode de compression d'en-tete de paquets bases sur la creation dynamique d'un gabarit
EP0559593B1 (fr) Procédé et dispositif de compression et décompression de données pour un système de transmission
EP3087701A1 (fr) Procede de diagnostic de fonctions service dans un reseau ip
FR2851708A1 (fr) Methode pour transmettre des paquets de haute priorite dans un reseau de transmission ip
EP0493286A1 (fr) Système de transmission par paquets à compression de données, procédé et équipement correspondant
FR2949931A1 (fr) Procedes et dispositifs de transmission d'un flux de donnees, produit programme d'ordinateur et moyen de stockage correspondants.
WO2009068822A2 (fr) Procede et dispositif de tri de paquets
FR3006534A1 (fr) Procedes de transmission et de reception de donnees entre un terminal et une passerelle, en particulier via une liaison satellite
WO2019068982A1 (fr) Signalisation d'une requête d'adaptation d'une session de communication en voix sur ip
EP3637845B1 (fr) Procédé de communication basé sur un protocole de transmission par trames
US20030215094A1 (en) Coding process method and coding process device
EP3332527A1 (fr) Procédé de transmission d'information entre deux domaines de niveaux de sécurité distincts
EP0547958B1 (fr) Procédé et un système de transmission d'information de communication sur une liaison de transmission par blocs de données de longueur variable en multiplexage temporel de type asynchrone
FR2900530A1 (fr) Dispositif de routage local de trafics locaux au sein d'un reseau de communitation radio, par detection dans des copies de trames descendantes de donnees correspondant a des copies de trames montantes
EP2469793A1 (fr) Dispositif de transmission de paquets de données, et procédé, programme d'ordinateur et moyens de stockage correspondants
EP1647125A1 (fr) Description de contenu de paquets dans un reseau de communication par paquets
WO2008145901A1 (fr) Procede et dispositif d'interface entre les protocoles udp ou tcp et sctp
EP1642439A1 (fr) Procede de transmission d informations supplementaires par c ompression d en-tete
WO2018178242A1 (fr) Procede d'apprentissage d'un contexte de compression/decompression, dispositif, systeme et produit programme d'ordinateur correspondants
FR2848050A1 (fr) Dispositif d'acces a un reseau de telecommunication pour la degradation selective des flots de donnees
FR2922068A1 (fr) Procede de notification a un dispositif source d'une taille limite de paquets de donnees, produit programme d'ordinateur, moyen de stockage et tete de tunnel correspondants
FR2951045A1 (fr) Procede de gestion de la taille de paquets de donnees d'un flux de donnees, produit programme d'ordinateur, moyen de stockage, et tete de tunnel correspondants.
FR3098366A1 (fr) Procédé et dispositif de codage du chemin d’un paquet de données
FR3069400A1 (fr) Adressage pour reseau de telecommunications utilisant la multidiffusion
EP0701355B1 (fr) Compression de paquets de données

Legal Events

Date Code Title Description
ST Notification of lapse

Effective date: 20160331