File:  [ELWIX - Embedded LightWeight unIX -] / embedaddon / libxml2 / VxWorks / README
Revision 1.1.1.1 (vendor branch): download - view: text, annotated - select for diffs - revision graph
Tue Feb 21 23:37:58 2012 UTC (13 years, 4 months ago) by misho
Branches: libxml2, MAIN
CVS tags: v2_9_1p0, v2_9_1, v2_8_0p0, v2_8_0, v2_7_8, HEAD
libxml2

    1:              libxml2 on VxWorks 6.4+
    2: 
    3: Here are my instructions for building on VxWorks.... I am very ashamed of
    4: how I did this because it is a complete hack, but it works great, so I
    5: can't complain too much.
    6: 
    7: General Information
    8: 
    9: 1. The only way to build for VxWorks is to cross compile from a windows or
   10: linux system.  We use a RedHat 5.1 workstation system as our build
   11: environment.
   12: 
   13: 2. VxWorks 6.X has two main types of executable, DKMs (dynamic kernel
   14: modules), and RTPs (real-time processes).  Kernel modules are the bread
   15: and butter of VxWorks, but they look nothing like processes/threads in
   16: normal UNIX/Windows systems.  RTPs are more like processes that have
   17: memory protection, threads, etc.  VxWorks 6.X also introduces some level
   18: of POSIX conformance to their environment.  The POSIX conformance was the
   19: key for us to be able to port libxml2.  We support accessing libxml2 from
   20: both DKMs and RTPs.
   21: 
   22: 3. There are 2 compilers for VxWorks, the WindRiver compiler, and a port
   23: of the GNU toolchain, we have only tested and built with the GNU
   24: toolchain.
   25: 
   26: How To Build
   27: 
   28: 1. Run the configure on your native linux system (this is the cheesy
   29: hack).  Since the VxWorks GNU toolchain is very close in version to the
   30: one in red hat, it generates a good config.h file.  We configured libxml2
   31: with the following to keep the size down, (but we have done basic testing
   32: with everything compiled in).
   33: 
   34: ./configure --with-minimum --with-reader --with-writer --with-regexps
   35: --with-threads --with-thread-alloc
   36: 
   37: 2. Rename the libxml2 folder to "src".  This step is required for our
   38: replacement makefile to work.
   39: 
   40: 3. Run the replacement makefile.  I wrote a new makefile that sets all the
   41: proper vxworks defines and uses the correct compilers.  The two defines on
   42: the make command line are to tell it which VxWorks Target (SH3.2 little
   43: endian), and the executable type.  We have tested this code on PENTIUM2gnu
   44: and SH32gnule.
   45: 
   46: This makefile creates a shared library that runs on VxWorks: (libxml2.so)
   47: make -f Makefile.vxworks clean all VXCPU=SH32gnule VXTYPE=RTP
   48: 
   49: This makefile creates a kernel module that runs on VxWorks: (xml2.out)
   50: make -f Makefile.vxworks clean all VXCPU=SH32gnule VXTYPE=DKM
   51: 
   52: Important Notes
   53: 
   54: 1. There are several ways that this process could be improved, but at the
   55: end of the day, we make products, not port libraries, so we did a meets
   56: minimum for our needs.
   57: 
   58: 2. VxWorks is the devil, give me embedded linux every day.
   59: 
   60: 3. No matter what I tried, I couldn't get the configure to pick up the
   61: VxWorks toolchain, and in my investigation, it has something to do with
   62: automake/autoconf, not any individual package.  VxWorks doesn't play by
   63: the normal rules for building toolchains.
   64: 
   65: 4. The PIC flag in VxWorks (especially for SH processors) is very
   66: important, and very troublesome.  On linux, you can liberally use the PIC
   67: flag when compiling and the compiler/linker will ignore it as needed, on
   68: VxWorks if must always be on for shared libraries, and always be off for
   69: static libraries and executables.
   70: 
   71: 5. If anyone wants to work on a better way to do the build of libxml2 for
   72: VxWorks, I'm happy to help as much as I can, but I'm not looking to
   73: support it myself.
   74: 
   75: Attached Files
   76: 
   77: 1. To use my Makefile for vxworks, you should enter the vxworks
   78: environment (/opt/windriver/wrenv.linux -p vxworks-6.4 for me).
   79: 2. Run: build.sh libxml2-2.6.32 SH32gnule RTP (where you have
   80: libxml2-2.6.32.tar.gz and the Makefile in the same directory as the script
   81: file).
   82: 
   83: Thanks,
   84: 
   85: Jim Wert Jr.
   86: JWert@ILSTechnology.com

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>