Ian Goldberg fbf896e040 Mention ORExpand in the Enclave/OblivAlgs/README file 1 year ago
..
CONFIG.h 0a23f8293c Port code for oblivious compaction, shuffle, sort 1 year ago
ORExpand.cpp ccaa8afc38 More realistic test sizes in test_ORExpand_parallel 1 year ago
ORExpand.hpp d122d04a6d Implementation of ORExpand (multi-threaded version) 1 year ago
ORExpand.tcc 39a5066ab3 Add a comment for future possible optimization 1 year ago
README fbf896e040 Mention ORExpand in the Enclave/OblivAlgs/README file 1 year ago
RecursiveShuffle.cpp 2562d9ac86 Rather than pre-allocating an array of randomness pools, just give each thread its own thread-local randomness pool 1 year ago
RecursiveShuffle.hpp 0a23f8293c Port code for oblivious compaction, shuffle, sort 1 year ago
RecursiveShuffle.tcc 0a23f8293c Port code for oblivious compaction, shuffle, sort 1 year ago
SortingNetwork.cpp 0a23f8293c Port code for oblivious compaction, shuffle, sort 1 year ago
SortingNetwork.hpp 0a23f8293c Port code for oblivious compaction, shuffle, sort 1 year ago
SortingNetwork.tcc 0a23f8293c Port code for oblivious compaction, shuffle, sort 1 year ago
TightCompaction_v2.cpp 0a23f8293c Port code for oblivious compaction, shuffle, sort 1 year ago
TightCompaction_v2.hpp 0a23f8293c Port code for oblivious compaction, shuffle, sort 1 year ago
TightCompaction_v2.tcc 9aa189d357 adding ifdef for TightCompaction printf timing outputs 1 year ago
WaksmanNetwork.cpp ae3646cf41 Sort using precomputable shuffles 1 year ago
WaksmanNetwork.hpp df7e017f7f Don't crash for WNEvalPlans where N=2 and nthreads>1 1 year ago
WaksmanNetwork.tcc 5cb57bc4be Generalize sort_mtobliv to be able to sort on different kinds of keys 1 year ago
aes.hpp 0a23f8293c Port code for oblivious compaction, shuffle, sort 1 year ago
foav.h 0a23f8293c Port code for oblivious compaction, shuffle, sort 1 year ago
oasm_lib.h 7b94f67102 Add "earlyclobber" constraint to oselect_uint32_t 1 year ago
oasm_lib.tcc 0a23f8293c Port code for oblivious compaction, shuffle, sort 1 year ago
utils.cpp 876ba2eeec Remove an unused (and incorrect in any case) function 1 year ago
utils.hpp 876ba2eeec Remove an unused (and incorrect in any case) function 1 year ago

README

This directory contains code ported from "Fast Fully Oblivious
Compaction and Shuffling" and "Waks-On/Waks-Off: Fast Oblivious
Offline/Online Shuffling and Sorting with Waksman Networks" by
Sajin Sasy, Aaron Johnson, and Ian Goldberg:

https://crysp.uwaterloo.ca/software/obliv/

with some additional enhancements, such as a multithreaded
implementation of WaksShuffle + Sort and WaksSort, and an
implemention of ORExpand.