On Mon, Aug 17, 2020 at 10:38 AM Gary Bisson <gary.bisson@xxxxxxxxxxxxxxxxxxx> wrote: > > Hi, > > On Mon, Aug 10, 2020 at 09:51:07PM +0200, Bartosz Golaszewski wrote: > > On Mon, Jun 8, 2020 at 11:07 AM Gary Bisson > > <gary.bisson@xxxxxxxxxxxxxxxxxxx> wrote: > > > > > > - Defines both shared and static versions of libgpiod > > > - Defines all the libs/tools as vendor (installed in /vendor) > > > > > > Signed-off-by: Gary Bisson <gary.bisson@xxxxxxxxxxxxxxxxxxx> > > > --- > > > Hi, > > > > > > One thing that isn't ideal here is to set GPIOD_VERSION_STR manually, > > > that will require to keep track of it for all versions. > > > > > > Not sure if there's a better way to provide that value to Android.bp. > > > > > > > I don't know Android very well but if its build system can launch > > autotools, then maybe you could autotoolify this file by providing > > Android.bp.in and letting autotools expand this macro? > > No unfortunately that is not how the AOSP build system works (or at > least I'm not aware of it). > AFAIK all the open-source projects used in AOSP (see external/ folder) > have a separate Android.bp alongside the autotools files. > > Here are a few examples of Android.bp files added by Google to > well-known projects: > - curl [1] > - iputils [2] > - strace [3] > > In the case above it is up to Google to maintain that file as only > hosted on their servers (not merged upstream). > But some other projects are ok merging it which makes it easier (at > least for me) like can-utils [4]. > I'm perfectly fine with merging this file but I don't like having another place to look at when bumping the version number. I bunched up all API and ABI versions together in configure.ac in order to not forget anything when making new releases. I'm sure Android's build system is not as limited as not to allow to run some external scripts that would at least fetch the current version from configure.ac, is it? > > > Regards, > > > Gary > > > --- > > > Android.bp | 95 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ > > > 1 file changed, 95 insertions(+) > > > create mode 100644 Android.bp > > > > > > diff --git a/Android.bp b/Android.bp > > > new file mode 100644 > > > index 0000000..6c437df > > > --- /dev/null > > > +++ b/Android.bp > > > @@ -0,0 +1,95 @@ > > > +cc_library_shared { > > > + name: "libgpiod", > > > + vendor: true, > > > + srcs: [ > > > + "lib/core.c", > > > + "lib/ctxless.c", > > > + "lib/helpers.c", > > > + "lib/iter.c", > > > + "lib/misc.c", > > > + ], > > > + cflags: ["-Werror", "-Wno-macro-redefined", "-DGPIOD_VERSION_STR=\"1.6-devel\""], > > > + export_include_dirs: ["include"], > > > + local_include_dirs: ["include"], > > > +} > > > + > > > +cc_library_static { > > > + name: "libgpiod_static", > > > + vendor: true, > > > + srcs: [ > > > + "lib/core.c", > > > + "lib/ctxless.c", > > > + "lib/helpers.c", > > > + "lib/iter.c", > > > + "lib/misc.c", > > > + ], > > > + cflags: ["-Werror", "-Wno-macro-redefined", "-DGPIOD_VERSION_STR=\"1.6-devel\""], > > > + export_include_dirs: ["include"], > > > + local_include_dirs: ["include"], > > > +} > > > + > > > +cc_binary { > > > + name: "gpiodetect", > > > + vendor: true, > > > + srcs: [ > > > + "tools/tools-common.c", > > > + "tools/gpiodetect.c", > > > + ], > > > + shared_libs: ["libgpiod"], > > > + cflags: ["-Werror"], > > > +} > > > + > > > +cc_binary { > > > + name: "gpiofind", > > > + vendor: true, > > > + srcs: [ > > > + "tools/tools-common.c", > > > + "tools/gpiofind.c", > > > + ], > > > + shared_libs: ["libgpiod"], > > > + cflags: ["-Werror"], > > > +} > > > + > > > +cc_binary { > > > + name: "gpioget", > > > + vendor: true, > > > + srcs: [ > > > + "tools/tools-common.c", > > > + "tools/gpioget.c", > > > + ], > > > + shared_libs: ["libgpiod"], > > > + cflags: ["-Werror"], > > > +} > > > + > > > +cc_binary { > > > + name: "gpioinfo", > > > + vendor: true, > > > + srcs: [ > > > + "tools/tools-common.c", > > > + "tools/gpioinfo.c", > > > + ], > > > + shared_libs: ["libgpiod"], > > > + cflags: ["-Werror"], > > > +} > > > + > > > +cc_binary { > > > + name: "gpiomon", > > > + vendor: true, > > > + srcs: [ > > > + "tools/tools-common.c", > > > + "tools/gpiomon.c", > > > + ], > > > + shared_libs: ["libgpiod"], > > > + cflags: ["-Werror"], > > > +} > > > + > > > +cc_binary { > > > + name: "gpioset", > > > + vendor: true, > > > + srcs: [ > > > + "tools/tools-common.c", > > > + "tools/gpioset.c", > > > + ], > > > + shared_libs: ["libgpiod"], > > > + cflags: ["-Werror"], > > > +} > > > -- > > > 2.26.2 > > > > > > > Can I somehow test this build file on linux? We'll surely be expanding > > libgpiod in the future so I need to be able to update this file. > > I'm not sure what's the easiest way to get you a build env. > In my case I use the full AOSP tree [5][6] which might not be ideal for > you as it involves pulling 40G+ of data. > For me the commands were: > $ source build/envsetup.sh > $ lunch aosp_arm-eng > $ mmm external/libgpiod > > Maybe someone else has a way to setup a Soong build without pulling > everything. > > Let me know if you have any questions. > > Regards, > Gary > > [1] https://android.googlesource.com/platform/external/curl/+/refs/heads/master/Android.bp > [2] https://android.googlesource.com/platform/external/iputils/+/refs/heads/master/Android.bp > [3] https://android.googlesource.com/platform/external/strace/+/refs/heads/master/Android.bp > [4] https://github.com/linux-can/can-utils/blob/master/Android.mk > [5] https://source.android.com/setup/build/downloading > [6] https://source.android.com/setup/build/building Thanks for the links. I have access to a build server so at least for now I can fetch the whole tree alright. Bartosz