Skip to content

Source code of our DaMoN@SIGMOD 2024 paper "How Does Software Prefetching Work on GPU Query Processing?"

Notifications You must be signed in to change notification settings

DBGroup-SUSTech/GPUDB-Prefetch

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

88 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Software Prefetching on GPU Query Processing

Progress

Naive GP [1] SPP [1] AMAC [2] IMV [3]
Hash Join Probe
BTree Lookup

Workload Description

Hash Join

  • Adapted from Timo Kersten's [4][5] implementation on CPU.
  • Non-partitioned and non-unique hash join with early materialization.
  • Staticaly pre-allocated hash table entries.
  • Uniform distribution (--gtest_filter="unique.*") and skew distribution (--gtest_filter="skew.*")

BTree

  • Adapted from Vicktor Leis's [6][7] implementation on CPU.
  • Concurrent insertion with Optimistic Lock Coupling.
  • Allocate nodes with a centralized memory pool.

Reference

[1] S. Chen, A. Ailamaki, P. B. Gibbons and T. C. Mowry. 2004. Improving hash join performance through prefetching. ICDE.
[2] Onur Kocberber, Babak Falsafi, and Boris Grot. 2015. Asynchronous memory access chaining. VLDB.
[3] Zhuhe Fang, Beilei Zheng, and Chuliang Weng. 2019. Interleaved multi-vectorizing. VLDB.
[4] Timo Kersten, Viktor Leis, Alfons Kemper, Thomas Neumann, Andrew Pavlo, and Peter Boncz. 2018. Everything you always wanted to know about compiled and vectorized queries but were afraid to ask. VLDB.
[5] https://github.com/TimoKersten/db-engine-paradigms
[6] Leis, Viktor, Michael Haubenschild and Thomas Neumann. 2019. Optimistic Lock Coupling: A Scalable and Efficient General-Purpose Synchronization Method. IEEE Data Eng. Bull.
[7] https://github.com/wangziqi2016/index-microbench/tree/master/BTreeOLC \

About

Source code of our DaMoN@SIGMOD 2024 paper "How Does Software Prefetching Work on GPU Query Processing?"

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •