A storage system may include data protection systems that back up production site data by replicating production site data on a secondary backup storage system (e.g., a replication site). The backup storage system may be situated in a physically remote location from the production site and, in some instances, the backup storage system may be provided by a third party (e.g., a cloud-based backup system). In such systems, it may be desirable to independently verify data sent to, and received from, the third-party cloud backup system and/or to verify compliance with a service level agreement (SLA).
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
One aspect provides a method for verifying replicas of a storage system. A replica of a production site of the storage system is generated. A hash value associated with the generated replica is also generated. The replica is provided to a cloud backup provider. The hash value associated with the generated replica is provided to a blockchain in communication with the production site and the cloud backup provider. The blockchain may be employed to verify the replica.
Another aspect provides a system that includes a processor and memory storing computer program code that when executed on the processor causes the processor to operate a storage system. The storage system is operable to perform the operations of generating a replica of a production site of the storage system and generating a hash value associated with the generated replica. The replica is provided to a cloud backup provider. The hash value associated with the generated replica is provided to a blockchain in communication with the production site and the cloud backup provider. The blockchain may be employed to verify the replica.
Another aspect provides a computer program product including a non-transitory computer readable storage medium having computer program code encoded thereon that when executed on a processor of a computer causes the computer to operate a storage system. The computer program product includes computer program code for generating a replica of a production site of the storage system and generating a hash value associated with the generated replica. The replica is provided to a cloud backup provider. The hash value associated with the generated replica is provided to a blockchain in communication with the production site and the cloud backup provider. The blockchain may be employed to verify the replica.
Objects, aspects, features, and advantages of embodiments disclosed herein 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. For clarity, not every element may be labeled in every figure. The drawings are not necessarily to scale, emphasis instead being placed upon illustrating embodiments, principles, and concepts. The drawings are not meant to limit the scope of the claims included herewith.
Before describing embodiments of the concepts, structures, and techniques sought to be protected herein, some terms are explained. In some embodiments, the term “I/O request” or simply “I/O” may be used to refer to an input or output request (e.g., a data read or data write request). The term “storage system” may encompass physical computing systems, cloud or virtual computing systems, or a combination thereof. The term “storage device” may refer to any non-volatile memory (NVM) device, including hard disk drives (HDDs), solid state drivers (SSDs), flash devices (e.g., NAND flash devices), and similar devices that may be accessed locally and/or remotely (e.g., via a storage attached network (SAN)). The term “storage device” may also refer to a storage array including multiple storage devices.
Referring to the illustrative embodiment shown in
Cloud replication site 122 may replicate production site data and enable rollback of data of production site 102 to an earlier point in time (PIT). Rollback may be used in the event of data corruption of a disaster, or alternatively in order to view or to access data from an earlier point in time.
As shown in
Production site storage 110 and cloud replication site replica storage 130 may include storage devices for storing data, such as disks or arrays of disks. Storage 110 may provide (e.g., expose) one or more logical units (LUs) 112 to which production commands are issued. As described herein, an LU is a logical entity provided by a storage system for accessing data stored therein. In some embodiments, a logical unit may be a physical logical unit or a virtual logical unit, and may be identified by a unique logical unit number (LUN).
In some embodiments, DPA 108 may perform various data protection services, such as data replication of storage system 100, and journaling of I/O requests issued by device 104. DPA 108 may also enable rollback of production data in storage 110 to an earlier point-in-time (PIT) from replica data stored in cloud replica storage 130, and enable processing of rolled back data at the production site. In some embodiments, each DPA 108 may be a physical device, a virtual device, or may be a combination of a virtual and physical device.
In some embodiments, DPA 108 may be-receive commands (e.g., SCSI commands) issued by host 104 to storage 110. For example, splitter 106 may intercept commands from host 104, and provide the commands to storage 110 and also to DPA 108. Splitter 106 may act on intercepted SCSI commands issued to a logical unit or virtual disk 112 in one of the following ways: send the SCSI commands to its intended LU; redirect the SCSI command to another LU; split the SCSI command by sending it first to DPA 108 and, after DPA 108 returns an acknowledgement, send the SCSI command to its intended LU; fail a SCSI command by returning an error return code; and delay a SCSI command by not returning an acknowledgement to the respective host. In some embodiments, splitter 106 may handle different SCSI commands, differently, according to the type of the command. For example, in some embodiments, a SCSI command inquiring about the size of a certain LU may be sent directly to that LU, whereas a SCSI write command may be split and sent to DPA 108.
In certain embodiments, splitter 106 and DPA 108 may be drivers located in host devices of production site 102. Alternatively, in some embodiments, a protection agent may be located in a fiber channel switch, or in any other device situated in a data path between host 104 and storage 110. In a virtualized environment, the protection agent may run at the hypervisor layer or in a virtual machine providing a virtualization layer. For example, in such embodiments, a hypervisor may consume LUs and may generate a distributed file system on the logical units or virtual disks 112 such as Virtual Machine File System (VMFS) that may generate files in the file system and expose the files as LUs to the virtual machines (e.g., each virtual disk is seen as a SCSI device by virtual machine hosts). In another embodiment, a hypervisor may consume a network based file system and exposes files in the Network File System (NFS) as SCSI devices to virtual hosts.
In some embodiments, production DPA 108 may send its write transactions to cloud replication site 122 using a variety of modes of transmission, such as continuous replication or snapshot replication. For example, in continuous replication, production DPA 108 may send each write transaction to storage 110 and also send each write transaction to cloud replication site 122 to be replicated on cloud replica storage 130. In snapshot replication, production DPA 108 may receive several I/O requests and combine them into an aggregate “snapshot” or “batch” of write activity performed to storage 110 in the multiple I/O requests, and may send the snapshot to cloud replication site 122 for journaling and incorporation in in replica storage 130. In such embodiments, a snapshot replica may be a differential representation of a volume. For example, the snapshot may include pointers to the original volume, and may point to log volumes for locations of the original volume that store data changed by one or more I/O requests. In some embodiments, snapshots may be combined into a snapshot array, which may represent different images over a time period (e.g., for multiple PITs).
As described herein, when replicating data, the history may frequently be maintained in a journal. For example, such a journal may be implemented as described in as described in U.S. Pat. No. 7,516,287, issued Apr. 7, 2009, and entitled “Methods and Apparatus for Optimal Journaling for Continuous Data Replication,” which is hereby incorporated by reference herein. For example, in continuous replication, the journal may typically be implemented as a block device storing the history in a data structure or file system. In snapshot replication, the journal may typically contain only metadata that points to the snapshot replicas that hold the history.
In conventional systems, for example when the user/owner of the production site is also the owner of the replication site, the user has full control of both the production site and replication site and can have high degree of confidence in the consistency of the replicated data. For example, the user can directly monitor the creation and deletion of images and perform periodic testing of the images. However, when replicating to a cloud backup provider, the user no longer controls the replication site, and relies upon the cloud backup provider to generate points in time (PITs) at the correct times, to maintain consistent images in the journal, and provide the required retention time of the images. Such terms are typically specified in a service level agreement (SLA) between the cloud backup provider and the production site user.
Further, the production site user relies upon the cloud backup provider to provide the correct image for a given point in time (e.g., the image is from the correct time) and that the provided image is consistent with the correct production data at that point in time. Frequently, in such conventional systems, the production site user may not be able to verify the performance of the cloud backup provider since the user may not have a separate copy of the data from that same point in time for comparison. For example, if a disaster (e.g., data loss) occurs at the production site, the user will request an image from the cloud backup provider to restore the production volumes to contain the data at a point in time most recently before the disaster. If the image provided from the cloud backup provider is an older image than the most recent image before the disaster, the user would not have a way to prove otherwise (e.g., cannot prove whether the cloud backup provider is in compliance with the SLA). Similarly, the cloud backup provider cannot prove to the user that they are in compliance with the SLA.
As will be described herein, illustrative embodiments may employ a blockchain, such as blockchain 140, to validate, without relying on any third party, that an image (or replica) a cloud backup provider gives to a production site user represents the correct point in time (PIT) and it is consistent with the data of the protected production volumes at that time.
For example, in described embodiments, production site 102 may maintain a record of a hash value of each complete protected volume of storage 110. Production site 102 may periodically send these hash values to blockchain 140 as a proof of existence of a given image or replica of the protected volume(s). The cloud backup provider (e.g., cloud replication site 122) that receives replicated data may also maintain a record of a hash value of each complete protected volume. Various embodiments may employ any cryptographically sound hash function.
When the cloud backup provider receives an image, the cloud backup provider may determine a hash value of the received image, and also receive the hash value that the production site provided to the blockchain. If the hash value generated by the cloud backup provider matches the hash value provided by the production site to the blockchain, the cloud backup provider can acknowledge that the correct image or replica has been received, and, thus, acknowledge the image or replica as a transaction in the blockchain. This acknowledgment proves that the correct data has reached the cloud backup provider (e.g., the blockchain can be used to prove when consistent data was received by the cloud provider). As a result, described embodiments provide both the production site and the cloud backup provider a way to prove when each party received consistent data at a given point in time.
Similarly, when a user of production site 102 accesses a given image or replica (e.g., a given PIT) from cloud replication site 122, the production site may generate a hash value of the image received from cloud replication site 122, and compare the generated hash value to the hash value stored in blockchain 140 to verify that the received image is consistent and truly represents the requested PIT. Thus, the cloud backup provider cannot claim that a consistent PIT was not received, since the blockchain provides a transaction receipt. Similarly, the cloud backup provider cannot provide an image from an incorrect time, since the production site user can verify the PIT from the blockchain. Congruently, the production site user cannot claim that the cloud backup provider is providing an incorrect or inconsistent image since the blockchain independently verifies the PIT image.
Therefore, described embodiments allow proof of image data consistency by any production site and any cloud backup provider. Further, the blockchain proof is not dependent on any third-party organization and is tamper-resistant. Both users (e.g., production sites) and cloud backup providers can check and verify compliance with service level agreements (SLAs) through an independent blockchain. Further, both users (e.g., production sites) and cloud backup providers can monitor the blockchain (either periodically or in real time) to detect and/or correct inconsistencies between images (e.g. indicating an error, performing a full sweep replication of the production volume(s), maintaining transaction logs for analysis, etc.).
For example, referring back to
A blockchain maintains integrity (e.g., is difficult to tamper with) because each block refers to or includes a cryptographic hash value of any prior blocks. Accordingly, it can be difficult to modify or tamper with the transactions contained within the block since even a small modification to the data will change the hash value of the entire block.
Identifiers of sources and destinations used for blockchain transactions may be generated by cryptography such as public key cryptography. For example, an identifier may be generated based upon a private key. The relationship between the private key and the identifier can later be used to prove that the identifier is associated with the transaction. In other words, the identifier can be used to create another transaction based upon the prior transaction.
An illustrative blockchain is shown in
Cloud replication site 122′ receives replica 202 as replica 202′, and generates hash 206 of replica 202′, as indicated by dashed line 4. Cloud replication site 122′ requests hash 204′ from blockchain 140′ (e.g., cloud replication site 122′ requests the hash in blockchain 140′ that is associated with the replica 202′ received by cloud replication site 122′), as indicated by dashed line 5. Blockchain 140′ may send hash 204′ to cloud replication site 122′, as indicated by dashed line 6. Cloud replication site 122′ compares hash 204′ and hash 206.
If hash 204′ and hash 206 match, then cloud replication site 122′ has received the correct replica 202 (e.g., the data of replica 202′ received by cloud replication site 122′ is consistent with the data of replica 202 generated and sent by production site 102′). Cloud replication site 122′ sends an acknowledgement (ACK 208) of the replica to production site 102′ and/or blockchain 140′, as indicated by dashed line 7. For example, blockchain 140′ may record ACK 208 as a transaction in block 210, for example along with target identifier 214 that is uniquely associated with cloud replication site 122′ and a date and timestamp indicating when blockchain 140′ received ACK 208.
Alternatively, if hash 204′ and hash 206 do not match, then cloud replication site 122′ has not received the correct replica 202 (e.g., the data of replica 202′ received by cloud replication site 122′ is not consistent with the data of replica 202 generated and sent by production site 102′). Cloud replication site 122′ may send a negative acknowledgement (NAK 208) of the replica to production site 102′ and/or blockchain 140′, as indicated by dashed line 7. For example, blockchain 140′ may record NAK 208 as a transaction in block 210, for example along with target identifier 214 that is uniquely associated with cloud replication site 122′ and a date and timestamp indicating when blockchain 140′ received NAK 208.
Thus, blockchain 140′ may act as a record to confirm whether (and when) cloud replication site 122′ received correct replica data from production site 102′.
For example, as shown in
Referring to
Referring to
At block 410, if the hash value generated at block 404 and the hash value received at block 408 match, then at block 412, cloud replication site 122 sends an acknowledgement (ACK) of receipt of the correct replica. For example, the ACK may be sent to one or both of production site 102 and blockchain 140. In embodiments where cloud backup provider receives the hash value from the production site, the cloud backup provider may verify that the hash value of the replica is written to the blockchain prior to sending an acknowledgement of the replica. If, at block 410, the hash value generated at block 404 and the hash value received at block 408 do not match, then at block 414, cloud replication site 122 may send a negative acknowledgement (NAK) of receipt of the replica. For example, the NAK may be sent to one or both of production site 102 and blockchain 140. At block 416, process 400 completes.
If hash 204′ and hash 504 match, then production site 102″ has received the correct replica 202 (e.g., the data of replica 502′ received by production site 102″ is consistent with the data of the replica originally generated and sent by production site 102″ to cloud replication site 122″, as recorded by blockchain 140″). Production site 102″ may send an acknowledgement (ACK 508) of the replica to cloud replication site 122″ and/or blockchain 140″, as indicated by dashed line 5. For example, blockchain 140″ may record ACK 508 as a transaction in the blockchain, for example along with source identifier 212 that is uniquely associated with production site 102″ and a date and timestamp indicating when blockchain 140′ received ACK 508.
Alternatively, if hash 204′ and hash 504 do not match, then production site 102″ has not received the correct replica 502 (e.g., the data of replica 502′ received by production site 102″ is not consistent with the data of the replica originally generated and sent by production site 102″ to cloud replication site 122″). Production site 102″ may send a negative acknowledgement (NAK 508) of the replica to cloud replication site 122″ and/or blockchain 140″, as indicated by dashed line 5. For example, blockchain 140″ may record NAK 508 as a transaction in the blockchain, for example along with source identifier 212 that is uniquely associated with production site 102″ and a date and timestamp indicating when blockchain 140′ received NAK 508.
Thus, blockchain 140″ may act as a record to confirm whether (and when) production site 102″ received correct replica data from cloud replication site 122″.
Referring to
At block 610, if the hash value generated at block 606 and the hash value received at block 608 match, then at block 612, production site 102 sends an acknowledgement (ACK) of receipt of the correct replica. For example, the ACK may be sent to one or both of cloud replication site 122 and blockchain 140. If, at block 610, the hash value generated at block 606 and the hash value received at block 608 do not match, then at block 614, production site 102 may send a negative acknowledgement (NAK) of receipt of the replica. For example, the NAK may be sent to one or both of cloud replication site 122 and blockchain 140. At block 616, process 400 completes.
In some described embodiments, hosts 104 of
The processes described herein are not limited to use with the hardware and software of
The processes described herein are not limited to the specific embodiments described. For example, the processes are not limited to the specific processing order shown in
Processor 702 may be implemented by one or more programmable processors executing one or more computer programs to perform the functions of the system. As used herein, the term “processor” describes an electronic circuit that performs a function, an operation, or a sequence of operations. The function, operation, or sequence of operations may be hard coded into the electronic circuit or soft coded by way of instructions held in a memory device. A “processor” may perform the function, operation, or sequence of operations using digital values or using analog signals. In some embodiments, the “processor” can be embodied in one or more application specific integrated circuits (ASICs). In some embodiments, the “processor” may be embodied in one or more microprocessors with associated program memory. In some embodiments, the “processor” may be embodied in one or more discrete electronic circuits. The “processor” may be analog, digital or mixed-signal. In some embodiments, the “processor” may be one or more physical processors or one or more “virtual” (e.g., remotely located or “cloud”) processors.
Various functions of circuit elements may also be implemented as processing blocks in a software program. Such software may be employed in, for example, one or more digital signal processors, microcontrollers, or general purpose computers. Described embodiments may be implemented in hardware, a combination of hardware and software, software, or software in execution by one or more physical or virtual processors.
Some embodiments may be implemented in the form of methods and apparatuses for practicing those methods. Described embodiments may also be implemented in the form of program code, for example, 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. A non-transitory machine-readable medium may include but is not limited to tangible media, such as magnetic recording media including hard drives, floppy diskettes, and magnetic tape media, optical recording media including compact discs (CDs) and digital versatile discs (DVDs), solid state memory such as flash memory, hybrid magnetic and solid state memory, non-volatile memory, volatile memory, and so forth, but does not include a transitory signal per se. When embodied in a non-transitory machine-readable medium and the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the method.
When implemented on one or more processing devices, the program code segments combine with the processor to provide a unique device that operates analogously to specific logic circuits. Such processing devices may include, for example, a general-purpose microprocessor, a digital signal processor (DSP), a reduced instruction set computer (RISC), a complex instruction set computer (CISC), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), a programmable logic array (PLA), a microcontroller, an embedded controller, a multi-core processor, and/or others, including combinations of one or more of the above. Described embodiments may 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 as recited in the claims.
Various elements, which are described in the context of a single embodiment, may also be provided separately or in any suitable subcombination. It will be further understood that various changes in the details, materials, and arrangements of the parts that have been described and illustrated herein may 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 |
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 |
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 |
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 |
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 |
9792384 | Riemers | Oct 2017 | B2 |
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 |
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 |
20180091524 | Setty | Mar 2018 | A1 |
20180157700 | Roberts | Jun 2018 | A1 |
20180191502 | Karame | Jul 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/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 May 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. |