[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: Reducing code size of Position Independent Executables (PIE) by shrinking the size of dynamic relocations section
- To: Sriraman Tallam <tmsriram@google.com>
- Subject: Re: Reducing code size of Position Independent Executables (PIE) by shrinking the size of dynamic relocations section
- From: "Rahul Chaudhry via gnu-gabi" <gnu-gabi@sourceware.org>
- Date: Mon, 11 Dec 2017 15:50:26 -0800
- Authentication-results: sourceware.org; auth=none
- Cc: Florian Weimer <fw@deneb.enyo.de>, Rahul Chaudhry via gnu-gabi <gnu-gabi@sourceware.org>, Suprateeka R Hegde <hegdesmailbox@gmail.com>, Florian Weimer <fweimer@redhat.com>, David Edelsohn <dje.gcc@gmail.com>, Rafael Avila de Espindola <rafael.espindola@gmail.com>, Binutils Development <binutils@sourceware.org>, Alan Modra <amodra@gmail.com>, Cary Coutant <ccoutant@gmail.com>, Xinliang David Li <davidxl@google.com>, Sterling Augustine <saugustine@google.com>, Paul Pluzhnikov <ppluzhnikov@google.com>, Ian Lance Taylor <iant@google.com>, "H.J. Lu" <hjl.tools@gmail.com>, Luis Lozano <llozano@google.com>, Peter Collingbourne <pcc@google.com>, Rui Ueyama <ruiu@google.com>, llvm-dev@lists.llvm.org
- Delivered-to: listarch-gnu-gabi@sourceware.org
- Delivered-to: mailing list gnu-gabi@sourceware.org
- Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc:content-transfer-encoding; bh=QrwM5jxjXu8VboLBhwLRIMhbRHjNfiBjkUI7IVkKqDg=; b=rCdA9LWv4DmDvESw+iyyH5GhVmQi+F4lCfB1MVo0TYZx41S8teI0L+qpiR2xZPzjSF Y/qTtVYvY0EDgcweh7O14KeXlnFTo7G4V8De/uAm0BM157y6hZZ7Yi0TcRriPopGHenz wixcB7exgiHuwbcyVYAg15+L9PJ46wpDb4mklG4eZec94qgVG+6wJCYipjqODRntpNw7 u+bqiHDq5GD/M/mnhsY2lVUTC17DC+4tYoR/ZMCypIfwO1XczDN5v6EPAkZyzX6DJXrt S1GjbhGLaaOTklxZllyKQ/+Gv7ffiB31cb/BGoNRCYMv3BPfD5zxKmfesWs+s/PwygCE jG1Q==
- In-reply-to: <CAAs8HmwMRTjyLjvUAbP9drkagbpedonHOGGRvoFQVr1TE7wyCQ@mail.gmail.com>
- List-help: <mailto:gnu-gabi-help@sourceware.org>
- List-id: <gnu-gabi.sourceware.org>
- List-post: <mailto:gnu-gabi@sourceware.org>
- List-subscribe: <mailto:gnu-gabi-subscribe@sourceware.org>
- Mailing-list: contact gnu-gabi-help@sourceware.org; run by ezmlm
- References: <CAGWvnynFwXFGLj3tAVgDatn0zmuHcWHyRNuDvR+wRZCXLnar_A@mail.gmail.com> <8737cosnym.fsf@localhost.localdomain.i-did-not-set--mail-host-address--so-tickle-me> <CAGWvnynEe3QkhDMGc=Tx8Vr44egtv3xLuh1yiVcAhv+e3GLtZg@mail.gmail.com> <a3e5c76c-8cb9-fc53-a30a-96b2c85079e1@gmail.com> <a68a5d29-09d6-e758-8680-d94f42762adf@redhat.com> <7e698a5f-32d7-6549-7e23-8850b85e6c10@gmail.com> <CAAs8Hmziqc0hebPndiGuZN=buFm=M+O+2fGCfsv_rvDro9zJZA@mail.gmail.com> <CAJRD=ooGubyUOLE6W7LHdeU2ZNDEG1A=84+P=1iOvfmD7-7GNg@mail.gmail.com> <874lozec25.fsf@mid.deneb.enyo.de> <CAAs8HmwMRTjyLjvUAbP9drkagbpedonHOGGRvoFQVr1TE7wyCQ@mail.gmail.com>
- Reply-to: Rahul Chaudhry <rahulchaudhry@google.com>
- Sender: gnu-gabi-owner@sourceware.org
A simple combination of delta-encoding and run_length-encoding is one of the
first schemes we experimented with (32-bit entries with 24-bit 'delta' and an
8-bit 'count'). This gave really good results, but as Sri mentions, we observed
several cases where the relative relocations were not on consecutive offsets.
There were common cases where the relocations applied to alternate words, and
that totally wrecked the scheme (a bunch of entries with delta==16 and
count==1).
I dug up some numbers on how that scheme compared with the current proposal on
the three examples I posted before:
delta+run_length encoding is using 32-bit entries (24-bit delta, 8-bit count).
delta+bitmap encoding is using 64-bit entries (8-bit delta, 56-bit bitmap).
1. Chrome browser (x86_64, built as PIE):
605159 relocation entries (24 bytes each) in '.rela.dyn'
594542 are R_X86_64_RELATIVE relocations (98.25%)
14269008 bytes (13.61MB) in use in '.rela.dyn' section
385420 bytes (0.37MB) using delta+run_length encoding
109256 bytes (0.10MB) using delta+bitmap encoding
2. Go net/http test binary (x86_64, 'go test -buildmode=pie -c net/http')
83810 relocation entries (24 bytes each) in '.rela.dyn'
83804 are R_X86_64_RELATIVE relocations (99.99%)
2011296 bytes (1.92MB) in use in .rela.dyn section
204476 bytes (0.20MB) using delta+run_length encoding
43744 bytes (0.04MB) using delta+bitmap encoding
3. Vim binary in /usr/bin on my workstation (Ubuntu, x86_64)
6680 relocation entries (24 bytes each) in '.rela.dyn'
6272 are R_X86_64_RELATIVE relocations (93.89%)
150528 bytes (0.14MB) in use in .rela.dyn section
14388 bytes (0.01MB) using delta+run_length encoding
1992 bytes (0.00MB) using delta+bitmap encoding
Rahul
On Mon, Dec 11, 2017 at 10:41 AM, Sriraman Tallam <tmsriram@google.com> wrote:
> On Sat, Dec 9, 2017 at 3:06 PM, Florian Weimer <fw@deneb.enyo.de> wrote:
>> * Rahul Chaudhry via gnu-gabi:
>>
>>> The encoding used is a simple combination of delta-encoding and a
>>> bitmap of offsets. The section consists of 64-bit entries: higher
>>> 8-bits contain delta since last offset, and lower 56-bits contain a
>>> bitmap for which words to apply the relocation to. This is best
>>> described by showing the code for decoding the section:
>>>
>>> typedef struct
>>> {
>>> Elf64_Xword r_data; /* jump and bitmap for relative relocations */
>>> } Elf64_Relrz;
>>>
>>> #define ELF64_R_JUMP(val) ((val) >> 56)
>>> #define ELF64_R_BITS(val) ((val) & 0xffffffffffffff)
>>>
>>> #ifdef DO_RELRZ
>>> {
>>> ElfW(Addr) offset = 0;
>>> for (; relative < end; ++relative)
>>> {
>>> ElfW(Addr) jump = ELFW(R_JUMP) (relative->r_data);
>>> ElfW(Addr) bits = ELFW(R_BITS) (relative->r_data);
>>> offset += jump * sizeof(ElfW(Addr));
>>> if (jump == 0)
>>> {
>>> ++relative;
>>> offset = relative->r_data;
>>> }
>>> ElfW(Addr) r_offset = offset;
>>> for (; bits != 0; bits >>= 1)
>>> {
>>> if ((bits&1) != 0)
>>> elf_machine_relrz_relative (l_addr, (void *) (l_addr + r_offset));
>>> r_offset += sizeof(ElfW(Addr));
>>> }
>>> }
>>> }
>>> #endif
>>
>> That data-dependent “if ((bits&1) != 0)” branch looks a bit nasty.
>>
>> Have you investigated whether some sort of RLE-style encoding would be
>> beneficial? If there are blocks of relative relocations, it might even
>> be possible to use vector instructions to process them (although more
>> than four relocations at a time are probably not achievable in a
>> power-efficient manner on current x86-64).
>
> Yes, we originally investigated RLE style encoding but I guess the key
> insight which led us towards the proposed encoding is the following.
> The offset addresses which contain the relocations are close but not
> necessarily contiguous. We experimented with an encoding strategy
> where we would store the initial offset and the number of words after
> that which contained dynamic relocations. This gave us good
> compression numbers but the proposed scheme was way better. I will
> let Rahul say more as he did quite a bit of experiments with different
> strategies.
>
> Thanks
> Sri