High-assurance multi-domain network switch

US10587450B1 · US · B1

Patent metadata
FieldValue
Publication numberUS-10587450-B1
Application numberUS-201715583661-A
CountryUS
Kind codeB1
Filing dateMay 1, 2017
Priority dateApr 29, 2016
Publication dateMar 10, 2020
Grant dateMar 10, 2020

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

Embodiments for a method of implementing multiple domains in a network switching device are disclosed. The method includes assigning a plurality of hardware ports to a plurality of domains. Ports are assigned to at least two of the plurality of domains, and none of the ports are concurrently assigned to multiple domains. The method also includes loading rules for forwarding packets between the plurality of ports into a data plane. The rules direct the data plane to forward only between ports in a common domain of the plurality of domains. The method also includes assuring that a packet received at any port assigned to a first domain is not sent in legible form from any port assigned to a second domain if an error causes the data plane to forward or request forwarding the packet to any port assigned to a second domain.

First claim

Opening claim text (preview).

What is claimed is: 1. A method of implementing multiple domains in a network switching device having a plurality of hardware ports, the method comprising: assigning a plurality of hardware ports to a plurality of domains, wherein hardware ports are assigned to at least two of the plurality of domains, and none of the plurality of hardware ports are concurrently assigned to multiple domains of the plurality of domains; loading rules for forwarding packets between the plurality of hardware ports into a data plane for the network switching device, wherein the rules direct the data plane to forward only between hardware ports in a common domain of the plurality of domains; and assuring that a packet received at any hardware port assigned to a first domain of the plurality of domains is not sent in legible form from any hardware port assigned to a second domain of the plurality of domains if an error causes the data plane to forward or request forwarding the packet to any hardware port assigned to a second domain of the plurality of domains. 2. The method of claim 1 , wherein the error includes a corrupted data structure controlling packet switching decisions. 3. The method of claim 1 , comprising: executing, on the network switching device, a hypervisor to control access to hardware on the network switching device; executing a first forwarding rule custodian for a first domain, the first forwarding rule custodian executing in a first virtual machine implemented by the hypervisor, the first forwarding rule custodian maintaining first forwarding rules for the first domain; and executing a second forwarding rule custodian for a second domain, the second forwarding rule custodian executing in a second virtual machine implemented by the hypervisor, the second forwarding rule custodian maintaining second forwarding rules for the second domain, executing a port assignment manager in a third virtual machine implemented by the hypervisor, wherein assuring that a packet received at a hardware port assigned to the first domain is not sent in a legible form from any hardware port assigned to the second domain includes the port assignment manager cooperating with the hypervisor to restrict access for the first forwarding rule custodian from hardware ports assigned to a domain other than the first domain, and to restrict access for the second forwarding rule custodian from hardware ports assigned to a domain other than the second domain. 4. The method of claim 3 , comprising: executing a first software implemented traffic forwarding engine in a fourth virtual machine implemented by the hypervisor; executing a second software implemented traffic forwarding engine in a fifth virtual machine implemented by the hypervisor; wherein the first forwarding rule custodian loads first forwarding rules into the first software implemented traffic forwarding engine and wherein the second forwarding rule custodian loads second forwarding rules into the second software implemented traffic forwarding engine. 5. The method of claim 4 , wherein assuring that a packet received at a hardware port assigned to the first domain is not sent in a legible form from any hardware port assigned to the second domain includes: the port assignment manager and the hypervisor cooperating to deny requests by the first software implemented traffic forwarding engine for access to hardware ports that are not assigned to the first domain; and the port assignment manager and the hypervisor cooperating to deny requests by the second software implemented traffic forwarding engine for access to hardware ports that are not assigned to the second domain. 6. The method of claim 3 , wherein the port assignment manager only assigns a hardware port to a domain in response to a command from the network manager, wherein the network switching device receives the command from the network manager over a network link. 7. The method of claim 6 , wherein a first pair of hardware ports on the network switching device are not assigned to any domain and are used for network communications between the port assignment manager and the network manager, the communications including commands instructing the port assignment manager to assign a first set of hardware ports to the first domain and a second set of hardware ports to the second domain. 8. The method of claim 3 , wherein the first forwarding rule custodian directs forwarding between all the ports of the plurality of ports assigned to the first domain, wherein the second forwarding rule custodian directs forwarding between all the ports of the plurality of ports assigned to the second domain. 9. The method of claim 3 , wherein the port assignment manager is configured to: direct the first forwarding rule custodian to use only memory within a first block; and direct the second forwarding rule custodian to use only memory within a second block, wherein the second block does not overlap the first block. 10. The method of claim 4 , wherein a first set of hardware ports are assigned to the first domain and a second set of hardware ports are assigned to the second domain, the method comprising: executing a first one or more port hardware controllers for the first set of hardware ports, and a second one or more port hardware controllers for the second set of hardware ports, each port hardware controller of the first one or more port hardware controllers and the second one or more port hardware controllers executing in a distinct virtual machine implemented by the hypervisor, wherein each port hardware controller of the first one or more port hardware controllers and the second one or more port hardware controllers implements a TCP/IP stack for a corresponding hardware port. 11. The method of claim 10 , comprising: after assigning the first set of ports to the first domain, re-assigning one or more ports of the first set of ports by: removing the one or more ports from the first domain; and assigning the one or more ports to the second domain. 12. The method of claim 11 , wherein removing the one or more ports from the first domain includes: destroying the respective port hardware controller corresponding to each of the one or more ports or revoking access to the respective port hardware controller corresponding to each of the one or more ports for the virtual machine corresponding to the first software implemented traffic forwarding engine; and instructing the first forwarding rule custodian to no longer direct forwarding to or from the one or more ports; wherein assigning the one or more ports to the second domain includes: granting access to a respective port hardware controller for each of the one or more ports for the virtual machine corresponding to the second software implemented traffic forwarding engine; and instructing the second forwarding rule custodian to direct forwarding to and from the one or more ports. 13. The method of claim 1 , comprising: executing, on the network switching device, a secure kernel to control access to hardware on the network switching device; executing a first forwarding rule custodian on the secure kernel, the first forwarding rule custodian maintaining first forwarding rules for the first domain; and executing a second forwarding rule custodian on the secure kernel, the second forwarding rule custodian maintaining second forwarding rules for the second domain, executing a port assignment manager on the secure kernel, wherein assuring that a packet received at a hardware port assigned to the first domain is not sent in a legible form from any hardware port assigned to the second domain includes the port assignment ma

