Skip to content
  • Adhemerval Zanella's avatar
    d719d371
    ELF/AArch64: Refactor R_AARCH64_LDST{8,15,32,64,128}_ABS_LO12_NC Relocations · d719d371
    Adhemerval Zanella authored
    This patch refactor how to apply the R_AARCH64_LDST{8,16,32,64,128}_ABS_NC
    relocations by adding a new function to correct extract the bits expected
    by each relocation.  This make is explicit which are the bits range expected
    and simplify the code to mask and shift the deriable values.
    
    It also fixes the R_AARCH64_LDST128_ABS_LO12_NC mask, although in pratice
    the mask/shift always returns a 16 bytes aligned value.
    
    Checked on AArch64 and with test-suite.
    
    llvm-svn: 288921
    d719d371
    ELF/AArch64: Refactor R_AARCH64_LDST{8,15,32,64,128}_ABS_LO12_NC Relocations
    Adhemerval Zanella authored
    This patch refactor how to apply the R_AARCH64_LDST{8,16,32,64,128}_ABS_NC
    relocations by adding a new function to correct extract the bits expected
    by each relocation.  This make is explicit which are the bits range expected
    and simplify the code to mask and shift the deriable values.
    
    It also fixes the R_AARCH64_LDST128_ABS_LO12_NC mask, although in pratice
    the mask/shift always returns a 16 bytes aligned value.
    
    Checked on AArch64 and with test-suite.
    
    llvm-svn: 288921
Loading