Shared-memory synchronization

Bibliographic Information

Shared-memory synchronization

Michael L. Scott

(Synthesis lectures on computer architecture, 23)

Morgan & Claypool, c2013

  • : pbk

Available at  / 2 libraries

Search this Book/Journal

Note

Includes bibliographical references

Description and Table of Contents

Description

Since the advent of time sharing in the 1960s, designers of concurrent and parallel systems have needed to synchronize the activities of threads of control that share data structures in memory. In recent years, the study of synchronization has gained new urgency with the proliferation of multicore processors, on which even relatively simple user-level programs must frequently run in parallel. This lecture offers a comprehensive survey of shared-memory synchronization, with an emphasis on "systems-level" issues. It includes sufficient coverage of architectural details to understand correctness and performance on modern multicore machines, and sufficient coverage of higher-level issues to understand how synchronization is embedded in modern programming languages.The primary intended audience is "systems programmers"-the authors of operating systems, library packages, language run-time systems, concurrent data structures, and server and utility programs. Much of the discussion should also be of interest to application programmers who want to make good use of the synchronization mechanisms available to them, and to computer architects who want to understand the ramifications of their design decisions on systems-level code.

Table of Contents

Introduction Architectural Background Essential Theory Practical Spin Locks Busy-wait Synchronization with Conditions Read-mostly Atomicity Synchronization and Scheduling Nonblocking Algorithms Transactional Memory Author's Biography

by "Nielsen BookData"

Related Books: 1-1 of 1

Details

Page Top