Build system / win32
Phil Mayers
p.mayers at imperial.ac.uk
Sun Jun 26 10:56:05 CEST 2011
On 06/26/2011 08:47 AM, Alan DeKok wrote:
>
> See the existing source code, "master" branch. There's a lot of
> "ifdef WIN32" there already. It's been building under MingW for over a
> year, and getting as far as "radiusd -v".
Ah, I was using "master", and wondered where those had come from. Are
you building it directly under windows with msys, rather than
cross-compiling? I had to do a fair bit of fiddling to get the latter
working (although that could be my environment)
>> The main reason seems to be the build system; If you have a fully
>> autoconf/automake and libtool-ised source base, the cross-compile seems
>> to work this all out for you, but in the case of FreeRADIUS there seem
>> to be a mix - autoconf is used, but automake isn't and the libtool stuff
>> seems to be hand-crafted to work around the various bugs it's had?
>
> "automake" is a waste of time. It does nothing special. libtool
> *should* be capable of building windows libraries. I don't think
> there's any special magic required.
Again it could be the fact I'm trying to cross-compile (Windows is so
terrible that I don't have the stomach to actually build on it).
libtool can certainly generate DLLs even under cross-compilation; I made
a fake project with a similar structure (src/main, src/lib, src/modules)
and got it to build src/lib as a DLL and src/main as an .exe. But I did
that by following an example that used autoconf and automake, which
meant I couldn't trivially compare the resulting build rules with what
was implemented in FreeRADIUS :o(
>
>> Before I spend any more time on this - what's the future of the build
>> system? I'm only passingly familiar with autotools, but if we want to
>> keep it, I'm happy to take a look?
>
> I've been looking at getting rid of libtool and libltdl. See commits
> in the "master" branch. It currently does a static build, but doesn't
> do .so's, or .dll's. Still, a non-libtool build will be optional until
> such time as it's widely tested.
So your intention is to remove libtool completely, and instead use rules
in Make.inc to build .so/.dll directly? In which case it makes no sense
to look at libtool any further, and I'll drop it.
FWIW I wrote a quick LoadLibrary/GetProcAddress -> dlopen/dlsym wrapper
the other day, and that works fine; let me know if you want the code.
One thing I can't remember is, under windows, if a .dll can import
symbols from the .exe that loads it. I have a feeling it cannot, which
would necessitate making radiusd a tiny stub .exe ;o(
Hopefully I'm wrong!
>
>> If on the other hand the desire is to junk it (and in particular
>> libtool) then there's no point spending any time on it, and I'll try a
>> different approach (possibly a hand-crafted makefile.mingw32)
>
> All it should take is some DLL-specific build rules. Much of that is
> already abstracted in the build system.
Ok. Do you want someone to look at this, or do you have it in-hand?
>
> And even if the DLLs build, the socket code has to be fixed. And
> after that, making it run as a service, and then using the Windows event
> log, etc.
Indeed.
More information about the Freeradius-Devel
mailing list