HIPE: HMC Instruction Predication Extension Applied on Database Processing

Diego G. Tomé1,3,a, Paulo C. Santos2,d, Luigi Carro2,e, Eduardo C. Almeida1,c and Marco A. Z. Alves1,b
1Department of Informatics ‐ Federal University of Paraná ‐ Curitiba, Brazil
adgtome@inf.ufpr.br
bmazalves@inf.ufpr.br
ceduardo@inf.ufpr.br
2Informatics Institute ‐ Federal University of Rio Grande do Sul ‐ Porto Alegre, Brazil
dpcssjunior@inf.ufrgs.br
ecarro@inf.ufrgs.br
3Centrum Wiskunde & Informatica (CWI) ‐ Amsterdam, The Netherlands

ABSTRACT


The recent Hybrid Memory Cube (HMC) is a smart memory which includes functional units inside one logic layer of the 3D stacked memory design. In order to execute instructions inside the Hybrid Memory Cube (HMC), the processor needs to send instructions to be executed near data, keeping most of the pipeline complexity inside the processor. Thus, control‐flow and data‐flow dependencies are all managed inside the processor, in such way that only update instructions are supported by the HMC. In order to solve data‐flow dependencies inside the memory, previous work proposed HMC Instruction Vector Extensions (HIVE), which embeds a high number of functional units with a interlock register bank. In this work we propose HMC Instruction Prediction Extensions (HIPE), that supports predicated execution inside the memory, in order to transform control‐flow dependencies into data‐flow dependencies. Our mechanism focus on removing the high latency iteration between the processor and the smart memory during the execution of branches that depends on data processed inside the memory. In this paper we evaluate a balanced design of HIVE comparing to x86 and HMC executions. After we show the HIPE mechanism results when executing a database workload, which is a strong candidate to use smart memories. We show interesting trade‐offs of performance when comparing our mechanism to previous work.

Keywords:Processing‐In‐Memory, Predicated Instructions, Hybrid Memory Cube, Near‐Data Database.



Full Text (PDF)