One or more aspects of embodiments according to the present disclosure relate to data storage, and more particularly to a system and method for improving the data retention characteristics of a storage system using flash memory.
As lithographic geometry for NAND flash chips becomes smaller and the area of the memory cells becomes smaller, the number of electrons that may be used in storage decreases, and it may become more difficult to assure accurate storage of information. High-capacity NAND flash memory may achieve high density storage by using multi-level cells (2 bits/cell for multi-level cell (MLC), 3 bits/cell for triple-level cell (TLC), or 4 bits/cell for quad-level cell (QLC)) to store more than one bit per cell. The number of levels may increase further to provide more storage capability in the future. The increasing number of levels (and smaller distance between levels) and a corresponding reduction in the lower signal-to-noise ratio of the read channel may make a stronger error-correction code (ECC) advantageous.
The JEDEC JESD218 standard provides for both endurance and data retention requirements, for a solid state drive (SSD) built upon NAND flash. In the standard, “endurance” is the ability of NAND flash to withstand a number of erase and program cycles (or “P/E count”), and “data retention” is the ability of the SSD to retain data over time without unacceptable data loss.
Users of flash memory may on occasion have a need to preserve data stored in such memory over a long time interval, with or without accessing the data during that interval, and possibly with the flash memory system (e.g., an SSD including the flash memory) shut off. Thus, there is a need for a system and method for improving the data retention characteristics of a storage system using flash memory.
According to some embodiments of the present invention, there is provided a method, including: transitioning a flash memory to a long term data retention state by re-storing first encoded data, the first encoded data being initially stored in the flash memory at a first code rate, the re-storing including: determining a second code rate, lower than the first code rate; reading the first encoded data from the flash memory; decoding the first encoded data at the first code rate to obtain first decoded data; encoding the first decoded data at the second code rate to form second encoded data; and storing the second encoded data in the flash memory.
In some embodiments, the re-storing further includes, after reading a portion of the first encoded data from a first physical block of the flash memory, erasing the first physical block.
In some embodiments, the method further includes erasing a second physical block after erasing the first physical block, the amount of valid data on the first physical block before the erasing of the first physical block being less than the amount of valid data on the second physical block before the erasing of the second physical block.
In some embodiments, the re-storing further includes reading all valid data from the first physical block before erasing the first physical block.
In some embodiments, the determining of the second code rate includes selecting a code rate greater than a first ratio, the first ratio being the ratio of: a total data volume and a total available capacity.
In some embodiments, the total data volume is a sum of a total user data volume and a total system data volume; the total available capacity is a difference between a total capacity and a reserve capacity; and the selecting of a code rate greater than a first ratio includes selecting from among a set of available code rates the smallest code rate greater than the first ratio.
In some embodiments, the method further includes, in response to a request from a host: reading, while in the long term data retention state, a portion of the second encoded data, decoding the portion of the second encoded data to obtain decoded data, and sending the decoded data to the host.
In some embodiments, the method further includes, before the reading of the portion of the second encoded data: performing a plurality of trial reads at different respective threshold voltages from the flash memory, to obtain a corresponding set of raw data words; performing, with the raw data words, one or more successful decoding attempts and zero or more unsuccessful decoding attempts, to obtain an error rate for each successful coding attempt; and selecting a threshold voltage for use during the reading of the portion of the second encoded data.
In some embodiments: the performing of the one or more successful decoding attempts includes performing a plurality of successful decoding attempts; and the selecting of the threshold voltage for use during the reading of the portion of the second encoded data includes selecting a threshold voltage used during a successful decoding attempt, of the plurality of successful decoding attempts, having a minimum error rate.
In some embodiments, the reading of the portion of the second encoded data includes: performing a first read operation on a first plurality of flash memory cells, at a first reference voltage, to form a first raw data word; executing a first error correction code decoding attempt with the first raw data word; when the first error correction code decoding attempt succeeds: outputting a decoded data word generated by the first error correction code decoding attempt; and when the first error correction code decoding attempt does not succeed: performing a second read operation on the first plurality of flash memory cells, at a second reference voltage, to form a second raw data word; and executing a second error correction code decoding attempt with the first raw data word and the second raw data word.
In some embodiments, the method further includes transitioning from the long term data retention state to a normal operating state, the transitioning including: reading the second encoded data from the flash memory; decoding the second encoded data to obtain second decoded data; encoding the second decoded data at a third code rate, greater than the second code rate, to obtain third encoded data; and storing the third encoded data in the flash memory.
In some embodiments, the method further includes, before the reading of the second encoded data: performing a plurality of trial reads at different respective threshold voltages from the flash memory, to obtain a corresponding set of raw data words; performing, with the raw data words, one or more successful decoding attempts and zero or more unsuccessful decoding attempts, to obtain an error rate for each successful coding attempt; and selecting a threshold voltage for use during the reading of the second encoded data.
In some embodiments: the performing of the one or more successful decoding attempts includes performing a plurality of successful decoding attempts; and the selecting of the threshold voltage for use during the reading of the second encoded data includes selecting a threshold voltage used during a successful decoding attempt, of the plurality of successful decoding attempts, having a minimum error rate.
According to some embodiments of the present invention, there is provided a solid state drive, including: a flash memory; and a processing circuit, the processing circuit being configured to transition the flash memory to a long term data retention state by re-storing first encoded data, the first encoded data being initially stored in the flash memory at a first code rate, the re-storing including: determining a second code rate, lower than the first code rate; reading the first encoded data from the flash memory; decoding the first encoded data at the first code rate to obtain first decoded data; encoding the first decoded data at the second code rate to form second encoded data; and storing the second encoded data in the flash memory.
In some embodiments, the method further includes an error correcting code engine, the error correcting code engine being capable of: encoding data at the first code rate; encoding data at the second code rate; decoding data at the first code rate; and decoding data at the second code rate.
In some embodiments, the processing circuit is configured, in response to a request from a host, to: read, while in the long term data retention state, a portion of the second encoded data, decode the portion of the second encoded data to obtain decoded data, and send the decoded data to the host.
In some embodiments, the processing circuit is further configured, before the reading of the portion of the second encoded data, to: perform a plurality of trial reads at different respective threshold voltages from the flash memory, to obtain a corresponding set of raw data words; perform, with the raw data words, one or more successful decoding attempts and zero or more unsuccessful decoding attempts, to obtain an error rate for each successful coding attempt; and select a threshold voltage for use during the reading of the portion of the second encoded data.
In some embodiments, the performing of the one or more successful decoding attempts includes performing a plurality of successful decoding attempts; and the selecting of the threshold voltage for use during the reading of the portion of the second encoded data includes selecting a threshold voltage used during a successful decoding attempt, of the plurality of successful decoding attempts, having a minimum error rate.
In some embodiments, the processing circuit is further configured to transition from the long term data retention state to a normal operating state, the transitioning including: reading the second encoded data from the flash memory; decoding the second encoded data to obtain second decoded data; encoding the second decoded data at a third code rate, greater than the second code rate, to obtain third encoded data; and storing the third encoded data in the flash memory.
These and other features and advantages of the present disclosure will be appreciated and understood with reference to the specification, claims, and appended drawings wherein:
The detailed description set forth below in connection with the appended drawings is intended as a description of exemplary embodiments of a system and method for improving the data retention characteristics of a storage system using flash memory provided in accordance with the present disclosure and is not intended to represent the only forms in which the present disclosure may be constructed or utilized. The description sets forth the features of the present disclosure in connection with the illustrated embodiments. It is to be understood, however, that the same or equivalent functions and structures may be accomplished by different embodiments that are also intended to be encompassed within the scope of the disclosure. As denoted elsewhere herein, like element numbers are intended to indicate like elements or features.
Referring to
The solid state drive 110 may include a controller, buffer memory, error correcting code (ECC) engine, flash channel controller, and flash memory, as shown, all of the components of the solid state drive 110 being connected together. The controller may execute software and/or firmware, stored, for example, in the buffer memory, or in read-only memory in the controller (or separate from the controller). The ECC engine may encode data being written to the flash memory (through the flash channel controller), and decode data being read from the flash memory (through the flash channel controller); such encoding and decoding may make it possible to correct for bit errors, in the encoded data read from the flash memory, that may occur as a result of data degradation in the flash memory, or inaccuracy in writing or reading the flash memory cells.
The solid state drive 110 may include a flash memory, as shown. Data, e.g., user data to be stored in the flash memory at the request of the host, may be encoded, using an error correcting code, to form encoded data, and the encoded data may then be stored in the flash memory. Referring to
The ratio of the size of the unencoded code word to the size of the encoded code word may be referred to as the “code rate”. Generally, the greater the amount by which the encoding enlarges the data, the “stronger” the error correction code is, i.e., the more capable it is of correcting errors in the data. For example, when a lower code rate is used, the error correction code may be capable of correcting, during decoding, a larger number of bit errors than when a higher code rate is used.
Because a solid state drive may ordinarily be specified (e.g., to the host, or to a customer selecting a solid state drive) based on the amount of unencoded data it can store, the solid state drive may be constructed to contain more raw storage capacity (e.g., more flash memory) than the amount of unencoded data it is specified for. This type of construction may be referred to as “overprovisioning”.
The distributions of voltages corresponding to the levels of a flash memory cell may shift and widen over time, after a set of cells is written. Referring to
The flash memory may be configured as a plurality of physical blocks. Each physical block may be the smallest quantity of flash memory capable of being erased at a time, although it may be possible to read or write fractions of a physical block. As such, when a command to overwrite old data with new data is received from the host, the solid state drive may, instead of erasing the entire physical block containing the old data, write the new data in a different free region of flash memory, and mark the flash memory cells containing the old data as invalid. Each cell in the flash memory flash memory may be valid, invalid, or free. When a physical block contains a high proportion of invalid data, the solid state drive may (in a process referred to as “garbage collection”) move the remaining valid data in the physical block to one or more other physical blocks (decoding and re-encoding the data as needed), and erase the entire physical block so that all of the cells in it become free (i.e., available for writing).
In some embodiments, the solid state drive may be configured to transition (e.g., at the instruction of the host) to a long term data retention (LTDR) state. The transition may involve decreasing the code rate for some or all of the data stored in the solid state drive, so that it will be better able to endure a long period of inactivity without data loss. In some embodiments, all of the data (both the user data and the system data) are re-stored in the flash memory at a lower code rate (where “re-storing” means storing the same data in a different form, e.g., encoded with a different code rate). In other embodiments substantially all (e.g., at least 60%, or at least 80%, or at least 90%, or between 60% and 100%, of the stored data (e.g. of the stored user data or of the stored system data) are re-stored in the flash memory at a lower code rate.
In normal operation, data may be stored in the solid state drive at a first code rate, e.g., an operating code rate. Referring to
The determining, at 625, of the second code rate may be performed as follows, based on information regarding variable code rates supported by the ECC encoder/decoder, the raw size of the flash memory, and the space used. The following equation may be used:
CRmin=min(CRecc|CRecc>(U(GB)+S(GB))/((C(GiB)−Y(GiB))*1.0737/CRdef).
In this equation, U(GB) is the unencoded size of the used user data space in GB, and S(GB) is the unencoded size of the used system data space in GB. The precise value of S(GB) may not be readily available to the SSD controller, and an estimated number or an upper-bound number may be used. C(GiB) is the total NAND flash space acquired from the flash vendor in GiB (i.e., it is the effective storage capacity of the flash memory (which is smaller than the total flash memory capacity present), assuming that data will be encoded with the default code rate before being stored), and Y(GiB) is the minimum reserved free block space (discussed in further detail below) in GiB (multiplying (C(GiB)−Y(GiB)) by 1.0737 converts this quantity from units of GiB to units of GB). The effective storage capacity C is used in the expression above because vendors of flash media may specify the effective size, for data stored at the default code rate, of flash media chips or flash dies. CRdef is the default code rate. (C(GiB)−Y(GiB))*1.0737/CRdef is all space including spare bytes.
The expression
(U(GB)+S(GB))/((C(GiB)−Y(GiB))*1.0737/CRdef)
gives the lowest code rate at which all of the user data and system data would fit into the flash memory while leaving vacant the specified reserved free pool 751. The ECC engine, however, may not be able to provide an arbitrary code rate, and may instead be capable of operating with any one of a set of available code rates. The equation above, for CRmin, therefore selects, from among the set of available code rates, the smallest one that exceeds
(U(GB)+S(GB))/((C(GiB)−Y(GiB))*1.0737/CRdef).
The above expression may be seen to be the ratio of a total data volume and a total available capacity, where (i) the total data volume is a sum of a total user data volume (U) and a total system data volume (S) and (ii) the total available capacity is a difference between a total capacity (C) and a reserve capacity (the size Y of the reserved free pool 751). In this status, overprovisioning is reduced to 0. The above equation for CRmin may also be written as follows:
CRmin=min(CRecc|CRecc>(Uunenc+Sunenc)/(Craw−Yraw))
where the subscripts “unenc” and “raw” refer to sizes and capacities assuming that data are not encoded, or are encoded at a code rate of 1. For example, Uunenc is the unencoded size of the user data, i.e., the size of the data as processed by the host, and Craw is the capacity without encoding. In the above equation the units are omitted, and the equation will produce the same result regardless of whether units GB or GiB are used, if the same units are used throughout. The expression (Uunenc+Sunenc)/(Craw−Yraw) is also the ratio of a total data volume and a total available capacity, where (i) the total data volume is a sum of a total user data volume (Uunenc) and a total system data volume (Sunenc) and (ii) the total available capacity is a difference between a total capacity (Craw) and a reserve capacity (Yraw) (the size of the reserved free pool 751).
The process of re-storing may be performed beginning with the physical block (e.g., a “first physical block”) that has the least valid data. The valid data may be read out, decoded, re-encoded, and stored in another free erased physical block, and the first physical block may then be erased to become free erased blocks. The process may then be repeated for each remaining physical block that has valid data (encoded at, e.g., an operating code rate), in order of increasing amount of valid data. This order may reduce the risk that the solid state drive may run out of free erased block space during the process of re-storing. If the solid state drive nonetheless runs out of free erased block space during the process of re-storing, then the normal garbage collection may be invoked to obtain additional free erased blocks.
Once all of the data have been re-stored, the solid state drive may log its status (by saving a log file/status in the flash memory/or other non-volatile memory, e.g. on-board SPI flash), and prompt the host to shut off power to the solid state drive. An operator may then unplug the solid state drive and place it in storage (e.g., temperature-controlled storage, which may reduce the extent to which high temperatures may accelerate degradation of data on the device).
If the command is a read command, the solid state drive selects, at 861, a threshold voltage to be used to read raw (encoded) data from the flash memory. The selecting of the threshold voltage may include performing a plurality of trial reads, from the flash memory, at different respective threshold voltages (e.g., sweeping the threshold voltage over a range of voltages), to obtain a corresponding set of raw data words, and performing a hard-decision decoding attempt with each of the raw data words or performing a soft-decision decoding attempt with a set of raw data words. If none of the decoding attempts is successful, the solid state drive may return an error message. If only one of the decoding attempts is successful, the solid state drive may select, for use in subsequent read operations, the threshold voltage (Vt_min) that resulted in the successful decoding attempt. If several of the decoding attempts are successful, the solid state drive may select, for use in subsequent read operations, the threshold voltage (Vt_min) that resulted in the lowest error rate from among the error rates produced by the successful decoding attempts. The solid state drive then reads raw data corresponding to the read command, decodes it at the second (LTDR) code rate, and returns the decoded data to the host.
In another embodiment, the solid state drive may instead perform adaptive multiple reads with soft decision decoding attempts, as disclosed in the '962 Application, i.e., performing additional reads at additional threshold voltage values, until a decoding attempt succeeds.
If at 851 the solid state drive determines that it is being instructed to exit from the long term data retention state and transition back to the normal operating state, then it selects, at 852, a threshold voltage (Vt_min), e.g., using the same method as that used at 862, and, at 853, sets the threshold voltage to be used for subsequent reads to Vt_min. it then, at 854, sets the code rate to a higher code rate than the second (LTDR) code rate (e.g., to the code rate CRnew) and begins, at 855, (i) performing normal operations, accepting commands and performing garbage collection as needed (using the reserved free pool 751), while concurrently (ii) re-storing the data using the third code rate, i.e., reading the data from flash memory, decoding it at the second code rate, encoding it at the third code rate (to form “third encoded data”), and storing the third encoded data in the flash memory. Once the re-storing is complete, the solid state drive returns, at 856, to normal operations. CRnew can be expressed as (U(GB)+S(GB))/(((C(GiB)−Y(GiB))*1.0737/CRdef)*(1−OP)), where OP is an over-provisioning fraction selectable by the host or solid state drive.
As used herein, a “flash memory” is any quantity of flash memory. The flash memory may be in the form of one or more flash memory dies or one or more flash memory packages, each flash memory package containing one or more flash memory dies. As such, a plurality of flash memories may together form a flash memory, and a flash memory may include a plurality of flash memories.
The controller, the ECC engine, and other circuits described herein, or circuits for performing any of the functions described herein, may be implemented in one or more processing circuits. The term “processing circuit” is used herein to mean any combination of hardware, firmware, and software, employed to process data or digital signals. Processing circuit hardware may include, for example, application specific integrated circuits (ASICs), general purpose or special purpose central processing units (CPUs), digital signal processors (DSPs), graphics processing units (GPUs), and programmable logic devices such as field programmable gate arrays (FPGAs). In a processing circuit, as used herein, each function is performed either by hardware configured, i.e., hard-wired, to perform that function, or by more general purpose hardware, such as a CPU, configured to execute instructions stored in a non-transitory storage medium. A processing circuit may be fabricated on a single printed circuit board (PCB) or distributed over several interconnected PCBs. A processing circuit may contain other processing circuits; for example a processing circuit may include two processing circuits, an FPGA and a CPU, interconnected on a PCB.
As used herein, “a portion of” something means all, or less than all, of the thing. As such, for example “a portion the first encoded data” means all or less than all of the first encoded data. As used herein, the word “or” is inclusive, so that, for example, “A or B” means any one of (i) A, (ii) B, and (iii) A and B. It will be understood that, although the terms “first”, “second”, “third”, etc., may be used herein to describe various elements, components, regions, layers and/or sections, these elements, components, regions, layers and/or sections should not be limited by these terms. These terms are only used to distinguish one element, component, region, layer or section from another element, component, region, layer or section. Thus, a first element, component, region, layer or section discussed herein could be termed a second element, component, region, layer or section, without departing from the spirit and scope of the inventive concept.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the inventive concept. As used herein, the terms “substantially,” “about,” and similar terms are used as terms of approximation and not as terms of degree, and are intended to account for the inherent deviations in measured or calculated values that would be recognized by those of ordinary skill in the art.
As used herein, the singular forms “a” and “an” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising”, when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof. As used herein, the term “and/or” includes any and all combinations of one or more of the associated listed items. Expressions such as “at least one of,” when preceding a list of elements, modify the entire list of elements and do not modify the individual elements of the list. Further, the use of “may” when describing embodiments of the inventive concept refers to “one or more embodiments of the present disclosure”. Also, the term “exemplary” is intended to refer to an example or illustration. As used herein, the terms “use,” “using,” and “used” may be considered synonymous with the terms “utilize,” “utilizing,” and “utilized,” respectively.
It will be understood that when an element or layer is referred to as being “on”, “connected to”, “coupled to”, or “adjacent to” another element or layer, it may be directly on, connected to, coupled to, or adjacent to the other element or layer, or one or more intervening elements or layers may be present. In contrast, when an element or layer is referred to as being “directly on”, “directly connected to”, “directly coupled to”, or “immediately adjacent to” another element or layer, there are no intervening elements or layers present.
Any numerical range recited herein is intended to include all sub-ranges of the same numerical precision subsumed within the recited range. For example, a range of “1.0 to 10.0” is intended to include all subranges between (and including) the recited minimum value of 1.0 and the recited maximum value of 10.0, that is, having a minimum value equal to or greater than 1.0 and a maximum value equal to or less than 10.0, such as, for example, 2.4 to 7.6. Any maximum numerical limitation recited herein is intended to include all lower numerical limitations subsumed therein and any minimum numerical limitation recited in this specification is intended to include all higher numerical limitations subsumed therein.
Although exemplary embodiments of a system and method for improving the data retention characteristics of a storage system using flash memory have been specifically described and illustrated herein, many modifications and variations will be apparent to those skilled in the art. Accordingly, it is to be understood that a system and method for improving the data retention characteristics of a storage system using flash memory constructed according to principles of this disclosure may be embodied other than as specifically described herein. The invention is also defined in the following claims, and equivalents thereof.
The present application claims priority to and the benefit of U.S. Provisional Application No. 62/742,053, filed Oct. 5, 2018, entitled “METHOD OF INCREASING SSD LONG TERM DATA RETENTION DURATION”, and is a continuation-in-part of U.S. patent application Ser. No. 16/573,962 (“the '962 Application”), filed Sep. 17, 2019, which is a continuation of U.S. patent application Ser. No. 15/723,041, filed Oct. 2, 2017, now U.S. Pat. No. 10,417,087, issued Sep. 17, 2019; U.S. patent application Ser. No. 15/723,041 claims priority to and the benefit of U.S. Provisional Application No. 62/403,610, filed Oct. 3, 2016, and is continuation-in-part of U.S. patent application Ser. No. 15/230,075, filed Aug. 5, 2016, now U.S. Pat. No. 10,216,572, issued Feb. 26, 2019; U.S. patent application Ser. No. 15/230,075 is a continuation-in-part of U.S. patent application Ser. No. 14/806,063, filed Jul. 22, 2015, which claims priority to and the benefit of U.S. Provisional Application No. 62/027,683 filed Jul. 22, 2014. The entire contents of all of the applications identified in this paragraph are hereby incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
7778197 | Kim | Aug 2010 | B2 |
8250437 | Sakurada et al. | Aug 2012 | B2 |
8327245 | Radke | Dec 2012 | B2 |
8363738 | Gorokhov | Jan 2013 | B2 |
8707132 | Nakagawa et al. | Apr 2014 | B2 |
8762798 | Hu | Jun 2014 | B2 |
8869009 | Gurgi | Oct 2014 | B2 |
8875003 | Wolter et al. | Oct 2014 | B1 |
8924824 | Lu | Dec 2014 | B1 |
9013920 | Stoev | Apr 2015 | B2 |
9047882 | Pan | Jun 2015 | B2 |
9214963 | Garani | Dec 2015 | B1 |
9244763 | Kankani et al. | Jan 2016 | B1 |
9633740 | Alhussien et al. | Apr 2017 | B1 |
9697077 | Sokolov et al. | Jul 2017 | B2 |
9831969 | Song | Nov 2017 | B2 |
9870830 | Jeon | Jan 2018 | B1 |
10263814 | Eroz | Apr 2019 | B2 |
20030174771 | Sugahara | Sep 2003 | A1 |
20080106936 | Yang et al. | May 2008 | A1 |
20080109703 | Brandman | May 2008 | A1 |
20080263265 | Litsyn et al. | Oct 2008 | A1 |
20100020611 | Park | Jan 2010 | A1 |
20110066902 | Sharon et al. | Mar 2011 | A1 |
20130132652 | Wood et al. | May 2013 | A1 |
20140040704 | Wu et al. | Feb 2014 | A1 |
20140056068 | Strasser et al. | Feb 2014 | A1 |
20140149825 | Motwani et al. | May 2014 | A1 |
20150127883 | Chen et al. | May 2015 | A1 |
20150193302 | Hyun et al. | Jul 2015 | A1 |
20150309872 | Cai et al. | Oct 2015 | A1 |
20150339189 | Wu et al. | Nov 2015 | A1 |
20160006462 | Hanham et al. | Jan 2016 | A1 |
20160274969 | Chen et al. | Sep 2016 | A1 |
20160306694 | Tai et al. | Oct 2016 | A1 |
20170024279 | Lu | Jan 2017 | A1 |
Number | Date | Country |
---|---|---|
WO 2009002940 | Dec 2008 | WO |
Number | Date | Country | |
---|---|---|---|
20200034233 A1 | Jan 2020 | US |
Number | Date | Country | |
---|---|---|---|
62742053 | Oct 2018 | US | |
62403610 | Oct 2016 | US | |
62027683 | Jul 2014 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15723041 | Oct 2017 | US |
Child | 16573962 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16573962 | Sep 2019 | US |
Child | 16592727 | US | |
Parent | 15230075 | Aug 2016 | US |
Child | 15723041 | US | |
Parent | 14806063 | Jul 2015 | US |
Child | 15230075 | US |