This patent application relates to interface circuitry for a receive ring buffer of an Advanced Switching (AS) fabric end node device.
PCI (Peripheral Component Interconnect) Express is a serialized I/O interconnect standard developed to meet the increasing bandwidth needs of the next generation of computer systems. PCI Express was designed to be fully compatible with the widely used PCI local bus standard. PCI is beginning to hit the limits of its capabilities, and while extensions to the PCI standard have been developed to support higher bandwidths and faster clock speeds, these extensions may be insufficient to meet the rapidly increasing bandwidth demands of PCs in the near future. With its high-speed and scalable serial architecture, PCI Express may be an attractive option for use with, or as a possible replacement for, PCI in computer systems. [The PCI Express architecture is described in the PCI Express Base Architecture Specification, Revision 1.0 (Initial release Jul. 22, 2002), which is available through the PCI-SIG (PCI-Special Interest Group) (http://www.pcisig.com)].
AS is an extension to the PCI Express architecture. AS utilizes a packet-based transaction layer protocol that operates over the PCI Express physical and data link layers. The AS architecture provides a number of features common to multi-host, peer-to-peer communication devices such as blade servers, clusters, storage arrays, telecom routers, and switches. These features include support for flexible topologies, packet routing, congestion management (e.g., credit-based flow control), fabric redundancy, and fail-over mechanisms. The AS architecture is described in the Advanced Switching Core Architecture Specification, Revision 1.0 (December 2003), which is available through the ASI-SIG (Advanced Switching Interconnect-SIG) (http//:www.asi-sig.org).
Like reference numerals in different figures indicate like elements.
Generally speaking, a switching fabric is a combination of hardware and software that moves data coming into a network node out the correct port to a next network node. A switching fabric includes switching elements, e.g., individual devices in a network node, integrated circuits contained therein, and software that controls switching paths through the switch fabric.
In
As shown in
Referring to
The PI field in the AS route header specifies the format of the encapsulated packet. The PI field is inserted by the end node that originates the AS packet and is used by the end node that terminates the packet to correctly interpret the packet contents. The separation of routing information from the remainder of the packet enables an AS fabric to tunnel packets of any protocol.
PIs represent fabric management and application-level interfaces to AS fabric 11. Table 1 provides a list of PIs currently supported by the AS Specification.
PIs 0-7 are reserved for various fabric management tasks, and PIs 8-254 are application-level interfaces. As shown in Table 1, PI8 is used to tunnel or encapsulate native PCI Express. Other PIs may be used to tunnel various other protocols, e.g., Ethernet, Fibre Channel, ATM (Asynchronous Transfer Mode), InfiniBand®, and SLS (Simple Load Store). An advantage of an AS switch fabric is that a mixture of protocols may be simultaneously tunneled through a single, universal switch fabric making it a powerful and desirable feature for next generation modular applications such as media gateways, broadband access routers, and blade servers.
The AS architecture supports the establishment of direct end node-to-end node logical paths known as Virtual Channels (VCs). This enables a single AS fabric network to service multiple, independent logical interconnects simultaneously. Each VC interconnecting AS end nodes for control, management and data. Each VC provides its own queue so that blocking in one VC does not cause blocking in another. Since each VC has independent packet ordering requirements, each VC can be scheduled without dependencies on the other VCs.
The AS architecture defines three VC types: Bypass Capable Unicast (BVC); Ordered-Only Unicast (OVC); and Multicast (MVC). BVCs have bypass capability, which may be necessary for deadlock free tunneling of some, typically load/store, protocols. OVCs are single queue unicast VCs, which are suitable for message oriented “push” traffic. MVCs are single queue VCs for multicast “push” traffic.
The AS architecture provides a number of congestion management techniques, one of which is a credit-based flow control technique that ensures that packets are not lost due to congestion. Link partners in the network (e.g., an end node 14a and a switch element 12a) exchange flow control credit information to guarantee that the receiving end of a link has the capacity to accept packets. Flow control credits are computed on a VC-basis by the receiving end of the link and communicated to the transmitting end of the link. Typically, packets are transmitted only when there are enough credits available for a particular VC to carry the packet. Upon sending a packet, the transmitting end of the link debits its available credit account by an amount of flow control credits that reflects the packet size. As the receiving end of the link processes (e.g., forwards to an end node 14a) the received packet, space is made available on the corresponding VC and flow control credits are returned to the transmission end of the link. The transmission end of the link then adds the flow control credits to its credit account.
The AS architecture supports an AS Configuration Space in each AS device in the network. The AS Configuration Space is a storage area that includes fields that specify device characteristics, as well as fields used to control the AS device. The information is presented in the form of capability structures and other storage structures, such as tables and a set of registers. The information stored in the AS-native capability structures can be accessed through PI-4 packets, which are used for device management. In one embodiment of an AS fabric network, AS end node devices are restricted to read-only access of another AS device's AS native capability structures, with the exception of one or more AS end nodes that have been elected as fabric managers.
A fabric manager election process may be initiated by a variety of hardware or software mechanisms. A fabric manager is an AS end node that “owns” all of the AS devices, including itself, in the network. If multiple fabric managers, e.g., a primary fabric manager and a secondary fabric manager, are elected, then each fabric manager may own a subset of the AS devices in the network. Alternatively, the secondary fabric manager may declare ownership of the AS devices in the network upon a failure of the primary fabric manager, e.g., resulting from a fabric redundancy and fail-over mechanism.
Once a fabric manager declares ownership, it has privileged access to its AS devices' AS native capability structures. In other words, the fabric manager has read and write access to the AS native capability structures of all of the AS devices in the network, while the other AS devices are restricted to read-only access, unless granted write permission by the fabric manager.
AS fabric 11 supports the simple load store (SLS) protocol. SLS is a protocol that allows one end node device, such as the fabric manager, to store, and access, data in another end node device's memory, including, but not limited to, the device's configuration space. Memory accesses that are executed via SLS may be direct, meaning that an accessing device need not go through a local controller or processor on an accessed device in order to get to the memory of the accessed device. SLS data packets are recognized by specific packet headers that are familiar to AS end node devices, and are passed directly to hardware on the end node devices, which performs the requested memory access(s).
End node device 14a uses direct memory access (DMA) technology to build data packets for transmission to AS fabric 11. DMA is a technique for transferring data from memory without passing the data through a central controller (e.g., a processor) on the device. Device 14a may be a work station, a personal computer, a server, a portable computing device, or any other type of intelligent device capable of executing instructions and connecting to AS fabric 11.
Device 14a includes a central processing unit (CPU) 24. CPU 24 may be a microprocessor, microcontroller, programmable logic, or the like, which is capable of executing instructions (e.g., a computer program) to perform one or more operations. Such instructions may be stored in system memory 25 (i.e., local memory), which may be one or more hard drives or other internal or external memory devices connected to CPU 24 via one or more communications media, such as a bus 26. System memory 25 may include transmit ring buffers 100 and receive ring buffers 101, which make up a queue, for use in transmitting data packets to, and receiving data packets from, AS fabric 11.
Device 14a also includes protocol interface (PI) engine 29. PI engine 29 may include one or more separate hardware devices, or may be implemented in software running on CPU 24. In this embodiment, PI engine 29 is implemented on a separate chip, which communicates with CPU 24 via bus 26, and which may communicate with one or more PCI express devices (not shown) via PCI express bus(es) (also not shown). A chipset (not shown) may also be included to enable communication.
PI engine 29 functions as CPU 24's interface to AS fabric 11. In this embodiment, PI engine 29 contains a DMA engine 30, a work manager engine 31, and one or more acceleration engines 32. Registers 34 are included in PI engine 29 for use by its various components, and may include one or more first-in first-out (FIFO) registers. Transmit registers 28 provide a “transmit” interface to advanced switching (AS) fabric 11. PI engine 29 also contains a receive engine 102 that receives data packets from AS fabric 11, and a response content-addressable memory (CAM) 103 that is used in receiving packets, in particular reply packets. Receive engine may include an SLS-specific or PI4-specific engine for receiving and processing data packets of those types.
DMA engine 30, registers 34, work manager 31, acceleration engines 32 and transmit registers 28 comprise a transmit engine 104 for transmitting data packets to AS fabric 11. In other embodiments, transmit engine 104 may include different components than those of
DMA engine 30 is a direct memory access engine, which retrieves descriptors from transmit ring buffers 100, and which stores the descriptors in registers 34. As described below, descriptors are data structures that contain information used to build data packets. Work manager 31 is an engine that controls work flow among entities used to build data packets, including DMA engine 30 and acceleration engines 32. Work manager 31 also builds data packets for non-native AS protocols. Acceleration engines 32 are protocol-specific engines, which build data packets for predefined native AS protocols. The operation of these components of PI engine 29 is described below with respect to
Different “transmit” descriptor formats are supported by device 14a. Examples of such descriptor formats include the “immediate” descriptor format, the “indirect” descriptor format, and the “packet-type” descriptor format. An immediate descriptor contains all data needed to build a data packet for transmission over the AS fabric, including the payload of the packet. An indirect descriptor contains all data needed to build a data packet, except for the packet's payload. The indirect descriptor format instead contains one or more addresses identifying the location, in system memory 25, of data for the payload. A packet-type descriptor identifies a section of memory that is to be extracted and transmitted as a data packet. The packet-type descriptor is not used to format a packet, but instead is simply used to extract data specified at defined memory addresses, and to transmit that data as a packet. In this embodiment, each descriptor is 32 bits (one “D-word”) wide and sixteen D-words long.
An example of an immediate descriptor 35 is shown in
An example of an indirect descriptor 47 is shown in
An example of a packet-type descriptor 52 is shown in
DMA engine 30 retrieves descriptors from transmit ring buffers 100 for storage in registers 34. In this embodiment, there are eight registers capable of holding two descriptors each, and DMA engine 30 retrieves the descriptors in the order in which they were stored in the transmit ring buffers, i.e., first-in, first-out.
Each of registers 34 includes one or more associated status bits. These status bits indicate whether a register contains zero, one or two descriptors. The status bits are set, either by DMA engine 30 or work manager 31 (described below). DMA engine 30 determines whether to store the descriptors based on the status bits of registers 34. More specifically, as described below, work manager 31 processes (i.e., “consumes”) descriptors from registers 34. Once a descriptor has been consumed from a register, work manager 31 resets the status bits associated with that register to indicate that the register is no longer full. DMA engine 30 examines (62) the status bits periodically to determine whether a register has room for a descriptor. If so, DMA engine 30 retrieves (63) a descriptor (or two) from the ring buffers. DMA engine 30 stores that descriptor in an appropriate register. DMA engine 30 stores the descriptor in a register that is dedicated to the same virtual channel as the ring buffer from which the descriptor was retrieved. DMA engine 30 may also store a tag associated with each descriptor in registers 34. Use of this tag is described below.
Work manager 31 examines (64) the status bits of each register to determine whether a descriptor is available for processing. If a descriptor is available, work manager 31 retrieves (65) that descriptor and processes the descriptor in the manner described below.
A priority level associated with each register may affect how the work manager retrieves descriptors from the registers. More specifically, each register may be assigned a priority level. The priority level indicates, to work manager 31, a number of descriptors to retrieve from a target register before retrieving descriptors from other registers. Circuitry (not shown), such as a counter, associated with each register maintains the priority level of each register. The circuitry stores a value that corresponds to the priority level of an associated register, e.g., a higher value indicates a higher priority level. Each time work manager 31 retrieves a descriptor from the target register, the circuitry increments a count, and the current value of the count is compared to the priority level value. So long as the count is less than or equal to the priority level value of a target register, work manager 31 continues to retrieve descriptors only from the target register. If no descriptors are available from the target register, work manager 31 may move on to another register, and retrieve descriptors from that other register until descriptors from the target register become available.
Work manager 31 examines (66) retrieved descriptors in order to determine a type of the descriptor. In particular, work manager 31 examines the ID bytes of each descriptor to determine the type of the descriptor. Since packet-type descriptors simply define “chunks” of data as a packet, packet-type descriptors do not contain acceleration control information (see
For immediate descriptors and indirect descriptors, work manager 31 also examines the descriptor to determine whether the descriptor is for a data packet having a protocol that is native to AS, such as SLS, or for packets that have a protocol that is non-native to AS, such as ATM. In particular, work manager 31 examines the acceleration control information of immediate descriptors and indirect descriptors.
If the acceleration control information indicates (69) that the descriptor is for a data packet having a protocol that is non-native to AS fabric 11, work manager 31 builds (71) one or more data packets from the descriptor.
If the descriptor is an immediate descriptor, work manager 31 builds a data packet using the descriptor. In particular, work manager 31 builds a packet header from D-words 41 and 42 (
If the descriptor is an indirect descriptor, work manager 31 builds a header for the data packet in the same manner as for an immediate descriptor. Work manager 31 builds a packet payload by retrieving a payload for the packet from address(es) 50 (
Work manager 31 stores data packets in transmit registers 28, from which the data packets are output to AS fabric 11.
Work manager 31 may build request packets, which are used to request information from other end node devices on AS fabric 11. SLS packets may be used as request packets. Work manager 31 builds into each request packet a unique transaction identifier (ID), which should be returned in a reply to the request packet in order to recognize the reply as such. The transaction ID is set by CPU 24 in a descriptor. For example, bits 46 of descriptor 35 constitute its transaction ID. Upon completion of a request packet, work manager 31 stores, in response CAM 103, the transaction ID of the request packet. A descriptor of each request packet includes a local address to which reply data is to be written. This local address is also included in response CAM 103 in association with the transaction ID of a corresponding request packet.
Referring back to
Work manager 31 uses a tag system to keep track of packet processing with acceleration engines 32. As noted above, work manager 31 retrieves all necessary information/data it needs from registers 34, along with an associated tag. For native AS packets, work manager 31 instructs an acceleration engine 32 to build the packet (e.g., if the packet is SLS).
When building the packet header, acceleration engine 32a sends a payload fetch request to work manager 31 to request payload for the packet. Along with the request, the acceleration engine sends a copy of the tag that work manager 31 forwarded to acceleration engine 32a. The returned tag, however, has been altered to instruct work manager 31 to retrieve payload for the packet, and to provide the payload to the acceleration engine for packet building.
When building the data packet, acceleration engine 32a issues a write back command to work manager 31. The write back command may notify work manager 31 that a packet has been built. If the payload of the data packet is too big to be accommodated in a single packet, the write back command identifies the data that has been packetized by acceleration engine 32a. Specifically, the write back command specifies the ending address of the packetized data. Work manager 31 receives the write back command and determines whether all of the data in the original descriptor has been packetized (e.g., work manager 31 determines if the ending address in the write back command corresponds to the ending address of the total amount of data to be packetized). If all of the data has been packetized, work manager 31 sets the status bits of a corresponding register 34 to indicate that there is room for another descriptor. If all of the data in the original descriptor has not been packetized, work manager 31 instructs acceleration engine 32a to build another data packet using substantially the same packet header information as the previous data packet. Work manager 31 instructs acceleration engine 32a that the payload for this next packet is to start at the address at which the previous packet ended.
The back-and-forth process between the acceleration engine and the work manager continues until the entire descriptor has been consumed. Acceleration engine 32a stores completed data packets in transmit registers 28 for transmission onto AS fabric 11.
As was the case above, work manager 31 writes, into response CAM 103, the transaction ID and corresponding local address of each request packet generated by acceleration engine 32a. In alternative embodiments, acceleration 32a may be configured to write this information to response CAM 103.
The request packet is transmitted to another device (not shown) in communication with the AS fabric, such as end node device 14c (
PI engine 29, in particular receive engine 102, receives (110) the reply packet in response to the request packet. Receive engine 102 extracts the transaction ID from the reply packet and compares (111) the transaction ID to the transaction IDs stored in response CAM 103. If a match is found (112), receive engine 102 retrieves (113), from response CAM 103, the local address that corresponds to the “matched” transaction ID. Receive engine 102 uses this local address to store information from the reply packet for use by CPU 24.
More specifically, receive engine 102 parses (114) the reply packet to obtain its payload. Receive engine 102 decides to store (115) the payload in the local address associated with the reply packet's transaction ID, e.g., in data storage area 117. Receive engine 102 also decides to store (115), in a receive ring buffer 101, an indication that the reply packet has been received. The indication may include the transaction ID of the request and reply packets. The transaction ID may also include information identifying a sender of the reply packet. This information may be culled from the reply packet header. Receive engine 102 may use ring buffer interface logic to effect storage (see
In cases where plural reply packets are issued in response to a single request packet, receive engine 102 assigns, and keeps track of, a sequence identifier (ID) for each reply packet. That is, if receive engine 102 detects more than one reply packet with the same transaction ID, receive engine 102 knows that there is more than one reply packet in response to the request packet having that transaction ID. Receive engine 102, therefore, associates a sequence ID with each received reply packet. Each time a reply packet with the same transaction number is received, receive engine 102 increments the sequence ID. When receive engine 102 determines that there are no additional reply packets to receive, i.e., that a last reply packet in a series has been received, receive engine 102 stores an appropriate indication in receive ring buffers 101 along with the sequence number of the last reply packet. CPU 24 uses this information when retrieving payload data for the reply packets from data storage area 117. Receive engine 102 may identify a last reply packet in a series using information in the packet itself or based on an elapsed time following receipt of the first packet in the series.
CPU 24 checks receive ring buffer 101 periodically for indications of replies to issued request packets. CPU 24 does this by checking receive ring buffers 101 for a transaction ID (and sequence ID). CPU 24 then retrieves data from address(es) in data storage area 117 that correspond to the transaction ID (and sequence ID).
Process 105 may be implemented outside of a request packet/reply packet context. More specifically, a variant of process 105 may be used to identify devices attempting to read to, or write to, system memory 25. In this regard, as noted above, a first AS end node device has the capability, through the SLS protocol, to read from, or write to, local memory of a second AS end node device without going through the local CPU of the second AS end node device. This local CPU does not know the identity of a device attempting an access. Process 105 may be used to provide the local CPU with this identity.
More specifically, upon receiving a read request or write request packet for access to system memory 25, receive engine 102 may parse the packet's header from its payload. Receive engine 102 stores the packet header in receive ring buffer 101 and may issue an interrupt to CPU 24 indicating an attempted memory access. The interrupt may be issued when the access is first attempted, when the access has been completed, or somewhere in between. In response, CPU 24 may retrieve the header information from receive ring buffer 101 and determine the identity of the device making access.
In this embodiment, there are four receive ring buffers. Other embodiments may contain different numbers of receive ring buffers that are configured differently from those described herein. The receive ring buffers may also have different sizes. Here, the receive ring buffers are organized by PI number. For example, each receive ring buffer may be dedicated to receiving data packets for one or more PI numbers. As a result of this arrangement, the receive ring buffers may fill at different rates. Circuitry is therefore provided on PI engine 29 to assist CPU 24 in determining when to retrieve data from the receive ring buffers.
Delay timer 120 issues a processor interrupt at predetermined periods. Packet counter 122 issues a processor interrupt after a predetermined number of packets have been processed by receive engine 102. Ring status word register 123 contains data indicating a level of fullness of receive ring buffers 101. Receive engine 102 measures the fullness of each receive ring buffer (e.g., based on its head and tail pointers), and sets appropriate status words in ring status word register 123. For example, in
In other embodiments, more or less than four levels may be detected, and the levels detected may be other than the four listed, namely empty, full, ½ and ¼.
When either the delay timer or the counter issues an interrupt, both are initialized (i.e., returned to their starting values).
As noted, receive engine 102 detects the buffer levels and sets the status bits in ring status word register 123. Each time CPU 24 receives an interrupt from either delay timer 120 or packet counter 122, CPU 24 checks ring status word register 123. The information in ring status word register determines the ring buffer from which CPU 24 first retrieves data. For example, in one embodiment, CPU 24 retrieves data from the ring buffer that is most full, and then retrieves data from the ring buffer that is next most full, and so on.
Receive ring buffer 101a is accessed via a head pointer 130 and a tail pointer 131. Head pointer 130 is used, e.g., by CPU 24, to read from receive ring buffer 101a. Tail pointer 131 is used, e.g., by receive engine 102 to write to receive ring buffer 101a (via ring buffer interface logic 129—described below).
Both head pointer 130 and tail pointer 131 are offsets from a predetermined base address, labeled RRBAH/L in
Each receive ring buffer has an associated control register that contains a data structure 132 (
As shown in
Control D-word 140 contains acceleration control fields 144 a port number field 145, and a descriptor entry length field 146. Acceleration control fields 144 are similar to those described above. More specifically, acceleration control fields 144 identify the “type” of payload (e.g., SLS) associated with descriptor 139 and, in some cases, an acceleration engine (not shown) to process the payload.
If acceleration control fields 144 indicate that the payload is hardware accelerated (i.e., that the payload is for a native AS packet, such as SLS), then the payload is not stored the descriptor. Instead, the payload is stored at other system memory addresses, which may be defined in a “packet info” field 141. For SLS packets, packet info field 141 also include appropriate AS and SLS header fields.
Entry length field 146 specifies a length of descriptor 139. This feature of descriptor 139 enables CPU 24 to recognize descriptors having different sizes.
For non-native AS packets, packet info field 141 contains payload of a data packet that corresponds to descriptor 139. It is noted that a single data packet may be defined by multiple descriptors. In this case, a sequence number (defined above) may also be part of the descriptor.
Referring to
Receive engine 102 controls ring buffer interface logic 129 to store data for received packets in receive ring buffers 101. More specifically, upon receipt of a data packet, receive engine 102 generates a control D-word for the data packet. As shown in
Ring buffer interface logic 129 writes data from memory 147 to a data bus 154 that leads to receive ring buffers 101. Data bus 154 is 128 bits wide, but is left-justified, unlike memory 147 which is right-justified. Accordingly, alignment circuitry 155 is provided to shift the data blocks so that they are aligned for transmission on data bus 154.
More specifically, alignment circuitry 155 operates in response to control signals from write state machine controller 154. These control signals indicate a first position on data bus 154 to which data should be written. Packet header information is not to be transferred to receive ring buffers 101. The control signals from write state machine controller 150 ensure that data blocks containing header information are not written to data bus 154.
As shown in
Thus, a first row 159 of a shifted output includes control D-word 151 from memory 147 and, perhaps, one or more “invalid” data blocks from memory 147. Invalid data blocks may be written to data bus 154 if (as here) a first position on data bus 154 to which data is to be written is not the right-most position. As noted, receive engine 102 controls positioning of data on data bus 154 via write state machine controller 150.
Alignment circuitry 155 writes a first payload D-word 157 from memory 147 to a position on data bus 154 that is immediately after control D-word 151. It is noted that the initial D-word(s) following control D-word 151 may contain header information rather than payload information. Receive engine 102 identifies D-words that contain header information and controls alignment circuitry 155 to skip those D-words. So, for example, if D-words 156 and 157 contained header information, alignment circuitry 155 would skip over those D-words (i.e., not write them to data bus 154).
The example shown in
Although not shown in
Multiplexers 160 store selected D-words in appropriate registers 161. Registers 161 comprise flip-flops that are clocked by a clock signal 165 so that both a current set 166 of D-words and a former set 167 of D-words are applied to steering logic 162. Steering logic 162 selects and routes the former and current D-words to achieve the appropriate alignment on a current lane of data bus 154, as shown in
Referring back to
An example of circuitry 170 for generating commands to access a receive ring buffer is shown in
Address generation circuit 171 receives address information that may be used to determine a physical address in system memory 25 at which a write (or a read) operation is to start. Length regeneration circuit 172 receives a length of the data to be written (or read). First byte enable regeneration circuit 173 receives data identifying a first unmasked byte in the data to be written (or read). Last byte enable regeneration circuit 174 receives data identifying a last unmasked byte in the data to be written (or read). Controller 175 receives the same information provided to circuits 171 to 174.
Controller 175 uses the information to determine whether to generate a single write (or read) command for the data or whether to generate plural commands. The amount of data dictates the number of commands that are to be generated. For example, if data to be written spans two cacheline boundaries, then two write commands are generated. If data to be written spans three cacheline boundaries, then three write commands are generated, and so on.
Controller 175 outputs control signals 176 to circuits 171 to 174. Control signals 176 instruct those circuits to proceed according to the number of commands to be generated. If a single command is to be generated, controller 175 instructs circuits 171 to 174 to output their information to bus 177. There, the information is concatenated and passed to demultiplexer 179. An external signal 180 controls demultiplexer 179 to store a resulting command in write command queue 181 or a read command queue 182 based on whether the command is to write or read.
Controller 175 also generates output signals 184 and 185 using address and length information 187. The output signals may be generated in response to feedback from circuits 171 to 174. Output signal 185 controls output of one or more read commands from read command queue 182. Output signal 184 controls output of one or more write commands from write command queue 181. Demultiplexer 187 selects either command 184 or 185 based on an instruction 189 from controller 175 indicating whether a read or a write is to be performed.
In a case that controller 175 determines that the information requires that plural commands be generated, controller 175 instructs circuits 171 to 174 accordingly. In response, circuits 171 to 174 output their information to bus 177, as was the case for a single command. On bus 177, the information is concatenated and passed to demultiplexer 179. Circuits 177 to 179 then update their information and generate subsequent command(s) using the updated information.
Updating the address information includes increasing a current address by an amount that is equal to (or substantially equal to) a length associated with a current command. The next command will thus be to access data from the updated address. Updating the length information includes decreasing the length by an amount that is equal to (or substantially equal to) the length associated with the current command. The next command will thus be to access data having the updated length. Updating the first byte enable and last byte enable information includes identifying first and last significant (unmasked) bytes, respectively, associated with the updated address and length information.
Circuitry 190 includes a decoder 191, multiplexers 192 and 193, and an address calculation circuit 194. Decoder 191 obtains a PI number 195 associated with information 197 (
Address calculation circuit 194 determines a physical address in the matching receive ring buffer by adding tail pointer 202 to receive ring buffer base address 203. This physical address 207 is output from address regeneration circuit 171, as described above with respect to
The AS end node device described herein may be used in any context. For example, an AS end node device may be used in a storage system 80, as shown in
As shown in
In one example, PI engine 89 retrieves a descriptor from a queue, and uses the descriptor to build a read request packet for transmission to data server 84a via AS fabric 81. PI engine 89 includes a transmit engine, as described above, that generates a read request packet from the descriptor. The read request packet is for accessing data stored on disk drive 85a of data server 84a. The transmit engine associates a first transaction identifier with the read request packet. A receive engine receives a reply packet from data server 84a in response to the read request packet. The reply packet contains a second transaction identifier. The receive engine compares the first transaction identifier to the second transaction identifier. If the first transaction identifier matches the second transaction identifier, the receive engine decides to store data from the reply packet at a local address of data server 84a that is associated with the first transaction identifier. This arrangement facilitates storage of data from the reply packet on data server 84a, as described above. As noted, storage may be effected via ring buffer interface logic 129, which is described above.
One or more of the other data serves 84a, 84b, 84c may act as a local management server for a sub-set of data servers (or other data servers). Each server in this sub-set may include RAID or other storage media, which the local management server can access without going through a local CPU. The architecture of such a data server 84a is substantially identical to that of management server 82.
The AS end node device described herein may also be used in connection with a network processor. For example, as shown in
The foregoing are only two examples of systems in which the AS end node device of
Furthermore, the processes described herein are not limited to use with the hardware and software described herein; they may find applicability in any computing or processing environment
The processes can be implemented in digital electronic circuitry, or in computer hardware, firmware, software, or in combinations of them. The processes can be implemented as a computer program product or other article of manufacture, e.g., a computer program tangibly embodied in an information carrier, e.g., in a machine-readable storage device or in a propagated signal, for execution by, or to control the operation of, data processing apparatus, e.g., a programmable processor, a computer, or multiple computers. A computer program can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program can be deployed to be executed on one computer or on multiple computers at one site or distributed across multiple sites and interconnected by a communication network.
The processes can be performed by one or more programmable processors executing a computer program to perform functions. The processes can also be performed by, and corresponding apparatus be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit).
Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read-only memory or a random access memory or both. Elements of a computer include a processor for executing instructions and one or more memory devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks.
Information carriers suitable for embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, e.g., EPROM (electrically programmable read-only memory), EEPROM (electrically erasable programmable read-only memory), and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM (compact disc read-only memory) and DVD-ROM (digital video disc read-only memory). The processor and the memory can be supplemented by, or incorporated in special purpose logic circuitry.
The processes described herein can be implemented in a computing system that includes a back-end component, e.g., as a data server, or that includes a middleware component, e.g., an application server, or that includes a front-end component, e.g., a client computer, or any combination of such back-end, middleware, or front-end components.
The components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include a local area network (LAN) and a wide area network (WAN), e.g., the Internet.
The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
The features described herein may be implemented outside of an AS context. For example, they may be implemented in systems that are based on TCP/IP RDMA (Transmission Control Protocol/Internet Protocol/Remote Direct Memory Access)
Other embodiments not described herein are also within the scope of the following claims.