Programmable Transactional Memory

31
Programmable Transactional Memory Kunle Olukotun Pervasive Parallelism Laboratory Stanford University SOS-13

Transcript of Programmable Transactional Memory

Page 1: Programmable Transactional Memory

Programmable Transactional Memory

Kunle OlukotunPervasive Parallelism Laboratory

Stanford University

SOS-13

Page 2: Programmable Transactional Memory

The Memory Wall?

Multicore Is Bad News For Supercomputers Samuel K. Moore

Sharing and scheduling can help!

Page 3: Programmable Transactional Memory

The Stanford Pervasive Parallelism Laboratory

Goal: the parallel computing platform for 2012Make parallel application development practical for the average software developersParallel applications without parallel programming

PPL is a combination of Leading Stanford researchers across multiple domains

Applications, languages, software systems, architecture

Leading companies in computer systems and softwareSun, AMD, Nvidia, IBM, Intel, HP, NEC

An exciting vision for pervasive parallelism

Page 4: Programmable Transactional Memory

The PPL Vision

Parallel Object Language

Hardware Architecture

OOO CoresOOO Cores SIMD CoresSIMD Cores Threaded CoresThreaded Cores

ProgrammableHierarchies

ProgrammableHierarchies

Scalable CoherenceScalable

CoherenceIsolation & AtomicityIsolation & Atomicity

Pervasive MonitoringPervasive Monitoring

Virtual Worlds

Personal Robotics

Datainformatics

ScientificEngineering

Physics(PhysBam,

Lizst)

Scripting(Scala)

Probabilistic (Delite)

Machine Learning (Delite)

Rendering

Common Parallel Runtime

Explicit / Static Implicit / Dynamic

Hardware Prototypes

GPUGPU

CPUCPU

FPGAFPGA

Applications

DomainSpecific

Languages

Page 5: Programmable Transactional Memory

Transactional Memory (TM)

Memory transaction [Knight’86, Herlihy & Moss’93]

An atomic & isolated sequence of memory accesses Inspired by database transactions

Atomicity (all or nothing) At commit, all memory updates take effect at onceOn abort, none of the memory updates appear to take effect

IsolationNo other code can observe memory updates before commit

Serializability Transactions seem to commit in a single serial order

Page 6: Programmable Transactional Memory

int deposit(account, amount)atomic {

int t = bank.get(account);t = t + amount;bank.put(account, t);return (1);

}

int withdraw(account, amount)atomic {

int t = bank.get(account);t = t – amount;if (t<0) return (0);bank.put(account, t); return (1);

}

Programming with TM

Declarative synchronizationProgrammers says what but not howNo explicit declaration or management of locks

System implements synchronizationTypically with optimistic concurrency [Kung’81]

Slow down only on true conflicts (R-W or W-W)

int deposit(account, amount)synchronized(account) {

int t = bank.get(account);t = t + amount;bank.put(account, t);return (1);

}

int withdraw(account, amount)synchronized(account) {

int t = bank.get(account);t = t – amount;if (t<0) return (0);bank.put(account, t); return (1);

}

Page 7: Programmable Transactional Memory

Advantages of TM

Easy to use synchronization constructAs easy to use as coarse-grain locksProgrammer declares, system implements

Performs as well as fine-grain locksAutomatic read-read & fine-grain concurrencyNo tradeoff between performance & correctness

Failure atomicity & recoveryNo lost locks when a thread failsFailure recovery = transaction abort + restart

ComposabilitySafe & scalable composition of software modules

Page 8: Programmable Transactional Memory

Implementing Memory Transactions

Data versioning for updated dataManage new & old values for memory dataDeferred(lazy) updates (write-buffer) vs direct updates (undo-log)

Conflict detection for shared dataDetect R-W and W-W for concurrent transactionsTrack the read-set and write-set of each transactionCheck during execution (pessimistic) or at the end (optimistic)

Ideal implementationSoftware only: works with current & future hardwareFlexible: can modify, enhance, or use in alternative mannersHigh performance: faster than sequential code & scalableCorrect: no incorrect or surprising execution results

Page 9: Programmable Transactional Memory

Software Transactional Memory

Software barriers for TM bookkeepingVersioning, read/write-set tracking, commit, …Using locks, timestamps, object copying, …

Can be optimized by compilers [Adl-Tabatabai’06, Harris’06]

Requires function cloning or dynamic translation

