Alexandre Julliard | 3a5816f | 1994-12-27 14:11:53 +0000 | [diff] [blame] | 1 | 1. INTRODUCTION |
Alexandre Julliard | 2c25c3e | 1993-06-29 16:33:12 +0000 | [diff] [blame] | 2 | |
Douglas Ridgway | 692389d | 1998-11-22 16:56:44 +0000 | [diff] [blame] | 3 | Wine is a program which allows running Microsoft Windows programs |
| 4 | (including DOS, Windows 3.x and Win32 executables) on Unix. It |
James Juran | 0ff60a0 | 1999-04-26 14:57:06 +0000 | [diff] [blame] | 5 | consists of a program loader which loads and executes a Microsoft |
Douglas Ridgway | 692389d | 1998-11-22 16:56:44 +0000 | [diff] [blame] | 6 | Windows binary, and a library that implements Windows API calls using |
| 7 | their Unix or X11 equivalents. The library may also be used for |
| 8 | porting Win32 code into native Unix executables. |
Alexandre Julliard | 8d24ae6 | 1994-04-05 21:42:43 +0000 | [diff] [blame] | 9 | |
Douglas Ridgway | 692389d | 1998-11-22 16:56:44 +0000 | [diff] [blame] | 10 | Wine is free software, and its license (contained in the file LICENSE) |
| 11 | is BSD style. Basically, you can do anything with it except claim |
| 12 | that you wrote it. |
Alexandre Julliard | 1f57929 | 1994-05-25 16:25:21 +0000 | [diff] [blame] | 13 | |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 14 | 2. QUICK START |
Alexandre Julliard | 3a5816f | 1994-12-27 14:11:53 +0000 | [diff] [blame] | 15 | |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 16 | For the impatient, use the Wine Installer to build and install wine. |
| 17 | From the top-level Wine directory (which contains this file), run: |
| 18 | |
| 19 | ./tools/wineinstall |
| 20 | |
| 21 | Run programs as "wine [options] program". For more information and |
| 22 | problem resolution, read the rest of this file, the Wine manpage, |
| 23 | and the files in the documentation directory in the Wine source. |
| 24 | |
| 25 | 3. REQUIREMENTS |
Alexandre Julliard | 401710d | 1993-09-04 10:09:32 +0000 | [diff] [blame] | 26 | |
James Juran | 0ff60a0 | 1999-04-26 14:57:06 +0000 | [diff] [blame] | 27 | To compile and run Wine, you must have one of the following: |
Alexandre Julliard | f41aeca | 1993-09-14 16:47:10 +0000 | [diff] [blame] | 28 | |
Marcus Meissner | 9e15318 | 1999-04-19 16:19:25 +0000 | [diff] [blame] | 29 | Linux version 2.0.36 or above |
| 30 | FreeBSD-current or FreeBSD 3.0 or later |
Alexandre Julliard | a69b88b | 1998-03-15 20:29:56 +0000 | [diff] [blame] | 31 | Solaris x86 2.5 or later |
Alexandre Julliard | f41aeca | 1993-09-14 16:47:10 +0000 | [diff] [blame] | 32 | |
James Juran | 0ff60a0 | 1999-04-26 14:57:06 +0000 | [diff] [blame] | 33 | Although Linux version 2.0.x will mostly work, certain features |
| 34 | (specifically LDT sharing) required for properly supporting Win32 |
| 35 | threads were not implemented until kernel version 2.2. If you get |
| 36 | consistent thread-related crashes, you may want to upgrade to 2.2. |
Alexandre Julliard | 6abb89c | 1995-03-02 17:33:47 +0000 | [diff] [blame] | 37 | |
Juergen Lock | ca85139 | 1999-11-28 19:48:24 +0000 | [diff] [blame] | 38 | Similarly if you are on FreeBSD you may want to apply an LDT sharing |
Juergen Lock | 51721ff | 1999-12-20 03:54:43 +0000 | [diff] [blame] | 39 | patch too (unless you are tracking -current where it finally has |
| 40 | been committed just recently), and there also is a small sigtrap |
| 41 | fix thats needed for wine's debugger. (Actually now that its using |
| 42 | ptrace() by default it may no longer make a difference but it still |
| 43 | doesn't hurt...) And if you're running a system from the -stable |
| 44 | branch older than Nov 15 1999, like a 3.3-RELEASE, then you also |
| 45 | need to apply a signal handling change that was MFC'd at that date. |
| 46 | More information including patches for the -stable branch is in |
| 47 | the ports tree: |
Juergen Lock | ca85139 | 1999-11-28 19:48:24 +0000 | [diff] [blame] | 48 | ftp://ftp.freebsd.org/pub/FreeBSD/FreeBSD-current/ports/emulators/wine/files/ |
Juergen Lock | ca85139 | 1999-11-28 19:48:24 +0000 | [diff] [blame] | 49 | |
James Juran | 0ff60a0 | 1999-04-26 14:57:06 +0000 | [diff] [blame] | 50 | You also need to have libXpm installed on your system. The sources for |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 51 | it are available at ftp.x.org and all its mirror sites in the directory |
| 52 | /contrib/libraries. If you are using RedHat, libXpm is distributed as the |
| 53 | xpm and xpm-devel packages. Debian distributes libXpm as xpm4.7, xpm4g, |
| 54 | and xpm4g-dev 3.4j. SuSE calls these packages xpm and xpm-devel. |
James Juran | 0ff60a0 | 1999-04-26 14:57:06 +0000 | [diff] [blame] | 55 | |
| 56 | On x86 Systems gcc >= 2.7.2 is required. You also need flex version 2.5 |
| 57 | or later and yacc. Bison will work as a replacement for yacc. If you are |
| 58 | using RedHat, install the flex and bison packages. |
| 59 | |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 60 | 4. COMPILATION |
Alexandre Julliard | a69b88b | 1998-03-15 20:29:56 +0000 | [diff] [blame] | 61 | |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 62 | To build Wine, run the following commands: |
Alexandre Julliard | 401710d | 1993-09-04 10:09:32 +0000 | [diff] [blame] | 63 | |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 64 | ./configure |
| 65 | make depend |
| 66 | make |
| 67 | |
| 68 | This will build the library "libwine.a" and the program "wine". |
Alexandre Julliard | a0b2b1d | 1997-11-16 17:38:29 +0000 | [diff] [blame] | 69 | The program "wine" will load and run Windows executables. |
| 70 | The library "libwine.a" can be used to compile and link Windows source |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 71 | code under Unix. |
| 72 | |
| 73 | If you do not intend to compile Windows source code, use |
| 74 | "./configure --disable-lib" to skip building the library and reduce disk |
| 75 | space requirements. If you have an ELF compiler (which you probably do), |
| 76 | you can use "./configure --enable-dll" to build a shared library instead. |
| 77 | To see other configuration options, do ./configure --help. |
Alexandre Julliard | e2bfa4c | 1996-05-16 18:21:06 +0000 | [diff] [blame] | 78 | |
Alexandre Julliard | 3a5816f | 1994-12-27 14:11:53 +0000 | [diff] [blame] | 79 | To upgrade to a new release by using a patch file, first cd to the |
| 80 | top-level directory of the release (the one containing this README |
| 81 | file). Then do a "make clean", and patch the release with: |
| 82 | |
| 83 | gunzip -c patch-file | patch -p1 |
| 84 | |
| 85 | where "patch-file" is the name of the patch file (something like |
Alexandre Julliard | ff8331e | 1995-09-18 11:19:54 +0000 | [diff] [blame] | 86 | Wine-yymmdd.diff.gz). You can then re-run "./configure", and then |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 87 | run "make depend && make". |
Alexandre Julliard | 8d24ae6 | 1994-04-05 21:42:43 +0000 | [diff] [blame] | 88 | |
| 89 | |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 90 | 5. SETUP |
Alexandre Julliard | 8d24ae6 | 1994-04-05 21:42:43 +0000 | [diff] [blame] | 91 | |
Alexandre Julliard | 7e56f68 | 1996-01-31 19:02:28 +0000 | [diff] [blame] | 92 | Once Wine has been built correctly, you can do "make install"; this |
James Juran | 38a3d26 | 1999-01-01 18:45:52 +0000 | [diff] [blame] | 93 | will install the wine executable, the Wine man page, and a few other |
| 94 | needed files. |
Alexandre Julliard | 7e56f68 | 1996-01-31 19:02:28 +0000 | [diff] [blame] | 95 | |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 96 | Wine requires a configuration file named wine.conf. Its default location is |
| 97 | /usr/local/etc, but you can supply a different name when configuring wine by |
| 98 | using the --prefix or --sysconfdir options to ./configure. You can also override |
| 99 | the global configuration file with a .winerc file in your home directory. |
Alexandre Julliard | 8d24ae6 | 1994-04-05 21:42:43 +0000 | [diff] [blame] | 100 | |
Alexandre Julliard | 7e56f68 | 1996-01-31 19:02:28 +0000 | [diff] [blame] | 101 | The format of this file is explained in the man page. The file |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 102 | wine.ini contains an example configuration file which has to be adapted |
Andreas Mohr | 8a82991 | 1999-01-30 13:40:05 +0000 | [diff] [blame] | 103 | and copied to one of the two locations mentioned above. |
| 104 | |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 105 | See http://www.winehq.com/config.html for further configuration hints. |
Alexandre Julliard | 8d24ae6 | 1994-04-05 21:42:43 +0000 | [diff] [blame] | 106 | |
| 107 | |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 108 | 6. RUNNING PROGRAMS |
Alexandre Julliard | 8d24ae6 | 1994-04-05 21:42:43 +0000 | [diff] [blame] | 109 | |
James Juran | 38a3d26 | 1999-01-01 18:45:52 +0000 | [diff] [blame] | 110 | When invoking Wine, you may specify the entire path to the executable, |
Alexandre Julliard | 8d24ae6 | 1994-04-05 21:42:43 +0000 | [diff] [blame] | 111 | or a filename only. |
Alexandre Julliard | f41aeca | 1993-09-14 16:47:10 +0000 | [diff] [blame] | 112 | |
Douglas Ridgway | 692389d | 1998-11-22 16:56:44 +0000 | [diff] [blame] | 113 | For example: to run Solitaire: |
Alexandre Julliard | 5f721f8 | 1994-01-04 20:14:34 +0000 | [diff] [blame] | 114 | |
Alexandre Julliard | 8d24ae6 | 1994-04-05 21:42:43 +0000 | [diff] [blame] | 115 | wine sol (using the searchpath to locate the file) |
| 116 | wine sol.exe |
Alexandre Julliard | 5f721f8 | 1994-01-04 20:14:34 +0000 | [diff] [blame] | 117 | |
Douglas Ridgway | 692389d | 1998-11-22 16:56:44 +0000 | [diff] [blame] | 118 | wine c:\\windows\\sol.exe (using a DOS filename) |
Alexandre Julliard | 5f721f8 | 1994-01-04 20:14:34 +0000 | [diff] [blame] | 119 | |
Douglas Ridgway | 692389d | 1998-11-22 16:56:44 +0000 | [diff] [blame] | 120 | wine /usr/windows/sol.exe (using a Unix filename) |
Alexandre Julliard | f41aeca | 1993-09-14 16:47:10 +0000 | [diff] [blame] | 121 | |
Alexandre Julliard | 3a5816f | 1994-12-27 14:11:53 +0000 | [diff] [blame] | 122 | Note: the path of the file will also be added to the path when |
Alexandre Julliard | 5819953 | 1994-04-21 01:20:00 +0000 | [diff] [blame] | 123 | a full name is supplied on the commandline. |
| 124 | |
Douglas Ridgway | 692389d | 1998-11-22 16:56:44 +0000 | [diff] [blame] | 125 | Wine is not yet complete, so some programs may crash. You will be dropped |
James Juran | 38a3d26 | 1999-01-01 18:45:52 +0000 | [diff] [blame] | 126 | into a debugger so that you can investigate and fix the problem. For more |
| 127 | information on how to do this, please read the file documentation/debugging. |
| 128 | If you post a bug report, please read the file documentation/bugreports to |
| 129 | see what information is required. |
| 130 | |
Alexandre Julliard | 8d24ae6 | 1994-04-05 21:42:43 +0000 | [diff] [blame] | 131 | |
Alexandre Julliard | d6baf1b | 1999-07-18 15:47:22 +0000 | [diff] [blame] | 132 | 7. GETTING MORE INFORMATION |
Alexandre Julliard | 8d24ae6 | 1994-04-05 21:42:43 +0000 | [diff] [blame] | 133 | |
Andreas Mohr | 8cd9351 | 2000-01-29 21:12:58 +0000 | [diff] [blame] | 134 | DOCU: grep -i "SearchString" `find documentation/`|more |
| 135 | |
Ove Kaaven | 587729f | 1999-03-14 12:14:19 +0000 | [diff] [blame] | 136 | FAQ: The Wine FAQ is located at http://www.winehq.com/faq.html. |
Alexandre Julliard | 46ea8b3 | 1998-05-03 19:01:20 +0000 | [diff] [blame] | 137 | |
James Juran | 38a3d26 | 1999-01-01 18:45:52 +0000 | [diff] [blame] | 138 | WWW: A great deal of information about Wine is available from WineHQ at |
Douglas Ridgway | 692389d | 1998-11-22 16:56:44 +0000 | [diff] [blame] | 139 | http://www.winehq.com/. Untested patches against the current release |
| 140 | are available on the wine-patches mailing list; see |
| 141 | http://www.winehq.com/dev.html#ml for more information. |
Alexandre Julliard | 46ea8b3 | 1998-05-03 19:01:20 +0000 | [diff] [blame] | 142 | |
Andreas Mohr | 8cd9351 | 2000-01-29 21:12:58 +0000 | [diff] [blame] | 143 | HOWTO: The Wine HOWTO is available at |
James Juran | 0ff60a0 | 1999-04-26 14:57:06 +0000 | [diff] [blame] | 144 | http://www.westfalen.de/witch/wine-HOWTO.txt . |
| 145 | |
James Juran | 38a3d26 | 1999-01-01 18:45:52 +0000 | [diff] [blame] | 146 | Usenet: Please browse old messages on http://www.dejanews.com/ to check whether |
| 147 | your problem is already fixed before posting a bug report to the |
| 148 | newsgroup. |
| 149 | |
| 150 | The best place to get help or to report bugs is the Usenet newsgroup |
| 151 | comp.emulators.ms-windows.wine. Please read the file |
| 152 | documentation/bugreports to see what information should be included |
| 153 | in a bug report. |
| 154 | |
Andreas Mohr | 8cd9351 | 2000-01-29 21:12:58 +0000 | [diff] [blame] | 155 | IRC: Online help is available at channel #WineHQ on IRCnet. |
| 156 | |
Alexandre Julliard | 9d7fbc4 | 1998-10-18 16:32:47 +0000 | [diff] [blame] | 157 | CVS: The current Wine development tree is available through CVS. |
Douglas Ridgway | 692389d | 1998-11-22 16:56:44 +0000 | [diff] [blame] | 158 | Go to http://www.winehq.com/dev.html for more information. |
Alexandre Julliard | 46ea8b3 | 1998-05-03 19:01:20 +0000 | [diff] [blame] | 159 | |
Alexandre Julliard | ff8331e | 1995-09-18 11:19:54 +0000 | [diff] [blame] | 160 | If you add something, or fix a bug, please send a patch ('diff -u' |
Alexandre Julliard | 0c126c7 | 1996-02-18 18:44:41 +0000 | [diff] [blame] | 161 | format preferred) to julliard@lrc.epfl.ch for inclusion in the next |
Alexandre Julliard | ff8331e | 1995-09-18 11:19:54 +0000 | [diff] [blame] | 162 | release. |
Alexandre Julliard | 8d24ae6 | 1994-04-05 21:42:43 +0000 | [diff] [blame] | 163 | |
Alexandre Julliard | 3a5816f | 1994-12-27 14:11:53 +0000 | [diff] [blame] | 164 | -- |
| 165 | Alexandre Julliard |
Alexandre Julliard | ff8331e | 1995-09-18 11:19:54 +0000 | [diff] [blame] | 166 | julliard@lrc.epfl.ch |