A communication network spanning over a moderate-sized geographic area is typically configured into a local area network (LAN), according to a standard (e.g., an IEEE 802 LAN standard) for exchanging data over a network of interconnected end stations. In one type of network, end stations communicate over a shared access medium. Multiple end stations can be connected to a shared access medium, e.g., in a bus topology or in a star topology. In the bus topology, signals sent by one end station propagate along a bus and are received by other end stations. In the star topology signals sent by one end station propagate to a central device, such as a hub. The hub broadcasts the signals to all of the other end stations (typically after regenerating the signals). The end stations that share an access medium are in a common “access domain.”
When two or more end stations in an access domain attempt to send a signal over the shared access medium close enough in time such that their frames overlap, a “collision” occurs. Collisions are resolved according to the LAN standard, such as Ethernet or Carrier Sense Multiple Access with Collision Detection (CSMA/CD).
Referring to
The LAN 10 includes another VLAN-aware switch 29 that connects hub 90 having end stations 94-96 (in an access domain 143), and an end station 88, to the bus 80. A third VLAN-aware switch 30 connects the bus 80 to an end station 89 and a router 20 that connects the LAN 10 to a wide area network (WAN) 25. The router 20 exchanges traffic between the LAN 10 and the WAN 25 by examining the network address (e.g., an internet protocol (IP) address) in the frames that it receives.
The VLAN-aware switches 28-30 forward traffic according to a logical network arrangement of three VLANs. VLAN A includes end stations 74-76 in access domain 141, end station 88 (alone in its own access domain 144), and end station 89 (alone in its own access domain 145). VLAN B includes end stations 94-96 in access domain 143, and end stations 86-87 in access domain 142.
A management VLAN, VLAN_M, includes “management end stations” 76, 88, and 89, each of which includes a management controller.
In the LAN 10, the VLAN-aware switches 28-30 forward frames for VLAN M among the access domains 141, 142, 144, and 145. Even though the access domain 142 does not include a management end station, the switches forward frames with a VID corresponding to VLAN M (“management frames”) to this access domain 142 since it is on a path between management end stations. So in this network arrangement, non-management end stations 74, 75, 86, and 87 receive forwarded management frames. One way to increase efficiency by limiting the processing of management frames by the non-management end stations is to include an input filter to recognize management frames (e.g., by their VID) and prevent them from entering a protocol stack of a host computer system. The “protocol stack” receives and transmits data according to a set of networking protocols. The protocol stack is organized into layers (e.g., layers of the Open Systems Interconnection (OSI) model) that work together to perform functions such as segmenting data into data packets for transmission and reassembling received data packets. Data is encoded onto signals sent over the shared access medium in segments. A segment or “frame” includes a data packet and other protocol and address information.
A management end station may also use an input filter or switch to divert management frames from a host computer system in the management end station.
Referring to
The data packets in the management frames are typically used for system platform management functions, such as providing remote power on/off, reset, and boot control functions, and providing access to platform health status (e.g., temperatures, voltages, fan state, etc. of the hardware elements) and platform alerting (e.g., sending messages indicating event information). The management controller 204 handles these functions using an out-of-band protocol stack so that processors of the host computer system 202 do not have to handle the management traffic.
The network controller 200 includes an interface 212 (e.g., a peripheral component interconnect (PCI) or peripheral component interconnect express (PCI-E) bus interface) to the host computer system 202 for sending and receiving in-band traffic. Frames that pass the reception filter 210 are temporarily stored in a first-in first-out (FIFO) buffer 214. The interface 212 sends frames to the host computer system 202 from the incoming buffer 214, and stores frames received from the host computer system 202 in an outgoing FIFO buffer 216. An outgoing frame stored in the outgoing buffer 216 has a VID corresponding to a destination VLAN for the frame. The multiplexer (MUX) 222 combines the in-band outgoing frames from the host computer system 202 and the out-of-band outgoing frames from the management controller 204 into a stream of outgoing frames passed to MAC interface 208 for transmission over the LAN.
Alternatively, the interface 212 is configured to handle the incoming and outgoing traffic at another protocol layer. For example, the data segments stored in the incoming 214 and outgoing 216 buffers can be data packets (e.g., corresponding to OSI layer 3). In this case, the reception filter 210 extracts the packet from the frame after checking the VID. The packets stored in the outgoing buffer are thus “tagged” packets that include a VID in the packet (e.g., designated bit locations in the header portion of the packet). The MAC interface 208 inserts this VID into the correct location in the frame, for example, in the Tag Control Information (TCI) portion of the frame for the IEEE 802.1Q VLAN protocol.
The network controller 200 may optionally be configured to assign a VID to an incoming frame based on a higher layer protocol. For example, the network controller can map particular ports or IP addresses to a VID.
A transmission filter 220 is included in the network controller 200 to prevent in-band traffic from the host computer system 202 from interfering with the operation of the management VLAN. For example, a host computer system on a management end station or a non-management end station could generate a denial-of-service attack or otherwise interfere with the management VLAN traffic. The reception filter 210 prevents the host computer system 202 from receiving management VLAN traffic, but does not prevent the host computer system 210 from sending frames with a VID corresponding to the VLAN M. The transmission filter 220 prevents propagation of malicious or inadvertently inserted traffic on the management VLAN by in-band software.
In the example of the management end station 76 shown in
This approach to preventing host computer systems from interfering with management VLAN traffic (or other VLAN traffic) is particularly useful if all of the end stations in the LAN 10 incorporate transmission filters in their network controllers.
Referring to
There are a variety of options for filtering frames belonging to a particular VLAN. In one approach the selection list includes VIDs for frames that are allowed to be transmitted by the host computer system 202, and for any VID that is not on the list, its corresponding frame is excluded from being transmitted by the host computer system 202. In another approach the selection list includes VIDS for excluded frames that are not allowed to be transmitted by the host computer system 202, and for any VID that is not on the list, its corresponding frame is allowed to be transmitted by the host computer system 202. In either case, the excluded frames are blocked or dropped as they come into or out of a network controller's outgoing buffer.
Alternatively, to simplify the processing of frames entering or leaving the buffer, the excluded frames may be intentionally corrupted so that the frames generate an error at a receiving end station causing the end station to discard the corrupted frames.
In one approach to corrupting a frame, the transmission filter 220 sets the VID to an unused or illegal value. A VLAN-aware switch between the source and destination end stations, or a filter in the destination end station will discard the unrecognized frame. In another approach, the transmission filter 220 changes one or more bits in the frame invalidating an appended Cyclical Redundancy Check (CRC). Typically, this CRC has been generated from an algorithm and is based on the data in the frame. If the frame is altered between the source and destination, the receiving station will recognize that the CRC no longer corresponds to the data in the frame and discard the frame.
Referring to
The transmission filter 220 is provided such that the transmission filter 220 is not configurable by the host computer system that is being filtered. One way to accomplish this in a management end station is to only allow the management controller access to selection list registers 300. Another way to accomplish this in either a management or non-management end station is to configure the selection list registers via a run-time inaccessible process such as an interface that gets locked by the Basic Input/Output System (BIOS) during a Power-On Self Test (POST) (e.g., the BIOS software sets a “lock bit” in the registers before turning control of the network controller over to the operating system of the host computer system).
Alternatively, a secured interface can be used to allow only an authorized user to configure the transmission filter 220, for example, by modifying the selection list registers 300 or indicating whether untagged frames are excluded or allowed. An authenticated interface can be integrated into software in the management controller 204 or the host computer system 202, or an authenticated interface can be built into the network controller hardware. For example, a designated port address or VID can enable a remote application to securely configure the selection list registers 300. Other types of security mechanisms can be used to prevent “in-band” software from defeating the transmission filtering.
The reception filters 210 and 211 are also optionally provided such that they are not configurable by the host computer system that is being filtered. A reception filter is configured in a similar way to the transmission filter 220 to prevent “in-band” software from defeating the reception filtering, for example, to intercept management frames.
Other embodiments are within the scope of the following claims.