ListNode n;atomic {n = head;if (n != NULL) {

head = head.next;

}}

ListNode n;STMstart();n = STMread(&head);if (n != NULL) {ListNode t;t = STMread(&head.next);STMwrite(&head, t);

}STMcommit();

High-level Low-levelSTM Compiler

Page 10: Programmable Transactional Memory

STM Performance Challenges

2x to 8x overhead due to SW barriersAfter compiler optimizations, inlining, …

Short term: demotivates parallel programmingTM coding easier than locks but harder than sequential…

Long term: energy wasteful

Page 11: Programmable Transactional Memory

Hardware TM (HTM)

HW support for common case TM behavior Initial TMs used hardware [Knight’86, Herlihy & Moss’93]All HTMs include software too…

RationaleHW can track all loads/stores transparently, w/o overheadHW is good at fine-grain operations within a chipWe have transistors to spare in multi-core designs

Thanks to Moore’s law…

Basic HW mechanismsCache metadata track read-set & write-setCaches buffer deferred updatesCoherence protocol does conflict detection

Page 12: Programmable Transactional Memory

Multi-core Chip

HTM works with bus-based & scalable networksHTM works with private & shared caches

CPU 1

PrivateCaches

CPU 2

PrivateCaches

CPU 3

PrivateCaches

CPU N

PrivateCaches

. . .

Coherence Network

SharedCaches

SharedCaches

SharedCaches

. . .

off-chip & memory channels

Page 13: Programmable Transactional Memory

HTM Design The details in [ISCA’04, PACT’05, HPCA’07]

CPU

Cache

ALUs

TM State

Tag DataV

Registers

CPU changesRegister checkpoint (available in many CPUs)TM state registers (status, pointers to handlers, …)

Page 14: Programmable Transactional Memory

HTM Design The details in [ISCA’04, PACT’05, HPCA’07]

CPU

Cache

ALUs

TM State

Tag DataVWR

Registers

Cache changesR bit indicates membership in read-setW bit indicates membership in write-set

Page 15: Programmable Transactional Memory

HTM Transaction ExecutionXbegin

Load A

Store 5 � BLoad C

Xcommit

CPU

Cache

ALUs

TM State

Tag DataV

C 91

WR

Registers

Transaction beginInitialize CPU & cache stateTake register checkpoint

0 0

Page 16: Programmable Transactional Memory

HTM Transaction ExecutionXbegin

Load A

Store 5 � BLoad C

Xcommit

CPU

Cache

ALUs

TM State

Tag DataV

C 91

WR

Registers

0 0

Load operationServe cache miss if neededMark data as part of read-set

A 3311 0

Page 17: Programmable Transactional Memory

HTM Transaction ExecutionXbegin

Load A

Store 5 � BLoad C

Xcommit

CPU

Cache

ALUs

TM State

Tag DataV

C 91

WR

Registers

0 0

Store operationServe cache miss if needed (eXclusive if not shared, Shared otherwise)Mark data as part of write-set

A 3311 0B 510 1

Page 18: Programmable Transactional Memory

HTM Transaction ExecutionXbegin

Load A

Store 5 � BLoad C

Xcommit

CPU

Cache

ALUs

TM State

Tag DataV

C 91

WR

Registers

1 0

Fast, 2-phase commitValidate: request exclusive access to write-set lines (if needed)Commit: gang-reset R & W bits, turns write-set data to valid (dirty) data

A 3311 0

B 510 1 upgradeX B0 0

0 0

0 0

Page 19: Programmable Transactional Memory

HTM Conflict DetectionXbegin

Load A

Store 5 � BLoad C

Xcommit

CPU

Cache

ALUs

TM State

Tag DataV

C 91

WR

Registers

1 0

Fast conflict detection & abortCheck: lookup exclusive requests in the read-set and write-setAbort: invalidate write-set, gang-reset R and W bits, restore checkpoint

A 3311 0

B 510 1

upgradeX D

upgradeX A

11 0

01 0

00 10 0

0 0

0 0

Page 20: Programmable Transactional Memory

Performance with HTM

Scalable performance, up to 7x over STM [ISCA’07]

Within 10% of sequential for one threadUncommon HTM cases not a performance challenge

Page 21: Programmable Transactional Memory

TCC Architecture Model

TCC architecture approachProgrammer determines coherence and consistency points

At transaction boundaries

Use caches for fast local bufferingUse coherence protocol for commit & violation detection

