Jump to content

Multiprocessing: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
"Construed" was the right word, but it might not be familiar to all readers; some might think it's a typo for "constructed". Rewrite to try to make it a bit clearer what's meant.
 
(28 intermediate revisions by 22 users not shown)
Line 1: Line 1:
{{Short description|Use of two or more central processing units (CPUs) within a single computer system}}
{{Use dmy dates|date=April 2014}}
{{Use dmy dates|date=April 2014}}
{{refimprove|date=February 2014}}
{{refimprove|date=February 2014}}
'''Multiprocessing''' is the use of two or more [[CPU|central processing units]] (CPUs) within a single [[computer system]].<ref name="Rajagopal1999">{{cite book |author=Raj Rajagopal |title=Introduction to Microsoft Windows NT Cluster Server: Programming and Administration |url=https://books.google.com/books?id=kUJnHJJlnpUC&pg=PA4 |year=1999 |publisher=CRC Press |isbn=978-1-4200-7548-9 |page=4}}</ref><ref name="EbbersKettner2012"/> The term also refers to the ability of a system to support more than one processor or the ability to allocate tasks between them. There are many variations on this basic theme, and the definition of multiprocessing can vary with context, mostly as a function of how CPUs are defined ([[multi-core (computing)|multiple cores]] on one [[Die (integrated circuit)|die]], multiple dies in one [[Chip carrier|package]], multiple packages in one [[system unit]], etc.).
'''Multiprocessing''' is the use of two or more [[central processing unit]]s (CPUs) within a single [[computer system]].<ref name="Rajagopal1999">{{cite book |author=Raj Rajagopal |title=Introduction to Microsoft Windows NT Cluster Server: Programming and Administration |url=https://books.google.com/books?id=kUJnHJJlnpUC&pg=PA4 |year=1999 |publisher=CRC Press |isbn=978-1-4200-7548-9 |page=4}}</ref><ref name="EbbersKettner2012"/> The term also refers to the ability of a system to support more than one processor or the ability to allocate tasks between them. There are many variations on this basic theme, and the definition of multiprocessing can vary with context, mostly as a function of how CPUs are defined ([[multi-core (computing)|multiple cores]] on one [[Die (integrated circuit)|die]], multiple dies in one [[Chip carrier|package]], multiple packages in one [[system unit]], etc.).


According to some on-line dictionaries, a '''multiprocessor''' is a computer system having two or more [[Central processing unit|processing units]] (multiple processors) each sharing [[main memory]] and peripherals, in order to simultaneously process programs.<ref>{{cite web |url=http://www.yourdictionary.com/multiprocessor |title=Multiprocessor dictionary definition - multiprocessor defined |author= |date= |website=www.yourdictionary.com |accessdate=16 March 2018}}</ref><ref>{{cite web |url=http://www.thefreedictionary.com/multiprocessor |title=multiprocessor |author= |date= |publisher= |accessdate=16 March 2018 |via=The Free Dictionary}}</ref> A 2009 textbook defined multiprocessor system similarly, but noting that the processors may share "some or all of the system’s memory and I/O facilities"; it also gave '''tightly coupled system''' as a synonymous term.<ref>{{cite book |author=Irv Englander |title=The architecture of Computer Hardware and Systems Software. An Information Technology Approach. |publisher=Wiley |date=2009 |url= |edition=4th | isbn=978-0471715429 |page=265}}</ref>
According to some on-line dictionaries, a '''multiprocessor''' is a computer system having two or more [[Central processing unit|processing units]] (multiple processors) each sharing [[main memory]] and peripherals, in order to simultaneously process programs.<ref>{{cite web |url=http://www.yourdictionary.com/multiprocessor |title=Multiprocessor dictionary definition - multiprocessor defined |website=www.yourdictionary.com |access-date=16 March 2018 |archive-date=16 March 2018 |archive-url=https://web.archive.org/web/20180316151954/http://www.yourdictionary.com/multiprocessor |url-status=live }}</ref><ref>{{cite web |url=http://www.thefreedictionary.com/multiprocessor |title=multiprocessor |access-date=16 March 2018 |via=The Free Dictionary |archive-date=16 March 2018 |archive-url=https://web.archive.org/web/20180316151656/http://www.thefreedictionary.com/multiprocessor |url-status=live }}</ref> A 2009 textbook defined multiprocessor system similarly, but noting that the processors may share "some or all of the system’s memory and I/O facilities"; it also gave '''tightly coupled system''' as a synonymous term.<ref>{{cite book |author=Irv Englander |title=The architecture of Computer Hardware and Systems Software. An Information Technology Approach. |publisher=Wiley |date=2009 |edition=4th | isbn=978-0471715429 |page=265}}</ref>


At the [[operating system]] level, ''multiprocessing'' is sometimes used to refer to the execution of multiple concurrent [[Process (computing)|processes]] in a system, with each process running on a separate CPU or core, as opposed to a single process at any one instant.<ref name="MorleyParker2012">{{cite book |author1=Deborah Morley |author2=Charles Parker |title=Understanding Computers: Today and Tomorrow, Comprehensive |url=https://books.google.com/books?id=-2Ewg8QX8U4C&pg=PA183 |date=13 February 2012 |publisher=Cengage Learning |isbn=1-133-19024-3 |page=183}}</ref><ref name="Shibu">{{cite book |author=Shibu K. V. |title=Introduction to Embedded Systems |url=https://books.google.com/books?id=8hfn4gwR90MC&pg=PA402 |publisher=Tata McGraw-Hill Education |isbn=978-0-07-014589-4 |page=402}}</ref> When used with this definition, multiprocessing is sometimes contrasted with [[multitasking]], which may use just a single processor but switch it in time slices between tasks (i.e. a [[time-sharing system]]). Multiprocessing however means true parallel execution of multiple processes using more than one processor.<ref name="Shibu"/> Multiprocessing doesn't necessarily mean that a single process or task uses more than one processor simultaneously; the term [[Parallel computing|parallel processing]] is generally used to denote that scenario.<ref name="MorleyParker2012"/> Other authors prefer to refer to the operating system techniques as [[multiprogramming]] and reserve the term ''multiprocessing'' for the hardware aspect of having more than one processor.<ref name="EbbersKettner2012">{{cite book |author1=Mike Ebbers |author2=John Kettner |author3=Wayne O'Brien |author4=Bill Ogden |title=Introduction to the New Mainframe: z/OS Basics |url=https://books.google.com/books?id=c-a1AgAAQBAJ&pg=PA96 |year=2012 |publisher=IBM |isbn=978-0-7384-3534-3 |page=96}}</ref><ref name="Arora2006">{{cite book |author=Ashok Arora |title=Foundations of Computer Science |url=https://books.google.com/books?id=CrcoszZBMowC&pg=PA149 |year=2006 |publisher=Laxmi Publications |isbn=978-81-7008-971-1 |page=149}}</ref> The remainder of this article discusses multiprocessing only in this hardware sense.
At the [[operating system]] level, ''multiprocessing'' is sometimes used to refer to the execution of multiple concurrent [[Process (computing)|processes]] in a system, with each process running on a separate CPU or core, as opposed to a single process at any one instant.<ref name="MorleyParker2012">{{cite book |author1=Deborah Morley |author2=Charles Parker |title=Understanding Computers: Today and Tomorrow, Comprehensive |url=https://books.google.com/books?id=-2Ewg8QX8U4C&pg=PA183 |date=13 February 2012 |publisher=Cengage Learning |isbn=978-1-133-19024-0 |page=183}}</ref><ref name="Shibu">{{cite book |author=Shibu K. V. |title=Introduction to Embedded Systems |url=https://books.google.com/books?id=8hfn4gwR90MC&pg=PA402 |publisher=Tata McGraw-Hill Education |isbn=978-0-07-014589-4 |page=402}}</ref> When used with this definition, multiprocessing is sometimes contrasted with [[Computer multitasking|multitasking]], which may use just a single processor but switch it in time slices between tasks (i.e. a [[time-sharing system]]). Multiprocessing however means true parallel execution of multiple processes using more than one processor.<ref name="Shibu"/> Multiprocessing doesn't necessarily mean that a single process or task uses more than one processor simultaneously; the term [[Parallel computing|parallel processing]] is generally used to denote that scenario.<ref name="MorleyParker2012"/> Other authors prefer to refer to the operating system techniques as [[multiprogramming]] and reserve the term ''multiprocessing'' for the hardware aspect of having more than one processor.<ref name="EbbersKettner2012">{{cite book |author1=Mike Ebbers |author2=John Kettner |author3=Wayne O'Brien |author4=Bill Ogden |title=Introduction to the New Mainframe: z/OS Basics |url=https://books.google.com/books?id=c-a1AgAAQBAJ&pg=PA96 |year=2012 |publisher=IBM |isbn=978-0-7384-3534-3 |page=96}}</ref><ref name="Arora2006">{{cite book |author=Ashok Arora |title=Foundations of Computer Science |url=https://books.google.com/books?id=CrcoszZBMowC&pg=PA149 |year=2006 |publisher=Laxmi Publications |isbn=978-81-7008-971-1 |page=149}}</ref> The remainder of this article discusses multiprocessing only in this hardware sense.


In [[Flynn's taxonomy]], multiprocessors as defined above are [[MIMD]] machines.<ref name="Giladi2008"/><ref name="Shiva2005">{{cite book |author=Sajjan G. Shiva |title=Advanced Computer Architectures |url=https://books.google.com/books?id=DhdCwk5AhbEC&pg=PA221 |date=20 September 2005 |publisher=CRC Press |isbn=978-0-8493-3758-1 |page=221}}</ref> As the term "multiprocessor" normally refers to tightly coupled systems in which all processors share memory, multiprocessors are not the entire class of MIMD machines, which also contains [[message passing]] multicomputer systems.<ref name="Giladi2008">{{cite book |author=Ran Giladi |title=Network Processors: Architecture, Programming, and Implementation |url=https://books.google.com/books?id=_7aH_4axpwAC&pg=PA293 |year=2008 |publisher=Morgan Kaufmann |isbn=978-0-08-091959-1 |page=293}}</ref>
In [[Flynn's taxonomy]], multiprocessors as defined above are [[Multiple instruction, multiple data|MIMD]] machines.<ref name="Giladi2008"/><ref name="Shiva2005">{{cite book |author=Sajjan G. Shiva |title=Advanced Computer Architectures |url=https://books.google.com/books?id=DhdCwk5AhbEC&pg=PA221 |date=20 September 2005 |publisher=CRC Press |isbn=978-0-8493-3758-1 |page=221}}</ref> As the term "multiprocessor" normally refers to tightly coupled systems in which all processors share memory, multiprocessors are not the entire class of MIMD machines, which also contains [[message passing]] multicomputer systems.<ref name="Giladi2008">{{cite book |author=Ran Giladi |title=Network Processors: Architecture, Programming, and Implementation |url=https://books.google.com/books?id=_7aH_4axpwAC&pg=PA293 |year=2008 |publisher=Morgan Kaufmann |isbn=978-0-08-091959-1 |page=293}}</ref>

== Pre-history ==
Possibly the first expression of the idea of multiprocessing was written by [[Luigi Federico Menabrea]] in 1842, about [[Charles Babbage]]'s [[analytical engine]] (as translated by [[Ada Lovelace]]): "the machine can be brought into play so as to give several results at the same time, which will greatly abridge the whole amount of the processes."<ref>{{cite journal |url=http://www.fourmilab.ch/babbage/sketch.html |title=Sketch of The Analytical Engine Invented by Charles Babbage |author=L. F. Menabrea |authorlink=Luigi Federico Menabrea |journal=Bibliothèque Universelle de Genève |issue=82 |date=October 1842 |quote=Likewise, when a long series of identical computations is to be performed, such as those required for the formation of numerical tables, the machine can be brought into play so as to give several results at the same time, which will greatly abridge the whole amount of the processes.}}</ref>


== Key topics ==
== Key topics ==
Line 21: Line 19:


====Master/slave multiprocessor system====
====Master/slave multiprocessor system====
In a master/slave multiprocessor system, the master CPU is in control of the computer and the slave CPU(s) performs assigned tasks. The CPUs can be completely different in terms of speed and architecture. Some (or all) of the CPUs can have share common bus, each can also have a private bus (for private resources), or they may be isolated except for a common communications pathway. Likewise, the CPUs can share common RAM and/or have private RAM that the other processor(s) cannot access. The roles of master and slave can change from one CPU to another.
In a master/slave multiprocessor system, the master CPU is in control of the computer and the slave CPU(s) performs assigned tasks. The CPUs can be completely different in terms of speed and architecture. Some (or all) of the CPUs can share a common bus, each can also have a private bus (for private resources), or they may be isolated except for a common communications pathway. Likewise, the CPUs can share common RAM and/or have private RAM that the other processor(s) cannot access. The roles of master and slave can change from one CPU to another.


Two early examples of a mainframe master/slave multiprocessor are the [[Bull Gamma 60]] and the [[Burroughs Large Systems#B5000, B5500, and B5700|Burroughs B5000]].<ref>{{cite manual
An early example of a master/slave multiprocessor system is the Tandy/Radio Shack [[TRS-80 Model 16]] desktop computer which came out in February 1982 and ran the multi-user/multi-tasking [[Xenix]] operating system, Microsoft's version of UNIX (called TRS-XENIX). The Model 16 has 3 microprocessors, an 8-bit [[Zilog Z80]] CPU running at 4MHz, a 16-bit [[Motorola 68000]] CPU running at 6MHz and an [[Intel 8021]] in the keyboard. When the system was booted, the Z-80 was the master and the Xenix boot process initialized the slave 68000, and then transferred control to the 68000, whereupon the CPUs changed roles and the Z-80 became a slave processor that was responsible for all I/O operations including disk, communications, printer and network, as well as the keyboard and integrated monitor, while the operating system and applications ran on the 68000 CPU. The Z-80 could be used to do other tasks.
|title = The Operational Characteristics of the Processors for the Burroughs B5000
|id = 5000-21005A
|version = Revision A
|year = 1963
|url = http://www.bitsavers.org/pdf/burroughs/LargeSystems/B5000_5500_5700/5000-21005_B5000_operChar.pdf
|publisher = [[Burroughs Corporation|Burroughs]]
|access-date = June 27, 2023
|archive-date = 30 May 2023
|archive-url = https://web.archive.org/web/20230530061204/http://www.bitsavers.org/pdf/burroughs/LargeSystems/B5000_5500_5700/5000-21005_B5000_operChar.pdf
|url-status = live
}}</ref>


An early example of a master/slave multiprocessor system of microprocessors is the Tandy/Radio Shack [[TRS-80 Model 16]] desktop computer which came out in February 1982 and ran the multi-user/multi-tasking [[Xenix]] operating system, Microsoft's version of UNIX (called TRS-XENIX). The Model 16 has two microprocessors: an 8-bit [[Zilog Z80]] CPU running at 4&nbsp;MHz, and a 16-bit [[Motorola 68000]] CPU running at 6&nbsp;MHz. When the system is booted, the Z-80 is the master and the Xenix boot process initializes the slave 68000, and then transfers control to the 68000, whereupon the CPUs change roles and the Z-80 becomes a slave processor responsible for all I/O operations including disk, communications, printer and network, as well as the keyboard and integrated monitor, while the operating system and applications run on the 68000 CPU. The Z-80 can be used to do other tasks.
The earlier [[TRS-80 Model II]], which was released in 1979, could also be considered a multiprocessor system as it had both a Z-80 CPU and an Intel 8021<ref>{{cite book |title=TRS-80 Model II Technical Reference Manual |date=1980 |publisher=Radio Shack |page=135}}</ref> microprocessor in the keyboard. The 8021 made the Model II the first desktop computer system with a separate detachable lightweight keyboard connected with by a single thin flexible wire, and likely the first keyboard to use a dedicated microprocessor, both attributes that would later be copied years later by Apple and IBM.

The earlier [[TRS-80 Model II]], which was released in 1979, could also be considered a multiprocessor system as it had both a Z-80 CPU and an Intel 8021<ref>{{cite book |title=TRS-80 Model II Technical Reference Manual |date=1980 |publisher=Radio Shack |page=135}}</ref> microcontroller in the keyboard. The 8021 made the Model II the first desktop computer system with a separate detachable lightweight keyboard connected with by a single thin flexible wire, and likely the first keyboard to use a dedicated microcontroller, both attributes that would later be copied years later by Apple and IBM.


===Instruction and data streams===
===Instruction and data streams===


In multiprocessing, the processors can be used to execute a single sequence of instructions in multiple contexts ([[SIMD|single-instruction, multiple-data]] or SIMD, often used in [[vector processing]]), multiple sequences of instructions in a single context ([[MISD|multiple-instruction, single-data]] or MISD, used for [[Redundancy (engineering)|redundancy]] in fail-safe systems and sometimes applied to describe [[pipelining|pipelined processors]] or [[hyper-threading]]), or multiple sequences of instructions in multiple contexts ([[MIMD|multiple-instruction, multiple-data]] or MIMD).
In multiprocessing, the processors can be used to execute a single sequence of instructions in multiple contexts ([[single instruction, multiple data]] or SIMD, often used in [[vector processing]]), multiple sequences of instructions in a single context ([[multiple instruction, single data]] or MISD, used for [[Redundancy (engineering)|redundancy]] in fail-safe systems and sometimes applied to describe [[Pipeline (computing)|pipelined processors]] or [[hyper-threading]]), or multiple sequences of instructions in multiple contexts ([[multiple instruction, multiple data]] or MIMD).


===Processor coupling===
===Processor coupling===
Line 40: Line 51:
====Loosely coupled multiprocessor system====
====Loosely coupled multiprocessor system====
{{main | shared nothing architecture}}
{{main | shared nothing architecture}}
Loosely coupled multiprocessor systems (often referred to as [[Computer cluster|clusters]]) are based on multiple standalone single or dual processor [[commodity computer]]s interconnected via a high speed communication system ([[Gigabit Ethernet]] is common). A Linux [[Beowulf cluster]] is an example of a [[loose coupling|loosely coupled]] system.
Loosely coupled multiprocessor systems (often referred to as [[Computer cluster|clusters]]) are based on multiple standalone relatively low processor count [[commodity computer]]s interconnected via a high speed communication system ([[Gigabit Ethernet]] is common). A Linux [[Beowulf cluster]] is an example of a [[loose coupling|loosely coupled]] system.


Tightly coupled systems perform better and are physically smaller than loosely coupled systems, but have historically required greater initial investments and may [[depreciation|depreciate]] rapidly; nodes in a loosely coupled system are usually inexpensive commodity computers and can be recycled as independent machines upon retirement from the cluster.
Tightly coupled systems perform better and are physically smaller than loosely coupled systems, but have historically required greater initial investments and may [[depreciation|depreciate]] rapidly; nodes in a loosely coupled system are usually inexpensive commodity computers and can be recycled as independent machines upon retirement from the cluster.


Power consumption is also a consideration. Tightly coupled systems tend to be much more energy efficient than clusters. This is because considerable economy can be realized by designing components to work together from the beginning in tightly coupled systems, whereas loosely coupled systems use components that were not necessarily intended specifically for use in such systems.
Power consumption is also a consideration. Tightly coupled systems tend to be much more energy-efficient than clusters. This is because a considerable reduction in power consumption can be realized by designing components to work together from the beginning in tightly coupled systems, whereas loosely coupled systems use components that were not necessarily intended specifically for use in such systems.


Loosely coupled systems have the ability to run different operating systems or OS versions on different systems.
Loosely coupled systems have the ability to run different operating systems or OS versions on different systems.

== Disadvantages ==
Merging data from multiple [[Thread (computing)|threads]] or [[Process (computing)|processes]] may incur significant overhead due to [[conflict resolution]], [[data consistency]], versioning, and synchronization. <ref>{{Cite book |title=Concurrent Programming: Algorithms, Principles, and Foundations |publisher=Springer |isbn=978-3642320262}}</ref>


==See also==
==See also==
*[[Multiprocessor system architecture]]
*[[Symmetric multiprocessing]]
*[[Symmetric multiprocessing]]
*[[Asymmetric multiprocessing]]
*[[Asymmetric multiprocessing]]

Latest revision as of 05:24, 24 November 2024

Multiprocessing is the use of two or more central processing units (CPUs) within a single computer system.[1][2] The term also refers to the ability of a system to support more than one processor or the ability to allocate tasks between them. There are many variations on this basic theme, and the definition of multiprocessing can vary with context, mostly as a function of how CPUs are defined (multiple cores on one die, multiple dies in one package, multiple packages in one system unit, etc.).

According to some on-line dictionaries, a multiprocessor is a computer system having two or more processing units (multiple processors) each sharing main memory and peripherals, in order to simultaneously process programs.[3][4] A 2009 textbook defined multiprocessor system similarly, but noting that the processors may share "some or all of the system’s memory and I/O facilities"; it also gave tightly coupled system as a synonymous term.[5]

At the operating system level, multiprocessing is sometimes used to refer to the execution of multiple concurrent processes in a system, with each process running on a separate CPU or core, as opposed to a single process at any one instant.[6][7] When used with this definition, multiprocessing is sometimes contrasted with multitasking, which may use just a single processor but switch it in time slices between tasks (i.e. a time-sharing system). Multiprocessing however means true parallel execution of multiple processes using more than one processor.[7] Multiprocessing doesn't necessarily mean that a single process or task uses more than one processor simultaneously; the term parallel processing is generally used to denote that scenario.[6] Other authors prefer to refer to the operating system techniques as multiprogramming and reserve the term multiprocessing for the hardware aspect of having more than one processor.[2][8] The remainder of this article discusses multiprocessing only in this hardware sense.

In Flynn's taxonomy, multiprocessors as defined above are MIMD machines.[9][10] As the term "multiprocessor" normally refers to tightly coupled systems in which all processors share memory, multiprocessors are not the entire class of MIMD machines, which also contains message passing multicomputer systems.[9]

Key topics

[edit]

Processor symmetry

[edit]

In a multiprocessing system, all CPUs may be equal, or some may be reserved for special purposes. A combination of hardware and operating system software design considerations determine the symmetry (or lack thereof) in a given system. For example, hardware or software considerations may require that only one particular CPU respond to all hardware interrupts, whereas all other work in the system may be distributed equally among CPUs; or execution of kernel-mode code may be restricted to only one particular CPU, whereas user-mode code may be executed in any combination of processors. Multiprocessing systems are often easier to design if such restrictions are imposed, but they tend to be less efficient than systems in which all CPUs are utilized.

Systems that treat all CPUs equally are called symmetric multiprocessing (SMP) systems. In systems where all CPUs are not equal, system resources may be divided in a number of ways, including asymmetric multiprocessing (ASMP), non-uniform memory access (NUMA) multiprocessing, and clustered multiprocessing.

Master/slave multiprocessor system

[edit]

In a master/slave multiprocessor system, the master CPU is in control of the computer and the slave CPU(s) performs assigned tasks. The CPUs can be completely different in terms of speed and architecture. Some (or all) of the CPUs can share a common bus, each can also have a private bus (for private resources), or they may be isolated except for a common communications pathway. Likewise, the CPUs can share common RAM and/or have private RAM that the other processor(s) cannot access. The roles of master and slave can change from one CPU to another.

Two early examples of a mainframe master/slave multiprocessor are the Bull Gamma 60 and the Burroughs B5000.[11]

An early example of a master/slave multiprocessor system of microprocessors is the Tandy/Radio Shack TRS-80 Model 16 desktop computer which came out in February 1982 and ran the multi-user/multi-tasking Xenix operating system, Microsoft's version of UNIX (called TRS-XENIX). The Model 16 has two microprocessors: an 8-bit Zilog Z80 CPU running at 4 MHz, and a 16-bit Motorola 68000 CPU running at 6 MHz. When the system is booted, the Z-80 is the master and the Xenix boot process initializes the slave 68000, and then transfers control to the 68000, whereupon the CPUs change roles and the Z-80 becomes a slave processor responsible for all I/O operations including disk, communications, printer and network, as well as the keyboard and integrated monitor, while the operating system and applications run on the 68000 CPU. The Z-80 can be used to do other tasks.

The earlier TRS-80 Model II, which was released in 1979, could also be considered a multiprocessor system as it had both a Z-80 CPU and an Intel 8021[12] microcontroller in the keyboard. The 8021 made the Model II the first desktop computer system with a separate detachable lightweight keyboard connected with by a single thin flexible wire, and likely the first keyboard to use a dedicated microcontroller, both attributes that would later be copied years later by Apple and IBM.

Instruction and data streams

[edit]

In multiprocessing, the processors can be used to execute a single sequence of instructions in multiple contexts (single instruction, multiple data or SIMD, often used in vector processing), multiple sequences of instructions in a single context (multiple instruction, single data or MISD, used for redundancy in fail-safe systems and sometimes applied to describe pipelined processors or hyper-threading), or multiple sequences of instructions in multiple contexts (multiple instruction, multiple data or MIMD).

Processor coupling

[edit]

Tightly coupled multiprocessor system

[edit]

Tightly coupled multiprocessor systems contain multiple CPUs that are connected at the bus level. These CPUs may have access to a central shared memory (SMP or UMA), or may participate in a memory hierarchy with both local and shared memory (SM)(NUMA). The IBM p690 Regatta is an example of a high end SMP system. Intel Xeon processors dominated the multiprocessor market for business PCs and were the only major x86 option until the release of AMD's Opteron range of processors in 2004. Both ranges of processors had their own onboard cache but provided access to shared memory; the Xeon processors via a common pipe and the Opteron processors via independent pathways to the system RAM.

Chip multiprocessors, also known as multi-core computing, involves more than one processor placed on a single chip and can be thought of the most extreme form of tightly coupled multiprocessing. Mainframe systems with multiple processors are often tightly coupled.

Loosely coupled multiprocessor system

[edit]

Loosely coupled multiprocessor systems (often referred to as clusters) are based on multiple standalone relatively low processor count commodity computers interconnected via a high speed communication system (Gigabit Ethernet is common). A Linux Beowulf cluster is an example of a loosely coupled system.

Tightly coupled systems perform better and are physically smaller than loosely coupled systems, but have historically required greater initial investments and may depreciate rapidly; nodes in a loosely coupled system are usually inexpensive commodity computers and can be recycled as independent machines upon retirement from the cluster.

Power consumption is also a consideration. Tightly coupled systems tend to be much more energy-efficient than clusters. This is because a considerable reduction in power consumption can be realized by designing components to work together from the beginning in tightly coupled systems, whereas loosely coupled systems use components that were not necessarily intended specifically for use in such systems.

Loosely coupled systems have the ability to run different operating systems or OS versions on different systems.

Disadvantages

[edit]

Merging data from multiple threads or processes may incur significant overhead due to conflict resolution, data consistency, versioning, and synchronization. [13]

See also

[edit]

References

[edit]
  1. ^ Raj Rajagopal (1999). Introduction to Microsoft Windows NT Cluster Server: Programming and Administration. CRC Press. p. 4. ISBN 978-1-4200-7548-9.
  2. ^ a b Mike Ebbers; John Kettner; Wayne O'Brien; Bill Ogden (2012). Introduction to the New Mainframe: z/OS Basics. IBM. p. 96. ISBN 978-0-7384-3534-3.
  3. ^ "Multiprocessor dictionary definition - multiprocessor defined". www.yourdictionary.com. Archived from the original on 16 March 2018. Retrieved 16 March 2018.
  4. ^ "multiprocessor". Archived from the original on 16 March 2018. Retrieved 16 March 2018 – via The Free Dictionary.
  5. ^ Irv Englander (2009). The architecture of Computer Hardware and Systems Software. An Information Technology Approach (4th ed.). Wiley. p. 265. ISBN 978-0471715429.
  6. ^ a b Deborah Morley; Charles Parker (13 February 2012). Understanding Computers: Today and Tomorrow, Comprehensive. Cengage Learning. p. 183. ISBN 978-1-133-19024-0.
  7. ^ a b Shibu K. V. Introduction to Embedded Systems. Tata McGraw-Hill Education. p. 402. ISBN 978-0-07-014589-4.
  8. ^ Ashok Arora (2006). Foundations of Computer Science. Laxmi Publications. p. 149. ISBN 978-81-7008-971-1.
  9. ^ a b Ran Giladi (2008). Network Processors: Architecture, Programming, and Implementation. Morgan Kaufmann. p. 293. ISBN 978-0-08-091959-1.
  10. ^ Sajjan G. Shiva (20 September 2005). Advanced Computer Architectures. CRC Press. p. 221. ISBN 978-0-8493-3758-1.
  11. ^ The Operational Characteristics of the Processors for the Burroughs B5000 (PDF). Revision A. Burroughs. 1963. 5000-21005A. Archived (PDF) from the original on 30 May 2023. Retrieved 27 June 2023.
  12. ^ TRS-80 Model II Technical Reference Manual. Radio Shack. 1980. p. 135.
  13. ^ Concurrent Programming: Algorithms, Principles, and Foundations. Springer. ISBN 978-3642320262.