[llvm-objcopy] Add --only-keep-debug as a noop
authorJake Ehrlich <jakehehrlich@google.com>
Tue, 15 May 2018 20:53:53 +0000 (20:53 +0000)
committerJake Ehrlich <jakehehrlich@google.com>
Tue, 15 May 2018 20:53:53 +0000 (20:53 +0000)
commite40398ad98d2de236ea40b4bbf79f23f4d812dda
tree7ced9f6ac909ab87cd6c51512457fb7f26def3e7
parent8d522d811a6d8ec72b10dbd76ba670678bc4251b
[llvm-objcopy] Add --only-keep-debug as a noop

This option just keeps being a problem and really needs to be implemented
in some fashion. Implementing it properly requires some kind of
"replaceSectionReference" method because all the existing links need to be
maintained. The desired behavior is just for allocated sections to become
NOBITS but actually implementing that is rather tricky due to the current
design of llvm-objcopy. However converting allocated sections to NOBITS is
just an optimization and not something debuggers need. Debuggers can debug
a stripped executable and take an unstripped executable for that stripped
executable as input. Additionally allocated sections account for a very
small part of debug binaries so this optimization is quite small. I propose
that for the time being we implement this as a NOP so that people can use
llvm-objcopy where they need to, just in a sub-optimal way.

This option has already blocked a lot of people and its currently blocking me.

llvm-svn: 332396
llvm/test/tools/llvm-objcopy/basic-only-keep-debug.test [new file with mode: 0644]
llvm/tools/llvm-objcopy/ObjcopyOpts.td
llvm/tools/llvm-objcopy/llvm-objcopy.cpp