Build ntdll as a real dll, including everything that was previously in
libwine.so. Created a new (mostly empty) libwine.so in library/ subdir.

diff --git a/library/port.c b/library/port.c
new file mode 100644
index 0000000..a23711a
--- /dev/null
+++ b/library/port.c
@@ -0,0 +1,341 @@
+/*
+ * Misc. functions for systems that don't have them
+ *
+ * Copyright 1996 Alexandre Julliard
+ */
+
+#include "config.h"
+
+#ifdef __BEOS__
+#include <be/kernel/fs_info.h>
+#include <be/kernel/OS.h>
+#endif
+
+#include <assert.h>
+#include <ctype.h>
+#include <stdio.h>
+#include <string.h>
+#include <unistd.h>
+#include <sys/types.h>
+#include <sys/time.h>
+#include <sys/stat.h>
+#include <sys/ioctl.h>
+#include <errno.h>
+#include <fcntl.h>
+#include <termios.h>
+#ifdef HAVE_LIBIO_H
+# include <libio.h>
+#endif
+#ifdef HAVE_SYSCALL_H
+# include <syscall.h>
+#endif
+#ifdef HAVE_PTY_H
+# include <pty.h>
+#endif
+#ifdef HAVE_LIBUTIL_H
+# include <libutil.h>
+#endif
+
+#include "wine/port.h"
+
+/***********************************************************************
+ *		usleep
+ */
+#ifndef HAVE_USLEEP
+unsigned int usleep (unsigned int useconds)
+{
+#if defined(__EMX__)
+    DosSleep(useconds);
+    return 0;
+#elif defined(__BEOS__)
+    return snooze(useconds);
+#elif defined(HAVE_SELECT)
+    struct timeval delay;
+
+    delay.tv_sec = useconds / 1000000;
+    delay.tv_usec = useconds % 1000000;
+
+    select( 0, 0, 0, 0, &delay );
+    return 0;
+#else /* defined(__EMX__) || defined(__BEOS__) || defined(HAVE_SELECT) */
+    errno = ENOSYS;
+    return -1;
+#endif /* defined(__EMX__) || defined(__BEOS__) || defined(HAVE_SELECT) */
+}
+#endif /* HAVE_USLEEP */
+
+/***********************************************************************
+ *		memmove
+ */
+#ifndef HAVE_MEMMOVE
+void *memmove( void *dest, const void *src, unsigned int len )
+{
+    register char *dst = dest;
+
+    /* Use memcpy if not overlapping */
+    if ((dst + len <= (char *)src) || ((char *)src + len <= dst))
+    {
+        memcpy( dst, src, len );
+    }
+    /* Otherwise do it the hard way (FIXME: could do better than this) */
+    else if (dst < src)
+    {
+        while (len--) *dst++ = *((char *)src)++;
+    }
+    else
+    {
+        dst += len - 1;
+        src = (char *)src + len - 1;
+        while (len--) *dst-- = *((char *)src)--;
+    }
+    return dest;
+}
+#endif  /* HAVE_MEMMOVE */
+
+/***********************************************************************
+ *		strerror
+ */
+#ifndef HAVE_STRERROR
+const char *strerror( int err )
+{
+    /* Let's hope we have sys_errlist then */
+    return sys_errlist[err];
+}
+#endif  /* HAVE_STRERROR */
+
+/***********************************************************************
+ *		clone
+ */
+#if !defined(HAVE_CLONE) && defined(__linux__)
+int clone( int (*fn)(void *), void *stack, int flags, void *arg )
+{
+#ifdef __i386__
+    int ret;
+    void **stack_ptr = (void **)stack;
+    *--stack_ptr = arg;  /* Push argument on stack */
+    *--stack_ptr = fn;   /* Push function pointer (popped into ebx) */
+    __asm__ __volatile__( "pushl %%ebx\n\t"
+                          "movl %2,%%ebx\n\t"
+                          "int $0x80\n\t"
+                          "popl %%ebx\n\t"   /* Contains fn in the child */
+                          "testl %%eax,%%eax\n\t"
+                          "jnz 0f\n\t"
+                          "call *%%ebx\n\t"       /* Should never return */
+                          "xorl %%eax,%%eax\n\t"  /* Just in case it does*/
+                          "0:"
+                          : "=a" (ret)
+                          : "0" (SYS_clone), "r" (flags), "c" (stack_ptr) );
+    assert( ret );  /* If ret is 0, we returned from the child function */
+    if (ret > 0) return ret;
+    errno = -ret;
+    return -1;
+#else
+    errno = EINVAL;
+    return -1;
+#endif  /* __i386__ */
+}
+#endif  /* !HAVE_CLONE && __linux__ */
+
+/***********************************************************************
+ *		strcasecmp
+ */
+#ifndef HAVE_STRCASECMP
+int strcasecmp( const char *str1, const char *str2 )
+{
+    while (*str1 && toupper(*str1) == toupper(*str2)) { str1++; str2++; }
+    return toupper(*str1) - toupper(*str2);
+}
+#endif /* HAVE_STRCASECMP */
+
+/***********************************************************************
+ *		strncasecmp
+ */
+#ifndef HAVE_STRNCASECMP
+int strncasecmp( const char *str1, const char *str2, size_t n )
+{
+    int res;
+    if (!n) return 0;
+    while ((--n > 0) && *str1)
+      if ((res = toupper(*str1++) - toupper(*str2++))) return res;
+    return toupper(*str1) - toupper(*str2);
+}
+#endif /* HAVE_STRNCASECMP */
+
+/***********************************************************************
+ *		wine_openpty
+ * NOTE
+ *   It looks like the openpty that comes with glibc in RedHat 5.0
+ *   is buggy (second call returns what looks like a dup of 0 and 1
+ *   instead of a new pty), this is a generic replacement.
+ *
+ * FIXME
+ *   We should have a autoconf check for this.
+ */
+int wine_openpty(int *master, int *slave, char *name,
+                 struct termios *term, struct winsize *winsize)
+{
+#ifdef HAVE_OPENPTY
+    return openpty(master,slave,name,term,winsize);
+#else
+    char *ptr1, *ptr2;
+    char pts_name[512];
+
+    strcpy (pts_name, "/dev/ptyXY");
+
+    for (ptr1 = "pqrstuvwxyzPQRST"; *ptr1 != 0; ptr1++) {
+        pts_name[8] = *ptr1;
+        for (ptr2 = "0123456789abcdef"; *ptr2 != 0; ptr2++) {
+            pts_name[9] = *ptr2;
+
+            if ((*master = open(pts_name, O_RDWR)) < 0) {
+                if (errno == ENOENT)
+                    return -1;
+                else
+                    continue;
+            }
+            pts_name[5] = 't';
+            if ((*slave = open(pts_name, O_RDWR)) < 0) {
+                pts_name[5] = 'p';
+                continue;
+            }
+
+            if (term != NULL)
+                tcsetattr(*slave, TCSANOW, term);
+            if (winsize != NULL)
+                ioctl(*slave, TIOCSWINSZ, winsize);
+            if (name != NULL)
+                strcpy(name, pts_name);
+            return *slave;
+        }
+    }
+    return -1;
+#endif
+}
+
+/***********************************************************************
+ *		getnetbyaddr
+ */
+#ifndef HAVE_GETNETBYADDR
+struct netent *getnetbyaddr(unsigned long net, int type)
+{
+    errno = ENOSYS;
+    return NULL;
+}
+#endif /* defined(HAVE_GETNETBYNAME) */
+
+/***********************************************************************
+ *		getnetbyname
+ */
+#ifndef HAVE_GETNETBYNAME
+struct netent *getnetbyname(const char *name)
+{
+    errno = ENOSYS;
+    return NULL;
+}
+#endif /* defined(HAVE_GETNETBYNAME) */
+
+/***********************************************************************
+ *		getprotobyname
+ */
+#ifndef HAVE_GETPROTOBYNAME
+struct protoent *getprotobyname(const char *name)
+{
+    errno = ENOSYS;
+    return NULL;
+}
+#endif /* !defined(HAVE_GETPROTOBYNAME) */
+
+/***********************************************************************
+ *		getprotobynumber
+ */
+#ifndef HAVE_GETPROTOBYNUMBER
+struct protoent *getprotobynumber(int proto)
+{
+    errno = ENOSYS;
+    return NULL;
+}
+#endif /* !defined(HAVE_GETPROTOBYNUMBER) */
+
+/***********************************************************************
+ *		getservbyport
+ */
+#ifndef HAVE_GETSERVBYPORT
+struct servent *getservbyport(int port, const char *proto)
+{
+    errno = ENOSYS;
+    return NULL;
+}
+#endif /* !defined(HAVE_GETSERVBYPORT) */
+
+/***********************************************************************
+ *		getsockopt
+ */
+#ifndef HAVE_GETSOCKOPT
+int getsockopt(int socket, int level, int option_name,
+               void *option_value, size_t *option_len)
+{
+    errno = ENOSYS;
+    return -1;
+}
+#endif /* !defined(HAVE_GETSOCKOPT) */
+
+/***********************************************************************
+ *		inet_network
+ */
+#ifndef HAVE_INET_NETWORK
+unsigned long inet_network(const char *cp)
+{
+    errno = ENOSYS;
+    return 0;
+}
+#endif /* defined(HAVE_INET_NETWORK) */
+
+/***********************************************************************
+ *		settimeofday
+ */
+#ifndef HAVE_SETTIMEOFDAY
+int settimeofday(struct timeval *tp, void *reserved)
+{
+    tp->tv_sec = 0;
+    tp->tv_usec = 0;
+
+    errno = ENOSYS;
+    return -1;
+}
+#endif /* HAVE_SETTIMEOFDAY */
+
+/***********************************************************************
+ *		statfs
+ */
+#ifndef HAVE_STATFS
+int statfs(const char *name, struct statfs *info)
+{
+#ifdef __BEOS__
+    dev_t mydev;
+    fs_info fsinfo;
+
+    if(!info) {
+        errno = ENOSYS;
+        return -1;
+    }
+
+    if ((mydev = dev_for_path(name)) < 0) {
+        errno = ENOSYS;
+        return -1;
+    }
+
+    if (fs_stat_dev(mydev,&fsinfo) < 0) {
+        errno = ENOSYS;
+        return -1;
+    }
+
+    info->f_bsize = fsinfo.block_size;
+    info->f_blocks = fsinfo.total_blocks;
+    info->f_bfree = fsinfo.free_blocks;
+    return 0;
+#else /* defined(__BEOS__) */
+    errno = ENOSYS;
+    return -1;
+#endif /* defined(__BEOS__) */
+}
+#endif /* !defined(HAVE_STATFS) */