Explorando memoria transacional em software nos contextos de arquiteturas assimetricas, jogos computacionais e consumo de energia
Exploiting software transactional memory in the context of asymmetric architectures
dc.creator | Baldassin, Alexandro Jose | |
dc.date | 2009 | |
dc.date | 2017-03-31T06:46:14Z | |
dc.date | 2017-06-09T15:04:48Z | |
dc.date | 2017-03-31T06:46:14Z | |
dc.date | 2017-06-09T15:04:48Z | |
dc.date.accessioned | 2018-03-29T02:17:38Z | |
dc.date.available | 2018-03-29T02:17:38Z | |
dc.identifier | BALDASSIN, Alexandro Jose. Explorando memoria transacional em software nos contextos de arquiteturas assimetricas, jogos computacionais e consumo de energia. 2009. 101 p. Tese (doutorado) - Universidade Estadual de Campinas, Instituto de Computação, Campinas, SP. Disponível em: <http://cutter.unicamp.br/document/?code=000768401>. Acesso em: 31 mar. 2017. | |
dc.identifier | http://repositorio.unicamp.br/jspui/handle/REPOSIP/275821 | |
dc.identifier.uri | http://repositorioslatinoamericanos.uchile.cl/handle/2250/1313726 | |
dc.description | Orientador: Paulo Cesar Centoducatte | |
dc.description | Tese (doutorado) - Universidade Estadual de Campinas, Instituto de Computação | |
dc.description | Resumo: A adoção dos microprocessadores com múltiplos núcleos de execução pela indústria semicondutora tem criado uma crescente necessidade por novas linguagens, metodologias e ferramentas que tornem o desenvolvimento de sistemas concorrentes mais rápido, eficiente e acessível aos programadores de todos os níveis. Uma das principais dificuldades em programação concorrente com memória compartilhada é garantir a correta sincronização do código, evitando assim condições de corrida que podem levar o sistema a um estado inconsistente. A sincronização tem sido tradicionalmente realizada através de métodos baseados em travas, reconhecidos amplamente por serem de difícil uso e pelas anomalias causadas. Um novo mecanismo, conhecido como memória transacional (TM), tem sido alvo de muita pesquisa recentemente e promete simplificar o processo de sincronização, além de possibilitar maior oportunidade para extração de paralelismo e consequente desempenho. O cerne desta tese é formado por três trabalhos desenvolvidos no contexto dos sistemas de memória transacional em software (STM). Primeiramente, apresentamos uma implementação de STM para processadores assimétricos, usando a arquitetura Cell/B.E. como foco. Como principal resultado, constatamos que o uso de sistemas transacionais em arquiteturas assimétricas também é promissor, principalmente pelo fator escalabilidade. No segundo trabalho, adotamos uma abordagem diferente e sugerimos um sistema de STM especialmente voltado para o domínio de jogos computacionais. O principal motivo que nos levou nesta direção é o baixo desempenho das implementações atuais de STM. Um estudo de caso conduzido a partir de um jogo complexo mostra a eficácia do sistema proposto. Finalmente, apresentamos pela primeira vez uma caracterização do consumo de energia de um sistema de STM considerado estado da arte. Além da caracterização, também propomos uma técnica para redução do consumo em casos de alta contenção. Resultados obtidos a partir dessa técnica revelam ganhos de até 87% no consumo de energia | |
dc.description | Abstract: The shift towards multicore processors taken by the semiconductor industry has initiated an era in which new languages, methodologies and tools are of paramount importance to the development of efficient concurrent systems that can be built in a timely way by all kinds of programmers. One of the main obstacles faced by programmers when dealing with shared memory programming concerns the use of synchronization mechanisms so as to avoid race conditions that could possibly lead the system to an inconsistent state. Synchronization has been traditionally achieved by means of locks (or variations thereof), widely known by their anomalies and hard-to-get-it-right facets. A new mechanism, known as transactional memory (TM), has recently been the focus of a lot of research and shows potential to simplify code synchronization as well as delivering more parallelism and, therefore, better performance. This thesis presents three works focused on different aspects of software transactional memory (STM) systems. Firstly, we show an STM implementation for asymmetric processors, focusing on the architecture of Cell/B.E. As an important result, we find out that memory transactions are indeed promising for asymmetric architectures, specially due to their scalability. Secondly, we take a different approach to STM implementation by devising a system specially targeted at computer games. The decision was guided by poor performance figures usually seen on current STM implementations. We also conduct a case study using a complex game that effectively shows the system's efficiency. Finally, we present the energy consumption characterization of a state-of-the-art STM for the first time. Based on the observed characterization, we also propose a technique aimed at reducing energy consumption in highly contended scenarios. Our results show that the technique is indeed effective in such cases, improving the energy consumption by up to 87% | |
dc.description | Doutorado | |
dc.description | Sistemas de Computação | |
dc.description | Doutor em Ciência da Computação | |
dc.format | 101 p. : il. | |
dc.format | application/octet-stream | |
dc.language | Português | |
dc.publisher | [s.n.] | |
dc.subject | Memória transacional | |
dc.subject | Programação paralela (Computação) | |
dc.subject | Arquitetura de computador | |
dc.subject | Estimativa de potência | |
dc.subject | Transactional memory | |
dc.subject | Parallel programming (Computer science) | |
dc.subject | Computer architecture | |
dc.subject | Power estimation | |
dc.title | Explorando memoria transacional em software nos contextos de arquiteturas assimetricas, jogos computacionais e consumo de energia | |
dc.title | Exploiting software transactional memory in the context of asymmetric architectures | |
dc.type | Tesis |