Transaction scheduling using dynamic conflict avoidance


Autoria(s): Nicácio, Daniel; Baldassin, Alexandro; Araújo, Guido
Contribuinte(s)

Universidade Estadual Paulista (UNESP)

Data(s)

27/05/2014

27/05/2014

01/02/2013

Resumo

Software transaction memory (STM) systems have been used as an approach to improve performance, by allowing the concurrent execution of atomic blocks. However, under high-contention workloads, STM-based systems can considerably degrade performance, as transaction conflict rate increases. Contention management policies have been used as a way to select which transaction to abort when a conflict occurs. In general, contention managers are not capable of avoiding conflicts, as they can only select which transaction to abort and the moment it should restart. Since contention managers act only after a conflict is detected, it becomes harder to effectively increase transaction throughput. More proactive approaches have emerged, aiming at predicting when a transaction is likely to abort, postponing its execution. Nevertheless, most of the proposed proactive techniques are limited, as they do not replace the doomed transaction by another or, when they do, they rely on the operating system for that, having little or no control on which transaction to run. This article proposes LUTS, a lightweight user-level transaction scheduler. Unlike other techniques, LUTS provides the means for selecting another transaction to run in parallel, thus improving system throughput. We discuss LUTS design and propose a dynamic conflict-avoidance heuristic built around its scheduling capabilities. Experimental results, conducted with the STAMP and STMBench7 benchmark suites, running on TinySTM and SwissTM, show how our conflict-avoidance heuristic can effectively improve STM performance on high contention applications. © 2012 Springer Science+Business Media, LLC.

Formato

89-110

Identificador

http://dx.doi.org/10.1007/s10766-012-0205-x

International Journal of Parallel Programming, v. 41, n. 1, p. 89-110, 2013.

0885-7458

http://hdl.handle.net/11449/74455

10.1007/s10766-012-0205-x

WOS:000313061500003

2-s2.0-84872606762

Idioma(s)

eng

Relação

International Journal of Parallel Programming

Direitos

closedAccess

Palavras-Chave #Concurrent programming #Contention management #Multiprocessor systems #Transactional memory #Atomic blocks #Benchmark suites #Concurrent execution #Conflict avoidance #Improving systems #Management policy #Multi processor systems #Pro-active approach #Rate increase #Software Transaction Memory #Transaction scheduling #Transaction throughput #Computer programming #Java programming language #Management #Managers #Scheduling
Tipo

info:eu-repo/semantics/article