Switching ethernet controller
First Claim
1. A generally full-wire throughput, switching Ethernet controller for use within an Ethernet network of other switching Ethernet controllers connected together by a bus, the controller comprising:
- a. a plurality of ports including at least one bus port associated with ports connected to other switching Ethernet controllers;
b. a hash table for storing addresses of ports within said Ethernet network;
c. hash table address control for hashing the address of a packet to initial hash table location values, for changing the hash table location values by a fixed jump amount if the address values stored in said initial hash table location does not match the received address, and for providing at least an output port number of the port associated with the received address;
d. a storage buffer including a multiplicity of contiguous buffers in which to temporarily store said packet;
e. an empty list including a multiplicity of single bit buffers;
f. a packet storage manager for associating the state of the bit of a single bit buffer with the empty or full state of an associated contiguous buffer and for generating the address of a contiguous buffer through a simple function of the address or number of its associated single bit buffer;
g. a packet transfer manager for directing said temporarily stored packet to the port determined by said hash table control unit; and
h. a write-only bus communication unit, activated by said packet transfer manager, for transferring said packet out said at least one bus port by utilizing said bus only for write operations.
1 Assignment
0 Petitions
Accused Products
Abstract
An Ethernet controller, for use within an Ethernet network of other Ethernet controller connected together by a bus, is provided. The Ethernet controller includes a plurality of ports including at least one bus port associated with ports connected to other switching Ethernet controllers, a hash table for storing addresses of ports within the Ethernet network, a hash table address control, a storage buffer including a multiplicity of contiguous buffers in which to temporarily store said packet, an empty list including a multiplicity of single bit buffers, a packet storage manager, a packet transfer manager and a write-only bus communication unit. The hash table address control hashes the address of a packet to initial hash table location values, changes the hash table location values by a fixed jump amount if the address values stored in the initial hash table location do not match the received address, and provides at least an output port number of the port associated with the received address. The packet storage manager associates the state of the bit of a single bit buffer with the empty or full state of an associated contiguous buffer and generates the address of a contiguous buffer. The packet transfer manager directs the temporarily stored packet to the port determined by said hash table control unit. The write-only bus communication unit is activated by the packet transfer manager, for transferring the packet out of the bus port by utilizing the bus for write only operations.
49 Citations
32 Claims
-
1. A generally full-wire throughput, switching Ethernet controller for use within an Ethernet network of other switching Ethernet controllers connected together by a bus, the controller comprising:
-
a. a plurality of ports including at least one bus port associated with ports connected to other switching Ethernet controllers; b. a hash table for storing addresses of ports within said Ethernet network; c. hash table address control for hashing the address of a packet to initial hash table location values, for changing the hash table location values by a fixed jump amount if the address values stored in said initial hash table location does not match the received address, and for providing at least an output port number of the port associated with the received address; d. a storage buffer including a multiplicity of contiguous buffers in which to temporarily store said packet; e. an empty list including a multiplicity of single bit buffers; f. a packet storage manager for associating the state of the bit of a single bit buffer with the empty or full state of an associated contiguous buffer and for generating the address of a contiguous buffer through a simple function of the address or number of its associated single bit buffer; g. a packet transfer manager for directing said temporarily stored packet to the port determined by said hash table control unit; and h. a write-only bus communication unit, activated by said packet transfer manager, for transferring said packet out said at least one bus port by utilizing said bus only for write operations. - View Dependent Claims (2)
-
-
3. A switching controller, comprising:
-
a hash table including a plurality of hash table locations that store destination addresses; a hash table controller that selects a first address in the hash table based on a hash of a first destination address in at least one packet; and a packet transfer manager that transfers the at least one packet from a source port to a destination port when a second destination address stored at the first address matches the first destination address and that selects a second address that is offset from the first address in the hash table when the second destination address stored at the first address does not match the first destination address. - View Dependent Claims (4, 5, 6, 7, 8, 9, 10, 11, 12)
-
-
13. A switching controller, comprising:
-
hash table storing means for storing a plurality of hash table locations that store destination addresses; hash table control means for selecting a first address in the hash table based on a hash of a first destination address in at least one packet; and packet transfer managing means for transferring the at least one packet from a source port to a destination port when a second destination address stored at the first address matches the first destination address and that selects a second address that is offset from the first address in the hash table when the second destination address stored at the first address does not match the first destination address. - View Dependent Claims (14, 15, 16, 17, 18, 19, 20, 21, 22)
-
-
23. A method for operating a switching controller, comprising:
-
providing a hash table including a plurality of hash table locations that store destination addresses; selecting a first address in the hash table based on a hash of a first destination address in at least one packet; transferring the at least one packet from a source port to a destination port when a second destination address stored at the first address matches the first destination address; and selecting a second address that is offset from the first address in the hash table when the second destination address stored at the first address does not match the first destination address. - View Dependent Claims (24, 25, 26, 27, 28, 29, 30, 31, 32)
-
Specification