FR3012655A1 - Compteur en memoire flash - Google Patents
Compteur en memoire flash Download PDFInfo
- Publication number
- FR3012655A1 FR3012655A1 FR1360440A FR1360440A FR3012655A1 FR 3012655 A1 FR3012655 A1 FR 3012655A1 FR 1360440 A FR1360440 A FR 1360440A FR 1360440 A FR1360440 A FR 1360440A FR 3012655 A1 FR3012655 A1 FR 3012655A1
- Authority
- FR
- France
- Prior art keywords
- counter
- flash memory
- page
- memory
- value
- 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
Links
Classifications
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/34—Determination of programming status, e.g. threshold voltage, overprogramming or underprogramming, retention
- G11C16/349—Arrangements for evaluating degradation, retention or wearout, e.g. by counting erase cycles
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/10—Programming or data input circuits
- G11C16/14—Circuits for erasing electrically, e.g. erase voltage switching circuits
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/0223—User address space allocation, e.g. contiguous or non contiguous base addressing
- G06F12/023—Free address space management
- G06F12/0238—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
- G06F12/0246—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/10—Programming or data input circuits
- G11C16/20—Initialising; Data preset; Chip identification
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/26—Sensing or reading circuits; Data output circuits
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/34—Determination of programming status, e.g. threshold voltage, overprogramming or underprogramming, retention
- G11C16/3436—Arrangements for verifying correct programming or erasure
- G11C16/344—Arrangements for verifying correct erasure or for detecting overerased cells
- G11C16/345—Circuits or methods to detect overerased nonvolatile memory cells, usually during erasure verification
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Read Only Memory (AREA)
- Techniques For Improving Reliability Of Storages (AREA)
Abstract
L'invention concerne un procédé de mise à jour d'un compteur en mémoire flash, comportant : une première phase (41, 42, 43, 44, 45, 46) dans laquelle un ensemble de valeurs susceptibles d'être prises par le compteur sont programmées dans au moins une page de la mémoire flash ; et une deuxième phase (47, 48) dans laquelle, à chaque incrément/décrément du compteur, la valeur courante est programmée à l'état zéro dans la mémoire flash.
Description
COMPTEUR EN MÉMOIRE FLASH Domaine La présente description concerne de façon générale les circuits électroniques et, plus particulièrement, les circuits exploitant une mémoire flash. La présente description vise plus particulièrement la réalisation d'un compteur dont la valeur est stockée dans une mémoire flash. Exposé de l'art antérieur Dans de nombreuses applications, on a besoin de stocker de façon non volatile le résultat d'un compteur afin qu'il soit conservé indépendamment de l'alimentation du circuit. C'est le cas notamment dans les cartes à microcircuits qui intègrent un microprocesseur et au moins une mémoire non volatile, et plus généralement dans tout circuit électronique requérant des éléments de comptage en mémoire non volatile.
Jusqu'à présent, on utilise des mémoires de type EEPROM pour stocker la valeur d'un compteur. Résumé Suite au développement des mémoires de type flash, il serait souhaitable de pouvoir utiliser ces mémoires pour stocker 20 les valeurs de compteurs. Cependant, une contrainte est que les mémoires de type flash ne sont effaçables que par page entière de la mémoire.
B12947 - 13-ZV2-0366 2 Ainsi, un mode de réalisation vise un procédé de mise à jour d'un compteur en mémoire flash, comportant : une première phase dans laquelle un ensemble de valeurs susceptibles d'être prises par le compteur sont 5 programmées dans au moins une page de la mémoire flash ; et une deuxième phase dans laquelle, à chaque incrément/décrément du compteur, la valeur courante est programmée à l'état zéro dans la mémoire flash. Selon un mode de réalisation, la première phase 10 comporte : une étape d'effacement de la page de la mémoire ; et une étape d'écriture des valeurs successives du compteur en une seule fois dans la page. Selon un mode de réalisation, une lecture de la valeur 15 du compteur consiste à examiner séquentiellement le contenu de la page et à considérer la première valeur non nulle. Selon un mode de réalisation, une page comporte 64, 128 ou 256 octets. Selon un mode de réalisation, on prévoit également une 20 mémoire flash, programmée conformément au procédé ci-dessus. Selon un mode de réalisation, on prévoit également un circuit électronique comportant une telle mémoire flash. Brève description des dessins Ces caractéristiques et avantages, ainsi que d'autres, 25 seront exposés en détail dans la description suivante de modes de réalisation particuliers faite à titre non limitatif en relation avec les figures jointes parmi lesquelles : la figure 1 est un schéma-bloc d'un exemple de circuit électronique du type auquel s'applique les modes de réalisation 30 qui vont être décrits ; la figure 2 illustre, de façon très schématique et sous forme de blocs, un exemple de système exploitant un routeur NFC ; la figure 3 est une représentation schématique d'un 35 exemple de mémoire flash ; et B12947 - 13-ZV2-0366 3 la figure 4 illustre un mode de mise en oeuvre du procédé de programmation d'un compteur dans une mémoire flash. Description détaillée De mêmes éléments ont été désignés par de mêmes 5 références aux différentes figures. Par souci de clarté, seuls les étapes et éléments utiles à la compréhension des modes de réalisation qui vont être décrits ont été représentés et seront détaillés. En particulier, le fonctionnement électrique d'une mémoire flash lors des étapes d'écriture, de lecture et 10 d'effacement n'ont pas été détaillées, les modes de réalisation décrits étant compatibles avec les technologies usuelles des mémoires flash. De plus, les applications utilisant la mise à jour d'un compteur à stocker dans une mémoire flash n'ont pas non plus été détaillées, les modes de réalisation décrits étant, 15 là encore, compatibles avec les applications usuelles. Utiliser une mémoire flash pour stocker un compteur pose plusieurs problèmes par rapport à l'utilisation habituelle d'une mémoire EEPROM. Traditionnellement, lorsqu'un compteur est stocké dans 20 un mémoire EEPROM, la programmation et l'effacement s'effectuent par octet ou par mot dans la mémoire, ce qui offre une granularité suffisante. Une mémoire flash se programme, à partir d'un état initial vers des états 0 (états non conducteurs des cellules). 25 Cela signifie que les cellules de la mémoire doivent être initialisées à un état haut et que, pour stocker une donnée, on choisit soit de ne pas intervenir sur l'état du bit, soit de programmer ce bit à 0. Par ailleurs, un effacement (remise dans l'état 30 initial) s'effectue forcément par page mémoire. Une page est définie comme la taille minimale susceptible d'être adressée simultanément pour effacement. En pratique, cela correspond à la taille d'un registre recevant les données en série pour les transférer en parallèle au plan mémoire pour stockage.
B12947 - 13-ZV2-0366 4 Typiquement, une page représente actuellement, dans une mémoire flash, 32, 64, 128, 256 ou 512 octets. Or, un compteur requiert de changer l'état d'un seul bit (ou de quelques bits selon le pas d'incrément/décrément).
L'opération d'effacement d'une page est relativement longue (typiquement de l'ordre de quelques millisecondes) par rapport à une opération de programmation d'un octet (typiquement de l'ordre de la dizaine de microsecondes). Un processus consistant à effacer la page pour 10 programmer le nouvel état du compteur à chaque incrément prendrait trop de temps. En particulier, dans de nombreuses applications, le temps disponible pour écrire en mémoire non volatile est limité. C'est en particulier le cas dans des applications exploitant une technologie de communication en 15 champ proche et sans contact (NFC - Near Field Communication) car la durée de la transaction entre deux éléments communiquant n'est que temporaire et risque à tout moment d'être interrompue. Or, l'utilisation d'un compteur en mémoire non volatile est, dans ces applications, souvent liée à des questions de sécurité 20 en termes d'accès à certaines informations. La fiabilité du compteur est alors critique. On peut être amené à mettre en oeuvre des procédures dites d'atomicité pour améliorer cette fiabilité. Toutefois, ces procédures accroissent encore le besoin de mise à jour d'informations en mémoire non volatile. 25 La figure 1 représente, schématiquement, sous forme de blocs, un exemple de circuit électronique 1 du type auquel s'appliquent les modes de réalisation qui vont être décrits. Un tel circuit comporte une unité de traitement 12 (PU) susceptible de communiquer, par l'intermédiaire d'un ou plusieurs bus 13 de 30 données, d'adresses et de commandes, avec différents éléments parmi lesquels, par exemple, une interface d'entrée/sortie 14 (I/O) de communication avec l'extérieur du circuit 1, une ou plusieurs mémoires 15 (MEM) volatiles ou non volatiles, une ou plusieurs fonctions (symbolisées par un bloc 16, FCT) liées à 35 l'application, et au moins une mémoire flash 3 (FLASH). D'autres B12947 - 13-ZV2-0366 éléments sont susceptibles d'être raccordés aux bus 13 et/ou d'être inclus dans le circuit. Le cas échéant, la mémoire flash est externe au circuit 1. La figure 2 est une représentation schématique d'un 5 exemple de dispositif 2 incluant un ou plusieurs circuits électroniques 1' formant un routeur de communication en champ proche (NFC) susceptible de communiquer par différents bus 13 avec le reste du dispositif 2. Le routeur NFC sert d'interface entre les différents éléments du dispositif 2 et une antenne 22 de communication en champ proche avec un dispositif voisin non représenté. Dans l'exemple de la figure 2, le circuit NFC inclut au moins une mémoire flash 3. Les applications visées par la présente description exploitent, au moins un compteur dont la valeur est stockée dans 15 cette mémoire flash. La figure 3 illustre, de façon très schématique un exemple d'architecture d'une mémoire flash 3, une telle mémoire est généralement organisée en blocs 32 (BLOCK) comportant chacun plusieurs pages 34 (PAGE), chacune d'un nombre donné d'octets, 20 par exemple de 512, 1024 ou 2048 octets. L'écriture de données DATA dans la mémoire 3 ou l'effacement s'effectue par l'intermédiaire d'un registre d'entrée 36 (REG). Les données sont typiquement envoyées dans une communication série, ou par octet, dans le registre 36 d'écriture qui est ensuite déchargé 25 en parallèle vers un bloc de la mémoire. En lecture, l'adressage d'une zone conduit également à la lecture d'une page à travers un registre de sortie 38 qui fournit les données lues à l'extérieur. La représentation de la figure 3 est schématique et 30 les différents circuits de commande et d'adressage n'ont pas été illustrés. L'utilisation normale d'une mémoire flash pour stocker des données de taille inférieure à la page prendrait trop de temps. En effet, à chaque nouvelle valeur devant être stockée B12947 - 13-ZV2-0366 6 dans le compteur, il serait nécessaire d'effacer toute la page pour pouvoir reprogrammer une nouvelle valeur. On prévoit, dans une phase d'initialisation du compteur, d'effacer une page entière de la mémoire, puis de programmer toutes les valeurs attendues du compteur susceptibles d'être stockées dans cette page. Une fois cette initialisation de la page terminée, à chaque incrément ou décrément du compteur, on programme à zéro la valeur correspondante dans la page. En lecture, la valeur courante du compteur est donnée par la première valeur adressée (typiquement dans l'ordre séquentiel) qui n'est pas à zéro. La figure 4 illustre, de façon très schématique, un mode de mise en oeuvre d'un procédé de mise à jour d'un compteur dans une mémoire flash.
Dans une phase d'initialisation (INIT) du compteur, on commence par effacer (bloc 41, ERASE PAGE) la page correspondante de la mémoire, c'est-à-dire à placer tous les bits de la page dans un état 1 (octet à la valeur FF). Puis, dans une deuxième étape de cette phase d'initialisation, on 20 écrit toutes les valeurs successives du compteur en une seule fois dans la page de la mémoire. Par exemple, on génère en mémoire vive ou, dans des registres, les différentes valeurs par incréments ou décréments successifs de toutes les valeurs du compteur. Cette étape est illustrée en figure 4 par un bloc 42 25 (COUNT=00) d'initialisation de la valeur du compteur à 0 (octet à 00), puis par une boucle (blocs 42 à 46) dans laquelle la valeur courante est stockée (bloc 43, COUNT -> REG) dans un registre ayant, de préférence, la taille d'une page de la mémoire flash, un test (bloc 44, COUNT=FF ?) pour déterminer si 30 la valeur maximale du compteur est atteinte. Tant que toutes les valeurs n'ont pas été calculées (sortie N du test 44), le compteur est incrémenté (bloc 45, COUNT = COUNT + 1). Une fois que toutes les valeurs sont présentes dans le registre (sortie Y du test 44), le contenu de ce dernier est programmé dans la page 35 de la mémoire flash.
B12947 - 13-ZV2-0366 7 Un exemple de contenu de page est illustré en partie centrale en figure 4. Ces deux opérations prennent du temps mais ne sont à effectuées qu'une fois pour un compteur représenté par la 5 capacité d'une page. Lors du fonctionnement du compteur (OPERATION), c'est- à-dire de son utilisation par le circuit 1 et, plus particulièrement, lors d'un incrément de celui-ci (bloc 47, COUNT+1), on programme (bloc 48, PROG BYTE 00) les bits de 10 l'octet correspondant à la valeur 0 (octet à la valeur 00). Cette programmation s'effectue rapidement dans une mémoire flash à la différence de l'effacement car elle se fait par octet. Dans l'exemple de la figure 4, on suppose que la valeur courante est 00011010. Comme l'illustre la partie centrale de la figure 4, 15 cet octet (ainsi que tout les octets précédents par lesquels sont passées les valeurs du compteur se trouvent alors à 0. La phase d'initialisation peut être mise en oeuvre à chaque besoin de réinitialisation du compteur. Par exemple, en utilisant un compteur d'un octet (8 20 bits), une page de 256 octets de mémoire flash contient toutes les valeurs possibles du compteur. Dans le cas où le compteur est sur un nombre plus grand que contenu dans un octet, il suffit d'utiliser plusieurs pages et de concaténer les valeurs lues.
25 Un avantage des modes de réalisation qui ont été décrits est qu'ils rendent possibles l'utilisation d'une mémoire flash pour stocker la valeur d'un compteur. Un autre avantage est que la mise à jour du compteur est rapide en particulier par rapport au temps nécessaire à 30 l'effacement d'une page dans la mémoire flash. Divers modes de réalisation ont été décrits. Diverses variantes et modifications apparaîtront à l'homme de l'art. En particulier, la mise en oeuvre pratique des modes de réalisation qui ont été décrits est à la portée de l'homme du métier à
Claims (4)
- REVENDICATIONS1. PrOcédé de mise à jour d'un compteur en mémoire flash (3), comportant : une première phase (41, 42, 43, 44, 45, 46) dans laquelle un ensemble de valeurs susceptibles d'être prises par 5 le compteur sont programmées dans aû moins une page de la mémoire flash ; et une deuxième phase (47, 48) dans laquelle, à chaque incrément/décrément du compteur, la valeur courante est programmée à l'état zéro dans la mémoire flash.
- 2. Procédé selon la revendication 1, dans lequel la première phase comporte : une étape (41) d'effacement de la page de la mémoire ; une étape (46), d'écriture des valeurs successives du 15 compteur en une seule fois dans la page.
- 3. Procédé selon la revendication 1 ou 2, dans lequel une lecture de la valeur du compteur consiste à examiner séquentiellement le contenu de la page et à considérer la première valeur non nulle.
- 4. Procédé selon l'une quelconque des revendications 1 à 3, dans. lequel une page comporte 64, 128 ou 256 octets.
Priority Applications (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
FR1360440A FR3012655B1 (fr) | 2013-10-25 | 2013-10-25 | Compteur en memoire flash |
US14/522,007 US9390804B2 (en) | 2013-10-25 | 2014-10-23 | Flash memory counter |
US15/182,411 US9666290B2 (en) | 2013-10-25 | 2016-06-14 | Flash memory counter |
US15/494,134 US10181356B2 (en) | 2013-10-25 | 2017-04-21 | Flash memory counter |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
FR1360440A FR3012655B1 (fr) | 2013-10-25 | 2013-10-25 | Compteur en memoire flash |
Publications (2)
Publication Number | Publication Date |
---|---|
FR3012655A1 true FR3012655A1 (fr) | 2015-05-01 |
FR3012655B1 FR3012655B1 (fr) | 2015-12-25 |
Family
ID=50231291
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
FR1360440A Expired - Fee Related FR3012655B1 (fr) | 2013-10-25 | 2013-10-25 | Compteur en memoire flash |
Country Status (2)
Country | Link |
---|---|
US (3) | US9390804B2 (fr) |
FR (1) | FR3012655B1 (fr) |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
FR3020712B1 (fr) * | 2014-04-30 | 2017-09-01 | Proton World Int Nv | Compteur bidirectionnel en memoire flash |
FR3046267B1 (fr) * | 2015-12-28 | 2018-02-16 | Proton World International N.V. | Stockage de donnees dans une memoire flash |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20080064476A (ko) * | 2007-01-05 | 2008-07-09 | 주식회사 하이닉스반도체 | 플래쉬 메모리 소자의 소거 횟수 저장 방법 |
US20090259877A1 (en) * | 2008-04-14 | 2009-10-15 | Dell Products, Lp | Method to Implement a Monotonic Counter with Reduced Flash Part Wear |
Family Cites Families (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
TW302588B (en) * | 1996-03-05 | 1997-04-11 | Microchip Tech Inc | Method and apparatus for electronic encoding and decoding |
US5901225A (en) * | 1996-12-05 | 1999-05-04 | Advanced Micro Devices, Inc. | System and method for performing software patches in embedded systems |
US7551706B2 (en) * | 2004-12-03 | 2009-06-23 | Kyocera Mita Corporation | Counter device and counting method |
US7616508B1 (en) * | 2006-08-10 | 2009-11-10 | Actel Corporation | Flash-based FPGA with secure reprogramming |
JP5134255B2 (ja) * | 2007-01-30 | 2013-01-30 | 富士通株式会社 | データ記録システム |
US8239612B2 (en) * | 2007-09-27 | 2012-08-07 | Tdk Corporation | Memory controller, flash memory system with memory controller, and control method of flash memory |
KR101138101B1 (ko) * | 2010-05-27 | 2012-04-24 | 에스케이하이닉스 주식회사 | 불휘발성 메모리 소자의 프로그램 방법 |
FR3006804A1 (fr) * | 2013-06-05 | 2014-12-12 | St Microelectronics Rousset | Procede d’effacement par bloc d’une memoire de type eeprom effacable par page |
-
2013
- 2013-10-25 FR FR1360440A patent/FR3012655B1/fr not_active Expired - Fee Related
-
2014
- 2014-10-23 US US14/522,007 patent/US9390804B2/en active Active
-
2016
- 2016-06-14 US US15/182,411 patent/US9666290B2/en active Active
-
2017
- 2017-04-21 US US15/494,134 patent/US10181356B2/en active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20080064476A (ko) * | 2007-01-05 | 2008-07-09 | 주식회사 하이닉스반도체 | 플래쉬 메모리 소자의 소거 횟수 저장 방법 |
US20090259877A1 (en) * | 2008-04-14 | 2009-10-15 | Dell Products, Lp | Method to Implement a Monotonic Counter with Reduced Flash Part Wear |
Also Published As
Publication number | Publication date |
---|---|
US20170229187A1 (en) | 2017-08-10 |
US10181356B2 (en) | 2019-01-15 |
US9390804B2 (en) | 2016-07-12 |
US9666290B2 (en) | 2017-05-30 |
US20150117106A1 (en) | 2015-04-30 |
FR3012655B1 (fr) | 2015-12-25 |
US20160293262A1 (en) | 2016-10-06 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP2940690B1 (fr) | Compteur bidirectionnel en mémoire flash | |
US9086996B2 (en) | Nonvolatile memory, reading method of nonvolatile memory, and memory system including nonvolatile memory | |
EP2786317B1 (fr) | Ecriture de données dans une mémoire non volatile de carte à puce | |
EP1988548A1 (fr) | Mémoire non volatile à écriture rapide | |
CN104240749B (zh) | 半导体器件及其操作方法 | |
FR2926382A1 (fr) | Hierarchisation de cles cryptographiques dans un circuit electronique | |
FR3041806A1 (fr) | Dispositif de memoire non volatile, par exemple du type eeprom, ayant une capacite memoire importante, par exemple 16mbits | |
EP3293637A1 (fr) | Gestion d'index dans une mémoire flash | |
FR2982406A1 (fr) | Memoire securisee qui evite la degradation de donnees | |
FR2643478A1 (fr) | Carte a circuit integre | |
FR3012655A1 (fr) | Compteur en memoire flash | |
FR3008534A1 (fr) | Procede de gestion du fonctionnement d'un dispositif de memoire associant un plan-memoire du type sram et un plan memoire du type non volatil, et dispositif de memoire correspondant | |
FR3051574A1 (fr) | Gestion du stockage dans une memoire flash | |
FR2764073A1 (fr) | Protocole de communication pour carte a memoire asynchrone | |
EP1344137A1 (fr) | Procede et dispositif de securisation d'un traitement de donnees | |
FR2627316A1 (fr) | Memoire eeprom " flash " a processeur de controle du port d'ordres | |
EP3246819B1 (fr) | Compteur en mémoire flash | |
EP1980968B1 (fr) | Protection de l'exécution d'un programme | |
FR2809223A1 (fr) | Effacement d'eeprom en temps masque | |
EP3188024B1 (fr) | Stockage dans une mémoire flash | |
EP3188032B1 (fr) | Stockage de données dans une mémoire flash | |
FR3065303B1 (fr) | Procede d'ecriture dans un dispositif de memoire non volatile et dispositif de memoire non volatile correspondant | |
EP3522020A1 (fr) | Gestion d'une mémoire non volatile | |
FR3101974A1 (fr) | Procédé d’aide à l’identification de secteurs vierges d’une mémoire non-volatile d’un microcontrôleur | |
EP3416087A1 (fr) | Gestion d'atomicité dans une mémoire eeprom |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PLFP | Fee payment |
Year of fee payment: 3 |
|
CA | Change of address |
Effective date: 20160301 |
|
PLFP | Fee payment |
Year of fee payment: 4 |
|
PLFP | Fee payment |
Year of fee payment: 5 |
|
PLFP | Fee payment |
Year of fee payment: 6 |
|
PLFP | Fee payment |
Year of fee payment: 7 |
|
PLFP | Fee payment |
Year of fee payment: 8 |
|
ST | Notification of lapse |
Effective date: 20220605 |