A distributed storage system may include a plurality of storage devices (e.g., storage arrays) to provide data storage to a plurality of nodes. The plurality of storage devices and the plurality of nodes may be situated in the same physical location, or in one or more physically remote locations. The plurality of nodes may be coupled to the storage devices by a high-speed interconnect, such as a switch fabric.
According to aspects of the disclosure, a method is provided for storing data in a storage system, comprising: receiving a write request at the storage system, the write request being associated with a first LBA; detecting whether the write request is associated with one of a deduplication tier or a non-deduplication tier of the storage system, the deduplication tier of the storage system including a first portion of a volume in the storage system, and the non-deduplication tier including a second portion of the volume; when the write request is associated with the deduplication tier of the storage system, storing data associated with the write request in the first portion of the volume and updating a first mapping structure to map the first LBA to at least one first hash digest that is generated based on the data; and when the write request is associated with the non-deduplication tier of the storage system, storing data associated with the write request in the second portion of the volume and updating the first mapping structure to map the first LBA to a second hash digest that is generated based on a second LBA, the second LBA identifying a first region in the second portion of the storage system where the data is stored.
According to aspects of the disclosure, a system is provided, comprising: a memory; and one or more processors operatively coupled to the memory, the one or more processors being configured to perform the operations of: receiving a write request at the storage system, the write request being associated with a first LBA; detecting whether the write request is associated with one of a deduplication tier or a non-deduplication tier of the storage system, the deduplication tier of the storage system including a first portion of a volume in the storage system, and the non-deduplication tier including a second portion of the volume; when the write request is associated with the deduplication tier of the storage system, storing data associated with the write request in the first portion of the volume and updating a first mapping structure to map the first LBA to at least one first hash digest that is generated based on the data; and when the write request is associated with the non-deduplication tier of the storage system, storing data associated with the write request in the second portion of the volume and updating the first mapping structure to map the first LBA to a second hash digest that is generated based on a second LBA, the second LBA identifying a first region in the second portion of the storage system where the data is stored.
According to aspects of the disclosure, a non-transitory computer-readable medium configured to store one or more processor-executable instructions, which when executed by one or more processors, cause the processors to perform the operations of: receiving a write request at the storage system, the write request being associated with a first LBA; detecting whether the write request is associated with one of a deduplication tier or a non-deduplication tier of the storage system, the deduplication tier of the storage system including a first portion of a volume in the storage system, and the non-deduplication tier including a second portion of the volume; when the write request is associated with the deduplication tier of the storage system, storing data associated with the write request in the first portion of the volume and updating a first mapping structure to map the first LBA to at least one first hash digest that is generated based on the data; and when the write request is associated with the non-deduplication tier of the storage system, storing data associated with the write request in the second portion of the volume and updating the first mapping structure to map the first LBA to a second hash digest that is generated based on a second LBA, the second LBA identifying a first region in the second portion of the storage system where the data is stored.
Other aspects, features, and advantages of the claimed invention will become more fully apparent from the following detailed description, the appended claims, and the accompanying drawings in which like reference numerals identify similar or identical elements. Reference numerals that are introduced in the specification in association with a drawing figure may be repeated in one or more subsequent figures without additional description in the specification in order to provide context for other features.
According to the present example, the processor 310 may be configured to execute at least I/O provider(s) 314. The I/O provider(s) 314 may include one or more processes for executing incoming I/O requests (e.g., write requests). Although in the present example, the I/O provider 314 is implemented in software, alternative implementations are possible in which the I/O provider 314 is implemented in hardware or as a combination of hardware and software. Stated succinctly, the present disclosure is not limited to any specific implementation of the I/O provider. As used throughout the disclosure, the term “I/O provider” may refer to any process which, alone or in combination with other processes, is configured to execute I/O requests that are received at the storage system 100, such as write requests for example.
The R-nodes 402 may be configured to terminate I/O requests received at the storage system 100 and route them to appropriate C-nodes 404 and D-nodes 406 for further execution. In doing so, the R-nodes 402 may distribute a workload over multiple C-nodes 404 and D-nodes 406. In some implementations, any of the R-nodes 402 may be configured to write I/O requests (e.g., SCSI I/O requests) to selected ones of the C-nodes 404 for further processing.
The C-nodes 404 may be configured to control the execution of C-node commands supplied by the R-nodes 402. The C-node commands may be used to implement read requests, write requests, and/or any other suitable type of I/O request. In addition, each of the C-nodes 404 may maintain and manage key metadata elements. Each of the C-nodes 404 may be configured to receive C-node commands from the R-nodes and communicate with the D-nodes 406 to execute the commands. In some implementations, each C-node 404 may maintain, an address-to-hash (A2H) structure 460 and a hash-to-D-node (H2D) structure 450. An example of one possible implementation of the H2D structure 450 and the A2H structure 460 is discussed further below with respect to
The D-nodes 406 may be configured to control the execution of D-node commands supplied by the C-nodes 404. Each of the D-nodes 406 may be attached to one or more of the storage devices 340. Each of the D-nodes 406 may be configured to map hash digests received from the C-nodes (in provided C-node commands) to different physical locations in the volumes 160 managed by the D-nodes 406
According to the present example, the R-nodes 402, the C-nodes 404, and the D-nodes 406 are arranged to implement a two-tier address space having a first portion that is deduplicated (hereinafter “deduplication tier”) and a second portion that is non-deduplicated (hereinafter “non-deduplication tier”). In the deduplication tier, data is stored using content-based addressing. On the other hand, in the non-deduplicated tier, data is stored using location-based addressing. When content-based addressing is used to store data, the physical location on the physical medium where the data is stored is selected, at least in part, based on the content of data. On the other hand, when location-based addressing is used, the physical location where the data is stored is selected based on a provided LBA, rather than on the data's contents.
In operation, any of the R-nodes 402 may receive an I/O request that spans a range of logical data addresses (LDAs) from a multipath agent. The request may include a block of data and an opcode identifying an action that is required to be performed. In response to the request, the R-node 402 may use its respective A2C table to identify a plurality of C-nodes 404. Afterwards, the R-node 402 may decompose the I/O request into a plurality of C-node commands and forward the C-node commands to the identified C-nodes 404 for further processing.
In operation, any of the C-nodes 404 may receive a C-node command that is generated by one of the R-nodes 402. The C-node command may include a data payload and an opcode identifying an action that is required to be performed. Upon receiving the C-node command, the C-node 404 may determine whether the data associated with the C-node command needs to be stored in the deduplication tier of the storage system or the non-deduplication tier of the storage system by using the C-node's 404 respective A2H structure.
If the data is to be stored in the deduplication tier of the storage system 100, the data may be stored by using content-based addressing. To store the data using content-based addressing, the C-node 404 may generate one or more D-node commands (e.g., by executing a process that is the same or similar to the process 700A which is discussed with respect to
In operation, any of the D-nodes 406 may receive a D-node command that is generated by one of the C-nodes 404. Next, the D-node 406 may identify a physical address in one of the storage devices 340 that corresponds to a hash digest that is contained in the D-node command. Afterwards, the D-node 406 may store the payload of the D-node command (i.e., the page of data contained in the D-node command) at the identified physical address.
When a write request is received at the storage system, which identifies a logical block in the deduplication tier 514, data associated with the write request may be stored in the storage system 100 by using content-based addressing. On the other hand, when a write request is received that identifies a logical block in the non-deduplication tier 516, data associated with the write request may be stored in the storage system 100 by using location-based addressing. In some implementations, when the storage system 100 includes a RAID array, each of the regions in the non-deduplication tier 516 may be substantially the same size as a stripe in the array (e.g., a RAID6 stripe). Additionally or alternatively, in some implementations, the size of each region in the non-deduplication tier 516 may be in the range of 11-22 MB.
The two-tier arrangement of the volume 510 may allow the storage system to balance its use of random-access memory (RAM) against its use of permanent storage space. Data that is stored using content-based addressing is deduplicated, whereas data that is stored by using location-based addressing is not deduplicated. For each logical block (e.g., page) of the data that is stored using content-based addressing, the storage system is required to maintain a corresponding hash digest in its RAM. On the other hand, location-based storage of data, does not require the maintenance of hash digests in RAM. So, storing data using content-based addressing helps utilize permanent storage more efficiently, but it is more RAM-intensive in comparison to location-based addressing.
Each of the entries 532 may include a deduplication counter 536 (e.g. a reference counter), a data hash digest 538a, and an address ID 540. The data hash digest 538a in any given entry 532 may be a hash digest of a unit of data (e.g., a page of data) that is stored in one of the logical blocks 512 of the deduplication tier 514. The address ID 540 in the given entry 532 may identify the physical address in the storage system 100 where the unit of data is stored. The physical address where the data is stored may be identified either directly or indirectly. For example, when the address ID 540 identifies a physical address directly, the address ID 540 may include a physical location identifier in one or more storage devices in the storage system 100. By contrast, when the address ID 540 identifies the physical address indirectly, the address ID 540 may include an identifier of a D-node 406 (or another type of node), that is part of an execution pipeline, and responsible for resolving the physical location where the data is stored. According to the present disclosure, the A2H and H2D structures are not limited to using any specific type of physical location identifier.
The deduplication counter 536 in any given entry 532 may indicate the extent to which the data corresponding to the given entry 532 has been deduplicated. In operation, when a command to store one or more units of data (e.g., a C-node command) is received (and/or generated) at one of the C-nodes 404 of the storage system 100, the C-node may determine whether any of the units of data has already been stored in the storage system 100 (e.g., by determining whether the hash digest of the unit of data is already present in the H2D structure 450). When the unit of data associated with the command is already present in the storage system, there is no need to store it again, and the deduplication counter 536 that is mapped to the hash digest of the data (e.g., by one of the entries 532) may be incremented to indicate that the data has been deduplicated one more time.
Each of the entries 534 may include an LBA hash digest 538b and an address ID 540. As noted above, the LBA hash digest 538b in a given entry 534 may include a hash digest of the first LBA in a region where one or more units of data are stored. The LBA may be associated with a write request received at the storage system and/or a command to store data (e.g., a C-node command) that is generated internally at the storage system 100 based on the write request. In some implementations, each entry 532 may correspond to only one unit of data (e.g., a page or logical block) that is stored in the storage system, and each entry 534 may correspond to multiple units of data (e.g., multiple pages or logical blocks).
The data hash digests 538a and the LBA hash digests 538b may have the same format, in some implementations. Shown in
According to the example of
Each of the CDR and PDRs that are indicated by the history vector 564 may be generated based on the value of the deduplication counter 536 for at least one of the logical blocks (or pages) in the group of logical blocks. In this regard, in some implementations, to accumulate the indication of CDR and PDR in the history vector 564, the value of the deduplication counter for any of the logical blocks in the group may be reset to an initial value at the beginning of each period for which the CDR and PDRs are calculated. Each of the PDRs indicated by the history vector 564 may correspond to a different past period. In this regard, the PDRs, when viewed together, may describe a pattern (or trend) at which the deduplication ratio for the group of logical blocks has changed over time.
In some implementations, the CDR that is indicated by the history vector 564 may be calculated by: (i) obtaining the value of the deduplication counter of each logical block in the group for the current period, (ii) calculating the sum of all obtained deduplication counters, and (iii) dividing the sum by the total count of logical blocks (e.g., pages) in the group. Additionally or alternatively, in some implementations, the value of any of the PDRs that are indicated by the history vector 564 may be generated by: (i) obtaining the deduplication counter of each logical block (e.g. pages) in the group for the past period which corresponds to the PDR 574, (ii) calculating the sum of all obtained references counters, and (iii) and dividing the calculated sum by the total count of logical blocks (e.g., pages) in the group. Although in the present example, each of the CCDRs and the PDRs for a group of logical blocks is calculated by summing up the deduplication counters for the logical blocks (e.g., pages) in the group (for a particular period) and dividing the sum over the total count of logical blocks (e.g., pages) in the group, the present disclosure is not limited to any specific method for calculating the CCDRs and/or PDRs. Although in the present example, each history vector 564 indicates one or more PDRs 574 for the vector's corresponding group of logical blocks, alternative implementations are possible in which any of the history vectors 564 indicates only a CCDR for the group of logical blocks corresponding to the vector.
The history vector 564 may have any suitable format. For example, in some implementations, the history vector 564 may be 8 bits wide. In such implementations, the indication of CDR 572 may be 2-bits wide, and each indication of PDR 574 may be 1-bit wide. For instance: when the value of the CDR for the group of logical blocks is less than a first threshold (e.g., 1.1), the indication of CDR 572 may be assigned a first value (e.g., ‘00’); when the value of the CDR for the group of logical blocks is less than a second threshold (e.g., 1.5) but greater than the first threshold, the indication of CDR 572 may be assigned a second value (e.g., ‘01’); when the value of the CDR is less than a third threshold (e.g., 2) but greater than the second threshold, the indication of CDR 572 may be assigned a third value (e.g., ‘10’); and when the value of the CDR is greater than the third threshold, the indication of CDR may be given a fourth value (e.g., ‘11’). The indications of PDR 574 may be calculated in a similar manner: for instance, when the value of a PDR is less than a threshold (e.g., 1.1), the indication 574 of this PDR may be assigned a first value (e.g., ‘0’); and when the value of the PDR is greater than the threshold, the indication 574 of this PDR may be assigned a second value (e.g., ‘1’). Encoding the CDR and PDRs in this manner may reduce the overhead that is placed on the storage system 100 as a result of having to maintain history vectors 564 and the history data structure 560. More particularly, encoding the history vectors 564 in this manner may result in the history vectors 564 occupying about 5 MB of storage space per 1 PB of data that is stored in the storage system 100. Moreover, the inclusion of indications 574 of PDRs in the history vector 564 may permit the identification of increasing trends in the rate at which data is deduplicated, and distinguish such trends from short-lived fluctuations. Although in the present example the history vector 564 includes values that are generated by thresholding the CDR and PDRs, alternative implementations are possible in which the history vector includes the actual values of the CDR and PDRs. Stated succinctly, the present disclosure is not limited to any specific format of the history vector and/or any of the indications of the CDR and PDRs.
At step 602, an A2H and H2D structures are identified that are associated with an address space of a volume in the storage system. The H2D structure may be the same or similar to the H2D structure 450, which is discussed above with respect to
At step 604, a first portion of an address space is assigned to a deduplication tier of the storage system and a second portion of the address space is assigned to a non-deduplication tier of the storage system. In some implementations, the deduplication tier of the storage system may be the same or similar to the deduplication tier 514, Which is discussed above with respect to
At step 606, an instruction to store data is obtained (e.g., received). In some implementations, the instruction to store data may include a write request that is received at the storage system from a host (e.g., a SCSI) command, etc.) Additionally or alternatively, in some implementations, the instruction to store data may include a command (e.g., a c-node command) that is generated internally within the storage system based on a write request that is received at the storage system from a host. In the latter case, the instruction may be generated by the node executing the process 600 or another node in the storage system. In some implementations, the command to store data may identify data and at least one LEA where the data is requested to be stored.
At step 608, a determination is made if the instruction to store data is associated with the deduplication or non-deduplication tier. When the LEA associated with the write request belongs in the deduplication tier, the instruction to store data is deemed associated with the deduplication tier and the process 600 proceeds to step 610. Otherwise, when the LEA associated with the write request belongs in the non-deduplication tier, the instruction to store data is deemed associated with the non-deduplication tier and the process 600 proceeds to step 612. In some implementations, the determination may be made by performing a search of the A2H structure based on the LBA associated with the write request. If the search returns an entry corresponding to a region in the non-deduplication tier (e.g., an entry 534), the instruction may be deemed associated with the non-deduplication tier. Otherwise, if the search fails to return a result or returns an entry associated with the deduplication tier (e.g., an entry 532), the instruction may be deemed associated with the deduplication tier.
At step 610, the instruction to store data is executed using content-based addressing. Step 608 is discussed in further detail with respect to
At step 612, the instruction to store data is executed using location-based addressing. Step 610 is discussed in further detail with respect to
At step 614, an instruction to read data is obtained (e.g., received). In some implementations, the instruction may include a read request that is received at the storage system from a host (e.g., a SCSI) command, etc.). Additionally or alternatively, in some implementations, the instruction to read data may include a command (e.g., a c-node command) that is generated internally within the storage system based on a read request received at the storage system from a host. In the latter case, the instruction may be generated by the node executing the process 600 or another node in the storage system. In some implementations, the instruction may identify at least one LBA where data is requested to be retrieved from.
At step 616, a determination is made if the instruction to read data is associated with the deduplication or non-deduplication tier. When the LBA associated with the instructions belongs in the deduplication tier, the instruction is deemed associated with the deduplication tier and the process 600 proceeds to step 618. Otherwise, when the LBA associated with the instruction belongs in the non-deduplication tier, the instruction is deemed associated with the non-deduplication tier and the process 600 proceeds to step 620. In some implementations, the determination may be made by performing a search of the A2H structure based on the LBA associated with the instruction. If the search returns an entry corresponding to a region in the non-deduplication tier (e.g., an entry 534), the instruction may be deemed associated with the non-deduplication tier. Otherwise, if the search returns an entry associated with the deduplication tier (e.g., an entry 532), the instruction may be deemed associated with the deduplication tier.
At step 618, the instruction to read data is executed using content-based addressing. Step 618 is discussed in further detail with respect to
At step 620, the instruction to read data is executed using location-based addressing. Step 620 is discussed in further detail with respect to
At step 622, the deduplication tier and the non-deduplication tier are resized. Resizing the tiers includes assigning a portion of one of the tiers to the other. The manner in which the resizing is performed is further discussed with respect to
At step 704, the data associated with the instruction to store data is identified. The identified data may include data whose storage is requested by the instruction. In some implementations, identifying the data may include loading the data at a predetermined memory location.
At step 706, one or more portions of the data are identified. According to the present example, each portion is the same size as a block (or page) in the storage system. However, alternative implementations are possible in which the size of each portion is equal to the size of another data unit that is utilized in the storage system.
At step 708, a plurality of hash digests is generated. Each of the hash digests in the plurality is generated based on a different one of the data portions. Each of the hash digests may be the same or similar to the hash digests 538a, which are discussed above with respect to
At step 710, one of the data portions is selected along with the hash digest that is generated based on the data portion.
At step 712, a determination is made if the selected data portion has already been stored in the storage system. In some implementations, determining whether the selected data portion has already been stored in the storage system may include, at least in part, detecting whether the selected hash digest (of the selected data portion) is present in the H2D structure. If the selected data portion has already been stored in the storage system, the process 700A proceeds to step 714. Otherwise, if the selected data portion has not been stored in the storage system, the process 700A proceeds to step 718.
At step 714, an entry in the H2D structure is identified that contains the selected hash digest. The identified entry may be the same or similar to any of the entries 532, which are discussed above with respect to
At step 716, the deduplication counter of the identified entry is incremented. The deduplication counter may be the same or similar to any of the deduplication counters 536, which are discussed above with respect to
At step 718, the selected data portion is stored in the deduplication tier of the storage system by using content-based addressing. In some implementations, storing the selected data portion in the storage system may include generating a D-node command including the selected data portion and forwarding the D-node command to a D-node in the storage system. Additionally or alternatively, in some implementations, storing the selected data portion in the storage system may include generating a command for a storage device (e.g., an SSD drive) in the storage system, and providing the command directly to the storage device. Stated succinctly, the present disclosure is not limited to any specific method for storing the selected data portion.
At step 720, the A2H and H2D structures are updated to include the selected hash digest. In some implementations, updating the H2D structure may include generating a first new entry that includes the selected hash digest and adding the first new entry to the H2D structure. In some implementations, the first new entry may be the same or similar to any of the entries 532, which are discussed above with respect to
At step 722, a determination is made if there any data portions that remain to be processed. If there are remaining data portions, the process 710A returns to step 710, and steps 710-720 are repeated for another portion. Otherwise, if there are no more data portions that remain to be processed, the process 700A proceeds to step 612.
At step 734, the data associated with the instruction to store data is identified. The identified data may include data whose storage is requested by the instruction. In some implementations, identifying the data may include loading the data at a predetermined memory location.
At step 736, an LBA associated with the instruction to store data is identified. In some implementations, the LBA may be contained in the instruction to store data and it may identify a location in the storage system where the data associated with the instruction is desired to be stored.
At step 738, a region in the non-deduplication tier of the storage system is identified that is associated with the write request. As noted above, each region in the non-deduplication tier may include multiple logical blocks, with each logical block having a different respective LBA. In this regard, a region may be associated with the write request, when the region includes a logical block having the LBA associated with the write request. The identified region may be addressed using a second LBA. The second LBA may be the starting (e.g., smallest) LBA in the region.
At step 740, a hash digest is generated of the second LBA. In some implementations, the hash digest may be the same or similar to the hash digest 538b, which is discussed above with respect to
At step 742, the data associated with write request is stored in the non-deduplication tier of the storage system by using location-based addressing. In some implementations, storing the data in the-non-deduplication tier of the storage system may include generating a command to store the data and providing the command directly to a storage device (e.g., an SSD drive) in the storage system. In some implementations, storing the data in the-non-deduplication tier of the storage system may include generating a command to store the data and providing the command directly to another node (e.g., a D-node) in the storage system. Stated succinctly, the present disclosure is not limited to any specific method for storing the data.
At step 744, the A2H and H2D structures are updated to include the generated hash digest of the LBA. In some implementations, updating the H2D structure may include generating a first new entry that includes the generated hash digest of the LBA, and adding the first new entry to the H2D structure. In some implementations, the first new entry may be the same or similar to any of the entries 534, which are discussed above with respect to
At step 752, one or more data hash digests associated with the instruction to read data are identified. Each of the data hash digests may correspond to a different logical block of the data. Each of the data hash digests may be retrieved from the A2H structure by performing a search of the A2H structure. The search may be performed based on the LBA identified by the instruction.
At step 754, one of the identified data hash digests is selected.
At step 756, an address ID associated with the data hash digest is obtained. The address ID may be the same or similar to any of the address IDs 540, which are discussed above with respect to
At step 758, the logical block of data corresponding to the selected data hash digest is retrieved from the deduplication tier of the storage system. The logical block is retrieved based on the obtained address ID. In implementations in which the process 700C is executed by a C-node in the storage system, retrieving the logical block of data may include transmitting a D-node command to one of the D-nodes in the storage system and receiving the logical block in response.
At step 760, a determination is made if any of the data hash digests identified at step 752 remain to be processed. If there are data hash digests that remain to be processed, the process 700C returns to step 754. Otherwise, if there are no more data hash digests that remain to be processed, the process 700C proceeds to step 762.
At step 762, all logical blocks that are retrieved at step 758 are returned to the sender of the read instruction. For example, in implementations in which the process 700C is executed by a C-node in the storage system and the instruction to read data is provided by an R-node, the logical blocks of data may be provided to the R-node.
At step 772, an LBA hash digest associated with the instruction to read data is identified. The LBA hash digest may be the same or similar to any of the LBA hash digests 538b, which are discussed above with respect to
At step 774, an address ID associated with the LBA hash digest is obtained. The address ID may be the same or similar to any of the address IDs 540, which are discussed above with respect to
At step 776, an offset within the region is determined. In some implementations, the offset may be calculated based on the difference between the LBA associated with the region and the LBA identified by the instruction to read data. As can be readily appreciated, the offset may identify the location within the region where the requested data is stored.
At step 778, the requested data is retrieved from the non-deduplication tier based on the address ID and offset. When the process 700C is executed by a C-node in the storage system, retrieving the data may include transmitting a D-node command to one of the D-nodes in the storage system and receiving the data in response.
At step 780, the retrieved data is returned to the sender of the read request. For example, in implementations in which the process 700D is executed by a C-node in the storage system and the request to read data is provided by an R-node, the data blocks may be provided to the R-node.
At step 802, a determination is made whether one of a first event and a second event has been generated within the storage system. In some implementations, the first event may occur when the amount of random-access memory that is available to one or more nodes in the storage system falls below a threshold. In some implementations, the second event may occur when the utilization rate of one or more regions in the non-deduplication tier of the storage system exceeds a threshold. Additionally or alternatively, in some implementations, the first event and/or the second event may occur when a timer associated with the first event and/or the second event expires. In the latter case, the first event and the second event may be generated periodically within the storage system (as opposed to being generated dynamically based on utilization rate and/or memory usage).
At step 804, a plurality of logical blocks groups is identified. Each of the logical block groups may have a combined size that equals the size of the regions in the non-deduplication layer. Each of the logical block groups may be the same or similar to the logical block groups discussed with respect to
At step 806, a respective history vector is obtained for each of the identified logical block groups. In some implementations, the respective history vectors may be obtained from a data structure, such as the history data structure 560, which is discussed with respect to
At step 808 one or more groups are selected based on the groups' respective history vectors. In some implementations, the selected logical block groups may include logical groups whose respective indication of CDR is above a predetermined threshold. Additionally or alternatively, the selected logical block groups may be selected whose deduplication ratio increases at a rate exceeding a predetermined threshold over the period covered by the groups' respective history vectors. Additionally or alternatively, the selected one or more groups may include groups whose average deduplication ratio (as calculated based on the indications of CCDR and PDR in the groups' respective history vectors) exceed a predetermined threshold. Additionally or alternatively, in some implementations, the selected logical block groups may include N logical block groups that have the highest CCDR among all identified logical block groups, wherein N is an integer greater than or equal to 1 and less than the total number of logical block groups. Additionally or alternatively, in some implementations, the selected logical block groups may include N logical block groups whose respective deduplication ratios increase at the fastest rate among all identified logical block groups, Wherein N is an integer greater than or equal to 1 and less than the total number of logical block groups. Additionally or alternatively, in some implementations, the selected logical block groups may include N logical block groups that have the highest average deduplication ratios among all identified logical block groups, wherein N is an integer greater than or equal to 1 and less than the total number of logical block groups. Stated succinctly the present disclosure is not limited to any specific criterion for selecting a logical block group based on at least one of: (i) the history vector of the logical block group, or (ii) the history vectors of one or more other logical block groups that are associated with the deduplication tier of the same address space.
At step 810, the selected logical block groups are relocated from the deduplication tier to the non-deduplication tier of the storage system. As noted above, each logical block group may have the same size as the regions in the non-deduplication tier. Relocating any of the logical block groups may include deleting form each of the A2H and H2D structures a plurality of entries that correspond to individual logical blocks in the group (e.g., entries 532/552) and replacing each of the deleted pluralities of entries with an individual entry (e.g., an entry 523/554) that corresponds to the entire group—i.e., an entry that corresponds to the region that is formed by the group.
More particularly, when a group of logical blocks is relocated, a plurality of entries corresponding to individual logical blocks in the group (e.g., entries 532) may be deleted from the H2D structure and replaced with a single entry (e.g., an entry 534) that corresponds to the entire group of logical blocks, and which can be used to addressed the group of logical blocks as a region. Additionally or alternatively, when a group of logical blocks is relocated, a plurality of entries corresponding to individual logical blocks in the group (e.g., entries 552) may be deleted from the A2H structure and replaced with a single entry (e.g., an entry 554) that corresponds to the entire group of logical blocks, and which can be used to addressed the group of logical blocks as a region.
At step 812, one or more regions are selected based on the regions' respective utilization rates. The utilization rate of any one of the regions may be based on the count of writes performed in the region, a count of reads performed in the region, a total amount of data stored in the region during a particular period, a total amount of data retrieved from the region, and/or any other suitable metric that at least in part indicates the degree to Which the region is utilized. In some implementations, the selected one or more regions may include regions whose respective utilization rates exceed a fixed threshold. Additionally or alternatively, the selected regions may include N regions that have the highest utilization rate among a plurality of regions (e.g., all regions) in the non-deduplication tier of the storage system, where N is an integer greater than or equal to 1 and less than the total number of regions in the plurality.
At step 814, the selected regions are relocated from the non-deduplication tier of the storage system to the deduplication tier of the storage system. Relocating any of the selected regions may include deleting from the A2H and H2D structures respective entries (e.g., entries 534 and 544 that correspond to the region and replacing each of the deleted entries with a respective plurality of entries that correspond to individual blocks in the region. As discussed above, when data is relocated from the non-deduplication tier to the deduplication tier, the data may be deduplicated, which may result in a reduction in the amount of storage space that is used to hold the data.
More particularly, when a region is relocated, a single entry corresponding to the entire region (e.g., an entry 534) may be deleted from the H2D structure and replaced with a plurality of entries (e.g., an entry 532), wherein each of the plurality of entries corresponds to a different logical block in the region. Additionally or alternatively, when a region is relocated, a single entry corresponding to the entire region (e.g., an entry 554) may be deleted from the A2H structure and replaced with a plurality of entries (e.g., an entry 532), wherein each of the plurality of entries corresponds to a different logical block in the region.
Reference herein to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment can be included in at least one embodiment of the claimed subject matter. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment, nor are separate or alternative embodiments necessarily mutually exclusive of other embodiments. The same applies to the term “implementation.”
As used in this application, the word “exemplary” is used herein to mean serving as an example, instance, or illustration. Any aspect or design described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other aspects or designs. Rather, use of the word exemplary is intended to present concepts in a concrete fashion.
Additionally, the term “or” is intended to mean an inclusive “or” rather than an exclusive “or”. That is, unless specified otherwise, or clear from context, “X employs A or B” is intended to mean any of the natural inclusive permutations. That is, if X employs A; X employs B; or X employs both A and B, then “X employs A or B” is satisfied under any of the foregoing instances. In addition, the articles “a” and “an” as used in this application and the appended claims should generally be construed to mean “one or more” unless specified otherwise or clear from context to be directed to a singular form.
To the extent directional terms are used in the specification and claims (e.g., upper, lower, parallel, perpendicular, etc.), these terms are merely intended to assist in describing and claiming the invention and are not intended to limit the claims in any way. Such terms, do not require exactness (e.g., exact perpendicularity or exact parallelism, etc.), but instead it is intended that normal tolerances and ranges apply. Similarly, unless explicitly stated otherwise, each numerical value and range should be interpreted as being approximate as if the word “about”, “substantially” or “approximately” preceded the value of the value or range.
Moreover, the terms “system,” “component,” “module,” “interface,”, “model” or the like are generally intended to refer to a computer-related entity, either hardware, a combination of hardware and software, software, or software in execution. For example, a component may be, but is not limited to being, a process running on a processor, a processor, an object, an executable, a thread of execution, a program, and/or a computer. By way of illustration, both an application running on a controller and the controller can be a component. One or more components may reside within a process and/or thread of execution and a component may be localized on one computer and/or distributed between two or more computers.
Although the subject matter described herein may be described in the context of illustrative implementations to process one or more computing application features/operations for a computing application having user-interactive components the subject matter is not limited to these particular embodiments. Rather, the techniques described herein can be applied to any suitable type of user-interactive component execution management methods, systems, platforms, and/or apparatus.
While the exemplary embodiments have been described with respect to processes of circuits, including possible implementation as a single integrated circuit, a multi-chip module, a single card, or a multi-card circuit pack, the described embodiments are not so limited. As would be apparent to one skilled in the art, various functions of circuit elements may also be implemented as processing blocks in a software program. Such software may be employed in, for example, a digital signal processor, micro-controller, or general-purpose computer.
Some embodiments might be implemented in the form of methods and apparatuses for practicing those methods. Described embodiments might also be implemented in the form of program code embodied in tangible media, such as magnetic recording media, optical recording media, solid state memory, floppy diskettes, CD-ROMs, hard drives, or any other machine-readable storage medium, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the claimed invention. Described embodiments might also be implemented in the form of program code, for example, whether stored in a storage medium, loaded into and/or executed by a machine, or transmitted over some transmission medium or carrier, such as over electrical wiring or cabling, through fiber optics, or via electromagnetic radiation, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the claimed invention. When implemented on a general-purpose processor, the program code segments combine with the processor to provide a unique device that operates analogously to specific logic circuits. Described embodiments might also be implemented in the form of a bitstream or other sequence of signal values electrically or optically transmitted through a medium, stored magnetic-field variations in a magnetic recording medium, etc., generated using a method and/or an apparatus of the claimed invention.
It should be understood that the steps of the exemplary methods set forth herein are not necessarily required to be performed in the order described, and the order of the steps of such methods should be understood to be merely exemplary. Likewise, additional steps may be included in such methods, and certain steps may be omitted or combined, in methods consistent with various embodiments.
Also, for purposes of this description, the terms “couple,” “coupling,” “coupled,” “connect,” “connecting,” or “connected” refer to any manner known in the art or later developed in which energy is allowed to be transferred between two or more elements, and the interposition of one or more additional elements is contemplated, although not required. Conversely, the terms “directly coupled,” “directly connected,” etc., imply the absence of such additional elements.
As used herein in reference to an element and a standard, the term “compatible” means that the element communicates with other elements in a manner wholly or partially specified by the standard, and would be recognized by other elements as sufficiently capable of communicating with the other elements in the manner specified by the standard. The compatible element does not need to operate internally in a manner specified by the standard.
It will be further understood that various changes in the details, materials, and arrangements of the parts which have been described and illustrated in order to explain the nature of the claimed invention might be made by those skilled in the art without departing from the scope of the following claims.
Number | Name | Date | Kind |
---|---|---|---|
7203741 | Marco et al. | Apr 2007 | B2 |
7567188 | Anglin | Jul 2009 | B1 |
7719443 | Natanzon | May 2010 | B1 |
7840536 | Ahal et al. | Nov 2010 | B1 |
7840662 | Natanzon | Nov 2010 | B1 |
7844856 | Ahal et al. | Nov 2010 | B1 |
7860836 | Natanzon et al. | Dec 2010 | B1 |
7882286 | Natanzon et al. | Feb 2011 | B1 |
7934262 | Natanzon et al. | Apr 2011 | B1 |
7958372 | Natanzon | Jun 2011 | B1 |
8037162 | Marco et al. | Oct 2011 | B2 |
8041940 | Natanzon et al. | Oct 2011 | B1 |
8060713 | Natanzon | Nov 2011 | B1 |
8060714 | Natanzon | Nov 2011 | B1 |
8103937 | Natanzon et al. | Jan 2012 | B1 |
8108634 | Natanzon et al. | Jan 2012 | B1 |
8214612 | Natanzon | Jul 2012 | B1 |
8250149 | Marco et al. | Aug 2012 | B2 |
8271441 | Natanzon et al. | Sep 2012 | B1 |
8271447 | Natanzon et al. | Sep 2012 | B1 |
8332687 | Natanzon et al. | Dec 2012 | B1 |
8335761 | Natanzon | Dec 2012 | B1 |
8335771 | Natanzon et al. | Dec 2012 | B1 |
8341115 | Natanzon et al. | Dec 2012 | B1 |
8370648 | Natanzon | Feb 2013 | B1 |
8380885 | Natanzon | Feb 2013 | B1 |
8392680 | Natanzon et al. | Mar 2013 | B1 |
8429362 | Natanzon et al. | Apr 2013 | B1 |
8433869 | Natanzon et al. | Apr 2013 | B1 |
8438135 | Natanzon et al. | May 2013 | B1 |
8464101 | Natanzon et al. | Jun 2013 | B1 |
8478955 | Natanzon et al. | Jul 2013 | B1 |
8495032 | Anglin | Jul 2013 | B2 |
8495304 | Natanzon et al. | Jul 2013 | B1 |
8510279 | Natanzon et al. | Aug 2013 | B1 |
8521691 | Natanzon | Aug 2013 | B1 |
8521694 | Natanzon | Aug 2013 | B1 |
8543609 | Natanzon | Sep 2013 | B1 |
8583885 | Natanzon | Nov 2013 | B1 |
8600945 | Natanzon et al. | Dec 2013 | B1 |
8601085 | Ives et al. | Dec 2013 | B1 |
8627012 | Derbeko et al. | Jan 2014 | B1 |
8639899 | Kawakami | Jan 2014 | B2 |
8683592 | Dotan et al. | Mar 2014 | B1 |
8694700 | Natanzon et al. | Apr 2014 | B1 |
8706700 | Natanzon et al. | Apr 2014 | B1 |
8712962 | Natanzon et al. | Apr 2014 | B1 |
8719497 | Don et al. | May 2014 | B1 |
8725691 | Natanzon | May 2014 | B1 |
8725692 | Natanzon et al. | May 2014 | B1 |
8726066 | Natanzon et al. | May 2014 | B1 |
8738813 | Natanzon et al. | May 2014 | B1 |
8745004 | Natanzon et al. | Jun 2014 | B1 |
8751828 | Raizen et al. | Jun 2014 | B1 |
8769336 | Natanzon et al. | Jul 2014 | B1 |
8788466 | Anglin | Jul 2014 | B2 |
8805786 | Natanzon | Aug 2014 | B1 |
8806161 | Natanzon | Aug 2014 | B1 |
8825848 | Dotan et al. | Sep 2014 | B1 |
8832399 | Natanzon et al. | Sep 2014 | B1 |
8850143 | Natanzon | Sep 2014 | B1 |
8850144 | Natanzon et al. | Sep 2014 | B1 |
8862546 | Natanzon et al. | Oct 2014 | B1 |
8892835 | Natanzon et al. | Nov 2014 | B1 |
8898112 | Natanzon et al. | Nov 2014 | B1 |
8898409 | Natanzon et al. | Nov 2014 | B1 |
8898515 | Natanzon | Nov 2014 | B1 |
8898519 | Natanzon et al. | Nov 2014 | B1 |
8914595 | Natanzon | Dec 2014 | B1 |
8924668 | Natanzon | Dec 2014 | B1 |
8930500 | Marco et al. | Jan 2015 | B2 |
8930947 | Derbeko et al. | Jan 2015 | B1 |
8935498 | Natanzon | Jan 2015 | B1 |
8949180 | Natanzon et al. | Feb 2015 | B1 |
8954673 | Natanzon et al. | Feb 2015 | B1 |
8954796 | Cohen et al. | Feb 2015 | B1 |
8959054 | Natanzon | Feb 2015 | B1 |
8977593 | Natanzon et al. | Mar 2015 | B1 |
8977826 | Meiri et al. | Mar 2015 | B1 |
8996460 | Frank et al. | Mar 2015 | B1 |
8996461 | Natanzon et al. | Mar 2015 | B1 |
8996827 | Natanzon | Mar 2015 | B1 |
9003138 | Natanzon et al. | Apr 2015 | B1 |
9026696 | Natanzon et al. | May 2015 | B1 |
9031913 | Natanzon | May 2015 | B1 |
9032160 | Natanzon et al. | May 2015 | B1 |
9037818 | Natanzon et al. | May 2015 | B1 |
9063994 | Natanzon et al. | Jun 2015 | B1 |
9069479 | Natanzon | Jun 2015 | B1 |
9069709 | Natanzon et al. | Jun 2015 | B1 |
9081754 | Natanzon et al. | Jul 2015 | B1 |
9081842 | Natanzon et al. | Jul 2015 | B1 |
9087008 | Natanzon | Jul 2015 | B1 |
9087112 | Natanzon et al. | Jul 2015 | B1 |
9104529 | Derbeko et al. | Aug 2015 | B1 |
9110914 | Frank et al. | Aug 2015 | B1 |
9116811 | Derbeko et al. | Aug 2015 | B1 |
9128628 | Natanzon et al. | Sep 2015 | B1 |
9128855 | Natanzon et al. | Sep 2015 | B1 |
9134914 | Derbeko et al. | Sep 2015 | B1 |
9135119 | Natanzon et al. | Sep 2015 | B1 |
9135120 | Natanzon | Sep 2015 | B1 |
9146878 | Cohen et al. | Sep 2015 | B1 |
9152339 | Cohen et al. | Oct 2015 | B1 |
9152578 | Saad et al. | Oct 2015 | B1 |
9152814 | Natanzon | Oct 2015 | B1 |
9158578 | Derbeko et al. | Oct 2015 | B1 |
9158630 | Natanzon | Oct 2015 | B1 |
9160526 | Raizen et al. | Oct 2015 | B1 |
9177670 | Derbeko et al. | Nov 2015 | B1 |
9189339 | Cohen et al. | Nov 2015 | B1 |
9189341 | Natanzon et al. | Nov 2015 | B1 |
9201736 | Moore et al. | Dec 2015 | B1 |
9223659 | Natanzon et al. | Dec 2015 | B1 |
9225529 | Natanzon et al. | Dec 2015 | B1 |
9235481 | Natanzon et al. | Jan 2016 | B1 |
9235524 | Derbeko et al. | Jan 2016 | B1 |
9235632 | Natanzon | Jan 2016 | B1 |
9244997 | Natanzon et al. | Jan 2016 | B1 |
9256605 | Natanzon | Feb 2016 | B1 |
9274718 | Natanzon et al. | Mar 2016 | B1 |
9275063 | Natanzon | Mar 2016 | B1 |
9286052 | Solan et al. | Mar 2016 | B1 |
9305009 | Bono et al. | Apr 2016 | B1 |
9323750 | Natanzon et al. | Apr 2016 | B2 |
9330155 | Bono et al. | May 2016 | B1 |
9336094 | Wolfson et al. | May 2016 | B1 |
9336230 | Natanzon | May 2016 | B1 |
9367260 | Natanzon | Jun 2016 | B1 |
9378096 | Erel et al. | Jun 2016 | B1 |
9378219 | Bono et al. | Jun 2016 | B1 |
9378261 | Bono et al. | Jun 2016 | B1 |
9383937 | Frank et al. | Jul 2016 | B1 |
9389800 | Natanzon et al. | Jul 2016 | B1 |
9405481 | Cohen et al. | Aug 2016 | B1 |
9405684 | Derbeko et al. | Aug 2016 | B1 |
9405765 | Natanzon | Aug 2016 | B1 |
9411535 | Shemer et al. | Aug 2016 | B1 |
9459804 | Natanzon et al. | Oct 2016 | B1 |
9460028 | Raizen et al. | Oct 2016 | B1 |
9471579 | Natanzon | Oct 2016 | B1 |
9477407 | Marshak et al. | Oct 2016 | B1 |
9501542 | Natanzon | Nov 2016 | B1 |
9507732 | Natanzon et al. | Nov 2016 | B1 |
9507845 | Natanzon et al. | Nov 2016 | B1 |
9514138 | Natanzon et al. | Dec 2016 | B1 |
9524218 | Veprinsky et al. | Dec 2016 | B1 |
9529885 | Natanzon et al. | Dec 2016 | B1 |
9535800 | Natanzon et al. | Jan 2017 | B1 |
9535801 | Natanzon et al. | Jan 2017 | B1 |
9547459 | BenHanokh et al. | Jan 2017 | B1 |
9547591 | Natanzon et al. | Jan 2017 | B1 |
9552405 | Moore et al. | Jan 2017 | B1 |
9557921 | Cohen et al. | Jan 2017 | B1 |
9557925 | Natanzon | Jan 2017 | B1 |
9563517 | Natanzon et al. | Feb 2017 | B1 |
9563684 | Natanzon et al. | Feb 2017 | B1 |
9575851 | Natanzon et al. | Feb 2017 | B1 |
9575857 | Natanzon | Feb 2017 | B1 |
9575894 | Natanzon et al. | Feb 2017 | B1 |
9582382 | Natanzon et al. | Feb 2017 | B1 |
9588703 | Natanzon et al. | Mar 2017 | B1 |
9588847 | Natanzon et al. | Mar 2017 | B1 |
9594822 | Natanzon et al. | Mar 2017 | B1 |
9600377 | Cohen et al. | Mar 2017 | B1 |
9619543 | Natanzon et al. | Apr 2017 | B1 |
9632881 | Natanzon | Apr 2017 | B1 |
9665305 | Natanzon et al. | May 2017 | B1 |
9710177 | Natanzon | Jul 2017 | B1 |
9720618 | Panidis et al. | Aug 2017 | B1 |
9722788 | Natanzon et al. | Aug 2017 | B1 |
9727429 | Moore et al. | Aug 2017 | B1 |
9733969 | Derbeko et al. | Aug 2017 | B2 |
9737111 | Lustik | Aug 2017 | B2 |
9740572 | Natanzon et al. | Aug 2017 | B1 |
9740573 | Natanzon | Aug 2017 | B1 |
9740880 | Natanzon et al. | Aug 2017 | B1 |
9749300 | Cale et al. | Aug 2017 | B1 |
9772789 | Natanzon et al. | Sep 2017 | B1 |
9798472 | Natanzon et al. | Oct 2017 | B1 |
9798490 | Natanzon | Oct 2017 | B1 |
9804934 | Natanzon et al. | Oct 2017 | B1 |
9811431 | Natanzon et al. | Nov 2017 | B1 |
9823865 | Natanzon et al. | Nov 2017 | B1 |
9823973 | Natanzon | Nov 2017 | B1 |
9832261 | Don et al. | Nov 2017 | B2 |
9846698 | Panidis et al. | Dec 2017 | B1 |
9875042 | Natanzon et al. | Jan 2018 | B1 |
9875162 | Panidis et al. | Jan 2018 | B1 |
9880777 | Bono et al. | Jan 2018 | B1 |
9881014 | Bono et al. | Jan 2018 | B1 |
9910620 | Veprinsky et al. | Mar 2018 | B1 |
9910621 | Golan et al. | Mar 2018 | B1 |
9910735 | Natanzon | Mar 2018 | B1 |
9910739 | Natanzon et al. | Mar 2018 | B1 |
9917854 | Natanzon et al. | Mar 2018 | B2 |
9921955 | Derbeko et al. | Mar 2018 | B1 |
9933957 | Cohen et al. | Apr 2018 | B1 |
9934302 | Cohen et al. | Apr 2018 | B1 |
9940205 | Natanzon | Apr 2018 | B2 |
9940460 | Derbeko et al. | Apr 2018 | B1 |
9946649 | Natanzon et al. | Apr 2018 | B1 |
9959061 | Natanzon et al. | May 2018 | B1 |
9965306 | Natanzon et al. | May 2018 | B1 |
9990256 | Natanzon | Jun 2018 | B1 |
9996539 | Natanzon | Jun 2018 | B1 |
10001942 | Sharma | Jun 2018 | B1 |
10007626 | Saad et al. | Jun 2018 | B1 |
10019194 | Baruch et al. | Jul 2018 | B1 |
10025931 | Natanzon et al. | Jul 2018 | B1 |
10031675 | Veprinsky et al. | Jul 2018 | B1 |
10031690 | Panidis et al. | Jul 2018 | B1 |
10031692 | Elron et al. | Jul 2018 | B2 |
10031703 | Natanzon et al. | Jul 2018 | B1 |
10037251 | Bono et al. | Jul 2018 | B1 |
10042579 | Natanzon | Aug 2018 | B1 |
10042751 | Veprinsky et al. | Aug 2018 | B1 |
10055146 | Natanzon et al. | Aug 2018 | B1 |
10055148 | Natanzon et al. | Aug 2018 | B1 |
10061666 | Natanzon et al. | Aug 2018 | B1 |
10067694 | Natanzon et al. | Sep 2018 | B1 |
10067837 | Natanzon et al. | Sep 2018 | B1 |
10078459 | Natanzon et al. | Sep 2018 | B1 |
10082980 | Cohen et al. | Sep 2018 | B1 |
10083093 | Natanzon et al. | Sep 2018 | B1 |
10095489 | Lieberman et al. | Oct 2018 | B1 |
10101943 | Ayzenberg et al. | Oct 2018 | B1 |
10108356 | Natanzon et al. | Oct 2018 | B1 |
10108507 | Natanzon | Oct 2018 | B1 |
10108645 | Bigman et al. | Oct 2018 | B1 |
10114581 | Natanzon et al. | Oct 2018 | B1 |
10120787 | Shemer et al. | Nov 2018 | B1 |
10120925 | Natanzon et al. | Nov 2018 | B1 |
10126946 | Natanzon et al. | Nov 2018 | B1 |
10133874 | Natanzon et al. | Nov 2018 | B1 |
10140039 | Baruch et al. | Nov 2018 | B1 |
10146436 | Natanzon et al. | Dec 2018 | B1 |
10146639 | Natanzon et al. | Dec 2018 | B1 |
10146675 | Shemer et al. | Dec 2018 | B1 |
10146961 | Baruch et al. | Dec 2018 | B1 |
10148751 | Natanzon | Dec 2018 | B1 |
10152246 | Lieberman et al. | Dec 2018 | B1 |
10152267 | Ayzenberg et al. | Dec 2018 | B1 |
10152384 | Amit et al. | Dec 2018 | B1 |
10157014 | Panidis et al. | Dec 2018 | B1 |
10185583 | Natanzon et al. | Jan 2019 | B1 |
10191677 | Natanzon et al. | Jan 2019 | B1 |
10191687 | Baruch et al. | Jan 2019 | B1 |
10191755 | Natanzon et al. | Jan 2019 | B1 |
10203904 | Natanzon et al. | Feb 2019 | B1 |
10210073 | Baruch et al. | Feb 2019 | B1 |
10223007 | Natanzon et al. | Mar 2019 | B1 |
10223023 | Natanzon et al. | Mar 2019 | B1 |
10223131 | Lieberman et al. | Mar 2019 | B1 |
10229006 | Natanzon et al. | Mar 2019 | B1 |
10229056 | Panidis et al. | Mar 2019 | B1 |
10235055 | Saad et al. | Mar 2019 | B1 |
10235060 | Baruch et al. | Mar 2019 | B1 |
10235061 | Natanzon et al. | Mar 2019 | B1 |
10235064 | Natanzon et al. | Mar 2019 | B1 |
10235087 | Baruch et al. | Mar 2019 | B1 |
10235088 | Baruch et al. | Mar 2019 | B1 |
10235090 | Baruch et al. | Mar 2019 | B1 |
10235091 | Ayzenberg et al. | Mar 2019 | B1 |
10235092 | Natanzon et al. | Mar 2019 | B1 |
10235145 | Natanzon et al. | Mar 2019 | B1 |
10235196 | Natanzon et al. | Mar 2019 | B1 |
10235247 | Natanzon et al. | Mar 2019 | B1 |
10235249 | Natanzon et al. | Mar 2019 | B1 |
10235252 | Lieberman et al. | Mar 2019 | B1 |
10250679 | Natanzon et al. | Apr 2019 | B1 |
10255137 | Panidis et al. | Apr 2019 | B1 |
10255291 | Natanzon et al. | Apr 2019 | B1 |
10496314 | Sharma | Dec 2019 | B2 |
20100036887 | Anglin | Feb 2010 | A1 |
20100082558 | Anglin | Apr 2010 | A1 |
20110131390 | Srinivasan | Jun 2011 | A1 |
20180173449 | Sharma | Jun 2018 | A1 |
20180181339 | Sharma | Jun 2018 | A1 |
Entry |
---|
U.S. Appl. No. 14/496,783, filed Sep. 25, 2014, Natanzon et al. |
U.S. Appl. No. 14/496,790, filed Sep. 25, 2014, Cohen et al. |
U.S. Appl. No. 14/559,036, filed Dec. 3, 2014, Natanzon et al. |
U.S. Appl. No. 14/753,389, filed Jun. 29, 2015, Nir et al. |
U.S. Appl. No. 14/976,719, filed Dec. 21, 2015, Natanzon. |
U.S. Appl. No. 14/978,378, filed Dec. 22, 2015, Bigman et al. |
U.S. Appl. No. 15/085,148, filed Mar. 30, 2016, Baruch et al. |
U.S. Appl. No. 15/274,362, filed Sep. 23, 2016, Baruch et al. |
U.S. Appl. No. 15/275,768, filed Sep. 26, 2016, Natanzon et al. |
U.S. Appl. No. 15/275,756, filed Sep. 26, 2016, Natanzon et al. |
U.S. Appl. No. 15/379,940, filed Dec. 15, 2016, Baruch et al. |
U.S. Appl. No. 15/386,754, filed Dec. 21, 2016, Shemer et al. |
U.S. Appl. No. 15/380,013, filed Dec. 15, 2016, Baruch et al. |
U.S. Appl. No. 15/390,996, filed Dec. 27, 2016, Natanzon et al. |
U.S. Appl. No. 15/391,030, filed Dec. 27, 2016, Shemer et al. |
U.S. Appl. No. 15/970,243, filed Sep. 3, 2018, Schneider et al. |
U.S. Appl. No. 16/052,037, filed Aug. 1, 2018, Schneider et al. |
U.S. Appl. No. 16/048,763, filed Jul. 30, 2018, Schneider et al. |
U.S. Appl. No. 16/050,400, filed Jul. 31, 2018, Alkalay et al. |
U.S. Appl. No. 16/179,295, filed Nov. 2, 2018, Natanzon et al. |
U.S. Appl. No. 16/261,174, filed Jan. 29, 2019, Natanzon et al. |
U.S. Appl. No. 16/368,008, filed Mar. 28, 2019, Natanzon et al. |
Number | Date | Country | |
---|---|---|---|
20200241790 A1 | Jul 2020 | US |