Assignees

Inventors

Classifications

  • Filtering by address, protocol, port number or service, e.g. IP-address or URL · CPC title

  • Virtual LANs, VLANs, e.g. virtual private networks [VPN] (LAN interconnection over a bridge based backbone H04L12/462; encapsulation techniques H04L12/4633; routing of packets H04L45/00; packet switches H04L49/00; virtual private networks for security H04L63/0272) · CPC title

  • Single bridge functionality, e.g. connection of two networks over a single bridge · CPC title

  • H04L12/462Primary

    LAN interconnection over a bridge based backbone · CPC title

  • Hypervisor-specific management and integration aspects · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US10587450B1 cover?
Embodiments for a method of implementing multiple domains in a network switching device are disclosed. The method includes assigning a plurality of hardware ports to a plurality of domains. Ports are assigned to at least two of the plurality of domains, and none of the ports are concurrently assigned to multiple domains. The method also includes loading rules for forwarding packets between the …
Who is the assignee on this patent?
Architecture Tech Corp
What technology area does this patent fall under?
Primary CPC classification H04L63/0236. Mapped technology areas include Electricity.
When was this patent published?
Publication date Tue Mar 10 2020 00:00:00 GMT+0000 (Coordinated Universal Time) (B1). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 2 related publications on this page (citations in our corpus or others sharing the same primary CPC).