===================================================
timestone
├── include # public headers of timestone
├── lib #timestone library
├── lib++ #timestone C++ APIs
├── unittest #Unittest with linked list and B+Tree example
├── benchmark # benchmark
│ ├── rlu # - rlu implementation and benchmark
│ └── versioning # - versioned programming and benchmark
├── tools # misc build tools
cd timestone/
make
cd timestone/benchmark
sudo ./bench-timestone -b <no of buckets for hash table, set to 1 for linked list>
-d <duration(ms)> -i <initialize> -u <update ratio-- 20/200/800>
-n<number of threads>
### sample
sudo ./bench-timestone -b 1000 -d 10000 -i 100 -u 200 -n 16
cd timestone/lib/
CONF=gtest make
cd ../unittest/
make
sudo ./ut-ts --gtest_filter=cpp.btree_concurrent
Please contact us at [email protected] and [email protected]
@inproceedings{krishnan:timestone,
author = {Krishnan, R. Madhava and Kim, Jaeho and Mathew, Ajit and Fu, Xinwei
and Demeri, Anthony and Min, Changwoo and Kannan, Sudarsun},
title = {Durable Transactional Memory Can Scale with Timestone},
year = {2020},
isbn = {9781450371025},
publisher = {Association for Computing Machinery},
address = {New York, NY, USA},
url = {https://doi.org/10.1145/3373376.3378483},
doi = {10.1145/3373376.3378483},
booktitle = {Proceedings of the Twenty-Fifth International Conference on
Architectural Support for Programming Languages and Operating Systems},
pages = {335–349},
numpages = {15},
location = {Lausanne, Switzerland},
series = {ASPLOS '20}
}