fpc/rtl/netware
daniel 0c3a2a257d * Convert heap to ptruint.
git-svn-id: trunk@7950 -
2007-07-04 19:46:47 +00:00
..
demos * log and id tags removed 2005-05-21 09:42:41 +00:00
tests * changes for new threadvar support 2003-02-15 19:12:54 +00:00
aio.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
aio.pp * log and id tags removed 2005-05-21 09:42:41 +00:00
audnlm32.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
calnlm32.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
ccs-os.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
ccs.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
classes.pp + revive generics based tfplist/tstringlist implementation for generics testing; build with FPC_TESTGENERICS 2007-03-25 19:19:04 +00:00
clib.imp * added NetWare Alert 2004-12-16 12:42:54 +00:00
clibaux.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
clibctx.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
clxnlm32.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
convertimp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
crt.pp * log and id tags removed 2005-05-21 09:42:41 +00:00
dos.pp * fix from r7819 extended to more platforms 2007-06-26 21:08:37 +00:00
dplsv386.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
dsapi.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
dsevent.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
errno.inc * remove $Log 2005-06-07 09:47:55 +00:00
initc.pp * use ctypes instead of defining own types 2007-01-12 10:56:29 +00:00
keyboard.pp * log and id tags removed 2005-05-21 09:42:41 +00:00
lib0.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
locnlm32.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
Makefile * missing ctypes dependency for initc added 2007-04-01 10:25:20 +00:00
Makefile.fpc * missing ctypes dependency for initc added 2007-04-01 10:25:20 +00:00
mouse.pp * log and id tags removed 2005-05-21 09:42:41 +00:00
ndpsrpc.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
netnlm32.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
netware.pp * log and id tags removed 2005-05-21 09:42:41 +00:00
netwsockh.inc * fix INVALID_SOCKET for other platforms too 2007-05-13 19:20:17 +00:00
nit.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
nlmlib.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
npackoff.inc * remove $Log 2005-06-07 09:47:55 +00:00
npackon.inc * remove $Log 2005-06-07 09:47:55 +00:00
nwcalls.pp * currected some cvs conversion probs 2005-06-02 11:37:02 +00:00
nwnit.pp * currected some cvs conversion probs 2005-06-02 11:37:02 +00:00
nwpre.as initial import 2005-05-16 18:37:41 +00:00
nwpre.pp * log and id tags removed 2005-05-21 09:42:41 +00:00
nwprot.pp * currected some cvs conversion probs 2005-06-02 11:37:02 +00:00
nwpsrv3x.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
nwpsrv.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
nwserv.pp * currected some cvs conversion probs 2005-06-02 11:37:02 +00:00
nwsnut.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
nwsnut.pp * log and id tags removed 2005-05-21 09:42:41 +00:00
nwsock.inc + Restore and fix text/file socket functionality. 2007-01-14 18:50:19 +00:00
nwsys.inc * remove $Log 2005-06-07 09:47:55 +00:00
prelude.as initial import 2005-05-16 18:37:41 +00:00
qos.inc * remove $Log 2005-06-07 09:47:55 +00:00
README * made commandParser more compatible between clib and libc 2004-12-29 13:01:42 +00:00
requestr.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
sockets.pp * synchronized with SocketError change 2007-05-13 20:47:01 +00:00
socklib.imp initial import 2005-05-16 18:37:41 +00:00
streams.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
sysdir.inc * remove $Log 2005-06-07 09:47:55 +00:00
sysfile.inc * remove $Log 2005-06-07 09:47:55 +00:00
sysheap.inc * Convert heap to ptruint. 2007-07-04 19:46:47 +00:00
sysos.inc * remove $Log 2005-06-07 09:47:55 +00:00
sysosh.inc * remove $Log 2005-06-07 09:47:55 +00:00
system.pp * removed initfpu 2006-11-09 07:48:31 +00:00
systhrd.inc + heap manager now per thread, reduce heap lock contention 2007-05-20 20:58:12 +00:00
sysutils.pp * use __get_errno_ptr to implement GetLastOSError 2007-06-05 09:36:05 +00:00
threads.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
tli.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
tthread.inc * fixed leaking of TThread 2006-05-14 09:15:09 +00:00
unicode.imp initial import 2005-05-16 18:37:41 +00:00
varutils.pp * log and id tags removed 2005-05-21 09:42:41 +00:00
video.pp * log and id tags removed 2005-05-21 09:42:41 +00:00
vollib.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
winsock.pp * log and id tags removed 2005-05-21 09:42:41 +00:00
ws2_32.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00
ws2nlm.imp * moved rtl/netware/nwimp/*.imp to rtl/netware 2004-08-13 19:57:44 +00:00

    General
    =======

    Currently generating NetWare-NLM's only work under Linux and win32. (may work under other
    unix versions also but this is not tested yet)


    Binutils with netware-support needed
    ====================================

    You need a version of binutils compiled with netware-support. As of FreePascal 1.9.5 Nov 2004
    binutils needs to be named i386-netware-* (i.e. i386-netware-ld, i386-netware-nlmconv).
    Unfortunately in the Linux distibutions this component of the binutils is not included
    so you have to compile it. So download the latest stable binutils package from your
    favourite GNU mirror, decompress it ('tar xfz binutils-x.yy.z.tar.gz' on unices
    with GNU tar), change to the binutils-x.yy.z directory and configure:

      ./configure --prefix=/usr --enable-shared --enable-target=i386-netware

    I used the prefix /usr because thats the default location on redhat (thats what I'm using)

    and use

      make
      make install

    to build and install binutils. To check that netware is supported by the version of binutils
    installed, use i386-netware-ld --version. The emulation 'i386nw' must be present. Also check that 
    i386-netware-nlmconv
    is present and can be started without specifying the complete path of i386-netware-nlmconv.

    You can find more information and a binary version of binutils with netware-support for
    linux on:
           http://home.sch.bme.hu/~keresztg/novell/howto/NLM-Linux-HOWTO.html.

    Binutils for win32 and Fedora Core 2 are available from:
           ftp://ftp.freepascal.org/pub/fpc/contrib/cross
	  

    Building the freepascal runtime-library for netware
    ===================================================

    Install the current fpc sources from ftp.freepascal.org and change to the directory
    rtl/netware under the freepascal sourcetree. Verify the path of your units in
    Makefile. The default is /usr/lib/fpc/1.9.5/units/i386-netware/*.
    Compile and install the rtl with

      make install
      
    This will install the basic rtl files. To install all (packages,fcl and nlm's) do a
    
    make OS_TARGET=netware build
    
    and
    
    make OS_TARGET=netware install
    
    at the fpc source root dir.
    

    Settings and needed files to compile for netware
    ================================================

    Edit your /etc/fpc.cfg and add the rtl source path for netware. This are my settings,
    you may paste it to your fpc.cfg:

#IFDEF Netware_clib
  -Fu/usr/lib/fpc/1.9.5/units/i386-netware/*
  -Fl/usr/lib/fpc/1.9.5/units/i386-netware/rtl
#ENDIF

#IFDEF Netware_libc
  -Fu/usr/lib/fpc/1.9.5/units/i386-netwlibc/*
  -Fl/usr/lib/fpc/1.9.5/units/i386-netwlibc/rtl
  -XPi386-netware-
#ENDIF

    This adds the search path for the rtl-units as well as for the needed import-files.
    You can use the import files from the rtl/netware directory, they are automaticly
    installed. If you want to use import files from novell, be aware that you have to
    convert the files to unix format (i.e. with dos2unix).

    Building the first nlm
    ======================

    Ok, now you have installed all needed files, try the following program and compile it
    with

      ppc386 -Tnetware hello.pas

    PROGRAM Hello;
    {$Description The FreePascal HelloWorld for Netware}
    {$Version 1.0.0}
    {$Copyright Copyright (c) 2001 The FreePascal Development Team}
    {$Screenname FPC Hello World for Netware}

    BEGIN
      WriteLn ('This is open source, FreePascal for netware');
    END.

    Hints on using freepascal for nlm's
    ===================================

    - Compiler Switches for Netware
      -----------------------------
      The following compiler-swiches are supported for NetWare:
      $DESCRIPTION    : NLM-Description, will be displayed at load-time
      $M              : For Stack-Size. Heap-Size will be ignored
      $VERSION x.x.x  : Sets Major, Minor and Revision, Revision 0 is nothing, 1=a, 2=b ...
      $COPYRIGHT      : Sets Copyright, needs a patched nlmconv, patch is
                        available at the location for binutils-win32 shown
                        above.
      $SCREENNAME     : Sets the screen-name (i.e. shown in ctrl-esc screen)
                        $SCREENNAME DEFAULT : output to logger screen
			$SCREENNAME NONE    : no output at all (do not use this, writeln,
			                      even from a runtime error may crash the sever)
			$SCREENNAME MyScreen: Name the screen "MyScreen"
      $THREADNAME     : Sets the thread name (dont use names that are to long
                        for netware, that will prevent your nlm from loading)

    - Exports
      -------

      Exports will be handled like in win32:
      procedure bla; CDECL; EXPORT;
      begin
      end;

      exports bla name 'bla';

      Be aware that without Name 'bla' this will be exported in upper-case.

    - Netware import (.imp) files
      ---------------------------

      Import files are needed by nlmconv as with other netware linkers. FreePascal is
      searching import files via the specified library path (-Fl). If you plan to use
      import files from novell be aware that they have to be converted from CR/LF to
      LF only. The script 'convertimp' in rtl/netware/nwimp will do that.
      If a module name is specified in an import, the module is automaticly
      declared as autoload by FreePascal.

      I.e. the following declaration needs nlmlib.imp and sets nlmlib.nlm as autoload:

        FUNCTION rmdir (path : PCHAR) : LONGINT; CDECL; EXTERNAL 'nlmlib.nlm' NAME 'rmdir';

      while the following declaration only imports the symbol without autoloading:

        FUNCTION rmdir (path : PCHAR) : LONGINT; CDECL; EXTERNAL;

      If nlmlib.nlm is not loaded while loading your nlm, you will get an error about
      unknown symbols.


    - Debugging
      ---------

      Debugging is possible with gdb on Netware 4.11, 5, 6 and 6.5.
      See http://home.arcor.de/armin.diehl/fpcnw/gdbnw.html for details
      

    - Netware SDK
      -----------

      Delphi declarations for the multiplattform api is available at
      http://developer.novell.com. You can download the sdk after registering
      as a developer.
      The files are designed for win32 so they will not work off the box.
      I think changing the dll-name to the corrosponding nlm-name will work.
      i.e. in calwin32.imp the following declaration:

        function NWAbortServicingQueueJob2;  StdCall; external 'calwin32.dll' index 231;

       has to be changed to

        function NWAbortServicingQueueJob2;  CDecl; external 'calwin32.nlm';

armin@freepascal.org