cmusatyalab/coda

Reason for clearing CFLAGS poorly documented

Vaelatern opened this issue · 6 comments

In lib-src/rpc2/rp2gen/Makefile.am there is a block of code from commit b7ca288 that goes thus:

# override any cross compilation target flags
CFLAGS=-Wall
LDFLAGS=
LIBS=

The problem is that my build system tries to build everything with position independent binaries (referred to often as building with PIE) to try and increase security. The clearing of CFLAGS in this manner is thus breaking my assertion that all binaries build are position independent.

I just would like to know what the problem is with having any cross compilation target flags in this build, as I would not want to build coda locally without keeping that in mind.

rp2gen needs to run on the build machine to generate the rpc2 stub code.

Thank you! Isn't it also needed by the final installation of coda, on the target machine?

If you treat rpc2 as a standalone library, then yes it would be part of a -devel style package that also contains the headers and static libraries. But in the context of Coda, nothing at runtime needs the rp2gen binary, it is only used during the build, so it doesn't need to get installed on the target machine.

Thank you so much! Are there perhaps any other binaries that are only needed for build time?

That should be the only build-time specific one, there are some obscure binaries that get installed that I've personally never used that I'm not even sure if they still do anything useful, like printvrdb, xfrepair, xaskuser, parser, and inoder.

Thank you for your help