Re: COMMENTS: building git on AIX

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

Michael Felt wrote:

> I have, a couple of time, successfully built git for AIX. However, my
> prior attempt (version 2.18) - I never got around to finishing and today
> with version 2.23.0 - I am unsure how to proceed without a lot of hacking.
>
> Just some comments - long long way from calling anything a bug - just
> not as portable as I would have hoped.
>
> The simple issues:
>
> 1. The "Makefile" is surprising. I expect to run ./configure (or better,
> out-of tree, e.g., ../src/git-2.23.0/configure). Just running OOT
> configure does not result in a "Makefile". So, copy source tree to dest
> and try again.

See INSTALL:

 [...]
 Alternatively you can use autoconf generated ./configure script to
 set up install paths (via config.mak.autogen), so you can write instead

so the output of the configure script is a config.mak.autogen file.
Keep in mind that most of Git's developers don't use the configure
script, mostly because it's slow.

I like the idea of teaching the configure script to set up a VPATH
build.  Would you be interested in working on that?

> 2. Makefile assumes gmake. Standard make does not support :: syntax
> (fix: install cmake)

I assume that by cmake you mean gmake here.

> 3. The default CFLAGS contains -Wall. Not all compilers support -Wall.
> "Fixed" by adding CFLAGS="-g -O2". I am also undecided on having -g as a
> default flag.

Interesting!  That doesn't feel like a recent change:

 $ git log -GWall -- Makefile
[...]
 commit b05701c5b4c7983ef04d8c286c65089596553bd6
 Author: Pavel Roskin <proski@xxxxxxx>
 Date:   Sat Aug 6 01:36:15 2005 -0400

     Make CFLAGS overridable from make command line.
[...]
 commit 19b2860cba5742ab31fd682b80fefefac19be141
 Author: Linus Torvalds <torvalds@xxxxxxxxxxxxxxxxxxxx>
 Date:   Fri Apr 8 09:59:28 2005 -0700

     Use "-Wall -O2" for the compiler to get more warnings.

It seems worth calling out in the INSTALL file (and autodetecting in
the configure script).

> 4. Must have gettext installed, which needs GNU libiconv - sad to have
> these libraries as additional dependencies. e.g., bash 4.4 finally
> removed the gettext and iconv gnu dependencies. -- FYI!

See INSTALL:

 Set NO_GETTEXT to disable localization support and make Git only
 use English. Under autoconf the configure script will do this
 automatically if it can't find libintl on the system.

Did the part of the configure script that does this break?

> 5. Another "gcc"? dependency: "git-compat-util.h", line 361.1: 1506-277
> (S) Syntax error: possible missing ';'
> FIX: add 'CC=xlc_r' to get language extensions

That's

 static inline int noop_core_config(const char *var, const char *value, void *cb)

Does AIX cc have trouble with "static inline"?

> 6. Needs curl (libcurl and curl.h), but does not check until much later:
> FIX install curl; FIX2 add -I flag to find $prefix/include to CFLAGS
> (.e.g., CFLAGS="-g -O2 -I/opt/include") - FYI GNU autotools also fail to
> include $prefix/include

>From INSTALL:

  "libcurl" library is used by git-http-fetch, git-fetch, and, if
  the curl version >= 7.34.0, for git-imap-send.  You might also
  want the "curl" executable for debugging purposes. If you do not
  use http:// or https:// repositories, and do not want to put
  patches into an IMAP mailbox, you do not have to have them
  (use NO_CURL).

Would you be interested in improving the configure script's detection
of this?

> 7. More stuck here. libssh2 is built by curl, but as a static library. I
> could "hack" the libssh2.o file into the linkage, but unclear how well
> that will work. Also wonder if libssh2 is "required" or optional. For
> curl it has been optional (and I think it still is).
[...]
> git-imap-send   imap-send.o http.o common-main.o \
>           -L/opt/lib -lcurl -lssh2 -lssh2 -lssl -lcrypto -lldap -llber
> -lssl -lcrypto -lz  -lssl  -lcrypto libgit.a xdiff/lib.a  -lz  -liconv
> -lintl -lpthread
> ld: 0706-006 Cannot find or open library file: -l ssh2

The "-lssh2" comes from "curl-config --libs" output.  It sounds like
your copy of $(which curl-config) should have CURLLIBDIR set but
doesn't.  Should we use "curl-config --static-libs" on AIX instead?

If you know what flags to use to link to curl, you can use
CURL_LDFLAGS to set that instead.

> Not sure - if I can help - but do hope this already helps in a (small) way.

Thanks for working to keep Git portable.

Hope that helps,
Jonathan



[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux