Embodiments of the present invention generally relate to the field of memory, and, more particularly to a method, apparatus and system for global shared memory using serial optical memory.
Computing devices use memory to store data and instructions. Typically, memory devices have comprised arrays of capacitors or transistors where the capacity of the memory device is equal to the number of physical components present.
The present invention is illustrated by way of example and not limitation in the figures of the accompanying drawings in which like references indicate similar elements, and in which:
In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the invention. It will be apparent, however, to one skilled in the art that embodiments of the invention can be practiced without these specific details. In other instances, structures and devices are shown in block diagram form in order to avoid obscuring the invention.
Reference throughout this specification to “one embodiment” or “an embodiment” means that a particular feature, structure or characteristic described in connection with the embodiment is included in at least one embodiment of the present invention. Thus, appearances of the phrases “in one embodiment” or “in an embodiment” in various places throughout this specification are not necessarily all referring to the same embodiment. Furthermore, the particular features, structures or characteristics may be combined in any suitable manner in one or more embodiments.
Processor(s) 102 may represent any of a wide variety of control logic including, but not limited to one or more of a microprocessor, a programmable logic device (PLD), programmable logic array (PLA), application specific integrated circuit (ASIC), a microcontroller, and the like, although the present invention is not limited in this respect.
Memory controller 104 may represent any type of chipset or control logic that interfaces optical serial memory 106 with the other components of electronic appliance 100. In one embodiment, the connection between processor(s) 102 and memory controller 104 may be referred to as a front-side bus. In another embodiment, memory controller 104 may be referred to as a north bridge.
Optical serial memory 106 may have an architecture as described in greater detail with reference to
Input/output (1/0) controller 108 may represent any type of chipset or control logic that interfaces I/O device(s) 112 with the other components of electronic appliance 100. In one embodiment, I/O controller 108 may be referred to as a south bridge. In another embodiment, I/O controller 108 may comply with the Peripheral Component Interconnect (PCI) Express™ Base Specification, Revision 1.0a, PCI Special Interest Group, released Apr. 15, 2003.
Network controller 110 may represent any type of device that allows electronic appliance 100 to communicate with other electronic appliances or devices. In one embodiment, network controller 110 may comply with a The Institute of Electrical and Electronics Engineers, Inc. (IEEE) 802.11b standard (approved Sep. 16, 1999, supplement to ANSI/IEEE Std 802.11, 1999 Edition). In another embodiment, network controller 110 may be an Ethernet network interface card.
Input/output (I/O) device(s) 112 may represent any type of device, peripheral or component that provides input to or processes output from electronic appliance 100.
Optical serial memory 106 may have the ability to store data by circulating a signal among a plurality of optical emitters and receivers. In one embodiment, optical serial memory 106 may encode an n-dimensional array into a serial signal. In another embodiment, optical serial memory 106 may encode a sparse array into a serial signal.
As used herein control logic 202 provides the logical interface between optical serial memory 106 and its host electronic appliance 100. In this regard, control logic 202 may manage one or more aspects of optical serial memory 106 to provide a communication interface to electronic appliance 100, e.g., through memory controller 104. Control logic 202 may also enable optical serial memory 106 to write data and read data from the circulating serial signal. In one embodiment, control logic 202 will encode data received from memory controller 104 into a serial packet including, for example, unit bit sequences as a packet header. In another embodiment, control logic 202 will decode a serial packet read from circulating signal engine 208 into data to be sent to memory controller 104.
Buffer 204 is intended to represent any of a wide variety of memory devices and/or systems known in the art. According to one example implementation, though the claims are not so limited, buffer 204 may well include volatile and non-volatile memory elements, possibly random access memory (RAM) and/or read only memory (ROM). Buffer 204 may be used to store portions of the circulating signal that are queued to be added to the serial signal, for example.
Bus interface 206 provides a path through which optical serial memory 106 can communicate with memory controller 104. Optical serial memory 106 utilizes this interface to receive data to be stored and to send data and commands needed by processor(s) 102, for example.
As introduced above, circulating signal engine 208 may be utilized by control logic 202 to circulate a serial signal through a chain of optical emitters and receivers. Emitters 210 and receivers 212 may be configured in pairs as depicted in greater detail with reference to
Emitter 302 will propagate the serial signal optically to receiver 304, which will subsequently propagate the serial signal electrically to emitter 306, and so on. Depending on the speed with which the emitters and receivers are able to change state, it may be possible to have bits of information in flight between emitter 302 and receiver 304, for example, and/or between receiver 304 and emitter 306, for example. In one embodiment, there is a plurality of points, such as between receiver 304 and emitter 306, from which the circulating signal can be read and/or modified.
Entries 402 and 404 are two example entries in circulating signal 400. As sparse entries in global shared memory, entries 402 and 404 are not adjacent memory addresses. In this way, circulating signal 400 need only store data that is actually needed by processor(s) 102, and not large sections of data that my not be needed in their entirety. Also encoded in entries 402 and 404 is a MOESI (modified, owned, exclusive, shared, invalid) state for use by processor(s) 102.
Many of the methods are described in their most basic form but operations can be added to or deleted from any of the methods and information can be added or subtracted from any of the described messages without departing from the basic scope of the present invention. Any number of variations of the inventive concept is anticipated within the scope and spirit of the present invention. In this regard, the particular illustrated example embodiments are not provided to limit the invention but merely to illustrate it. Thus, the scope of the present invention is not to be determined by the specific examples provided above but only by the plain language of the following claims.