Skip to content
This repository has been archived by the owner on Oct 13, 2023. It is now read-only.
/ AES_on_RPi_GPU Public archive

Implementation of AES-ECB and an accompanying custom GPU Assembler for the Raspberry-Pi GPU

License

Notifications You must be signed in to change notification settings

PaulPauls/AES_on_RPi_GPU

Repository files navigation

Implementation of AES-ECB on the Raspberry-Pi GPU

This repository contains the accompanying code to my Bachelor-Thesis 'Parallelizing AES on Raspberry-Pi GPU in Custom Assembly'. It consists of three parts:

AES128ECB_GPU_192byte_Variant / AES256ECB_GPU_192byte_Variant

Implementation of AES in the Variants 128-bit and 256-bit in ECB mode in custom written Assembly as dictated by the custom GPU Assembler. Each repository contains furthermore comparison implementations of AES, such as tiny-aes or the original rijndael proposal, to which the GPU implementation is compared to in a timing benchmark.

GPU_Assembler

Custom GPU Assembler, that creates binary code from customly defined Syntax, which is extensively documented in my BSc-Thesis. The GPU is a Broadcom VideoCore IV and the Assembler is implemented according to its Architecture Reference Guide. The Custom GPU Assembler was first started by Eric Lorimer and extended upon by Pete Warden. This implementation again extends Pete Warden's implementation and adds multiple convenience and functionality features as well as plenty of in-code documentation.

VPM_Problem

Example Code to showcase the problems encountered while using more than 192byte of the GPUs Virtual Pipelined Memory (VPM) when using the custom GPU Assembler.

About

Implementation of AES-ECB and an accompanying custom GPU Assembler for the Raspberry-Pi GPU

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published