Skip to content

Latest commit

 

History

History
26 lines (15 loc) · 1.43 KB

README.md

File metadata and controls

26 lines (15 loc) · 1.43 KB

Table of Contents generated with DocToc

Common Template Project

About the project

This repository records how we implement the hijack part of CUDA driver API.

Why we use LD_PRELOAD

There are multiple ways to achieve hajicking CUDA driver APIs. One is using LD_PRELOAD while others inlcude replacing libcuda.so with hijack.so.

The second approach requires a complete implemtnation of all CUDA driver APIs, hijacked or not. For those non-hijacked APIs, at least a wrapper is neceessary. Otherwise, the implemtation of the function is missing.

With the second approach, when launching containers, we need to use docker images implanted with the hijacked shared library, which is not optimal if we would like to use this approach on a platform open to the users with their own images.

Under the consideration of LD_PRELOAD, a platform only needs to mount the hijacked shared library from each host (Node) onto the container if Nvidia GPU(s) is/are used as well as specifying the environment variable of LD_PRELOAD.