Distinguishing featureRe-design the coherence protocol just for transactionsAll communication at transaction commit pointsNo need to support other fine-grain communication

Simpler protocol, few short messages, …

Page 22: Programmable Transactional Memory

Scalable TCC Performance

Scalable TCC implementationDirectory-based, 2-phase commit, traffic filtering

Excellent scalabilityLazy commit not an overhead

Page 23: Programmable Transactional Memory

Pure HTMs Have Limitations

Page 24: Programmable Transactional Memory

Communication Landscape3 Ws and 1 S

Comm. Mech. When? What? Where? Synch?

Message passing

Programmer: send/receive

Message buffer

Processor list Yes

CC shared memory

System: load, store Cache line Broadcast/dir

ectory No

Stanford TCC Programmer: transactions

Write set Broadcast/directory

Yes

Illinois Bulk System: chunks

Write set Broadcast/directory

No

Update_all Programmer: update_all Write set Broadcast/dir

ectoryNo

Update_some Programmer: update_some Write set Processor list No

Update_mem Programmer: update_mem Write set memory No

Data_update Programmer: data_update Address list

Broadcast, processor list,

memoryNo

Page 25: Programmable Transactional Memory

Architecture Research Methodology

Conventional approaches are usefulDevelop app & SW system on existing platforms

Multi-core, accelerators, clusters, …

Simulate novel HW mechanismsNo realistic software

Need some method that bridges HW & SW research Makes new HW features available for SW researchDoes not compromise HW speed, SW features, or scaleAllows for full-system prototypes

Needed for research, convincing for industry, exciting for students

Approach: commodity chips + FPGAs in memory systemCommodity chips: fast system with rich SW environment FPGAs: prototyping platform for new HW featuresScale through cluster arrangement

Page 26: Programmable Transactional Memory

MemoryMemoryMemoryMemory

MemoryMemory MemoryMemory

Core 0Core 0 Core 1Core 1

Core 2Core 2 Core 3Core 3

Core 0Core 0 Core 1Core 1

Core 2Core 2 Core 3Core 3

Core 0Core 0 Core 1Core 1

Core 2Core 2 Core 3Core 3

Core 0Core 0 Core 1Core 1

Core 2Core 2 Core 3Core 3

FARM: Flexible Architecture Research Machine

Page 27: Programmable Transactional Memory

MemoryMemoryMemoryMemory

MemoryMemory MemoryMemory

Core 0Core 0 Core 1Core 1

Core 2Core 2 Core 3Core 3

Core 0Core 0 Core 1Core 1

Core 2Core 2 Core 3Core 3

Core 0Core 0 Core 1Core 1

Core 2Core 2 Core 3Core 3

FPGAFPGA

SRAMSRAM

IOIO

FARM: Flexible Architecture Research Machine

Page 28: Programmable Transactional Memory

MemoryMemoryMemoryMemory

MemoryMemory MemoryMemory

Core 0Core 0 Core 1Core 1

Core 2Core 2 Core 3Core 3

Core 0Core 0 Core 1Core 1

Core 2Core 2 Core 3Core 3

FPGAFPGA

SRAMSRAM

IOIO

GPU/Stream

FARM: Flexible Architecture Research Machine

Page 29: Programmable Transactional Memory

MemoryMemoryMemoryMemory

MemoryMemory MemoryMemory

Core 0Core 0 Core 1Core 1

Core 2Core 2 Core 3Core 3

Core 0Core 0 Core 1Core 1

Core 2Core 2 Core 3Core 3

Core 0Core 0 Core 1Core 1

Core 2Core 2 Core 3Core 3

FPGAFPGA

SRAMSRAM

(scalable)

InfinibandOr PCIe InterconnectI

OIO

FARM: Flexible Architecture Research Machine

Page 30: Programmable Transactional Memory

FARM PrototypeProcyon System

Hardware platform for FARMFrom A&D Technology, Inc.Full system board

AMD Opteron Socket FTwo DDR2 DIMMsUSB/eSATA/VGA/GigESun OpenSolaris OS

Extra CPU boardAMD Opteron Socket F

FPGA BoardAltera Stratix II FPGA

All connected via HT backplaneAlso provides PCIe and PCI

Page 31: Programmable Transactional Memory

Conclusions

Need a full system vision for pervasive parallelismApplications, programming models, programming languages, software systems, and hardware architecture

Key initial ideasDomain-specific languages

Programmable memory systems (TM)

Real system prototypes