[llvm-dev] Identify accessed memory regions with LLVM pass

Harish via llvm-dev llvm-dev at lists.llvm.org
Mon Dec 27 21:46:27 PST 2021


 I am working on an architecture that uses scratchpad memory. So I am
planning to implement a pass that inserts data transfer
instructions(custom) before the computation. Look at the below example
where the fun() needs A, B, C arrays. Before invoking fun(), I have the
move these arrays to the scratchpad. How do I identify the memory region
accessed by these arrays? Any pointers would be helpful.

void fun(int *A, int *B, int *C, int start, int end){
    for (int i = start; i < end; ++i) {
        [i] = A[i] + B[i];
    }

}

void test(){

    int start, end;
    int *A, *B, *C;
    // Intialize variables

    // TODO:
    //   1. Identify the memory region accessed by A, B and C
    //   2. Move the accessed regions to scratchpad memory
    fun(A, B, C, start, end);
}
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20211228/504e357a/attachment.html>


More information about the llvm-dev mailing list