Distributed computing systems, in which tasks are shared among multiple processors, are increasingly common. In such systems, tasks to be performed may be allocated to one among a group of processors. Processors may need to send messages to one another in a manner that allows operating software to manage resources deterministically.
A computer readable storage medium stores a set of instructions executable by a processor. The set of instructions is operable to receive, from a first processor, a message to be sent to a second processor; store the message in a portion of a shared memory, the shared memory being shared by the first processor and the second processor; store, in an instruction list stored in a further portion of the shared memory, an instruction corresponding to the message; and prompt the second processor to read the message list.
A system includes a first processor, a second processor, a shared memory and an instructions list stored in the shared memory. The first processor stores a message for the second processor in a portion of the shared memory. The first processor creates an entry in the instructions list corresponding to the message. The first processor prompts the second processor to access the instructions list.
The exemplary embodiments may be further understood with reference to the following description and the appended drawings, wherein like elements are referred to with the same reference numerals. The exemplary embodiments describe systems and methods for coordinating communications among processors of a multiprocessor system.
Distributed processing computing systems are increasingly common in a variety of settings. Such systems range from personal computers featuring two processing cores to large-scale distributed processing systems for performing extremely complicated tasks. In such environments, each processing core must be able to send messages to each other processing core in order to coordinate the performance of various tasks. Mechanisms for sending such messages should be deterministic and efficient and use minimal resources. Determinism may be advantageous because it allows an upper bound to be placed on the time needed to send, process, and respond to a message.
The system 100 includes a first processor 110 and a second processor 120, which may be any type of microprocessor capable of executing instructions embodied in code. The hardware of the first processor 110 and the second processor 120 may be substantially similar or may differ from one another. The system 100 further includes a shared memory 130 which may be utilized as will be described below. The shared memory 130 may be a separate physical memory dedicated for the purpose of coordinating interprocessor communications or may be a portion of a larger memory that is also used for other tasks, such as a partition of a hard drive or a segment of a computer's RAM. Data may be passed among the first processor 110, the second processor 120, and the shared memory 130 by way of a bus 140.
The shared memory 130 may comprise a plurality of blocks to be used for sending messages between the first processor 110 and the second processor 120. The message blocks may be of substantially the same size or may differ for the performance of differing types of tasks. Each message block may include a status indicator, which may be marked one of “FREE”, “SENT” and “PROCESSED”. Both the first processor 110 and the second processor 120 may read and write data in the shared memory 130, but writing permissions for individual elements on the shared memory 130 may be modified as will also be described in further detail below. The shared memory 130 may store (e.g., in one of the blocks dedicated for this purpose) an instructions list 150 (or “list 150”) describing the contents of the shared memory 130, the operation of which will be described in further detail below. In this exemplary embodiment, the list 150 is operable to store instructions sent from the first processor 110 to the second processor 120. In another exemplary embodiment, the memory 130 may store a further list for sending instructions from the second processor 120 to the first processor 110; similarly, in systems with more than two processors, each pair of processors may share two lists, one for communications in each direction.
In step 300, the first processor 110 prepares a message and sends it to the second processor 120. In step 400, the second processor 120 receives the message, performs any actions that may be required in accordance with the message, and replies to the first processor 110. In step 500, the first processor 110 receives the reply. In step 600, instructions governing the instructions list 150 of the shared memory 130 determine whether the instructions list 150 contains further items to be processed. If so, the method returns to step 300; if not, the method terminates.
Step 300, illustrated in detail in
In step 340, the first processor 110 adds the newly-written message to the end of the instructions list 150. The entry in the instructions list 150 may include a reference to the location of the message block in the shared memory 130 where the referenced message has been stored. Next, in step 350, the first processor 110 determines whether it needs to send a further message or messages to the second processor 120. If so, the method returns to step 310, and the first processor 110 may repeat the message-writing process as described above in steps 310-340. If not, the method continues to step 360.
In step 360, the first processor 110 updates the head pointer for the list such that it points to the first instruction pending for the second processor 120. Once this is done, the first processor 110 sends an inter-processor interrupt to the second processor 120 via the bus 140 in step 370. The inter-processor interrupt serves to alert the second processor 120 that the instructions list 150 contains instructions pending for it. At this point, the first processor 110 is done with the message-sending process and may perform other tasks until it receives a reply from the second processor, as will be discussed below.
Step 400, illustrated in detail in
After performing the list item, in step 440 the second processor 120 changes the memory block containing the item from “SENT” to “PROCESSED”. As is apparent, this denotes that the item contained in the memory block has been processed. Next, in step 450, the second processor 120 determines whether it is done iterating, i.e., whether there are more items remaining to be processed in the list. If the list contains more items, then the method returns to step 430, and the second processor 120 continues performing items on the list 150. In a preferred embodiment, the second processor 120 may be limited to performing steps 430 and 440 a limited times during a single performance of the method 400 in order to preserve determinism. If the list is complete, then the second processor 120 continues to step 460, where it updates its pointer to point to either the first item not yet processed, or to a NULL pointer if all items are processed. Once this is done, the second processor 120 sends an inter-processor interrupt to the first processor 110 in step 470 to indicate that it has performed the tasks indicated by the instructions list 150. At this point, the second processor 120 is done performing its tasks according to the exemplary method 200, and may perform other, unrelated tasks as necessary.
Step 500, illustrated in detail in
In step 530, the first processor 110 changes the state of the “PROCESSED” message blocks to “FREE”, which has the effect of freeing the blocks to handle other messages, such as subsequent messages from the first processor 110 to the second processor 120, messages from the second processor 120 to the first processor 110, or, in systems with more processors, messages to and from other processors. At this point, the use of blocks that have been marked “FREE” is complete; the blocks may optionally be added to a list of free blocks for reallocation to other purposes, but this is outside the scope of the exemplary method. In step 540, the first processor 110 updates its pointers. After step 540, the method terminates. Subsequently, if there are unprocessed items remaining on the list 150, the process may begin again and may repeat until the list 150 is empty.
The exemplary embodiments may be used for the transmission of any type of data, instructions, or other messages from one processor in a multi-processor architecture to another. This may include, but is not limited to, forwarding requests for primary allocation, forwarding interrupts from one processor to another, or forwarding any type of request or service from one processor to another. The exemplary embodiments thus present a method by which various standard idioms of programming may be performed more efficiently.
It will be apparent to those skilled in the art that various modifications may be made in the present invention, without departing from the spirit or the scope of the invention. Thus, it is intended that the present invention cover modifications and variations of this invention provided they come within the scope of the appended claims and their equivalents.
Number | Name | Date | Kind |
---|---|---|---|
4394730 | Suzuki et al. | Jul 1983 | A |
4914570 | Peacock | Apr 1990 | A |
5109512 | Bahr | Apr 1992 | A |
5490261 | Bean | Feb 1996 | A |
5560034 | Goldstein | Sep 1996 | A |
5592671 | Hirayama | Jan 1997 | A |
5793994 | Mitchell et al. | Aug 1998 | A |
5966547 | Hagan et al. | Oct 1999 | A |
6529983 | Marshall | Mar 2003 | B1 |
6691190 | Burroughs et al. | Feb 2004 | B1 |
6795901 | Florek et al. | Sep 2004 | B1 |
7035908 | Williams | Apr 2006 | B1 |
7870195 | Meiri | Jan 2011 | B1 |
8286188 | Brief | Oct 2012 | B1 |
8761188 | Krikelis | Jun 2014 | B1 |
20020059165 | Hersh | May 2002 | A1 |
20030041173 | Hoyle | Feb 2003 | A1 |
20030088626 | Gupta | May 2003 | A1 |
20030182465 | Moir | Sep 2003 | A1 |
20040068620 | Van Doren | Apr 2004 | A1 |
20040148472 | Barroso | Jul 2004 | A1 |
20050188372 | Inoue et al. | Aug 2005 | A1 |
20050188373 | Inoue et al. | Aug 2005 | A1 |
20050283577 | Sivaram | Dec 2005 | A1 |
20060149861 | Yamazaki | Jul 2006 | A1 |
20060190942 | Inoue | Aug 2006 | A1 |
20060242257 | Kuribayashi | Oct 2006 | A1 |
20070076735 | Soo | Apr 2007 | A1 |
20070271572 | Gupta et al. | Nov 2007 | A1 |
20080229325 | Supalov | Sep 2008 | A1 |
20090043970 | Jeong | Feb 2009 | A1 |
20090089545 | Kwon | Apr 2009 | A1 |
20100076941 | Dotsenko | Mar 2010 | A1 |
20100095089 | Kwon | Apr 2010 | A1 |
20100287320 | Querol | Nov 2010 | A1 |
20100299472 | Tanaka et al. | Nov 2010 | A1 |
20110047310 | Bonola | Feb 2011 | A1 |
20110093854 | Blanc | Apr 2011 | A1 |
20110161943 | Bellows | Jun 2011 | A1 |
20110225588 | Pollock | Sep 2011 | A1 |
20120204183 | Bayer | Aug 2012 | A1 |
20120210069 | Bayer | Aug 2012 | A1 |
Number | Date | Country |
---|---|---|
WO 2009077429 | Jun 2009 | WO |
Entry |
---|
“Message.” Dictionary.com Unabridged. Random House, Inc. Jun. 3, 2014. <Dictionary.comhttp://dictionary.reference.com/browse/message>. |
Number | Date | Country | |
---|---|---|---|
20110271060 A1 | Nov 2011 | US |