See README-pocl.md for original README.
See https://github.com/THU-DSP-LAB/llvm-project for detailed build guide with Ventus llvm based OpenCL Compiler and icd loader.
Original PoCL build instruction doesn't work for Ventus GPGPU.
TODOs are divided into 3 parts, first part contains jobs required to make sure OpenCL tests can be tested with pocl+spike, second part contains jobs required to enable real Ventus GPGPU work flow, third part contains generic TODOs.
-
Correctly report Ventus GPGPU virtual device after pocl is statically/dynamally linked with spike(Currently ventus device is hardcoded).
-
Determine how we implement workitem builtins, if using workitem.S implementation from ventus-llvm, some extra work should to be done in ventus pocl driver, otherwise we need to redesign how workitem builtins are implemented.
1). Functions such as
insertPrologue
from ParallelRegion.cc inserts instructions to getlocal_id_x/y/z
which are preset byWorkitemReplication::ProcessFunction
, this behavior is weird.2). Workitem variables local_size_x/y/z can have dynamic size which to be determined at runtime, this is done in pocl
WorkitemHandler
. -
Make sure pocl ventus driver is correctly initialized, such as
pocl_ventus_init
is double checked, basically every items instruct _cl_device_id
should be properly initialized. -
Make sure there is no native(host) device related code in ventus pocl driver, such as
kernel.so
in functionllvm_codegen
should be renamed tokernel.elf
or something else(a static elf file). Also the native kernel executiondlopen(kernel.so)
should be replaced by an elf loader(Should already be done by spike fesrv elf loader). -
Kernel metadata buffer and kernel args buffer should be prepared in pocl, then passed to spike by asking spike to store those buffer into the lowerest address of physical memory of Ventus GPGPU, related CSRs should be initialized with the kernel metadata buffer base address.
-
Check the behavior of all the OpenCL APIs for Ventus GPGPU are correctly coded(Some API implementations in common.c may not work for Ventus GPGPU), make sure all the examples and tests can be kicked off(may not run through) to spike(via spike elf loader).
-
Device side printf support. A buffer with size PRINTF_BUFFER_SIZE on device side should be reserved, and a CSR or event may be needed to notify OCL driver to copy device side printf buffer to host side.
- Ventus GPGPU kernel mode driver(kmd) should be provided and bridged with pocl.
- Correctly report Ventus GPGPU device after pocl(umd) can locate ventus kmd and read necessory information from the kmd(such as supported extensions etc).
- Fix hardcoded library search path for libworkitem.a in ventus.c.