Skip to content
@blindedcapabilities

blindedcapabilities

BLACKOUT: Data-Oblivious Computation with Blinded Capabilities

Abstract

Lack of memory-safety and exposure to side channels are two prominent, persistent challenges for the secure implementation of software. Memory-safe programming languages promise to significantly reduce the prevalence of memory-safety bugs, but make it more difficult to implement side-channel-resistant code. We aim to address both memory-safety and side-channel resistance by augmenting memory-safe hardware with the ability for data-oblivious programming. We describe an extension to the CHERI capability architecture to provide blinded capabilities that allow data-oblivious computation to be carried out by userspace tasks. We also present BLACKOUT, our realization of blinded capabilities on a FPGA softcore based on the speculative out-of-order CHERI-Toooba processor and extend the CHERI-enabled Clang/LLVM compiler and the CheriBSD operating system with support for blinded capabilities. BLACKOUT makes writing side-channel-resistant code easier by making non-data-oblivious operations via blinded capabilities explicitly fault. Through rigorous evaluation we show that BLACKOUT ensures memory operated on through blinded capabilities is securely allocated, used, and reclaimed and demonstrate that, in benchmarks comparable to those used by previous work, BLACKOUT imposes only a small performance degradation (1.5% geometric mean) compared to the baseline CHERI-Toooba processor.

@inproceedings{ElAtali25,
  title = {{BLACKOUT}: {Data-Oblivious Computation} with {Blinded Capabilities}},
  booktitle = {Proceedings of the 2025 {{ACM SIGSAC Conference}} on {{Computer}} and {{Communications Security}} ({{CCS}} '25)},
  author = {ElAtali, Hossam and G{\"u}lmez, Merve and Nyman, Thomas and Asokan, N.},
  year = {2025},
  month = oct,
  publisher = {ACM CCS'25},
  address = {Taipei, Taiwan},
  doi = {10.1145/3719027.3765169},
}

Blog posts

Source code

Popular repositories Loading

  1. blinded-cheri-sw blinded-cheri-sw Public

    C 1

  2. blindedcapabilities.github.io blindedcapabilities.github.io Public

    HTML

  3. .github .github Public

  4. blinded-cheri-llvm blinded-cheri-llvm Public

    C++

  5. blinded-cheribsd blinded-cheribsd Public

    C

  6. blackout-artifact blackout-artifact Public

    C

Repositories

Showing 8 of 8 repositories

People

This organization has no public members. You must be a member to see who’s a part of this organization.

Top languages

Loading…

Most used topics

Loading…