Embodiments presented in this disclosure generally relate to computer networking. More specifically, though not exclusively, embodiments disclosed herein relate to policy consolidation for network data centers.
Modern network data centers can include large numbers of network policies. For example, data centers can include a very large number of specific security policies governing traffic within the data center. In some circumstances, automated systems can be used to orchestrate dynamic generation of these security policies (and other network policies).
For example, data centers can include whitelist rules describing allowed network traffic within the data centers. But automated orchestration systems tend to create fine grained whitelist rules. These rules can be fine-grained to the point that they define specific allowed network traffic between specific network endpoints. The fine-grained nature of these automated policies can result in a huge number of whitelist rules on a single network node or switch.
So that the manner in which the above-recited features of the present disclosure can be understood in detail, a more particular description of the disclosure, briefly summarized above, may be had by reference to embodiments, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate typical embodiments and are therefore not to be considered limiting, other equally effective embodiments are contemplated.
To facilitate understanding, identical reference numerals have been used, where possible, to designate identical elements that are common to the figures. It is contemplated that elements disclosed in one embodiment may be beneficially used in other embodiments without specific recitation.
Embodiments described herein include a computerized method for generating whitelist policies in a communication network. The method includes identifying a first plurality of whitelist policies for the communication network, each whitelist policy including a pair of endpoints and a policy identifier identifying a rule governing traffic between the pair of endpoints. The method further includes consolidating the first plurality of whitelist policies into a second plurality of whitelist policies based on populating a plurality of tables using the first plurality of whitelist policies. The populated tables include a first table including the pairs of endpoints and associating each pair of endpoints with a service identifier and a second table associating the service identifiers with the policy identifiers. The method further includes programming the second plurality of whitelist policies into a network device in the communication network, based on at least one of the plurality of tables. The method further includes enforcing the rules governing traffic between the pair of endpoints, at the network device, using the programmed second plurality of whitelist policies.
Embodiments described herein further include a system, including a processor and a memory containing computer program code that, when executed by the processor, performs an operation. The operation includes identifying a first plurality of whitelist policies for the communication network, each whitelist policy including a pair of endpoints and a policy identifier identifying a rule governing traffic between the pair of endpoints. The operation further includes consolidating the first plurality of whitelist policies into a second plurality of whitelist policies based on populating a plurality of tables using the first plurality of whitelist policies. The populated tables include a first table including the pairs of endpoints and associating each pair of endpoints with a service identifier and a second table associating the service identifiers with the policy identifiers. The operation further includes programming the second plurality of whitelist policies into a network device in the communication network, based on at least one of the plurality of tables. The operation further includes enforcing the rules governing traffic between the pair of endpoints, at the network device, using the programmed second plurality of whitelist policies.
Embodiments described herein further include a non-transitory computer-readable medium containing computer program code that, when executed by operation of one or more computer processors, performs an operation. The operation includes identifying a first plurality of whitelist policies for the communication network, each whitelist policy including a pair of endpoints and a policy identifier identifying a rule governing traffic between the pair of endpoints. The operation further includes consolidating the first plurality of whitelist policies into a second plurality of whitelist policies based on populating a plurality of tables using the first plurality of whitelist policies. The populated tables include a first table including the pairs of endpoints and associating each pair of endpoints with a service identifier and a second table associating the service identifiers with the policy identifiers. The operation further includes programming the second plurality of whitelist policies into a network device in the communication network, based on at least one of the plurality of tables. The operation further includes enforcing the rules governing traffic between the pair of endpoints, at the network device, using the programmed second plurality of whitelist policies.
Large numbers of whitelist rules on network nodes in data centers can result in wasted memory and compute time. This can result in too many rules to fit on a given network node, or network delays from enforcing the rules. One or more embodiments described herein relate to techniques for consolidating these rules by exploiting patterns in auto-orchestrated whitelist rules. This significantly reduces the number of rules programmed into a given network node, freeing memory and reducing switching and routing times.
For example, in some data center deployments, a service offered by a virtual machine (VM) can be utilized by thousands of clients. This can translate to thousands of identical rules between different pairs of endpoints (e.g., devices communicating using the data center network). According to one or more techniques disclosed herein, these identical rules, which differ only on the source and destination endpoints, can be consolidated into a single policy (or smaller collection of policies) that is identified by a service identifier. All endpoints using the specified service, to which the policy applies, can then be classified with the service identifier. The policy can be administered for the clients and endpoints using the service identifier.
In practice, this can result in up to an 80% reduction in the number of policies. Further, applying one or more techniques disclosed herein the number of policies used to enforce the desired rules does not depend on the number of consumers. Instead, it depends on the services and types of flows in the network (e.g., the data center).
Further, if a client VM migrates from one device to another, the associated entry can simply be removed from the service identifier mapping. In this way, the rules for a service are present on a device as long as at least one client behind the device is using the service. The rules can be removed once all clients behind the device migrate away or stop using the service.
In an embodiment, a data center 120 includes a number of endpoints 102A-N. The data center 120 further includes a number of switches 122A-N. In an embodiment, the switches 122A-N are leaf switches in a spine-and-leaf architecture (e.g., in an SDN system). Alternatively, the switches 122A-N can be any suitable network switches or other routing devices in the data center 120. In an embodiment the switches 122A-N are programmable, and route traffic between the endpoints 102A-C in the data center 120. For example, an endpoint 102A can communicate with an endpoint 102B in the data center 120 using one or more of the switches 122A-N. The data center 120 can use any suitable network communication technique, including wired connections, wireless connections, cellular connections, and any other suitable technique. Further, the data center 120 can include any suitable network, including one or more local area networks (LANs), virtual local area networks (VLANs), or other suitable networks.
As another alternative, the switches 122A-N can be virtual switches (e.g., software or firmware applications operating to switch network traffic). For example, the switches 122A-N can be virtual switches operating in a private cloud environment. As another alternative, the switches 122A-N can be virtual switches operating in a public cloud environment.
As illustrated in
In an embodiment, the system 100 further includes a public cloud 130. The data center 120 can further communicate with the public cloud 130 (e.g., through one or more of the endpoints 102A-N).
The network components 220 include the components necessary for the switch 122 to interface with a communication network (e.g., in the data center 120 illustrated in
The memory 210 generally includes program code for performing various functions related to use of the switch 122. The program code is generally described as various functional “applications” or “modules” within the memory 210, although alternate implementations may have different functions and/or combinations of functions. Within the memory 210, the policy consolidator module 212 consolidates policies (e.g., whitelist policies), as described in relation to
At block 304, a policy consolidator (e.g., the policy consolidator 212 illustrated in
At block 306, the policy consolidator populates the tables using the collection of rules and endpoints. This is discussed further with regard to
In an embodiment,
Without consolidation, all fifteen of these flows would be programmed into the rule enforcement components (e.g., the rule enforcement components 230 of the switch 122 illustrated in
At block 402, a policy consolidator (e.g., policy consolidator 212 illustrated in
As illustrated in
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. The table 606 in
At block 422, the policy consolidator updates the service ID associated with the endpoints in the table 602, if necessary, based on the service ID used in the table 606. At block 424, the policy consolidator determines whether this is the last flow in the list of whitelist policies. It is not, so the flowchart returns to block 402 and selects the next flow.
This is illustrated in
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. Policy2 is not in the table 606, so the flowchart proceeds to block 418 and adds the policy combination to Table_3. In the example of
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. Policy1 is in the table 606, so the flowchart proceeds to block 420. At block 420, the policy consolidator updates the row associated with policy1 (and service ID 1) to include the endpoints (EP4-EP5). At block 422, the policy consolidator updates the service ID associated with the endpoints in the table 602, if necessary, based on the service ID used in the table 606. Flow-3 is again not the last flow, so the policy consolidator returns to block 402 and selects the next flow.
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. Policy2 is in the table 606, so the flowchart proceeds to block 420. At block 420, the policy consolidator updates the row associated with policy2 (and service ID 2) to include the endpoints (EP6-EP7). At block 422, the policy consolidator updates the service ID associated with the endpoints in the table 602, if necessary, based on the service ID used in the table 606. Flow-4 is again not the last flow, so the policy consolidator returns to block 402 and selects the next flow.
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. Policy1 is in the table 606, so the flowchart proceeds to block 420. At block 420, the policy consolidator updates the row associated with policy1 (and service ID 1) to include the endpoints (EP8-EP9). At block 422, the policy consolidator updates the service ID associated with the endpoints in the table 602, if necessary, based on the service ID used in the table 606. Flow-5 is again not the last flow, so the policy consolidator returns to block 402 and selects the next flow.
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. Policy4 is not in the table 606, so the flowchart proceeds to block 418. At block 418, the policy consolidator adds a row with service ID 3, policy4, and endpoints (EP10-EP2) to the table 606. At block 422, the policy consolidator updates the service ID associated with the endpoints in the table 602, if necessary, based on the service ID used in the table 606. Flow-6 is again not the last flow, so the policy consolidator returns to block 402 and selects the next flow.
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. The policy combination (policy1, policy4) is not in the table 606, so the flowchart proceeds to block 418. At block 418, the policy consolidator adds a row with service ID 4, policy combination (policy1, policy4), and endpoints (EP1-EP2) to the table 606. Of note, in an embodiment, each endpoint pairing is associated with only one service ID and one policy combination. Endpoint pair (EP1-EP2) is associated with both policy1 and policy4. So the policy consolidator removes endpoints (EP1-EP2) from the row in the table 606 associated with just policy1 (and service ID 1) when it adds endpoints (EP1-EP2) to the row associated with both policy1 and policy4 (and service ID 4). At block 422, the policy consolidator updates the service ID associated with the endpoints in the table 602, if necessary, based on the service ID used in the table 606. Flow-7 is again not the last flow, so the policy consolidator returns to block 402 and selects the next flow.
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. The policy combination (policy2, policy5) is not in the table 606, so the flowchart proceeds to block 418. At block 418, the policy consolidator adds a row with service ID 5, policy combination (policy2, policy5), and endpoints (EP1-EP3) to the table 606. Endpoint pair (EP1-EP3) is associated with both policy2 and policy5. So the policy consolidator removes endpoints (EP1-EP3) from the row in the table 606 associated with just policy2 (and service ID 2) when it adds endpoints (EP1-EP3) to the row associated with both policy2 and policy5 (and service ID 5). At block 422, the policy consolidator updates the service ID associated with the endpoints in the table 602, if necessary, based on the service ID used in the table 606. Flow-8 is again not the last flow, so the policy consolidator returns to block 402 and selects the next flow.
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. The policy combination (policy1, policy4) is in the table 606, so the flowchart proceeds to block 420. At block 420, the policy consolidator updates the row associated with (policy1, policy4), and service ID 4, to include the endpoints (EP4-EP5). Endpoint pair (EP4-EP5) is associated with both policy1 and policy4. So the policy consolidator removes endpoints (EP4-EP5) from the row in the table 606 associated with just policy1 (and service ID 1) when it adds endpoints (EP4-EP5) to the row associated with both policy1 and policy4 (and service ID 4). At block 422, the policy consolidator updates the service ID associated with the endpoints in the table 602, if necessary, based on the service ID used in the table 606. Flow-9 is again not the last flow, so the policy consolidator returns to block 402 and selects the next flow.
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. The policy combination (policy2, policy5) is in the table 606, so the flowchart proceeds to block 420. At block 420, the policy consolidator updates the row associated with (policy2, policy5), and service ID 5, to include the endpoints (EP6-EP7). Endpoint pair (EP6-EP7) is associated with both policy2 and policy5. So the policy consolidator removes endpoints (EP6-EP2) from the row in the table 606 associated with just policy2 (and service ID 2) when it adds endpoints (EP6-EP7) to the row associated with both policy2 and policy5 (and service ID 5). At block 422, the policy consolidator updates the service ID associated with the endpoints in the table 602, if necessary, based on the service ID used in the table 606. Flow-10 is again not the last flow, so the policy consolidator returns to block 402 and selects the next flow.
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. The policy combination (policy1, policy6) is not in the table 606, so the flowchart proceeds to block 418. At block 418, the policy consolidator adds the policy combination (policy1, policy6) to the table 606. In an embodiment, as illustrated in
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. The policy combination (policy4, policy6) is not in the table 606, so the flowchart proceeds to block 418. At block 418, the policy consolidator adds the policy combination (policy4, policy6) to the table 606. In an embodiment, as illustrated in
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. The policy combination (policy1, policy4, policy6) is not in the table 606, so the flowchart proceeds to block 418. At block 418, the policy consolidator adds the policy combination (policy1, policy4, policy6) to the table 606, and associates it with service ID 6. Endpoint pair (EP1-EP2) is associated with all three of policy1, policy4, and policy6. So the policy consolidator removes endpoints (EP1-EP2) from the row in the table 606 associated with just policy1 and policy4 (and service ID 4) when it adds the new row with service ID 6, policy combination (policy1, policy4, policy6) and endpoints (EP1-EP2). At block 422, the policy consolidator updates the service ID associated with the endpoints in the table 602, if necessary, based on the service ID used in the table 606. Flow-13 is again not the last flow, so the policy consolidator returns to block 402 and selects the next flow.
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. The policy combination (policy1, policy4, policy6) is in the table 606, so the flowchart proceeds to block 420. At block 420, the policy consolidator updates the row associated with policy combination (policy1, policy4, policy) and service ID 6 to includes endpoints (EP8-EP9). Endpoint pair (EP8-EP9) is associated with all three of policy1, policy4, and policy6. So the policy consolidator removes endpoints (EP8-EP9) from the row in the table 606 associated with just policy1 and policy6 (and service ID 1) when it adds the endpoints (EP8-EP9) to the row associated with service ID 6 and policy combination (policy1, policy4, policy6). At block 422, the policy consolidator updates the service ID associated with the endpoints in the table 602, if necessary, based on the service ID used in the table 606. Flow-14 is again not the last flow, so the policy consolidator returns to block 402 and selects the next flow.
At block 410, the policy consolidator determines whether the policy identifier is already in Table_2 (e.g., table 604 illustrated in
At block 416, the policy consolidator determines whether the policy combination is already in Table_3. The policy combination (policy1, policy4, policy6) is in the table 606, so the flowchart proceeds to block 420. At block 420, the policy consolidator updates the row associated with policy combination (policy1, policy4, policy) and service ID 6 to includes endpoints (EP4-EP5). Endpoint pair (EP4-EP5) is associated with all three of policy1, policy4, and policy6. So the policy consolidator removes endpoints (EP4-EP5) from the row in the table 606 associated with just policy1 and policy4 (and service ID 4) when it adds the endpoints (EP4-EP5) to the row associated with service ID 6 and policy combination (policy1, policy4, policy6). At block 422, the policy consolidator updates the service ID associated with the endpoints in the table 602, if necessary, based on the service ID used in the table 606. Flow-15 is, finally, the last flow so the flowchart in
At block 702 a policy consolidator (e.g., policy consolidator 212 illustrated in
At block 704, the policy consolidator programs the rules table in the hardware (e.g., into the rule enforcement components 230 in the switch 122). In an embodiment, the policy consolidator programs table 602 and table 802, as illustrated in
In the current disclosure, reference is made to various embodiments. However, the scope of the present disclosure is not limited to specific described embodiments. Instead, any combination of the described features and elements, whether related to different embodiments or not, is contemplated to implement and practice contemplated embodiments. Additionally, when elements of the embodiments are described in the form of “at least one of A and B,” it will be understood that embodiments including element A exclusively, including element B exclusively, and including element A and B are each contemplated. Furthermore, although some embodiments disclosed herein may achieve advantages over other possible solutions or over the prior art, whether or not a particular advantage is achieved by a given embodiment is not limiting of the scope of the present disclosure. Thus, the aspects, features, embodiments and advantages disclosed herein are merely illustrative and are not considered elements or limitations of the appended claims except where explicitly recited in a claim(s). Likewise, reference to “the invention” shall not be construed as a generalization of any inventive subject matter disclosed herein and shall not be considered to be an element or limitation of the appended claims except where explicitly recited in a claim(s).
As will be appreciated by one skilled in the art, the embodiments disclosed herein may be embodied as a system, method or computer program product. Accordingly, embodiments may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, embodiments may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for embodiments of the present disclosure may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the present disclosure are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatuses (systems), and computer program products according to embodiments presented in this disclosure. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the block(s) of the flowchart illustrations and/or block diagrams.
These computer program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other device to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the block(s) of the flowchart illustrations and/or block diagrams.
The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process such that the instructions which execute on the computer, other programmable data processing apparatus, or other device provide processes for implementing the functions/acts specified in the block(s) of the flowchart illustrations and/or block diagrams.
The flowchart illustrations and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods, and computer program products according to various embodiments. In this regard, each block in the flowchart illustrations or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the Figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustrations, and combinations of blocks in the block diagrams and/or flowchart illustrations, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
In view of the foregoing, the scope of the present disclosure is determined by the claims that follow.
Number | Name | Date | Kind |
---|---|---|---|
9571502 | Basso et al. | Feb 2017 | B2 |
9813420 | Basso et al. | Nov 2017 | B2 |
10380344 | David | Aug 2019 | B1 |
20130097660 | Das et al. | Apr 2013 | A1 |
20150180908 | Dang et al. | Jun 2015 | A1 |
20160183196 | Pitzely | Jun 2016 | A1 |
20160357424 | Pang et al. | Dec 2016 | A1 |
20160357587 | Yadav et al. | Dec 2016 | A1 |
20160357957 | Deen et al. | Dec 2016 | A1 |
20160359592 | Kulshreshtha et al. | Dec 2016 | A1 |
20160359628 | Singh et al. | Dec 2016 | A1 |
20160359658 | Yadav et al. | Dec 2016 | A1 |
20160359673 | Gupta et al. | Dec 2016 | A1 |
20160359678 | Madani et al. | Dec 2016 | A1 |
20160359679 | Parandehgheibi et al. | Dec 2016 | A1 |
20160359680 | Parandehgheibi et al. | Dec 2016 | A1 |
20160359686 | Parandehgheibi et al. | Dec 2016 | A1 |
20160359696 | Yadav et al. | Dec 2016 | A1 |
20160359697 | Scheib et al. | Dec 2016 | A1 |
20160359698 | Deen et al. | Dec 2016 | A1 |
20160359699 | Gandham et al. | Dec 2016 | A1 |
20160359701 | Pang et al. | Dec 2016 | A1 |
20160359703 | Gandham et al. | Dec 2016 | A1 |
20160359704 | Gandham et al. | Dec 2016 | A1 |
20160359705 | Parandehgheibi et al. | Dec 2016 | A1 |
20160359708 | Gandham et al. | Dec 2016 | A1 |
20160359709 | Deen et al. | Dec 2016 | A1 |
20160359711 | Deen et al. | Dec 2016 | A1 |
20160359712 | Alizadeh Attar et al. | Dec 2016 | A1 |
20160359740 | Parandehgheibi et al. | Dec 2016 | A1 |
20160359759 | Singh et al. | Dec 2016 | A1 |
20160359872 | Yadav et al. | Dec 2016 | A1 |
20160359877 | Kulshreshtha et al. | Dec 2016 | A1 |
20160359878 | Prasad et al. | Dec 2016 | A1 |
20160359879 | Deen et al. | Dec 2016 | A1 |
20160359880 | Pang et al. | Dec 2016 | A1 |
20160359881 | Yadav et al. | Dec 2016 | A1 |
20160359888 | Gupta et al. | Dec 2016 | A1 |
20160359890 | Deen et al. | Dec 2016 | A1 |
20160359891 | Pang et al. | Dec 2016 | A1 |
20160359897 | Yadav et al. | Dec 2016 | A1 |
20160359912 | Gupta et al. | Dec 2016 | A1 |
20160359913 | Gupta et al. | Dec 2016 | A1 |
20160359914 | Deen et al. | Dec 2016 | A1 |
20160359915 | Gupta et al. | Dec 2016 | A1 |
20170034018 | Parandehgheibi et al. | Feb 2017 | A1 |
20170331780 | Reddy et al. | Nov 2017 | A1 |
20180270127 | Pang et al. | Sep 2018 | A1 |
20180270129 | Kulshreshtha et al. | Sep 2018 | A1 |
20190081959 | Yadav et al. | Mar 2019 | A1 |
20190182132 | Gupta et al. | Jun 2019 | A1 |
20190215253 | Yadav et al. | Jul 2019 | A1 |
20190253330 | Gandham et al. | Aug 2019 | A1 |
20190260653 | Yadav et al. | Aug 2019 | A1 |
20190306035 | Scheib et al. | Oct 2019 | A1 |
Number | Date | Country |
---|---|---|
103890770 | Jun 2014 | CN |
107667505 | Feb 2018 | CN |
2769327 | Aug 2014 | EP |
3304824 | Apr 2018 | EP |
3304855 | Apr 2018 | EP |
3304858 | Apr 2018 | EP |
2016196683 | Dec 2016 | WO |
2016196684 | Dec 2016 | WO |